'defaultAsset'], ['accountRole' => 'savingAsset',], ['accountRole' => 'sharedAsset',], ['accountRole' => 'ccAsset', 'ccMonthlyPaymentDate' => '2015-05-27', 'ccType' => 'monthlyFull',], ['accountRole' => 'savingAsset',], ['accountRole' => 'savingAsset',], ]; foreach ($assets as $index => $name) { // create account: $account = Account::create( [ 'user_id' => $user->id, 'account_type_id' => 3, 'name' => $name, 'active' => 1, 'encrypted' => 1, 'iban' => $ibans[$index], ] ); foreach ($assetMeta[$index] as $name => $value) { AccountMeta::create(['account_id' => $account->id, 'name' => $name, 'data' => $value,]); } } return true; } /** * @param User $user * @param Carbon $start * * @return TransactionJournal */ public static function createAttachments(User $user, Carbon $start): TransactionJournal { $toAccount = TestData::findAccount($user, 'TestData Checking Account'); $fromAccount = TestData::findAccount($user, 'Job'); $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 2, 'transaction_currency_id' => 1, 'description' => 'Some journal for attachment', 'completed' => 1, 'date' => $start->format('Y-m-d'), ] ); self::createTransactions($journal, $fromAccount, $toAccount, '100'); // and now attachments $encrypted = Crypt::encrypt('I are secret'); $one = Attachment::create( [ 'attachable_id' => $journal->id, 'attachable_type' => 'FireflyIII\Models\TransactionJournal', 'user_id' => $user->id, 'md5' => md5('Hallo'), 'filename' => 'empty-file.txt', 'title' => 'Empty file', 'description' => 'This file is empty', 'notes' => 'What notes', 'mime' => 'text/plain', 'size' => strlen($encrypted), 'uploaded' => 1, ] ); // and now attachment. $two = Attachment::create( [ 'attachable_id' => $journal->id, 'attachable_type' => 'FireflyIII\Models\TransactionJournal', 'user_id' => $user->id, 'md5' => md5('Ook hallo'), 'filename' => 'empty-file-2.txt', 'title' => 'Empty file 2', 'description' => 'This file is empty too', 'notes' => 'What notes do', 'mime' => 'text/plain', 'size' => strlen($encrypted), 'uploaded' => 1, ] ); // echo crypted data to the file. file_put_contents(storage_path('upload/at-' . $one->id . '.data'), $encrypted); file_put_contents(storage_path('upload/at-' . $two->id . '.data'), $encrypted); return $journal; } /** * @param User $user * * @return bool */ public static function createBills(User $user): bool { Bill::create( [ 'name' => 'Rent', 'match' => 'rent,land,lord', 'amount_min' => 795, 'amount_max' => 805, 'user_id' => $user->id, 'date' => '2015-01-01', 'active' => 1, 'automatch' => 1, 'repeat_freq' => 'monthly', 'skip' => 0, ] ); Bill::create( [ 'name' => 'Health insurance', 'match' => 'zilveren,kruis,health', 'amount_min' => 120, 'amount_max' => 140, 'user_id' => $user->id, 'date' => '2015-01-01', 'active' => 1, 'automatch' => 1, 'repeat_freq' => 'monthly', 'skip' => 0, ] ); return true; } /** * @param User $user * @param Carbon $current * @param string $name * @param string $amount * * @return BudgetLimit */ public static function createBudgetLimit(User $user, Carbon $current, string $name, string $amount): BudgetLimit { $start = clone $current; $end = clone $current; $budget = self::findBudget($user, $name); $start->startOfMonth(); $end->endOfMonth(); $limit = BudgetLimit::create( [ 'budget_id' => $budget->id, 'startdate' => $start->format('Y-m-d'), 'amount' => $amount, 'repeats' => 0, 'repeat_freq' => 'monthly', ] ); return $limit; } /** * @param User $user * * @return bool */ public static function createBudgets(User $user): bool { Budget::firstOrCreateEncrypted(['name' => 'Groceries', 'user_id' => $user->id]); Budget::firstOrCreateEncrypted(['name' => 'Bills', 'user_id' => $user->id]); Budget::firstOrCreateEncrypted(['name' => 'Car', 'user_id' => $user->id]); // some empty budgets. foreach (['A', 'B', 'C', 'D', "E"] as $letter) { Budget::firstOrCreateEncrypted(['name' => 'Empty budget ' . $letter, 'user_id' => $user->id]); } return true; } /** * @param User $user * @param Carbon $date * * @return TransactionJournal * @SuppressWarnings(PHPMD.ExcessiveMethodLength) */ public static function createCar(User $user, Carbon $date): TransactionJournal { // twice: $date = new Carbon($date->format('Y-m') . '-10'); // paid on 10th $fromAccount = TestData::findAccount($user, 'TestData Checking Account'); $toAccount = TestData::findAccount($user, 'Shell'); $category = Category::firstOrCreateEncrypted(['name' => 'Car', 'user_id' => $user->id]); $budget = Budget::firstOrCreateEncrypted(['name' => 'Car', 'user_id' => $user->id]); $amount = strval(rand(4000, 5000) / 100); $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 1, 'transaction_currency_id' => 1, 'description' => 'Bought gas', 'completed' => 1, 'date' => $date, ] ); self::createTransactions($journal, $fromAccount, $toAccount, $amount); $journal->categories()->save($category); $journal->budgets()->save($budget); // and again! $date = new Carbon($date->format('Y-m') . '-20'); // paid on 20th $amount = rand(4000, 5000) / 100; $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 1, 'transaction_currency_id' => 1, 'description' => 'Gas for car', 'completed' => 1, 'date' => $date, ] ); self::createTransactions($journal, $fromAccount, $toAccount, strval($amount)); // and again! return $journal; } /** * @param User $user * * @return bool */ public static function createCategories(User $user): bool { Category::firstOrCreateEncrypted(['name' => 'Groceries', 'user_id' => $user->id]); Category::firstOrCreateEncrypted(['name' => 'Car', 'user_id' => $user->id]); return true; } /** * @param User $user * @param Carbon $date * * @return bool * * @SuppressWarnings(PHPMD.ExcessiveMethodLength) */ public static function createDrinksAndOthers(User $user, Carbon $date): bool { $start = clone $date; $end = clone $date; $today = new Carbon; $start->startOfMonth(); $end->endOfMonth(); $current = clone $start; while ($current < $end && $current < $today) { // weekly drink: $thisDate = clone $current; $thisDate->addDay(); $fromAccount = TestData::findAccount($user, 'TestData Checking Account'); $toAccount = TestData::findAccount($user, 'Cafe Central'); $category = Category::firstOrCreateEncrypted(['name' => 'Drinks', 'user_id' => $user->id]); $budget = Budget::firstOrCreateEncrypted(['name' => 'Going out', 'user_id' => $user->id]); $amount = strval(rand(1500, 3600) / 100); $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 1, 'transaction_currency_id' => 1, 'description' => 'Going out for drinks', 'completed' => 1, 'date' => $thisDate, ] ); self::createTransactions($journal, $fromAccount, $toAccount, $amount); $journal->categories()->save($category); $journal->budgets()->save($budget); // shopping at some (online) shop: $current->addWeek(); } return true; } /** * @param User $user * * @return bool */ public static function createExpenseAccounts(User $user): bool { $expenses = ['Adobe', 'Google', 'Vitens', 'Albert Heijn', 'PLUS', 'Apple', 'Bakker', 'Belastingdienst', 'bol.com', 'Cafe Central', 'conrad.nl', 'Coolblue', 'Shell', 'DUO', 'Etos', 'FEBO', 'Greenchoice', 'Halfords', 'XS4All', 'iCentre', 'Jumper', 'Land lord']; foreach ($expenses as $name) { // create account: Account::create( [ 'user_id' => $user->id, 'account_type_id' => 4, 'name' => $name, 'active' => 1, 'encrypted' => 1, ] ); } return true; } /** * @param User $user * @param Carbon $date * * @return bool * * @SuppressWarnings(PHPMD.ExcessiveMethodLength) */ public static function createGroceries(User $user, Carbon $date): bool { bcscale(2); $start = clone $date; $end = clone $date; $today = new Carbon; $start->startOfMonth(); $end->endOfMonth(); $fromAccount = TestData::findAccount($user, 'TestData Checking Account'); $stores = ['Albert Heijn', 'PLUS', 'Bakker']; $descriptions = ['Groceries', 'Bought some groceries', 'Got groceries']; $category = Category::firstOrCreateEncrypted(['name' => 'Daily groceries', 'user_id' => $user->id]); $budget = Budget::firstOrCreateEncrypted(['name' => 'Groceries', 'user_id' => $user->id]); $current = clone $start; while ($current < $end && $current < $today) { // daily groceries: $toAccount = TestData::findAccount($user, $stores[rand(0, count($stores) - 1)]); $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 1, 'transaction_currency_id' => 1, 'description' => $descriptions[rand(0, count($descriptions) - 1)], 'completed' => 1, 'date' => $current, ] ); if ($journal->id) { $number = (string)round((rand(1500, 2500) / 100), 2); $amount = $number;//'10';//strval((rand(1500, 2500) / 100)); self::createTransactions($journal, $fromAccount, $toAccount, $amount); $journal->categories()->save($category); $journal->budgets()->save($budget); } $current->addDay(); } return true; } /** * @param User $user * @param string $description * @param Carbon $date * @param string $amount * * @return TransactionJournal */ public static function createIncome(User $user, string $description, Carbon $date, string $amount): TransactionJournal { $date = new Carbon($date->format('Y-m') . '-23'); // paid on 23rd. $today = new Carbon; if ($date >= $today) { return new TransactionJournal; } $toAccount = TestData::findAccount($user, 'TestData Checking Account'); $fromAccount = TestData::findAccount($user, 'Job'); $category = Category::firstOrCreateEncrypted(['name' => 'Salary', 'user_id' => $user->id]); // create journal: $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 2, 'transaction_currency_id' => 1, 'description' => $description, 'completed' => 1, 'date' => $date, ] ); self::createTransactions($journal, $fromAccount, $toAccount, $amount); $journal->categories()->save($category); return $journal; } /** * @param User $user * * @return bool * * @SuppressWarnings(PHPMD.ExcessiveMethodLength) */ public static function createPiggybanks(User $user): bool { $account = self::findAccount($user, 'TestData Savings'); $camera = PiggyBank::create( [ 'account_id' => $account->id, 'name' => 'New camera', 'targetamount' => 1000, 'startdate' => '2015-04-01', 'reminder_skip' => 0, 'remind_me' => 0, 'order' => 1, ] ); $repetition = $camera->piggyBankRepetitions()->first(); $repetition->currentamount = 735; $repetition->save(); // events: PiggyBankEvent::create( [ 'piggy_bank_id' => $camera->id, 'date' => '2015-05-01', 'amount' => '245', ] ); PiggyBankEvent::create( [ 'piggy_bank_id' => $camera->id, 'date' => '2015-06-01', 'amount' => '245', ] ); PiggyBankEvent::create( [ 'piggy_bank_id' => $camera->id, 'date' => '2015-07-01', 'amount' => '245', ] ); $phone = PiggyBank::create( [ 'account_id' => $account->id, 'name' => 'New phone', 'targetamount' => 600, 'startdate' => '2015-04-01', 'reminder_skip' => 0, 'remind_me' => 0, 'order' => 2, ] ); $repetition = $phone->piggyBankRepetitions()->first(); $repetition->currentamount = 333; $repetition->save(); // events: PiggyBankEvent::create( [ 'piggy_bank_id' => $phone->id, 'date' => '2015-05-01', 'amount' => '111', ] ); PiggyBankEvent::create( [ 'piggy_bank_id' => $phone->id, 'date' => '2015-06-01', 'amount' => '111', ] ); PiggyBankEvent::create( [ 'piggy_bank_id' => $phone->id, 'date' => '2015-07-01', 'amount' => '111', ] ); $couch = PiggyBank::create( [ 'account_id' => $account->id, 'name' => 'New couch', 'targetamount' => 500, 'startdate' => '2015-04-01', 'reminder_skip' => 0, 'remind_me' => 0, 'order' => 3, ] ); $repetition = $couch->piggyBankRepetitions()->first(); $repetition->currentamount = 120; $repetition->save(); // events: PiggyBankEvent::create( [ 'piggy_bank_id' => $couch->id, 'date' => '2015-05-01', 'amount' => '40', ] ); PiggyBankEvent::create( [ 'piggy_bank_id' => $couch->id, 'date' => '2015-06-01', 'amount' => '40', ] ); PiggyBankEvent::create( [ 'piggy_bank_id' => $couch->id, 'date' => '2015-07-01', 'amount' => '40', ] ); // empty one. PiggyBank::create( [ 'account_id' => $account->id, 'name' => 'New head set', 'targetamount' => 500, 'startdate' => '2015-04-01', 'reminder_skip' => 0, 'remind_me' => 0, 'order' => 4, ] ); return true; } /** * @param User $user * @param string $description * @param Carbon $date * @param string $amount * * @return TransactionJournal */ public static function createPower(User $user, string $description, Carbon $date, string $amount): TransactionJournal { $date = new Carbon($date->format('Y-m') . '-06'); // paid on 10th $fromAccount = TestData::findAccount($user, 'TestData Checking Account'); $toAccount = TestData::findAccount($user, 'Greenchoice'); $category = Category::firstOrCreateEncrypted(['name' => 'House', 'user_id' => $user->id]); $budget = Budget::firstOrCreateEncrypted(['name' => 'Bills', 'user_id' => $user->id]); $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 1, 'transaction_currency_id' => 1, 'description' => $description, 'completed' => 1, 'date' => $date, ] ); self::createTransactions($journal, $fromAccount, $toAccount, $amount); $journal->categories()->save($category); $journal->budgets()->save($budget); return $journal; } /** * @param User $user * @param string $description * @param Carbon $date * @param string $amount * * @return TransactionJournal */ public static function createRent(User $user, string $description, Carbon $date, string $amount): TransactionJournal { $fromAccount = TestData::findAccount($user, 'TestData Checking Account'); $toAccount = TestData::findAccount($user, 'Land lord'); $category = Category::firstOrCreateEncrypted(['name' => 'Rent', 'user_id' => $user->id]); $budget = Budget::firstOrCreateEncrypted(['name' => 'Bills', 'user_id' => $user->id]); $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 1, 'transaction_currency_id' => 1, 'bill_id' => 1, 'description' => $description, 'completed' => 1, 'date' => $date, ] ); self::createTransactions($journal, $fromAccount, $toAccount, $amount); $journal->categories()->save($category); $journal->budgets()->save($budget); return $journal; } /** * @param User $user * * @return bool */ public static function createRevenueAccounts(User $user): bool { $revenues = ['Job', 'Belastingdienst', 'Bank', 'KPN', 'Google']; foreach ($revenues as $name) { // create account: Account::create( [ 'user_id' => $user->id, 'account_type_id' => 5, 'name' => $name, 'active' => 1, 'encrypted' => 1, ] ); } return true; } /** * @param User $user * * @return RuleGroup */ public static function createRules(User $user): RuleGroup { $group = RuleGroup::create( [ 'user_id' => $user->id, 'order' => 1, 'title' => trans('firefly.default_rule_group_name'), 'description' => trans('firefly.default_rule_group_description'), 'active' => 1, ] ); $rule = Rule::create( [ 'user_id' => $user->id, 'rule_group_id' => $group->id, 'order' => 1, 'active' => 1, 'stop_processing' => 0, 'title' => trans('firefly.default_rule_name'), 'description' => trans('firefly.default_rule_description'), ] ); // three triggers: RuleTrigger::create( [ 'rule_id' => $rule->id, 'order' => 1, 'active' => 1, 'stop_processing' => 0, 'trigger_type' => 'user_action', 'trigger_value' => 'store-journal', ] ); RuleTrigger::create( [ 'rule_id' => $rule->id, 'order' => 2, 'active' => 1, 'stop_processing' => 0, 'trigger_type' => 'description_is', 'trigger_value' => trans('firefly.default_rule_trigger_description'), ] ); RuleTrigger::create( [ 'rule_id' => $rule->id, 'order' => 3, 'active' => 1, 'stop_processing' => 0, 'trigger_type' => 'from_account_is', 'trigger_value' => trans('firefly.default_rule_trigger_from_account'), ] ); // two actions: RuleAction::create( [ 'rule_id' => $rule->id, 'order' => 1, 'active' => 1, 'action_type' => 'prepend_description', 'action_value' => trans('firefly.default_rule_action_prepend'), ] ); RuleAction::create( [ 'rule_id' => $rule->id, 'order' => 1, 'active' => 1, 'action_type' => 'set_category', 'action_value' => trans('firefly.default_rule_action_set_category'), ] ); return $group; } /** * @param User $user * @param Carbon $date * * @return TransactionJournal */ public static function createSavings(User $user, Carbon $date): TransactionJournal { $date = new Carbon($date->format('Y-m') . '-24'); // paid on 24th. $toAccount = TestData::findAccount($user, 'TestData Savings'); $fromAccount = TestData::findAccount($user, 'TestData Checking Account'); $category = Category::firstOrCreateEncrypted(['name' => 'Money management', 'user_id' => $user->id]); // create journal: $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 3, 'transaction_currency_id' => 1, 'description' => 'Save money', 'completed' => 1, 'date' => $date, ] ); self::createTransactions($journal, $fromAccount, $toAccount, '150'); $journal->categories()->save($category); return $journal; } /** * @param User $user * @param string $description * @param Carbon $date * @param string $amount * * @return TransactionJournal */ public static function createTV(User $user, string $description, Carbon $date, string $amount): TransactionJournal { $date = new Carbon($date->format('Y-m') . '-15'); // paid on 10th $fromAccount = TestData::findAccount($user, 'TestData Checking Account'); $toAccount = TestData::findAccount($user, 'XS4All'); $category = Category::firstOrCreateEncrypted(['name' => 'House', 'user_id' => $user->id]); $budget = Budget::firstOrCreateEncrypted(['name' => 'Bills', 'user_id' => $user->id]); $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 1, 'transaction_currency_id' => 1, 'description' => $description, 'completed' => 1, 'date' => $date, ] ); self::createTransactions($journal, $fromAccount, $toAccount, $amount); $journal->categories()->save($category); $journal->budgets()->save($budget); return $journal; } /** * @param User $user * @param Carbon $date * * @return Tag */ public static function createTags(User $user, Carbon $date): Tag { $title = 'SomeTag' . $date->month . '.' . $date->year . '.nothing'; $tag = Tag::create( [ 'user_id' => $user->id, 'tag' => $title, 'tagMode' => 'nothing', 'date' => $date->format('Y-m-d'), ] ); return $tag; } /** * @param TransactionJournal $journal * @param Account $from * @param Account $to * @param string $amount * * @return bool */ public static function createTransactions(TransactionJournal $journal, Account $from, Account $to, string $amount): bool { Log::debug('---- Transaction From: ' . bcmul($amount, '-1')); Log::debug('---- Transaction To : ' . $amount); Transaction::create( [ 'account_id' => $from->id, 'transaction_journal_id' => $journal->id, 'amount' => bcmul($amount, '-1'), ] ); Transaction::create( [ 'account_id' => $to->id, 'transaction_journal_id' => $journal->id, 'amount' => $amount, ] ); return true; } /** * @return User */ public static function createUsers(): User { $user = User::create(['email' => 'thegrumpydictator@gmail.com', 'password' => bcrypt('james'), 'reset' => null, 'remember_token' => null]); User::create(['email' => 'thegrumpydictator+empty@gmail.com', 'password' => bcrypt('james'), 'reset' => null, 'remember_token' => null]); User::create(['email' => 'thegrumpydictator+deleteme@gmail.com', 'password' => bcrypt('james'), 'reset' => null, 'remember_token' => null]); $admin = Role::where('name', 'owner')->first(); $user->attachRole($admin); return $user; } /** * @param User $user * @param string $description * @param Carbon $date * @param string $amount * * @return TransactionJournal */ public static function createWater(User $user, string $description, Carbon $date, string $amount): TransactionJournal { $date = new Carbon($date->format('Y-m') . '-10'); // paid on 10th $fromAccount = TestData::findAccount($user, 'TestData Checking Account'); $toAccount = TestData::findAccount($user, 'Vitens'); $category = Category::firstOrCreateEncrypted(['name' => 'House', 'user_id' => $user->id]); $budget = Budget::firstOrCreateEncrypted(['name' => 'Bills', 'user_id' => $user->id]); $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 1, 'transaction_currency_id' => 1, 'description' => $description, 'completed' => 1, 'date' => $date, ] ); self::createTransactions($journal, $fromAccount, $toAccount, $amount); $journal->categories()->save($category); $journal->budgets()->save($budget); return $journal; } /** * @param User $user * @param $name * * @return Account */ public static function findAccount(User $user, string $name): Account { /** @var Account $account */ foreach ($user->accounts()->get() as $account) { if ($account->name == $name) { return $account; } } return new Account; } /** * @param User $user * @param $name * * @return Budget */ public static function findBudget(User $user, string $name): Budget { /** @var Budget $budget */ foreach (Budget::get() as $budget) { if ($budget->name == $name && $user->id == $budget->user_id) { return $budget; break; } } return new Budget; } /** * @param User $user * @param Carbon $date * * @return TransactionJournal */ public static function openingBalanceSavings(User $user, Carbon $date): TransactionJournal { // opposing account for opening balance: $opposing = Account::create( [ 'user_id' => $user->id, 'account_type_id' => 6, 'name' => 'Opposing for savings', 'active' => 1, 'encrypted' => 1, ] ); // savings $savings = TestData::findAccount($user, 'TestData Savings'); $journal = TransactionJournal::create( [ 'user_id' => $user->id, 'transaction_type_id' => 4, 'transaction_currency_id' => 1, 'description' => 'Opening balance for savings account', 'completed' => 1, 'date' => $date->format('Y-m-d'), ] ); self::createTransactions($journal, $opposing, $savings, '10000'); return $journal; } }