Skip to content

Revert "add AWS_DEFAULT_REGION" #8

Revert "add AWS_DEFAULT_REGION"

Revert "add AWS_DEFAULT_REGION" #8

Workflow file for this run

name: Deploy to AWS
on:
push:
branches:
- main
jobs:
deploy:
runs-on: ubuntu-latest
steps:
# Checkout the repository
- name: Checkout Code
uses: actions/checkout@v2
# Set up SSH Key for EC2 Access
- name: Set Up SSH
env:
PRIVATE_KEY: ${{ secrets.EC2_SSH_KEY }}
EC2_USER: ${{ secrets.EC2_USER }}
EC2_HOST: ${{ secrets.EC2_HOST }}
run: |
echo "$PRIVATE_KEY" > github-ec2 && chmod 600 github-ec2
# Copy backend files to EC2
- name: Deploy Application to EC2
run: |
echo "Copying backend directory to EC2..."
ssh -v -o StrictHostKeyChecking=no -i github-ec2 ${EC2_USER}@${EC2_HOST} "echo Connected"
scp -o StrictHostKeyChecking=no -r backend/docker-compose.yml ${EC2_USER}@${EC2_HOST}:~/job-application-tracker/
# Create .env file on EC2
- name: Configure Environment Variables
env:
APP_URL: ${{ secrets.APP_URL }}
PORT: ${{ secrets.PORT }}
ALLOWED_ORIGINS: ${{ secrets.ALLOWED_ORIGINS }}
DB_USER: ${{ secrets.DB_USER }}
DB_PASS: ${{ secrets.DB_PASS }}
GEMINI_API_KEY: ${{ secrets.GEMINI_API_KEY }}
KEY_STORE_PASS: ${{ secrets.KEY_STORE_PASS }}
KEY_STORE_ALIAS: ${{ secrets.KEY_STORE_ALIAS }}
MAIL_HOST: ${{ secrets.MAIL_HOST }}
MAIL_PORT: ${{ secrets.MAIL_PORT }}
MAIL_USER: ${{ secrets.MAIL_USER }}
MAIL_PASS: ${{ secrets.MAIL_PASS }}
TURNSTILE_SECRET: ${{ secrets.TURNSTILE_SECRET }}
run: |
echo "Creating .env file on EC2..."
ssh -o StrictHostKeyChecking=no ${EC2_USER}@${EC2_HOST} << 'EOF'
mkdir -p ~/job-application-tracker
cat <<EOT > ~/job-application-tracker/.env
APP_URL=${APP_URL}
PORT=${PORT}
ALLOWED_ORIGINS=${ALLOWED_ORIGINS}
DB_USER=${DB_USER}
DB_PASS=${DB_PASS}
GEMINI_API_KEY=${GEMINI_API_KEY}
KEY_STORE_PASS=${KEY_STORE_PASS}
KEY_STORE_ALIAS=${KEY_STORE_ALIAS}
MAIL_HOST=${MAIL_HOST}
MAIL_PORT=${MAIL_PORT}
MAIL_USER=${MAIL_USER}
MAIL_PASS=${MAIL_PASS}
TURNSTILE_SECRET=${TURNSTILE_SECRET}
EOT
EOF
# Start Application on EC2
- name: Start Application
env:
EC2_USER: ${{ secrets.EC2_USER }}
EC2_HOST: ${{ secrets.EC2_HOST }}
run: |
echo "Deploying application on EC2..."
ssh -o StrictHostKeyChecking=no ${EC2_USER}@${EC2_HOST} << 'EOF'
cd ~/job-application-tracker
docker-compose down
docker-compose up --build -d
EOF