first commit

This commit is contained in:
denisdulici
2017-09-14 22:21:00 +03:00
commit 515bdaf5cd
598 changed files with 48030 additions and 0 deletions

View File

@@ -0,0 +1,47 @@
<?php
namespace Database\Seeds;
use App\Models\Model;
use App\Models\Banking\Account;
use Setting;
use Illuminate\Database\Seeder;
class Accounts extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create();
Model::reguard();
}
private function create()
{
$company_id = $this->command->argument('company');
$rows = [
[
'company_id' => $company_id,
'name' => trans('demo.accounts_cash'),
'number' => '1',
'currency_code' => 'USD',
'bank_name' => trans('demo.accounts_cash'),
'enabled' => '1',
],
];
foreach ($rows as $row) {
$account = Account::create($row);
Setting::set('general.default_account', $account->id);
}
}
}

View File

@@ -0,0 +1,57 @@
<?php
namespace Database\Seeds;
use App\Models\Model;
use App\Models\Expense\BillStatus;
use Illuminate\Database\Seeder;
class BillStatuses extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create();
Model::reguard();
}
private function create()
{
$company_id = $this->command->argument('company');
$rows = [
[
'company_id' => $company_id,
'name' => trans('bills.status.new'),
'code' => 'new',
],
[
'company_id' => $company_id,
'name' => trans('bills.status.updated'),
'code' => 'updated',
],
[
'company_id' => $company_id,
'name' => trans('bills.status.partial'),
'code' => 'partial',
],
[
'company_id' => $company_id,
'name' => trans('bills.status.paid'),
'code' => 'paid',
],
];
foreach ($rows as $row) {
BillStatus::create($row);
}
}
}

View File

@@ -0,0 +1,72 @@
<?php
namespace Database\Seeds;
use App\Models\Model;
use App\Models\Setting\Category;
use Illuminate\Database\Seeder;
class Categories extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create();
Model::reguard();
}
private function create()
{
$company_id = $this->command->argument('company');
$rows = [
[
'company_id' => $company_id,
'name' => trans_choice('general.transfers', 1),
'type' => 'other',
'color' => '#605ca8',
'enabled' => '1'
],
[
'company_id' => $company_id,
'name' => trans('demo.categories_deposit'),
'type' => 'income',
'color' => '#f39c12',
'enabled' => '1'
],
[
'company_id' => $company_id,
'name' => trans('demo.categories_sales'),
'type' => 'income',
'color' => '#6da252',
'enabled' => '1'
],
[
'company_id' => $company_id,
'name' => trans('demo.categories_uncat'),
'type' => 'expense',
'color' => '#d2d6de',
'enabled' => '1'
],
[
'company_id' => $company_id,
'name' => trans('general.general'),
'type' => 'item',
'color' => '#00c0ef',
'enabled' => '1'
],
];
foreach ($rows as $row) {
Category::create($row);
}
}
}

View File

@@ -0,0 +1,22 @@
<?php
use Illuminate\Database\Seeder;
class CompanySeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
$this->call(Database\Seeds\Accounts::class);
$this->call(Database\Seeds\BillStatuses::class);
$this->call(Database\Seeds\Categories::class);
$this->call(Database\Seeds\Currencies::class);
$this->call(Database\Seeds\InvoiceStatuses::class);
$this->call(Database\Seeds\Settings::class);
$this->call(Database\Seeds\Taxes::class);
}
}

View File

@@ -0,0 +1,62 @@
<?php
namespace Database\Seeds;
use App\Models\Model;
use App\Models\Setting\Currency;
use Illuminate\Database\Seeder;
class Currencies extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create();
Model::reguard();
}
private function create()
{
$company_id = $this->command->argument('company');
$rows = [
[
'company_id' => $company_id,
'name' => trans('demo.currencies_usd'),
'code' => 'USD',
'rate' => '1.00',
'enabled' => '1',
],
[
'company_id' => $company_id,
'name' => trans('demo.currencies_eur'),
'code' => 'EUR',
'rate' => '1.25',
],
[
'company_id' => $company_id,
'name' => trans('demo.currencies_gbp'),
'code' => 'GBP',
'rate' => '1.60',
],
[
'company_id' => $company_id,
'name' => trans('demo.currencies_try'),
'code' => 'TRY',
'rate' => '0.80',
],
];
foreach ($rows as $row) {
Currency::create($row);
}
}
}

View File

@@ -0,0 +1,16 @@
<?php
use Illuminate\Database\Seeder;
class DatabaseSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
}
}

View File

