. */ declare(strict_types=1); namespace FireflyIII\Repositories\Account; use Carbon\Carbon; use FireflyIII\Enums\UserRoleEnum; use FireflyIII\Models\TransactionCurrency; use FireflyIII\Models\UserGroup; use FireflyIII\User; use Illuminate\Contracts\Auth\Authenticatable; use Illuminate\Support\Collection; /** * Interface OperationsRepositoryInterface * * @method setUserGroup(UserGroup $group) * @method getUserGroup() * @method getUser() * @method checkUserGroupAccess(UserRoleEnum $role) * @method setUser(null|Authenticatable|User $user) * @method setUserGroupById(int $userGroupId) */ interface OperationsRepositoryInterface { /** * This method returns a list of all the withdrawal transaction journals (as arrays) set in that period * which have the specified accounts. It's grouped per currency, with as few details in the array * as possible. Amounts are always negative. */ public function listExpenses(Carbon $start, Carbon $end, Collection $accounts): array; /** * This method returns a list of all the deposit transaction journals (as arrays) set in that period * which have the specified accounts. It's grouped per currency, with as few details in the array * as possible. Amounts are always positive. */ public function listIncome(Carbon $start, Carbon $end, ?Collection $accounts = null): array; /** * Sum of withdrawal journals in period for a set of accounts, grouped per currency. Amounts are always negative. * * @SuppressWarnings("PHPMD.ExcessiveParameterList") */ public function sumExpenses( Carbon $start, Carbon $end, ?Collection $accounts = null, ?Collection $expense = null, ?TransactionCurrency $currency = null ): array; /** * Sum of withdrawal journals in period for a set of accounts, grouped per destination / currency. Amounts are * always negative. * * @SuppressWarnings("PHPMD.ExcessiveParameterList") */ public function sumExpensesByDestination( Carbon $start, Carbon $end, ?Collection $accounts = null, ?Collection $expense = null, ?TransactionCurrency $currency = null ): array; /** * Sum of withdrawal journals in period for a set of accounts, grouped per source / currency. Amounts are always * negative. * * @SuppressWarnings("PHPMD.ExcessiveParameterList") */ public function sumExpensesBySource( Carbon $start, Carbon $end, ?Collection $accounts = null, ?Collection $expense = null, ?TransactionCurrency $currency = null ): array; /** * Sum of income journals in period for a set of accounts, grouped per currency. Amounts are always positive. * * @SuppressWarnings("PHPMD.ExcessiveParameterList") */ public function sumIncome( Carbon $start, Carbon $end, ?Collection $accounts = null, ?Collection $revenue = null, ?TransactionCurrency $currency = null ): array; /** * Sum of income journals in period for a set of accounts, grouped per destination + currency. Amounts are always * positive. * * @SuppressWarnings("PHPMD.ExcessiveParameterList") */ public function sumIncomeByDestination( Carbon $start, Carbon $end, ?Collection $accounts = null, ?Collection $revenue = null, ?TransactionCurrency $currency = null ): array; /** * Sum of income journals in period for a set of accounts, grouped per source + currency. Amounts are always * positive. * * @SuppressWarnings("PHPMD.ExcessiveParameterList") */ public function sumIncomeBySource( Carbon $start, Carbon $end, ?Collection $accounts = null, ?Collection $revenue = null, ?TransactionCurrency $currency = null ): array; /** * Sum of transfers in period for a set of accounts, grouped per currency. Amounts are always positive. */ public function sumTransfers(Carbon $start, Carbon $end, ?Collection $accounts = null, ?TransactionCurrency $currency = null): array; }