snipe-it/database/seeders/ManufacturerSeeder.php
2023-03-20 11:19:34 -07:00

57 lines
2.3 KiB
PHP

<?php
namespace Database\Seeders;
use App\Models\Manufacturer;
use App\Models\User;
use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\Log;
use Illuminate\Support\Facades\Storage;
class ManufacturerSeeder extends Seeder
{
public function run()
{
Manufacturer::truncate();
$admin = User::where('permissions->superuser', '1')->first() ?? User::factory()->firstAdmin()->create();
Manufacturer::factory()->count(1)->apple()->create(['user_id' => $admin->id]); // 1
Manufacturer::factory()->count(1)->microsoft()->create(['user_id' => $admin->id]); // 2
Manufacturer::factory()->count(1)->dell()->create(['user_id' => $admin->id]); // 3
Manufacturer::factory()->count(1)->asus()->create(['user_id' => $admin->id]); // 4
Manufacturer::factory()->count(1)->hp()->create(['user_id' => $admin->id]); // 5
Manufacturer::factory()->count(1)->lenovo()->create(['user_id' => $admin->id]); // 6
Manufacturer::factory()->count(1)->lg()->create(['user_id' => $admin->id]); // 7
Manufacturer::factory()->count(1)->polycom()->create(['user_id' => $admin->id]); // 8
Manufacturer::factory()->count(1)->adobe()->create(['user_id' => $admin->id]); // 9
Manufacturer::factory()->count(1)->avery()->create(['user_id' => $admin->id]); // 10
Manufacturer::factory()->count(1)->crucial()->create(['user_id' => $admin->id]); // 10
$src = public_path('/img/demo/manufacturers/');
$dst = 'manufacturers'.'/';
$del_files = Storage::files($dst);
foreach ($del_files as $del_file) { // iterate files
$file_to_delete = str_replace($src, '', $del_file);
Log::debug('Deleting: '.$file_to_delete);
try {
Storage::disk('public')->delete($dst.$del_file);
} catch (\Exception $e) {
Log::debug($e);
}
}
$add_files = glob($src.'/*.*');
foreach ($add_files as $add_file) {
$file_to_copy = str_replace($src, '', $add_file);
Log::debug('Copying: '.$file_to_copy);
try {
Storage::disk('public')->put($dst.$file_to_copy, file_get_contents($src.$file_to_copy));
} catch (\Exception $e) {
Log::debug($e);
}
}
}
}