@@ -0,0 +1,67 @@
<?php
namespace Database\Seeds;
use App\Models\Model;
use App\Models\Income\InvoiceStatus;
use Illuminate\Database\Seeder;
class InvoiceStatuses extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create();
Model::reguard();
}
private function create()
{
$company_id = $this->command->argument('company');
$rows = [
[
'company_id' => $company_id,
'name' => trans('invoices.status.draft'),
'code' => 'draft',
],
[
'company_id' => $company_id,
'name' => trans('invoices.status.sent'),
'code' => 'sent',
],
[
'company_id' => $company_id,
'name' => trans('invoices.status.viewed'),
'code' => 'viewed',
],
[
'company_id' => $company_id,
'name' => trans('invoices.status.approved'),
'code' => 'approved',
],
[
'company_id' => $company_id,
'name' => trans('invoices.status.partial'),
'code' => 'partial',
],
[
'company_id' => $company_id,
'name' => trans('invoices.status.paid'),
'code' => 'paid',
],
];
foreach ($rows as $row) {
InvoiceStatus::create($row);
}
}
}

152
database/seeds/Roles.php Normal file
View File

@@ -0,0 +1,152 @@
<?php
namespace Database\Seeds;
use App\Models\Model;
use App\Models\Auth\Role;
use App\Models\Auth\Permission;
use Illuminate\Database\Seeder;
class Roles extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create($this->roles(), $this->map());
Model::reguard();
}
private function roles()
{
$rows = [
'admin' => [
'admin-panel' => 'r',
'api' => 'r',
'auth-users' => 'c,r,u,d',
'auth-roles' => 'c,r,u,d',
'auth-permissions' => 'c,r,u,d',
'auth-profile' => 'r,u',
'companies-companies' => 'c,r,u,d',
'items-items' => 'c,r,u,d',
'incomes-invoices' => 'c,r,u,d',
'incomes-revenues' => 'c,r,u,d',
'incomes-customers' => 'c,r,u,d',
'expenses-bills' => 'c,r,u,d',
'expenses-payments' => 'c,r,u,d',
'expenses-vendors' => 'c,r,u,d',
'banking-accounts' => 'c,r,u,d',
'banking-transfers' => 'c,r,u,d',
'banking-transactions' => 'r',
'settings-categories' => 'c,r,u,d',
'settings-settings' => 'r,u',
'settings-taxes' => 'c,r,u,d',
'settings-currencies' => 'c,r,u,d',
'settings-modules' => 'r,u',
'modules-home' => 'r',
'modules-tiles' => 'r',
'modules-item' => 'c,r,u,d',
'modules-token' => 'c,u',
'install-updates' => 'r,u',
'notifications' => 'r,u',
'reports-income-summary' => 'r',
'reports-expense-summary' => 'r',
'reports-income-expense-summary' => 'r',
],
'manager' => [
'admin-panel' => 'r',
'auth-profile' => 'r,u',
'companies-companies' => 'c,r,u,d',
'items-items' => 'c,r,u,d',
'incomes-invoices' => 'c,r,u,d',
'incomes-revenues' => 'c,r,u,d',
'incomes-customers' => 'c,r,u,d',
'expenses-bills' => 'c,r,u,d',
'expenses-payments' => 'c,r,u,d',
'expenses-vendors' => 'c,r,u,d',
'banking-accounts' => 'c,r,u,d',
'banking-transfers' => 'c,r,u,d',
'banking-transactions' => 'r',
'settings-settings' => 'r,u',
'settings-categories' => 'c,r,u,d',
'settings-taxes' => 'c,r,u,d',
'settings-currencies' => 'c,r,u,d',
'settings-modules' => 'r,u',
'install-updates' => 'r,u',
'notifications' => 'r,u',
'reports-income-summary' => 'r',
'reports-expense-summary' => 'r',
'reports-income-expense-summary' => 'r',
],
'customer' => [
'customer-panel' => 'r',
'customers-invoices' => 'r,u',
'customers-payments' => 'r,u',
'customers-transactions' => 'r',
'customers-profile' => 'r,u',
],
];
return $rows;
}
private function map()
{
$rows = [
'c' => 'create',
'r' => 'read',
'u' => 'update',
'd' => 'delete'
];
return $rows;
}
private function create($roles, $map)
{
$mapPermission = collect($map);
foreach ($roles as $key => $modules) {
// Create a new role
$role = Role::create([
'name' => $key,
'display_name' => ucwords(str_replace("_", " ", $key)),
'description' => ucwords(str_replace("_", " ", $key))
]);
$this->command->info('Creating Role '. strtoupper($key));
// Reading role permission modules
foreach ($modules as $module => $value) {
$permissions = explode(',', $value);
foreach ($permissions as $p => $perm) {
$permissionValue = $mapPermission->get($perm);
$moduleName = ucwords(str_replace("-", " ", $module));
$permission = Permission::firstOrCreate([
'name' => $permissionValue . '-' . $module,
'display_name' => ucfirst($permissionValue) . ' ' . $moduleName,
'description' => ucfirst($permissionValue) . ' ' . $moduleName,
]);
$this->command->info('Creating Permission to '.$permissionValue.' for '. $moduleName);
if (!$role->hasPermission($permission->name)) {
$role->attachPermission($permission);
} else {
$this->command->info($key . ': ' . $p . ' ' . $permissionValue . ' already exist');
}
}
}
}
}
}

