/*
This file is part of Cyclos (www.cyclos.org).
A project of the Social Trade Organisation (www.socialtrade.org).
Cyclos is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
Cyclos is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Cyclos; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package nl.strohalm.cyclos.services.elements;
import java.util.Calendar;
import nl.strohalm.cyclos.entities.accounts.fees.transaction.BrokerCommission;
import nl.strohalm.cyclos.entities.groups.MemberGroup;
import nl.strohalm.cyclos.entities.members.Member;
import nl.strohalm.cyclos.entities.members.brokerings.BrokerCommissionContract;
import nl.strohalm.cyclos.entities.members.brokerings.Brokering;
import nl.strohalm.cyclos.entities.members.brokerings.BrokeringCommissionStatus;
import nl.strohalm.cyclos.entities.members.brokerings.DefaultBrokerCommission;
/**
* Local interface. It must be used only from other services.
*/
public interface CommissionServiceLocal extends CommissionService {
/**
* Activates broker commission contracts that were accepted and begin today
*/
void activateAcceptedBrokerCommissionContracts(final Calendar time);
/**
* This method closes the brokering commission status setting an end date (= now) when the max number of transactions that generates this
* commission is reached
*/
BrokeringCommissionStatus closeBrokeringCommissionStatus(BrokeringCommissionStatus brokeringCommissionStatus);
/**
* Creates the brokering commission status objects for each broker (and his/her brokereds) of the broker groups selected in the broker commission
*/
void createBrokeringCommissionStatus(final BrokerCommission brokerCommission);
/**
* Creates the brokering commission status object
*/
BrokeringCommissionStatus createBrokeringCommissionStatus(final Brokering brokering, final BrokerCommission brokerCommission);
/**
* Creates a default broker commission for each broker of the broker groups selected in the broker commission
*/
void createDefaultBrokerCommissions(final BrokerCommission brokerCommission);
/**
* Expires broker commission contracts that were not accepted until it´s beginning and close contracts that expired at the end of the previous day
*/
void expireBrokerCommissionContracts(final Calendar time);
/**
* Expires brokering commission status
*/
void expireBrokeringCommissionStatus(final Calendar date);
/**
* Returns the active broker commission contract or null if it doesn't exist
*/
BrokerCommissionContract getActiveBrokerCommissionContract(Brokering brokering, BrokerCommission brokerCommission);
/**
* Shows the present status of the brokering commission
*/
BrokeringCommissionStatus getBrokeringCommissionStatus(final Brokering brokering, final BrokerCommission brokerCommission);
/**
* Returns the default broker commission
*/
DefaultBrokerCommission getDefaultBrokerCommission(Member broker, BrokerCommission brokerCommission);
/**
* Returns the brokering commission status or null if it doesn't exist
*/
BrokeringCommissionStatus getOrUpdateBrokeringCommissionStatus(final Brokering brokering, final BrokerCommission brokerCommission);
/**
*
* @return
*/
boolean hasAllPermissions();
/**
* Create default broker commissions or brokering commission status applicable to the new group and suspend commissions that are not applicable to
* new group
*/
void updateBrokerCommissions(Member broker, MemberGroup oldGroup, MemberGroup newGroup);
/**
* Create brokering commission status for groups added to the commission and suspend commissions for groups removed from the commission
*/
void updateBrokeringCommissionStatus(final BrokerCommission brokerCommission, final BrokerCommission savedBrokerCommission);
/**
* Saves the brokering commission status
*/
BrokeringCommissionStatus updateBrokeringCommissionStatus(BrokeringCommissionStatus brokeringCommissionStatus);
/**
* Create default broker commissions for groups added to the commission and suspend commissions for groups removed from the commission
*/
void updateDefaultBrokerCommissions(final BrokerCommission brokerCommission, final BrokerCommission savedBrokerCommission);
}