feat: Prepare Zemailnator for Dokploy deployment
- Add highly optimized Dockerfile with Nginx and PHP-FPM 8.4 - Add docker-compose.yml configured with Redis and MariaDB 10.11 - Implement entrypoint.sh and supervisord.conf for background workers - Refactor legacy IMAP scripts into scheduled Artisan Commands - Secure app by removing old routes with hardcoded basic auth credentials - Configure email attachments to use Laravel Storage instead of insecure public/tmp
This commit is contained in:
@@ -12,7 +12,7 @@ return new class extends Migration
|
||||
$table->longText('html')->nullable()->change();
|
||||
$table->longText('text')->nullable()->change();
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
|
||||
public function down()
|
||||
|
||||
@@ -11,7 +11,7 @@ return new class extends Migration
|
||||
Schema::table(config('mails.database.tables.events', 'mail_events'), function (Blueprint $table) {
|
||||
$table->longText('link')->nullable()->change();
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
|
||||
public function down()
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
class CreateActivityLogTable extends Migration
|
||||
{
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
class AddEventColumnToActivityLogTable extends Migration
|
||||
{
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
class AddBatchUuidColumnToActivityLogTable extends Migration
|
||||
{
|
||||
|
||||
@@ -2,8 +2,8 @@
|
||||
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
return new class extends Migration
|
||||
{
|
||||
@@ -18,7 +18,7 @@ return new class extends Migration
|
||||
try {
|
||||
// MySQL automatically names check constraints in different ways,
|
||||
// so we attempt a generic drop and ignore failures.
|
||||
DB::statement("ALTER TABLE `payment_providers` DROP CHECK `payment_providers.configuration`;");
|
||||
DB::statement('ALTER TABLE `payment_providers` DROP CHECK `payment_providers.configuration`;');
|
||||
} catch (\Throwable $e) {
|
||||
// ignore if constraint does not exist
|
||||
}
|
||||
@@ -37,7 +37,7 @@ return new class extends Migration
|
||||
AND pg_get_constraintdef(pg_constraint.oid) LIKE '%configuration%json%';
|
||||
");
|
||||
|
||||
if (!empty($constraint->conname)) {
|
||||
if (! empty($constraint->conname)) {
|
||||
DB::statement("ALTER TABLE payment_providers DROP CONSTRAINT {$constraint->conname};");
|
||||
}
|
||||
} catch (\Throwable $e) {
|
||||
|
||||
@@ -34,4 +34,4 @@ return new class extends Migration
|
||||
$table->unique('username', 'usernames_username_unique');
|
||||
});
|
||||
}
|
||||
};
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user