frappe_docker/.github/workflows/build-dokploy.yml
ubden 0ac9cd8a94 fix: Change port from 8088 back to 8080 (standard Frappe port for SSL)
Port changes:
- HTTP_PORT: 8088 → 8080 (default Frappe port)
- All documentation updated to reflect port 8080
- GitHub Actions tests updated to port 8080
- SSL works correctly with standard port 8080 in Dokploy

Reason:
- Port 8080 is the standard Frappe frontend port
- Dokploy SSL/HTTPS works better with default port
- Consistent with Frappe conventions

Files updated:
- README.md
- dokploy/README.md
- dokploy/QUICKSTART.md
- dokploy/DEPLOYMENT.md
- dokploy/SSL_SETUP.md
- dokploy/SUMMARY.md
- dokploy/CHANGELOG.md
- dokploy/CHECKLIST.md
- dokploy/docker-compose.yml
- .github/workflows/build-dokploy.yml

SSL/HTTPS:
- Dokploy handles SSL termination on port 443
- Internal communication uses port 8080
- HTTPS redirect automatic
- Let's Encrypt auto-renewal
2025-10-14 09:33:46 +03:00

149 lines
4.2 KiB
YAML

name: Build Dokploy Image
on:
push:
branches:
- main
paths:
- 'dokploy/**'
- 'images/production/**'
- 'resources/**'
tags:
- 'v*.*.*'
- 'dokploy-v*.*.*'
pull_request:
branches:
- main
paths:
- 'dokploy/**'
workflow_dispatch:
env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}/erpnext-complete
jobs:
build-and-push:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log in to Container Registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
tags: |
type=ref,event=branch
type=ref,event=pr
type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}}
type=semver,pattern={{major}}
type=sha,prefix={{branch}}-
type=raw,value=latest,enable={{is_default_branch}}
flavor: |
latest=auto
- name: Free Disk Space
run: |
sudo rm -rf /usr/share/dotnet
sudo rm -rf /opt/ghc
sudo rm -rf "/usr/local/share/boost"
sudo rm -rf "$AGENT_TOOLSDIRECTORY"
sudo docker system prune -af
df -h
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: .
file: ./dokploy/Dockerfile
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
platforms: linux/amd64
build-args: |
FRAPPE_BRANCH=version-15
PYTHON_VERSION=3.11.6
NODE_VERSION=20.19.2
no-cache: false
# Essential apps: ERPNext, CRM, Helpdesk, Payments
- name: Image digest
run: echo ${{ steps.meta.outputs.digest }}
test-deployment:
needs: build-and-push
runs-on: ubuntu-latest
if: github.event_name == 'pull_request'
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Create test environment file
run: |
cd dokploy
cat > .env.test << EOF
SITE_NAME=test.localhost
ADMIN_PASSWORD=testpassword
DB_PASSWORD=testdbpassword
HTTP_PORT=8080
EOF
- name: Start services
run: |
cd dokploy
docker-compose --env-file .env.test up -d
- name: Wait for services to be healthy
run: |
timeout 900 bash -c 'until docker-compose -f dokploy/docker-compose.yml ps | grep -q "healthy"; do sleep 15; done'
- name: Check site creation
run: |
docker-compose -f dokploy/docker-compose.yml logs create-site
docker-compose -f dokploy/docker-compose.yml ps create-site | grep "Exit 0"
- name: Verify installed apps
run: |
docker-compose -f dokploy/docker-compose.yml exec -T backend bench --site test.localhost list-apps
- name: Test site accessibility
run: |
sleep 30
curl -f http://localhost:8080/api/method/ping || exit 1
- name: Test installed apps
run: |
echo "Verifying 4 essential apps are installed..."
docker-compose -f dokploy/docker-compose.yml exec -T backend bash -c "
bench --site test.localhost list-apps | grep -q 'erpnext' || exit 1
bench --site test.localhost list-apps | grep -q 'crm' || exit 1
bench --site test.localhost list-apps | grep -q 'helpdesk' || exit 1
bench --site test.localhost list-apps | grep -q 'payments' || exit 1
"
- name: Cleanup
if: always()
run: |
cd dokploy
docker-compose down -v