View File

@@ -0,0 +1,54 @@
<?php
namespace Database\Seeds;
use App\Models\Model;
use Illuminate\Database\Seeder;
use Setting;
class Settings extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create();
Model::reguard();
}
private function create()
{
$company_id = $this->command->argument('company');
Setting::set([
'general.date_format' => 'd M Y',
'general.date_separator' => 'space',
'general.timezone' => 'Europe/London',
'general.invoice_prefix' => 'INV-',
'general.invoice_digit' => '5',
'general.invoice_start' => '1',
'general.default_payment_method' => 'cash',
'general.email_protocol' => 'mail',
'general.email_sendmail_path' => '/usr/sbin/sendmail -bs',
'general.send_invoice_reminder' => '0',
'general.schedule_invoice_days' => '1,3,5,10',
'general.send_bill_reminder' => '0',
'general.schedule_bill_days' => '10,5,3,1',
'general.schedule_time' => '09:00',
'general.admin_theme' => 'skin-green-light',
'general.list_limit' => '25',
'general.use_gravatar' => '0',
'general.session_handler' => 'file',
'general.session_lifetime' => '30',
'general.file_size' => '2',
'general.file_types' => 'pdf,jpeg,jpg,png',
'offline.payment.methods' => '[{"code":"offline.cash.1","name":"Cash","order":"1","description":null},{"code":"offline.bank_transfer.2","name":"Bank Transfer","order":"2","description":null}]',
]);
}
}

55
database/seeds/Taxes.php Normal file
View File

@@ -0,0 +1,55 @@
<?php
namespace Database\Seeds;
use App\Models\Model;
use App\Models\Setting\Tax;
use Illuminate\Database\Seeder;
class Taxes extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->create();
Model::reguard();
}
private function create()
{
$company_id = $this->command->argument('company');
$rows = [
[
'company_id' => $company_id,
'name' => trans('demo.taxes_exempt'),
'rate' => '0',
'enabled' => '1'
],
[
'company_id' => $company_id,
'name' => trans('demo.taxes_normal'),
'rate' => '5',
'enabled' => '1'
],
[
'company_id' => $company_id,
'name' => trans('demo.taxes_sales'),
'rate' => '15',
'enabled' => '1'
],
];
foreach ($rows as $row) {
Tax::create($row);
}
}
}

View File

@@ -0,0 +1,75 @@
<?php
namespace Database\Seeds;
use App\Models\Model;
use App\Models\Auth\User;
use App\Models\Company\Company;
use Jenssegers\Date\Date;
use Illuminate\Database\Seeder;
use Setting;
class TestCompany extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
Model::unguard();
$this->call(Roles::class);
$this->createCompany();
$this->createUser();
Model::reguard();
}
private function createCompany()
{
$rows = [
[
'id' => '1',
'domain' => 'test.com',
],
];
foreach ($rows as $row) {
Company::create($row);
}
Setting::setExtraColumns(['company_id' => '1']);
Setting::set('general.company_name', 'Test Inc.');
Setting::set('general.company_email', 'info@test.com');
Setting::set('general.company_address', 'New Street 1254');
Setting::set('general.default_currency', 'USD');
Setting::set('general.default_account', '1');
Setting::set('general.default_payment_method', 'cash');
Setting::save();
$this->command->info('Test company created.');
}
public function createUser()
{
// Create user
$user = User::create([
'name' => 'Admin',
'email' => 'admin@akaunting.com',
'password' => '123456',
'last_logged_in_at' => Date::now(),
]);
// Attach Role
$user->roles()->attach(1);
// Attach company
$user->companies()->attach(1);
$this->command->info('Admin user created.');
}
}