Added repo secrets for .env file + google-services.json file. #10
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Deploy Next.js Docker App | |
on: | |
push: | |
branches: | |
- main | |
jobs: | |
build-and-deploy: | |
# Run on your self-hosted runner so it has Docker | |
runs-on: self-hosted | |
# Alternatively: runs-on: [self-hosted, linux] | |
steps: | |
- name: Check out repository | |
uses: actions/checkout@v3 | |
# Create the secret file "google-services.json" from the repo secret | |
- name: Create google-services.json | |
run: echo "${{ secrets.GOOGLE_SERVICES_JSON }}" > google-services.json | |
# Create a .env file from a repo secret (if needed) | |
- name: Create .env file | |
run: echo "${{ secrets.ENV_FILE_CONTENT }}" > .env | |
- name: Build Docker image | |
run: | | |
docker build -t codebuilder-webapp:latest . | |
- name: Stop and remove old container (if running) | |
run: | | |
# Find any running container based on the image | |
OLD_CONTAINER_ID=$(docker ps -q --filter ancestor=codebuilder-webapp:latest) | |
if [ -n "$OLD_CONTAINER_ID" ]; then | |
echo "Stopping and removing container $OLD_CONTAINER_ID..." | |
docker stop $OLD_CONTAINER_ID | |
docker rm $OLD_CONTAINER_ID | |
else | |
echo "No old container found." | |
fi | |
- name: Start new container | |
run: | | |
docker run -d --network host -p 3000:3000 --name codebuilder-webapp codebuilder-webapp:latest |