Compare commits
7 Commits
2ac5fdca30
...
v0.2.5
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f4185364d5 | ||
|
|
860159ccd0 | ||
|
|
b21d8fe52c | ||
|
|
c6fa25ed47 | ||
|
|
0e97c23579 | ||
|
|
865a1b0081 | ||
|
|
b3e5119568 |
64
.gitea/workflows/deploy.yml
Normal file
64
.gitea/workflows/deploy.yml
Normal file
@@ -0,0 +1,64 @@
|
||||
name: Deploy AgentLens
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- "v*"
|
||||
workflow_dispatch:
|
||||
|
||||
env:
|
||||
COMPOSE_PROJECT_NAME: agentlens
|
||||
DOCKER_HOST: tcp://192.168.1.133:2375
|
||||
|
||||
jobs:
|
||||
deploy:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v4
|
||||
with:
|
||||
fetch-depth: 0
|
||||
|
||||
- name: Verify Docker access
|
||||
run: |
|
||||
docker version
|
||||
docker compose version
|
||||
|
||||
- name: Write environment file
|
||||
run: |
|
||||
cat > .env <<'ENVEOF'
|
||||
AUTH_SECRET=${{ secrets.AUTH_SECRET }}
|
||||
STRIPE_SECRET_KEY=${{ secrets.STRIPE_SECRET_KEY }}
|
||||
STRIPE_WEBHOOK_SECRET=${{ secrets.STRIPE_WEBHOOK_SECRET }}
|
||||
POSTGRES_PASSWORD=${{ secrets.POSTGRES_PASSWORD }}
|
||||
REDIS_PASSWORD=${{ secrets.REDIS_PASSWORD }}
|
||||
EMAIL_PASSWORD=${{ secrets.EMAIL_PASSWORD }}
|
||||
ENVEOF
|
||||
sed -i 's/^[[:space:]]*//' .env
|
||||
|
||||
- name: Build and deploy
|
||||
run: |
|
||||
echo "Deploying AgentLens ${{ gitea.ref_name }}..."
|
||||
docker compose build web migrate
|
||||
docker compose up -d --no-deps --remove-orphans web migrate redis postgres
|
||||
echo "Waiting for migration and startup..."
|
||||
sleep 25
|
||||
|
||||
- name: Health check
|
||||
run: |
|
||||
for i in 1 2 3 4 5; do
|
||||
STATUS=$(docker inspect --format='{{.State.Running}}' agentlens-web-1 2>/dev/null || true)
|
||||
if [ "$STATUS" = "true" ]; then
|
||||
echo "Container running (attempt $i)"
|
||||
exit 0
|
||||
fi
|
||||
echo "Attempt $i/5 — retrying in 10s..."
|
||||
sleep 10
|
||||
done
|
||||
echo "Health check failed after 5 attempts"
|
||||
docker compose logs web --tail 50
|
||||
exit 1
|
||||
|
||||
- name: Cleanup
|
||||
if: always()
|
||||
run: docker image prune -f
|
||||
@@ -14,7 +14,11 @@ FROM base AS builder
|
||||
COPY --from=deps /app/node_modules ./node_modules
|
||||
COPY . .
|
||||
RUN npx prisma generate --schema=packages/database/prisma/schema.prisma
|
||||
RUN npx turbo build
|
||||
RUN npx turbo build --filter=@agentlens/web...
|
||||
|
||||
FROM base AS migrate
|
||||
COPY --from=deps /app/node_modules ./node_modules
|
||||
COPY packages/database/prisma ./packages/database/prisma
|
||||
|
||||
FROM base AS web
|
||||
RUN addgroup --system --gid 1001 nodejs && \
|
||||
|
||||
@@ -74,7 +74,7 @@ services:
|
||||
migrate:
|
||||
build:
|
||||
context: .
|
||||
target: builder
|
||||
target: migrate
|
||||
command: npx prisma db push --schema=packages/database/prisma/schema.prisma --skip-generate
|
||||
environment:
|
||||
- DATABASE_URL=postgresql://${POSTGRES_USER:-agentlens}:${POSTGRES_PASSWORD:-agentlens}@postgres:5432/${POSTGRES_DB:-agentlens}
|
||||
|
||||
Reference in New Issue
Block a user