2016-04-30 02:48:39 -05:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* SplitDataSeeder.php
|
|
|
|
* Copyright (C) 2016 thegrumpydictator@gmail.com
|
|
|
|
*
|
|
|
|
* This software may be modified and distributed under the terms
|
|
|
|
* of the MIT license. See the LICENSE file for details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
declare(strict_types = 1);
|
|
|
|
/**
|
|
|
|
* SplitDataSeeder.php
|
|
|
|
* Copyright (C) 2016 thegrumpydictator@gmail.com
|
|
|
|
*
|
|
|
|
* This software may be modified and distributed under the terms
|
|
|
|
* of the MIT license. See the LICENSE file for details.
|
|
|
|
*/
|
|
|
|
|
2016-04-30 13:24:47 -05:00
|
|
|
use Carbon\Carbon;
|
|
|
|
use FireflyIII\Models\Transaction;
|
|
|
|
use FireflyIII\Models\TransactionJournal;
|
2016-04-30 02:48:39 -05:00
|
|
|
use FireflyIII\Support\Migration\TestData;
|
2016-05-05 14:25:20 -05:00
|
|
|
use FireflyIII\User;
|
2016-04-30 02:48:39 -05:00
|
|
|
use Illuminate\Database\Seeder;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class SplitDataSeeder
|
|
|
|
*/
|
|
|
|
class SplitDataSeeder extends Seeder
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* TestDataSeeder constructor.
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Run the database seeds.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function run()
|
|
|
|
{
|
2016-04-30 14:20:39 -05:00
|
|
|
$skipWithdrawal = false;
|
|
|
|
$skipDeposit = true;
|
|
|
|
$skipTransfer = true;
|
2016-04-30 02:48:39 -05:00
|
|
|
// start by creating all users:
|
|
|
|
// method will return the first user.
|
|
|
|
$user = TestData::createUsers();
|
|
|
|
|
|
|
|
// create all kinds of static data:
|
2016-05-05 14:25:20 -05:00
|
|
|
$assets = [['name' => 'Checking Account', 'iban' => 'NL11XOLA6707795988', 'meta' => ['accountRole' => 'defaultAsset']],
|
|
|
|
['name' => 'Alternate Checking Account', 'iban' => 'NL40UKBK3619908726', 'meta' => ['accountRole' => 'defaultAsset']],
|
|
|
|
['name' => 'Savings Account', 'iban' => 'NL96DZCO4665940223', 'meta' => ['accountRole' => 'savingAsset']],
|
|
|
|
['name' => 'Shared Checking Account', 'iban' => 'NL81RCQZ7160379858', 'meta' => ['accountRole' => 'sharedAsset']]];
|
|
|
|
|
|
|
|
// some asset accounts
|
2016-04-30 14:20:39 -05:00
|
|
|
TestData::createAssetAccounts($user, $assets);
|
2016-05-05 14:25:20 -05:00
|
|
|
|
|
|
|
// budgets, categories and others:
|
2016-04-30 02:48:39 -05:00
|
|
|
TestData::createBudgets($user);
|
|
|
|
TestData::createCategories($user);
|
|
|
|
TestData::createExpenseAccounts($user);
|
|
|
|
TestData::createRevenueAccounts($user);
|
2016-04-30 14:20:39 -05:00
|
|
|
TestData::createPiggybanks($user, 'Savings Account');
|
2016-05-05 14:25:20 -05:00
|
|
|
TestData::createBills($user);
|
|
|
|
// some bills
|
2016-04-30 13:24:47 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Create splitted expense of 66,-
|
|
|
|
*/
|
2016-05-05 14:25:20 -05:00
|
|
|
$today = new Carbon('2012-03-14');
|
2016-04-30 13:24:47 -05:00
|
|
|
|
2016-04-30 14:20:39 -05:00
|
|
|
if (!$skipWithdrawal) {
|
2016-05-05 14:25:20 -05:00
|
|
|
$this->generateWithdrawals($user);
|
2016-04-30 13:24:47 -05:00
|
|
|
}
|
2016-05-05 14:25:20 -05:00
|
|
|
|
|
|
|
// create splitted income of 99,-
|
2016-05-05 11:59:46 -05:00
|
|
|
$today->addDay();
|
2016-05-05 14:25:20 -05:00
|
|
|
|
|
|
|
if (!$skipDeposit) {
|
|
|
|
$this->generateDeposits();
|
|
|
|
}
|
|
|
|
// create a splitted transfer of 57,- (19)
|
|
|
|
// $today->addDay();
|
|
|
|
|
|
|
|
if (!$skipTransfer) {
|
|
|
|
$this->generateTransfers();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private function generateDeposits()
|
|
|
|
{
|
2016-05-05 11:59:46 -05:00
|
|
|
$journal = TransactionJournal::create(
|
|
|
|
[
|
|
|
|
'user_id' => $user->id,
|
2016-05-05 14:25:20 -05:00
|
|
|
'transaction_type_id' => 2, // expense
|
2016-05-05 11:59:46 -05:00
|
|
|
'transaction_currency_id' => 1,
|
2016-05-05 14:25:20 -05:00
|
|
|
'description' => 'Split Income (journal)',
|
2016-05-05 11:59:46 -05:00
|
|
|
'completed' => 1,
|
|
|
|
'date' => $today->format('Y-m-d'),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
// split in 6 transactions (multiple destinations). 22,- each
|
|
|
|
// source is TestData Checking Account.
|
|
|
|
// also attach some budgets and stuff.
|
2016-05-05 14:25:20 -05:00
|
|
|
$destinations = ['Checking Account', 'Savings Account', 'Shared Checking Account'];
|
|
|
|
$source = TestData::findAccount($user, 'Belastingdienst');
|
2016-05-05 11:59:46 -05:00
|
|
|
$budgets = ['Groceries', 'Groceries', 'Car'];
|
|
|
|
$categories = ['Bills', 'Bills', 'Car'];
|
|
|
|
foreach ($destinations as $index => $dest) {
|
|
|
|
$bud = $budgets[$index];
|
|
|
|
$cat = $categories[$index];
|
|
|
|
$destination = TestData::findAccount($user, $dest);
|
|
|
|
|
|
|
|
$one = Transaction::create(
|
|
|
|
[
|
|
|
|
'account_id' => $source->id,
|
|
|
|
'transaction_journal_id' => $journal->id,
|
2016-05-05 14:25:20 -05:00
|
|
|
'amount' => '-33',
|
2016-05-05 11:59:46 -05:00
|
|
|
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
$two = Transaction::create(
|
|
|
|
[
|
|
|
|
'account_id' => $destination->id,
|
|
|
|
'transaction_journal_id' => $journal->id,
|
2016-05-05 14:25:20 -05:00
|
|
|
'amount' => '33',
|
2016-05-05 11:59:46 -05:00
|
|
|
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
$one->budgets()->save(TestData::findBudget($user, $bud));
|
|
|
|
$two->budgets()->save(TestData::findBudget($user, $bud));
|
|
|
|
|
|
|
|
$one->categories()->save(TestData::findCategory($user, $cat));
|
|
|
|
$two->categories()->save(TestData::findCategory($user, $cat));
|
|
|
|
}
|
2016-05-05 14:25:20 -05:00
|
|
|
}
|
2016-05-05 11:59:46 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
private function generateTransfers()
|
|
|
|
{
|
|
|
|
$journal = TransactionJournal::create(
|
|
|
|
[
|
|
|
|
'user_id' => $user->id,
|
|
|
|
'transaction_type_id' => 3, // transfer
|
|
|
|
'transaction_currency_id' => 1,
|
|
|
|
'description' => 'Split Transfer (journal)',
|
|
|
|
'completed' => 1,
|
|
|
|
'date' => $today->format('Y-m-d'),
|
|
|
|
]
|
|
|
|
);
|
2016-04-30 13:24:47 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
|
|
|
|
$source = TestData::findAccount($user, 'Alternate Checking Account');
|
|
|
|
$destinations = ['Checking Account', 'Savings Account', 'Shared Checking Account'];
|
|
|
|
$budgets = ['Groceries', 'Groceries', 'Car'];
|
|
|
|
$categories = ['Bills', 'Bills', 'Car'];
|
|
|
|
foreach ($destinations as $index => $dest) {
|
|
|
|
$bud = $budgets[$index];
|
|
|
|
$cat = $categories[$index];
|
|
|
|
$destination = TestData::findAccount($user, $dest);
|
|
|
|
|
|
|
|
$one = Transaction::create(
|
|
|
|
[
|
|
|
|
'account_id' => $source->id,
|
|
|
|
'transaction_journal_id' => $journal->id,
|
|
|
|
'amount' => '-19',
|
|
|
|
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
$two = Transaction::create(
|
2016-04-30 13:24:47 -05:00
|
|
|
[
|
2016-05-05 14:25:20 -05:00
|
|
|
'account_id' => $destination->id,
|
|
|
|
'transaction_journal_id' => $journal->id,
|
|
|
|
'amount' => '19',
|
|
|
|
|
2016-04-30 13:24:47 -05:00
|
|
|
]
|
|
|
|
);
|
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
$one->budgets()->save(TestData::findBudget($user, $bud));
|
|
|
|
$two->budgets()->save(TestData::findBudget($user, $bud));
|
|
|
|
|
|
|
|
$one->categories()->save(TestData::findCategory($user, $cat));
|
|
|
|
$two->categories()->save(TestData::findCategory($user, $cat));
|
2016-04-30 13:24:47 -05:00
|
|
|
}
|
2016-05-05 14:25:20 -05:00
|
|
|
}
|
2016-04-30 13:24:47 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
private function generateWithdrawals(User $user)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* TRANSACTION ONE
|
|
|
|
*/
|
|
|
|
$date = new Carbon('2012-03-15');
|
|
|
|
$journal = TransactionJournal::create(
|
|
|
|
[
|
|
|
|
'user_id' => $user->id,
|
|
|
|
'transaction_type_id' => 1, // withdrawal
|
|
|
|
'transaction_currency_id' => 1,
|
|
|
|
'description' => 'Split Even Expense (journal (50/50))',
|
|
|
|
'completed' => 1,
|
|
|
|
'date' => $date->format('Y-m-d'),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
// split in 6 transactions (multiple destinations). 22,- each
|
|
|
|
// source is TestData Checking Account.
|
|
|
|
// also attach some budgets and stuff.
|
|
|
|
$destinations = ['SixtyFive', 'EightyFour'];
|
|
|
|
$budgets = ['Groceries', 'Car'];
|
|
|
|
$categories = ['Bills', 'Bills'];
|
|
|
|
$amounts = [50, 50];
|
|
|
|
$source = TestData::findAccount($user, 'Alternate Checking Account');
|
|
|
|
foreach ($destinations as $index => $dest) {
|
|
|
|
$bud = $budgets[$index];
|
|
|
|
$cat = $categories[$index];
|
|
|
|
$destination = TestData::findAccount($user, $dest);
|
|
|
|
|
|
|
|
$one = Transaction::create(
|
2016-04-30 13:24:47 -05:00
|
|
|
[
|
2016-05-05 14:25:20 -05:00
|
|
|
'account_id' => $source->id,
|
|
|
|
'transaction_journal_id' => $journal->id,
|
|
|
|
'amount' => $amounts[$index] * -1,
|
|
|
|
|
2016-04-30 13:24:47 -05:00
|
|
|
]
|
|
|
|
);
|
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
$two = Transaction::create(
|
|
|
|
[
|
|
|
|
'account_id' => $destination->id,
|
|
|
|
'transaction_journal_id' => $journal->id,
|
|
|
|
'amount' => $amounts[$index],
|
2016-04-30 13:24:47 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
]
|
|
|
|
);
|
2016-04-30 13:24:47 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
$one->budgets()->save(TestData::findBudget($user, $bud));
|
|
|
|
$two->budgets()->save(TestData::findBudget($user, $bud));
|
2016-04-30 13:24:47 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
$one->categories()->save(TestData::findCategory($user, $cat));
|
|
|
|
$two->categories()->save(TestData::findCategory($user, $cat));
|
|
|
|
}
|
2016-04-30 14:20:39 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
/*
|
|
|
|
* GENERATE TRANSACTION TWO.
|
|
|
|
*/
|
2016-04-30 13:24:47 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
$date = new Carbon;
|
|
|
|
$journal = TransactionJournal::create(
|
|
|
|
[
|
|
|
|
'user_id' => $user->id,
|
|
|
|
'transaction_type_id' => 1, // withdrawal
|
|
|
|
'transaction_currency_id' => 1,
|
|
|
|
'description' => 'Split Uneven Expense (journal (15/34/51=100))',
|
|
|
|
'completed' => 1,
|
|
|
|
'date' => $date->format('Y-m-d'),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
// split in 6 transactions (multiple destinations). 22,- each
|
|
|
|
// source is TestData Checking Account.
|
|
|
|
// also attach some budgets and stuff.
|
|
|
|
$destinations = ['SixtyFive', 'EightyFour', 'Fiftyone'];
|
|
|
|
$budgets = ['Groceries', 'Groceries', 'Car'];
|
|
|
|
$categories = ['Bills', 'Bills', 'Car'];
|
|
|
|
$amounts = [15, 34, 51];
|
|
|
|
$source = TestData::findAccount($user, 'Checking Account');
|
|
|
|
foreach ($destinations as $index => $dest) {
|
|
|
|
$bud = $budgets[$index];
|
|
|
|
$cat = $categories[$index];
|
|
|
|
$destination = TestData::findAccount($user, $dest);
|
|
|
|
|
|
|
|
$one = Transaction::create(
|
|
|
|
[
|
|
|
|
'account_id' => $source->id,
|
|
|
|
'transaction_journal_id' => $journal->id,
|
|
|
|
'amount' => $amounts[$index] * -1,
|
2016-04-30 13:24:47 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
]
|
|
|
|
);
|
2016-04-30 14:20:39 -05:00
|
|
|
|
2016-05-05 14:25:20 -05:00
|
|
|
$two = Transaction::create(
|
|
|
|
[
|
|
|
|
'account_id' => $destination->id,
|
|
|
|
'transaction_journal_id' => $journal->id,
|
|
|
|
'amount' => $amounts[$index],
|
|
|
|
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
$one->budgets()->save(TestData::findBudget($user, $bud));
|
|
|
|
$two->budgets()->save(TestData::findBudget($user, $bud));
|
|
|
|
|
|
|
|
$one->categories()->save(TestData::findCategory($user, $cat));
|
|
|
|
$two->categories()->save(TestData::findCategory($user, $cat));
|
2016-04-30 14:20:39 -05:00
|
|
|
}
|
2016-04-30 02:48:39 -05:00
|
|
|
}
|
|
|
|
}
|