Compare commits
22 Commits
55711a88ef
...
test
| Author | SHA1 | Date | |
|---|---|---|---|
| 38e1058e05 | |||
|
|
acd3298c61 | ||
| 486d1b55c5 | |||
|
|
733607493a | ||
|
|
8bd35c425d | ||
|
|
5ad61853b4 | ||
| 1fd5cab540 | |||
|
|
272010d738 | ||
| 72da6a7600 | |||
|
|
9e88de9902 | ||
| 87fbf98858 | |||
|
|
fa14e752ac | ||
| a24c2f18d8 | |||
|
|
fea885f6cf | ||
|
|
268bf371df | ||
| 49f9f69b1e | |||
|
|
e51d6b0cb0 | ||
| c7e251cc1c | |||
|
|
cb5c24648d | ||
|
|
f008e2d9d1 | ||
|
|
b25c5d2cfb | ||
|
|
79d0b2e54f |
34
.drone.yml
34
.drone.yml
@@ -1,29 +1,15 @@
|
|||||||
kind: pipeline
|
kind: pipeline
|
||||||
type: docker
|
type: docker
|
||||||
name: default
|
name: bogazici-api
|
||||||
|
|
||||||
trigger:
|
trigger:
|
||||||
|
event:
|
||||||
|
- push
|
||||||
branch:
|
branch:
|
||||||
- develop
|
|
||||||
- test
|
- test
|
||||||
- main
|
- main
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: laravel-check
|
|
||||||
image: php:8.4-cli
|
|
||||||
when:
|
|
||||||
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
|
|
||||||
- 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 test || true
|
|
||||||
|
|
||||||
- name: deploy-test
|
- name: deploy-test
|
||||||
image: appleboy/drone-ssh
|
image: appleboy/drone-ssh
|
||||||
when:
|
when:
|
||||||
@@ -31,11 +17,12 @@ steps:
|
|||||||
- test
|
- test
|
||||||
settings:
|
settings:
|
||||||
host:
|
host:
|
||||||
from_secret: server_host
|
from_secret: SERVER_HOST
|
||||||
username:
|
username:
|
||||||
from_secret: server_user
|
from_secret: SERVER_USER
|
||||||
key:
|
key:
|
||||||
from_secret: server_ssh_key
|
from_secret: SERVER_SSH_KEY
|
||||||
|
port: 22
|
||||||
script:
|
script:
|
||||||
- cd /opt/projects/bogazici/corporate-api/test/api
|
- cd /opt/projects/bogazici/corporate-api/test/api
|
||||||
- bash scripts/deploy-test.sh
|
- bash scripts/deploy-test.sh
|
||||||
@@ -47,11 +34,12 @@ steps:
|
|||||||
- main
|
- main
|
||||||
settings:
|
settings:
|
||||||
host:
|
host:
|
||||||
from_secret: server_host
|
from_secret: SERVER_HOST
|
||||||
username:
|
username:
|
||||||
from_secret: server_user
|
from_secret: SERVER_USER
|
||||||
key:
|
key:
|
||||||
from_secret: server_ssh_key
|
from_secret: SERVER_SSH_KEY
|
||||||
|
port: 22
|
||||||
script:
|
script:
|
||||||
- cd /opt/projects/bogazici/corporate-api/prod/api
|
- cd /opt/projects/bogazici/corporate-api/prod/api
|
||||||
- bash scripts/deploy-prod.sh
|
- bash scripts/deploy-prod.sh
|
||||||
|
|||||||
@@ -31,6 +31,7 @@ use App\Repositories\Eloquent\UserRepository;
|
|||||||
use Illuminate\Cache\RateLimiting\Limit;
|
use Illuminate\Cache\RateLimiting\Limit;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Support\Facades\RateLimiter;
|
use Illuminate\Support\Facades\RateLimiter;
|
||||||
|
use Illuminate\Support\Facades\URL;
|
||||||
use Illuminate\Support\ServiceProvider;
|
use Illuminate\Support\ServiceProvider;
|
||||||
use Illuminate\Support\Str;
|
use Illuminate\Support\Str;
|
||||||
|
|
||||||
@@ -39,6 +40,8 @@ class AppServiceProvider extends ServiceProvider
|
|||||||
/**
|
/**
|
||||||
* @var array<class-string, class-string>
|
* @var array<class-string, class-string>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public array $bindings = [
|
public array $bindings = [
|
||||||
CategoryRepositoryInterface::class => CategoryRepository::class,
|
CategoryRepositoryInterface::class => CategoryRepository::class,
|
||||||
CourseRepositoryInterface::class => CourseRepository::class,
|
CourseRepositoryInterface::class => CourseRepository::class,
|
||||||
@@ -68,6 +71,8 @@ class AppServiceProvider extends ServiceProvider
|
|||||||
*/
|
*/
|
||||||
public function boot(): void
|
public function boot(): void
|
||||||
{
|
{
|
||||||
|
URL::forceScheme('https');
|
||||||
|
|
||||||
Str::macro('turkishSlug', function (string $text, string $separator = '-'): string {
|
Str::macro('turkishSlug', function (string $text, string $separator = '-'): string {
|
||||||
$map = [
|
$map = [
|
||||||
'ç' => 'c',
|
'ç' => 'c',
|
||||||
|
|||||||
@@ -1,9 +1,10 @@
|
|||||||
|
name: bogazici-api-prod
|
||||||
|
|
||||||
services:
|
services:
|
||||||
bdc-api-prod:
|
bdc-api-prod:
|
||||||
build:
|
build:
|
||||||
context: .
|
context: .
|
||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
container_name: bdc-api-prod
|
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
volumes:
|
volumes:
|
||||||
- ./:/var/www/html
|
- ./:/var/www/html
|
||||||
|
|||||||
@@ -1,9 +1,10 @@
|
|||||||
|
name: bogazici-api-test
|
||||||
|
|
||||||
services:
|
services:
|
||||||
bdc-api-test:
|
bdc-api-test:
|
||||||
build:
|
build:
|
||||||
context: .
|
context: .
|
||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
container_name: bdc-api-test
|
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
volumes:
|
volumes:
|
||||||
- ./:/var/www/html
|
- ./:/var/www/html
|
||||||
|
|||||||
@@ -6,17 +6,19 @@ ENV_SOURCE="/opt/projects/bogazici/corporate-api/prod/.env.prod"
|
|||||||
BRANCH="main"
|
BRANCH="main"
|
||||||
CONTAINER="bdc-api-prod"
|
CONTAINER="bdc-api-prod"
|
||||||
COMPOSE_FILE="docker-compose.prod.yml"
|
COMPOSE_FILE="docker-compose.prod.yml"
|
||||||
|
COMPOSE_PROJECT="bogazici-api-prod"
|
||||||
UPLOADS_DIR="/opt/projects/bogazici/corporate-api/prod/uploads"
|
UPLOADS_DIR="/opt/projects/bogazici/corporate-api/prod/uploads"
|
||||||
|
|
||||||
echo "🚀 [API] Production deploy başlatılıyor..."
|
echo "🚀 [API] Production deploy başlatılıyor..."
|
||||||
|
|
||||||
cd "$PROJECT_DIR"
|
cd "$PROJECT_DIR"
|
||||||
|
|
||||||
sudo chown -R "$USER":www-data storage bootstrap/cache 2>/dev/null || true
|
git config --global --add safe.directory "$PROJECT_DIR" || true
|
||||||
sudo find storage -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
|
||||||
sudo find storage -type f -exec chmod 664 {} \; 2>/dev/null || true
|
find storage -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
||||||
sudo find bootstrap/cache -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
find storage -type f -exec chmod 664 {} \; 2>/dev/null || true
|
||||||
sudo find bootstrap/cache -type f -exec chmod 664 {} \; 2>/dev/null || true
|
find bootstrap/cache -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
||||||
|
find bootstrap/cache -type f -exec chmod 664 {} \; 2>/dev/null || true
|
||||||
|
|
||||||
git fetch origin
|
git fetch origin
|
||||||
git checkout "$BRANCH"
|
git checkout "$BRANCH"
|
||||||
@@ -35,23 +37,35 @@ if ! grep -q '^APP_KEY=base64:' .env; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sudo mkdir -p "$UPLOADS_DIR"/{images,videos,hero-slides,settings,pages,courses,announcements,categories}
|
|
||||||
sudo chown -R "$USER":www-data "$UPLOADS_DIR" 2>/dev/null || true
|
|
||||||
sudo find "$UPLOADS_DIR" -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
|
||||||
sudo find "$UPLOADS_DIR" -type f -exec chmod 664 {} \; 2>/dev/null || true
|
|
||||||
|
|
||||||
docker stop "$CONTAINER" 2>/dev/null || true
|
mkdir -p "$UPLOADS_DIR"
|
||||||
docker rm "$CONTAINER" 2>/dev/null || true
|
chmod 2775 "$UPLOADS_DIR" 2>/dev/null || true
|
||||||
docker compose -f "$COMPOSE_FILE" down --remove-orphans 2>/dev/null || true
|
|
||||||
docker compose -f "$COMPOSE_FILE" up -d --build
|
|
||||||
|
|
||||||
sleep 3
|
docker rm -f bogazici-api-prod-bdc-api-prod-1 2>/dev/null || true
|
||||||
docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" composer install --no-interaction --prefer-dist --optimize-autoloader --no-dev || true
|
docker rm -f bdc-api-prod 2>/dev/null || 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 -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" down --remove-orphans || true
|
||||||
docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan config:cache || true
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" up -d --build
|
||||||
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
|
echo "⏳ Container hazır olması bekleniyor..."
|
||||||
|
for i in {1..30}; do
|
||||||
|
if docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" ps --status running | grep -q "$CONTAINER"; then
|
||||||
|
echo "✅ Container ayakta"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
if [ "$i" -eq 30 ]; then
|
||||||
|
echo "❌ HATA: Container zamanında ayağa kalkmadı"
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" logs --tail=100
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" composer install --no-interaction --prefer-dist --optimize-autoloader --no-dev
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan optimize:clear
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan config:cache
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan route:cache
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan view:cache
|
||||||
|
|
||||||
docker image prune -f 2>/dev/null || true
|
docker image prune -f 2>/dev/null || true
|
||||||
|
|
||||||
|
|||||||
@@ -6,17 +6,19 @@ ENV_SOURCE="/opt/projects/bogazici/corporate-api/test/.env.test"
|
|||||||
BRANCH="test"
|
BRANCH="test"
|
||||||
CONTAINER="bdc-api-test"
|
CONTAINER="bdc-api-test"
|
||||||
COMPOSE_FILE="docker-compose.test.yml"
|
COMPOSE_FILE="docker-compose.test.yml"
|
||||||
|
COMPOSE_PROJECT="bogazici-api-test"
|
||||||
UPLOADS_DIR="/opt/projects/bogazici/corporate-api/test/uploads"
|
UPLOADS_DIR="/opt/projects/bogazici/corporate-api/test/uploads"
|
||||||
|
|
||||||
echo "🚀 [API] Test deploy başlatılıyor..."
|
echo "🚀 [API] Test deploy başlatılıyor..."
|
||||||
|
|
||||||
cd "$PROJECT_DIR"
|
cd "$PROJECT_DIR"
|
||||||
|
|
||||||
sudo chown -R "$USER":www-data storage bootstrap/cache 2>/dev/null || true
|
git config --global --add safe.directory "$PROJECT_DIR" || true
|
||||||
sudo find storage -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
|
||||||
sudo find storage -type f -exec chmod 664 {} \; 2>/dev/null || true
|
find storage -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
||||||
sudo find bootstrap/cache -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
find storage -type f -exec chmod 664 {} \; 2>/dev/null || true
|
||||||
sudo find bootstrap/cache -type f -exec chmod 664 {} \; 2>/dev/null || true
|
find bootstrap/cache -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
||||||
|
find bootstrap/cache -type f -exec chmod 664 {} \; 2>/dev/null || true
|
||||||
|
|
||||||
git fetch origin
|
git fetch origin
|
||||||
git checkout "$BRANCH"
|
git checkout "$BRANCH"
|
||||||
@@ -35,23 +37,35 @@ if ! grep -q '^APP_KEY=base64:' .env; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
sudo mkdir -p "$UPLOADS_DIR"/{images,videos,hero-slides,settings,pages,courses,announcements,categories}
|
mkdir -p "$UPLOADS_DIR"
|
||||||
sudo chown -R "$USER":www-data "$UPLOADS_DIR" 2>/dev/null || true
|
chmod 2775 "$UPLOADS_DIR" 2>/dev/null || true
|
||||||
sudo find "$UPLOADS_DIR" -type d -exec chmod 2775 {} \; 2>/dev/null || true
|
|
||||||
sudo find "$UPLOADS_DIR" -type f -exec chmod 664 {} \; 2>/dev/null || true
|
|
||||||
|
|
||||||
docker stop "$CONTAINER" 2>/dev/null || true
|
docker rm -f bogazici-api-test-bdc-api-test-1 2>/dev/null || true
|
||||||
docker rm "$CONTAINER" 2>/dev/null || true
|
docker rm -f bdc-api-test 2>/dev/null || true
|
||||||
docker compose -f "$COMPOSE_FILE" down --remove-orphans 2>/dev/null || true
|
|
||||||
docker compose -f "$COMPOSE_FILE" up -d --build
|
|
||||||
|
|
||||||
sleep 3
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" down --remove-orphans || true
|
||||||
docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" composer install --no-interaction --prefer-dist --optimize-autoloader || true
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" up -d --build
|
||||||
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
|
echo "⏳ Container hazır olması bekleniyor..."
|
||||||
docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan route:cache || true
|
for i in {1..30}; do
|
||||||
docker compose -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan view:cache || true
|
if docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" ps --status running | grep -q "$CONTAINER"; then
|
||||||
|
echo "✅ Container ayakta"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
if [ "$i" -eq 30 ]; then
|
||||||
|
echo "❌ HATA: Container zamanında ayağa kalkmadı"
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" logs --tail=100
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" composer install --no-interaction --prefer-dist --optimize-autoloader
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan optimize:clear
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan config:cache
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan route:cache
|
||||||
|
docker compose -p "$COMPOSE_PROJECT" -f "$COMPOSE_FILE" exec -T "$CONTAINER" php artisan view:cache
|
||||||
|
|
||||||
docker image prune -f 2>/dev/null || true
|
docker image prune -f 2>/dev/null || true
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user