From 9b8ee6ead1e1b08689ee5ce8035f4be536df96d7 Mon Sep 17 00:00:00 2001 From: Josip Igrec Date: Sun, 17 Nov 2024 22:02:43 +0100 Subject: [PATCH] Add CI --- .dockerignore | 5 ++- .github/workflows/main.yaml | 69 ++++++++++++++++++++++++++++++ Dockerfile | 3 +- docker-compose.yml => compose.yaml | 4 +- 4 files changed, 76 insertions(+), 5 deletions(-) create mode 100644 .github/workflows/main.yaml rename docker-compose.yml => compose.yaml (87%) diff --git a/.dockerignore b/.dockerignore index 8d91ebee3..fd7f5f7bc 100644 --- a/.dockerignore +++ b/.dockerignore @@ -1,5 +1,8 @@ .vscode +.git +.github .dockerignore Dockerfile +compose.yaml ui -db.sqlite3 \ No newline at end of file +db.sqlite3 diff --git a/.github/workflows/main.yaml b/.github/workflows/main.yaml new file mode 100644 index 000000000..c36e445c0 --- /dev/null +++ b/.github/workflows/main.yaml @@ -0,0 +1,69 @@ +name: Build and deploy + +on: + push: + +concurrency: + group: ${{ github.workflow }}-${{ github.ref || github.run_id }} + cancel-in-progress: true + +jobs: + build-frontend: + runs-on: [self-hosted] + steps: + - uses: actions/checkout@v3 + - name: Login to Docker Hub + uses: docker/login-action@v3 + if: github.event_name != 'pull_request' + with: + username: ${{ vars.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Add some env variables (REMOVE WHEN FIXED) + run: | + echo "VUE_APP_DJANGO_USER=comp" >> ./ui/.env + echo "VUE_APP_DJANGO_PASS=Qf1EAPLhMv5c4CC8cbB0FUkB35rHSRcZ" >> ./ui/.env + echo "VUE_APP_BASE_URL=/api" >> ./ui/.env + - name: Build and push + uses: docker/build-push-action@v6 + with: + context: ./ui + push: ${{ github.event_name != 'pull_request' }} + pull: true + tags: | + ksetcomp/brucifer-karte-2022-frontend:latest + ksetcomp/brucifer-karte-2022-frontend:${{ github.sha }} + + build-backend: + runs-on: [self-hosted] + steps: + - uses: actions/checkout@v3 + - name: Login to Docker Hub + uses: docker/login-action@v3 + if: github.event_name != 'pull_request' + with: + username: ${{ vars.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Build and push + uses: docker/build-push-action@v6 + with: + context: . + push: ${{ github.event_name != 'pull_request' }} + pull: true + tags: | + ksetcomp/brucifer-karte-2022-backend:latest + ksetcomp/brucifer-karte-2022-backend:${{ github.sha }} + + notify-watchtower: + runs-on: [self-hosted] + needs: [build-frontend, build-backend] + steps: + - name: Notify Watchtower + run: | + curl -sL -v \ + --header 'Authorization: Bearer ${{ secrets.WATCHTOWER_TOKEN }}' \ + "${{ vars.WATCHTOWER_URL }}/v1/update" + diff --git a/Dockerfile b/Dockerfile index ddced8850..723f7aad8 100644 --- a/Dockerfile +++ b/Dockerfile @@ -8,4 +8,5 @@ RUN pip install -r requirements.txt ADD . /code/ COPY ./docker-entrypoint.sh /docker-entrypoint.sh RUN chmod a+x /docker-entrypoint.sh -ENTRYPOINT ["bash","/docker-entrypoint.sh"] \ No newline at end of file +EXPOSE 8000 +ENTRYPOINT ["bash","/docker-entrypoint.sh"] diff --git a/docker-compose.yml b/compose.yaml similarity index 87% rename from docker-compose.yml rename to compose.yaml index d7542a58e..7d4ffae54 100644 --- a/docker-compose.yml +++ b/compose.yaml @@ -1,5 +1,3 @@ -version: '3.3' - services: django: build: @@ -13,4 +11,4 @@ services: context: ./ui dockerfile: Dockerfile depends_on: - - django \ No newline at end of file + - django