adding pipeline and dockerfile

This commit is contained in:
José Henrique 2025-01-22 21:38:36 -03:00
parent d25dae734c
commit f8381dd4fd
3 changed files with 96 additions and 0 deletions

18
.gitea/workflows/ci.yml Normal file
View File

@ -0,0 +1,18 @@
name: CI
on:
pull_request:
branches: [ "master" ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Setup project
run: npm install
- name: Build
run: npm run build

View File

@ -0,0 +1,58 @@
name: Master Build
on:
push:
branches: [ "master" ]
jobs:
build_amd64:
name: Build and Push Docker Image (amd64)
runs-on: self-hosted-ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Install docker and docker compose
run: |
apt update
apt install -y docker
- name: Login to Docker Hub
uses: https://github.com/docker/login-action@v3.3.0
with:
registry: git.ivanch.me
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_ACCESS_TOKEN }}
- name: Build Docker image and push
id: docker_build
uses: https://github.com/docker/build-push-action@v6.12.0
with:
context: ./
file: ./Dockerfile
push: true
tags: https://git.ivanch.me/ivanch/new-home/home-page:latest
platforms: linux/amd64
- name: Image digest
run: echo ${{ steps.docker_build.outputs.digest }}
deploy:
name: Update running container
runs-on: self-hosted-ubuntu-latest
needs: build_amd64
steps:
- name: Recreate container
uses: https://github.com/appleboy/ssh-action@v1.2.0
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
key: ${{ secrets.KEY }}
port: ${{ secrets.PORT }}
script: |
cd ${{ secrets.PROJECT_DIR }}
docker compose down
docker compose rm
docker compose pull
docker compose up -d

20
Dockerfile Normal file
View File

@ -0,0 +1,20 @@
FROM node:14 AS build
WORKDIR /app
COPY package*.json ./
RUN npm install
COPY . .
RUN npm run build
FROM nginx:alpine
COPY --from=build /app/build /usr/share/nginx/html
EXPOSE 80
# Start Nginx server
CMD ["nginx", "-g", "daemon off;"]