From 79d0b2e54faf9608ed5892ff3f35f2e8f5ad75e5 Mon Sep 17 00:00:00 2001 From: bulut Date: Fri, 27 Mar 2026 11:28:18 +0300 Subject: [PATCH 1/4] Add Drone CI pipeline --- .drone.yml | 22 ++++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/.drone.yml b/.drone.yml index 31eec26..7b6f5b6 100644 --- a/.drone.yml +++ b/.drone.yml @@ -1,6 +1,6 @@ kind: pipeline type: docker -name: default +name: bogazici-api trigger: branch: @@ -15,13 +15,13 @@ steps: branch: - develop commands: - - apt-get update && apt-get install -y git unzip curl libzip-dev default-mysql-client - - docker-php-ext-install pdo_mysql zip + - apt-get update && apt-get install -y git unzip curl libzip-dev libicu-dev default-mysql-client + - docker-php-ext-install pdo_mysql zip intl - curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer - cp .env.example .env || true - composer install --no-interaction --prefer-dist --optimize-autoloader - php artisan key:generate --force || true - - php artisan config:clear || true + - php artisan optimize:clear || true - php artisan test || true - name: deploy-test @@ -31,11 +31,12 @@ steps: - test settings: host: - from_secret: server_host + from_secret: SERVER_HOST username: - from_secret: server_user + from_secret: SERVER_USER key: - from_secret: server_ssh_key + from_secret: SERVER_SSH_KEY + port: 22 script: - cd /opt/projects/bogazici/corporate-api/test/api - bash scripts/deploy-test.sh @@ -47,11 +48,12 @@ steps: - main settings: host: - from_secret: server_host + from_secret: SERVER_HOST username: - from_secret: server_user + from_secret: SERVER_USER key: - from_secret: server_ssh_key + from_secret: SERVER_SSH_KEY + port: 22 script: - cd /opt/projects/bogazici/corporate-api/prod/api - bash scripts/deploy-prod.sh From b25c5d2cfb5d9502aba75a4f178e30f2b3866f23 Mon Sep 17 00:00:00 2001 From: bulut Date: Fri, 27 Mar 2026 11:40:00 +0300 Subject: [PATCH 2/4] update ssl force --- app/Providers/AppServiceProvider.php | 3 +++ 1 file changed, 3 insertions(+) diff --git a/app/Providers/AppServiceProvider.php b/app/Providers/AppServiceProvider.php index 1ec5462..fea32e3 100644 --- a/app/Providers/AppServiceProvider.php +++ b/app/Providers/AppServiceProvider.php @@ -31,6 +31,7 @@ use App\Repositories\Eloquent\UserRepository; use Illuminate\Cache\RateLimiting\Limit; use Illuminate\Http\Request; use Illuminate\Support\Facades\RateLimiter; +use Illuminate\Support\Facades\URL; use Illuminate\Support\ServiceProvider; use Illuminate\Support\Str; @@ -68,6 +69,8 @@ class AppServiceProvider extends ServiceProvider */ public function boot(): void { + URL::forceScheme('https'); + Str::macro('turkishSlug', function (string $text, string $separator = '-'): string { $map = [ 'ç' => 'c', From f008e2d9d11ccd52256a618b70281fb75c9cc568 Mon Sep 17 00:00:00 2001 From: bulut Date: Fri, 27 Mar 2026 12:00:58 +0300 Subject: [PATCH 3/4] trust proxies 1 --- app/Providers/AppServiceProvider.php | 2 ++ 1 file changed, 2 insertions(+) diff --git a/app/Providers/AppServiceProvider.php b/app/Providers/AppServiceProvider.php index fea32e3..86fdf31 100644 --- a/app/Providers/AppServiceProvider.php +++ b/app/Providers/AppServiceProvider.php @@ -40,6 +40,8 @@ class AppServiceProvider extends ServiceProvider /** * @var array */ + + public array $bindings = [ CategoryRepositoryInterface::class => CategoryRepository::class, CourseRepositoryInterface::class => CourseRepository::class, From cb5c24648d9b9a460502730e2f07ebf8eb0f365d Mon Sep 17 00:00:00 2001 From: Bulut Kuru Date: Fri, 27 Mar 2026 13:36:55 +0300 Subject: [PATCH 4/4] deploy sh --- scripts/deploy-prod.sh | 17 +++++++++-------- scripts/deploy-test.sh | 17 +++++++++-------- 2 files changed, 18 insertions(+), 16 deletions(-) diff --git a/scripts/deploy-prod.sh b/scripts/deploy-prod.sh index a559eb1..2dda304 100755 --- a/scripts/deploy-prod.sh +++ b/scripts/deploy-prod.sh @@ -28,6 +28,7 @@ if [ ! -f "$ENV_SOURCE" ]; then exit 1 fi + cp "$ENV_SOURCE" .env if ! grep -q '^APP_KEY=base64:' .env; then @@ -42,16 +43,16 @@ sudo find "$UPLOADS_DIR" -type f -exec chmod 664 {} \; 2>/dev/null || true docker stop "$CONTAINER" 2>/dev/null || true docker rm "$CONTAINER" 2>/dev/null || true -docker compose -f "$COMPOSE_FILE" down --remove-orphans 2>/dev/null || true -docker compose -f "$COMPOSE_FILE" up -d --build +docker compose -p bogazici-api-prod -f "$COMPOSE_FILE" down --remove-orphans 2>/dev/null || true +docker compose -p bogazici-api-prod -f "$COMPOSE_FILE" up -d --build sleep 3 -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" composer install --no-interaction --prefer-dist --optimize-autoloader --no-dev || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan migrate --force || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan optimize:clear || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan config:cache || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan route:cache || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan view:cache || true +docker compose -p bogazici-api-prod -f "$COMPOSE_FILE" exec -T "$CONTAINER" composer install --no-interaction --prefer-dist --optimize-autoloader --no-dev || true +docker compose -p bogazici-api-prod -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan migrate --force || true +docker compose -p bogazici-api-prod -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan optimize:clear || true +docker compose -p bogazici-api-prod -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan config:cache || true +docker compose -p bogazici-api-prod -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan route:cache || true +docker compose -p bogazici-api-prod -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan view:cache || true docker image prune -f 2>/dev/null || true diff --git a/scripts/deploy-test.sh b/scripts/deploy-test.sh index 7d6a3aa..58f2e7a 100755 --- a/scripts/deploy-test.sh +++ b/scripts/deploy-test.sh @@ -30,6 +30,7 @@ fi cp "$ENV_SOURCE" .env + if ! grep -q '^APP_KEY=base64:' .env; then echo "❌ HATA: APP_KEY eksik veya boş -> $ENV_SOURCE" exit 1 @@ -42,16 +43,16 @@ sudo find "$UPLOADS_DIR" -type f -exec chmod 664 {} \; 2>/dev/null || true docker stop "$CONTAINER" 2>/dev/null || true docker rm "$CONTAINER" 2>/dev/null || true -docker compose -f "$COMPOSE_FILE" down --remove-orphans 2>/dev/null || true -docker compose -f "$COMPOSE_FILE" up -d --build +docker compose -p bogazici-api-test -f "$COMPOSE_FILE" down --remove-orphans 2>/dev/null || true +docker compose -p bogazici-api-test -f "$COMPOSE_FILE" up -d --build sleep 3 -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" composer install --no-interaction --prefer-dist --optimize-autoloader || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan migrate --force || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan optimize:clear || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan config:cache || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan route:cache || true -docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan view:cache || true +docker compose -p bogazici-api-test -f "$COMPOSE_FILE" exec -T "$CONTAINER" composer install --no-interaction --prefer-dist --optimize-autoloader || true +docker compose -p bogazici-api-test -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan migrate --force || true +docker compose -p bogazici-api-test -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan optimize:clear || true +docker compose -p bogazici-api-test -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan config:cache || true +docker compose -p bogazici-api-test -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan route:cache || true +docker compose -p bogazici-api-test -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan view:cache || true docker image prune -f 2>/dev/null || true