Skip to content

Merge pull request #8 from MASSIVEMAGNETICS/copilot/upgrade-vocal-gen… #1

Merge pull request #8 from MASSIVEMAGNETICS/copilot/upgrade-vocal-gen…

Merge pull request #8 from MASSIVEMAGNETICS/copilot/upgrade-vocal-gen… #1

Workflow file for this run

name: Web Deployment
on:
push:
branches: [ main ]
tags:
- 'v*.*.*'
workflow_dispatch:
inputs:
environment:
description: 'Deployment environment'
required: true
default: 'staging'
type: choice
options:
- staging
- production
permissions:
contents: read
env:
DOCKER_REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}/songbloom-web
jobs:
test:
runs-on: ubuntu-latest
permissions:
contents: read
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: '3.10'
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
- name: Run syntax check
run: |
python -m py_compile streamlit_app.py
- name: Test imports
run: |
python -c "import streamlit; print('✓ Streamlit imported successfully')"
build-docker:
runs-on: ubuntu-latest
needs: test
if: github.event_name == 'push' && (github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/v'))
permissions:
contents: read
packages: write
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Log in to Container Registry
uses: docker/login-action@v2
with:
registry: ${{ env.DOCKER_REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: Extract metadata
id: meta
uses: docker/metadata-action@v4
with:
images: ${{ env.DOCKER_REGISTRY }}/${{ env.IMAGE_NAME }}
tags: |
type=ref,event=branch
type=ref,event=pr
type=semver,pattern={{version}}
type=semver,pattern={{major}}.{{minor}}
type=sha,prefix={{branch}}-
- name: Build and push Docker image
uses: docker/build-push-action@v4
with:
context: .
file: ./Dockerfile.web
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
build-args: |
BUILD_DATE=${{ github.event.repository.updated_at }}
VCS_REF=${{ github.sha }}
VERSION=${{ steps.meta.outputs.version }}
deploy-streamlit-cloud:
runs-on: ubuntu-latest
needs: test
if: github.ref == 'refs/heads/main'
permissions:
contents: read
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Deploy to Streamlit Cloud
run: |
echo "Streamlit Cloud auto-deploys on push to main branch"
echo "Visit: https://share.streamlit.io/ to manage deployment"
echo "Main file: streamlit_app.py"
deploy-production:
runs-on: ubuntu-latest
needs: [test, build-docker]
if: startsWith(github.ref, 'refs/tags/v')
permissions:
contents: read
deployments: write
environment:
name: production
url: https://songbloom.ai
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Deploy to production
run: |
echo "Deploying version ${{ github.ref_name }} to production"
# Add your production deployment commands here
# Example: kubectl rollout, helm upgrade, etc.
- name: Create deployment notification
uses: actions/github-script@v6
with:
script: |
github.rest.repos.createDeploymentStatus({
owner: context.repo.owner,
repo: context.repo.repo,
deployment_id: context.payload.deployment.id,
state: 'success',
environment_url: 'https://songbloom.ai',
description: 'Deployment completed successfully'
})
security-scan:
runs-on: ubuntu-latest
needs: build-docker
if: github.event_name == 'push'
permissions:
contents: read
security-events: write
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Run Trivy vulnerability scanner
uses: aquasecurity/trivy-action@master
with:
image-ref: ${{ env.DOCKER_REGISTRY }}/${{ env.IMAGE_NAME }}:${{ github.sha }}
format: 'sarif'
output: 'trivy-results.sarif'
- name: Upload Trivy results to GitHub Security
uses: github/codeql-action/upload-sarif@v2
with:
sarif_file: 'trivy-results.sarif'