lasthourcloud/database/seeders/ProductionSeeder.php

103 lines
3.4 KiB
PHP
Raw Normal View History

2023-04-14 08:00:42 +00:00
<?php
namespace Database\Seeders;
2023-05-22 10:47:15 +00:00
use App\Data\ServerMetadata;
use App\Enums\ProxyStatus;
use App\Enums\ProxyTypes;
2023-05-02 12:12:15 +00:00
use App\Models\GithubApp;
use App\Models\GitlabApp;
2023-04-27 09:29:02 +00:00
use App\Models\InstanceSettings;
2023-04-14 08:00:42 +00:00
use App\Models\PrivateKey;
use App\Models\Server;
2023-04-14 08:00:42 +00:00
use App\Models\Team;
use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\Storage;
class ProductionSeeder extends Seeder
{
public function run(): void
{
2023-04-27 09:29:02 +00:00
if (InstanceSettings::find(0) == null) {
InstanceSettings::create([
'id' => 0
]);
}
2023-05-08 07:33:10 +00:00
if (GithubApp::find(0) == null) {
GithubApp::create([
'id' => 0,
'name' => 'Public GitHub',
'api_url' => 'https://api.github.com',
'html_url' => 'https://github.com',
'is_public' => true,
'team_id' => 0,
]);
}
if (GitlabApp::find(0) == null) {
GitlabApp::create([
'id' => 0,
'name' => 'Public GitLab',
'api_url' => 'https://gitlab.com/api/v4',
'html_url' => 'https://gitlab.com',
'is_public' => true,
'team_id' => 0,
]);
}
2023-04-27 09:29:02 +00:00
// Add first Team if it doesn't exist
if (Team::find(0) == null) {
Team::create([
'id' => 0,
'name' => "Root's Team",
'personal_team' => true,
]);
}
// Save SSH Keys for the Coolify Host
$coolify_key_name = "id.root@host.docker.internal";
$coolify_key = Storage::disk('local')->get("ssh-keys/{$coolify_key_name}");
2023-04-27 10:25:32 +00:00
if ($coolify_key) {
$private_key = PrivateKey::find(0);
if ($private_key == null) {
PrivateKey::create([
'id' => 0,
'name' => 'localhost\'s key',
'description' => 'The private key for the Coolify host machine (localhost).',
'private_key' => $coolify_key,
'team_id' => 0,
]);
} else {
$private_key->private_key = $coolify_key;
$private_key->save();
}
} else {
2023-05-08 07:33:10 +00:00
// TODO: Add a command to generate a new SSH key for the Coolify host machine (localhost).
2023-04-27 10:25:32 +00:00
echo "No SSH key found for the Coolify host machine (localhost).\n";
echo "Please generate one and save it in storage/app/ssh-keys/{$coolify_key_name}\n";
}
2023-04-27 09:29:02 +00:00
// Add Coolify host (localhost) as Server if it doesn't exist
if (Server::find(0) == null) {
2023-05-22 10:47:15 +00:00
$server_details = [
'id' => 0,
'name' => "localhost",
2023-05-22 10:47:15 +00:00
'description' => "This is the server where Coolify is running on. Don't delete this!",
'user' => 'root',
'ip' => "host.docker.internal",
'team_id' => 0,
2023-05-22 10:47:15 +00:00
'private_key_id' => 0
];
if (env('COOLIFY_DEFAULT_PROXY') == 'traefik') {
$server_details['extra_attributes'] = ServerMetadata::from([
'proxy_type' => ProxyTypes::TRAEFIK_V2->value,
'proxy_status' => ProxyStatus::EXITED->value
]);
}
$server = Server::create($server_details);
2023-05-08 07:33:10 +00:00
$server->settings->is_validated = true;
$server->settings->save();
2023-05-02 12:12:15 +00:00
}
2023-04-14 08:00:42 +00:00
}
}