AccountEventBean.java 4.42 KB
package fi.insomnia.bortal.beans;

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

import javax.ejb.EJB;
import javax.ejb.Stateless;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import fi.insomnia.bortal.enums.Permission;
import fi.insomnia.bortal.enums.RolePermission;
import fi.insomnia.bortal.facade.AccountEventFacade;
import fi.insomnia.bortal.model.AccountEvent;
import fi.insomnia.bortal.model.EventPk;
import fi.insomnia.bortal.model.LanEvent;
import fi.insomnia.bortal.model.Place;
import fi.insomnia.bortal.model.Product;
import fi.insomnia.bortal.model.Role;
import fi.insomnia.bortal.model.User;

/**
 * Session Bean implementation class AccountEventBean
 */
@Stateless
public class AccountEventBean implements AccountEventBeanLocal {

    @EJB
    private AccountEventFacade accountfacade;

    @EJB
    private UserBeanLocal userbean;
    @EJB
    private SecurityBeanLocal sessionbean;
    @EJB
    private EventBeanLocal eventBean;
    @EJB
    private ProductBeanLocal prodbean;
    @EJB
    private PlaceBeanLocal placebean;

    private static final Logger logger = LoggerFactory.getLogger(AccountEventBean.class);

    public AccountEventBean() {
        super();
    }

    @Override
    public AccountEvent merge(AccountEvent account) {
        userbean.fatalPermission(Permission.ACCOUNT_MANAGEMENT, RolePermission.WRITE, "Error mergin account event", account);
        return accountfacade.merge(account);
    }

    @Override
    public void delete(AccountEvent account) {
        userbean.fatalPermission(Permission.ACCOUNT_MANAGEMENT, RolePermission.WRITE, "Error deleting account event: ", account);

        AccountEvent acco = accountfacade.find(account.getId());
        sessionbean.logMessage(SecurityLogType.accountEvent, userbean.getCurrentUser(), "Deleting AccountEvent '", acco.getProduct().getName(), "' count: '", acco.getQuantity().toString(), "' unitprice: '", acco.getUnitPrice().toString(), "' accouser: '", acco.getUser().getLogin(), "'");
        acco.getProduct().getAccountEvents().remove(acco);
        if (acco.getBill() != null) {
            acco.getBill().setAccountEvent(null);
        }
        acco.getUser().getAccountEvents().remove(acco);

        accountfacade.remove(acco);

    }

    @Override
    public AccountEvent find(EventPk id) {
        return accountfacade.find(id);
    }

    @Override
    public List<Role> getRolesFromAccountEvents(User u) {
        return accountfacade.findProvidedRoles(eventBean.getCurrentEvent(), u);
    }

    @Override
    public List<AccountEvent> shopCash(User shoppingUser, Map<Product, BigDecimal> shopMap, boolean buyInstant) {
        logger.debug("Shoping cash. buyinstant {}", buyInstant);
        userbean.fatalPermission(Permission.SHOP, RolePermission.EXECUTE, "User tried to create accountEvents via shop without SHOP:EXECUTE");
        ArrayList<AccountEvent> ret = new ArrayList<AccountEvent>();
        LanEvent ev = eventBean.getCurrentEvent();
        User seller = userbean.getCurrentUser();
        BigDecimal tot = BigDecimal.ZERO;

        for (Entry<Product, BigDecimal> prodentry : shopMap.entrySet()) {
            AccountEvent ac = new AccountEvent(ev, shoppingUser, prodentry.getKey(), prodentry.getKey().getPrice(), prodentry.getValue(), Calendar.getInstance());
            if (buyInstant && prodentry.getKey().getPrice().compareTo(BigDecimal.ZERO) > 0) {
                tot = tot.add(prodentry.getValue().multiply(prodentry.getKey().getPrice()));
            }

            if (prodentry.getKey().isPrepaidInstant() && prodentry.getKey().getPlaces() != null && prodentry.getKey().getPlaces().size() > 0) {
                logger.debug("Prepaidplace");

                placebean.lockPlaceProduct(shoppingUser, prodentry.getKey(), BigDecimal.ONE);
                
            }
            ac.setSeller(seller);
            shoppingUser.getAccountEvents().add(ac);
        }

        logger.debug("ShopCash price {}", tot);
        if (buyInstant && tot.compareTo(BigDecimal.ZERO) > 0) {
            logger.debug("Creating buy instant product!");
            Product creditProd = prodbean.findCreditProduct();
            AccountEvent ac = new AccountEvent(ev, shoppingUser, creditProd, creditProd.getPrice(), tot, Calendar.getInstance());
            shoppingUser.getAccountEvents().add(ac);
        }

        userbean.mergeChanges(shoppingUser);

        return ret;
    }
}