Files
InvoiceShelf/database/seeders/DemoSeeder.php
Darko Gjorgjijoski 00d5abae5f Eliminate Company\CompaniesController, introduce owner role
Redistribute methods:
- show() -> BootstrapController::currentCompany()
- store(), destroy(), userCompanies() -> Admin\CompaniesController
- transferOwnership() -> CompanySettingsController

Security fix: introduce 'owner' role for company-level admin, distinct
from 'super admin' which is now global platform admin only.
- CompanyService::setupRoles() creates 'owner' role per company
- Company creation assigns scoped 'owner' role instead of global 'super admin'
- Seeders updated to assign 'owner'

Migration renames all existing company-scoped 'super admin' roles to
'owner' and ensures every company owner has the role assigned.
2026-04-03 22:33:56 +02:00

76 lines
2.1 KiB
PHP

<?php
namespace Database\Seeders;
use App\Facades\Hashids;
use App\Models\Company;
use App\Models\CompanySetting;
use App\Models\Customer;
use App\Models\Setting;
use App\Models\User;
use App\Services\CompanyService;
use Illuminate\Database\Seeder;
use Silber\Bouncer\BouncerFacade;
class DemoSeeder extends Seeder
{
/**
* Run the database seeds.
*/
public function run(): void
{
// Create demo user
$user = User::factory()->create([
'email' => 'demo@invoiceshelf.com',
'name' => 'Demo User',
'role' => 'super admin',
'password' => 'demo',
]);
// Create demo company
$company = Company::factory()->create([
'name' => 'Demo Company',
'owner_id' => $user->id,
'slug' => 'demo-company',
]);
$company->unique_hash = Hashids::connection(Company::class)->encode($company->id);
$company->save();
app(CompanyService::class)->setupDefaults($company);
$user->companies()->attach($company->id);
BouncerFacade::scope()->to($company->id);
$user->assign('owner');
// Set default user settings
$user->setSettings([
'language' => 'en',
'timezone' => 'UTC',
'date_format' => 'DD-MM-YYYY',
'currency_id' => 1, // USD
]);
// Set company settings
CompanySetting::setSettings([
'currency' => 1,
'date_format' => 'DD-MM-YYYY',
'language' => 'en',
'timezone' => 'UTC',
'fiscal_year' => 'calendar_year',
'tax_per_item' => false,
'discount_per_item' => false,
'invoice_prefix' => 'INV-',
'estimate_prefix' => 'EST-',
'payment_prefix' => 'PAY-',
], $company->id);
// Create demo customers
Customer::factory()->count(5)->create([
'company_id' => $company->id,
]);
// Mark profile setup as complete
Setting::setSetting('profile_complete', 'COMPLETED');
}
}