ci: new workflow to build and deploy the app
This commit is contained in:
		
							parent
							
								
									d454ec8fc9
								
							
						
					
					
						commit
						f9f22cd7f4
					
				
					 2 changed files with 137 additions and 59 deletions
				
			
		
							
								
								
									
										137
									
								
								.github/workflows/deploy-to-staging.yml
									
										
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								.github/workflows/deploy-to-staging.yml
									
										
									
									
										vendored
									
									
										Normal file
									
								
							|  | @ -0,0 +1,137 @@ | ||||||
|  | name: Deploy to staging from main branch | ||||||
|  | 
 | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
|  |     tags-ignore: | ||||||
|  |       - '*' # ignore all tags | ||||||
|  | 
 | ||||||
|  | concurrency: | ||||||
|  |   group: deploy-staging | ||||||
|  |   cancel-in-progress: true | ||||||
|  | 
 | ||||||
|  | env: | ||||||
|  |   NAMESPACE: backoffice-staging | ||||||
|  |   HELM_VERSION: "3.12.1" | ||||||
|  |   DOCKER_REGISTRY: ghcr.io | ||||||
|  |   DOCKER_IMAGE: vojtechmares/backoffice | ||||||
|  | 
 | ||||||
|  | jobs: | ||||||
|  |   build: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  | 
 | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v3 | ||||||
|  |         with: | ||||||
|  |           ref: ${{ github.ref }} | ||||||
|  | 
 | ||||||
|  |       - name: set up qemu | ||||||
|  |         uses: docker/setup-qemu-action@v2 | ||||||
|  | 
 | ||||||
|  |       - name: set up docker buildx | ||||||
|  |         uses: docker/setup-buildx-action@v2 | ||||||
|  | 
 | ||||||
|  |       - name: docker login | ||||||
|  |         uses: docker/login-action@v2 | ||||||
|  |         with: | ||||||
|  |           registry: ${{ env.DOCKER_REGISTRY }} | ||||||
|  |           username: ${{ github.actor }} | ||||||
|  |           password: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  | 
 | ||||||
|  |       - name: docker meta | ||||||
|  |         id: docker_meta | ||||||
|  |         uses: docker/metadata-action@v4 | ||||||
|  |         with: | ||||||
|  |           tags: | | ||||||
|  |             type=schedule | ||||||
|  |             type=ref,event=branch | ||||||
|  |             type=ref,event=tag | ||||||
|  |             type=ref,event=pr | ||||||
|  |             type=sha,format=long | ||||||
|  |             type=raw,value=${{ github.ref_name }}-${{ github.sha }} | ||||||
|  |             type=raw,value=latest,enable=${{ github.ref == format('refs/heads/{0}', 'main') }} | ||||||
|  |           images: | | ||||||
|  |             ${{ env.DOCKER_REGISTRY }}/${{ env.DOCKER_IMAGE }} | ||||||
|  | 
 | ||||||
|  |       - name: build and push | ||||||
|  |         uses: docker/build-push-action@v4 | ||||||
|  |         with: | ||||||
|  |           pull: true | ||||||
|  |           push: true | ||||||
|  |           tags: ${{ steps.docker_meta.outputs.tags }} | ||||||
|  |           labels: ${{ steps.docker_meta.outputs.labels }} | ||||||
|  |           # platforms: linux/amd64,linux/arm64,linux/arm/v7 | ||||||
|  |           cache-from: type=registry,ref=${{ env.DOCKER_REGISTRY }}/${{ env.DOCKER_IMAGE }}:latest | ||||||
|  | 
 | ||||||
|  |   deploy: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     environment: | ||||||
|  |       name: staging | ||||||
|  |       url: https://staging.backoffice.mareshq.com | ||||||
|  |     needs: | ||||||
|  |       - build | ||||||
|  | 
 | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v3 | ||||||
|  |         with: | ||||||
|  |           ref: ${{ github.ref }} | ||||||
|  | 
 | ||||||
|  |       # Setup kubectl and Helm for Azure | ||||||
|  |       - uses: azure/setup-helm@v3 | ||||||
|  |         with: | ||||||
|  |           version: "${{ env.HELM_VERSION }}" | ||||||
|  | 
 | ||||||
|  |       - uses: azure/k8s-set-context@v3 | ||||||
|  |         with: | ||||||
|  |            method: kubeconfig | ||||||
|  |            kubeconfig: ${{ secrets.KUBECONFIG_CONTENT }} | ||||||
|  |            context: kiwi | ||||||
|  | 
 | ||||||
|  |       # - name: set imagepullsecret | ||||||
|  |       #  uses: azure/k8s-create-secret@v4 | ||||||
|  |       #  with: | ||||||
|  |       #     namespace: ${{ env.NAMESPACE }}} | ||||||
|  |       #     secret-name: ghcr-io-pull-secret | ||||||
|  |       #     container-registry-url: ${{ env.DOCKER_REGISTRY }} | ||||||
|  |       #     container-registry-username: ${{ secrets.REGISTRY_USERNAME }} | ||||||
|  |       #     container-registry-password: ${{ secrets.REGISTRY_PASSWORD }} | ||||||
|  |       #  id: create-secret | ||||||
|  | 
 | ||||||
|  |       - name: deploy dry run | ||||||
|  |         run: | | ||||||
|  |           helm upgrade \ | ||||||
|  |             --atomic \ | ||||||
|  |             --wait=true \ | ||||||
|  |             --wait-for-jobs=true \ | ||||||
|  |             --timeout 900s \ | ||||||
|  |             --dry-run=true \ | ||||||
|  |             --install \ | ||||||
|  |             --namespace=${{ env.NAMESPACE }} \ | ||||||
|  |             -f ./charts/backoffice/values.staging.yaml \ | ||||||
|  |             --set image.tag=${{ github.ref_name }}-${{ github.sha }} \ | ||||||
|  |             --set secrets.databaseURL=dummy \ | ||||||
|  |             --set secrets.nextauthSecret=dummy \ | ||||||
|  |             --set secrets.googleClientID=dummy \ | ||||||
|  |             --set secrets.googleClientSecret=dummy \ | ||||||
|  |             backoffice \ | ||||||
|  |             ./charts/backoffice | ||||||
|  | 
 | ||||||
|  |       - name: deploy | ||||||
|  |         run: | | ||||||
|  |           helm upgrade \ | ||||||
|  |             --atomic \ | ||||||
|  |             --wait=true \ | ||||||
|  |             --wait-for-jobs=true \ | ||||||
|  |             --timeout 900s \ | ||||||
|  |             --dry-run=true \ | ||||||
|  |             --install \ | ||||||
|  |             --namespace=${{ env.NAMESPACE }} \ | ||||||
|  |             -f ./charts/backoffice/values.staging.yaml \ | ||||||
|  |             --set image.tag=${{ github.ref_name }}-${{ github.sha }} \ | ||||||
|  |             --set secrets.databaseURL=${{ secrets.DATABASE_URL }} \ | ||||||
|  |             --set secrets.nextauthSecret=${{ secrets.NEXTAUTH_SECRET }} \ | ||||||
|  |             --set secrets.googleClientID=${{ secrets.GOOGLE_CLIENT_ID }} \ | ||||||
|  |             --set secrets.googleClientSecret=${{ secrets.GOOGLE_CLIENT_SECRET }} \ | ||||||
|  |             backoffice \ | ||||||
|  |             ./charts/backoffice | ||||||
							
								
								
									
										59
									
								
								.github/workflows/docker.yml
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										59
									
								
								.github/workflows/docker.yml
									
										
									
									
										vendored
									
									
								
							|  | @ -1,59 +0,0 @@ | ||||||
| name: Docker build on main branch |  | ||||||
| 
 |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|       - main |  | ||||||
| 
 |  | ||||||
| env: |  | ||||||
|   DOCKER_REGISTRY: ghcr.io |  | ||||||
|   DOCKER_IMAGE: vojtechmares/backoffice |  | ||||||
| 
 |  | ||||||
| jobs: |  | ||||||
|   build: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
| 
 |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v3 |  | ||||||
|         with: |  | ||||||
|           ref: ${{ github.ref }} |  | ||||||
| 
 |  | ||||||
|       # Setup Docker |  | ||||||
|       - name: Set up QEMU |  | ||||||
|         uses: docker/setup-qemu-action@v2 |  | ||||||
| 
 |  | ||||||
|       - name: Set up Docker Buildx |  | ||||||
|         uses: docker/setup-buildx-action@v2 |  | ||||||
| 
 |  | ||||||
|       - name: Docker login |  | ||||||
|         uses: docker/login-action@v2 |  | ||||||
|         with: |  | ||||||
|           registry: ${{ env.DOCKER_REGISTRY }} |  | ||||||
|           # Use repository secrets for username and password, not organization secrets |  | ||||||
|           username: ${{ github.actor }} |  | ||||||
|           password: ${{ secrets.GITHUB_TOKEN }} |  | ||||||
| 
 |  | ||||||
|       - name: Docker meta |  | ||||||
|         id: docker_meta |  | ||||||
|         uses: docker/metadata-action@v4 |  | ||||||
|         with: |  | ||||||
|           tags: | |  | ||||||
|             type=schedule |  | ||||||
|             type=ref,event=branch |  | ||||||
|             type=ref,event=tag |  | ||||||
|             type=ref,event=pr |  | ||||||
|             type=sha,format=long |  | ||||||
|             type=raw,value=${{ github.ref_name }}-${{ github.sha }} |  | ||||||
|             type=raw,value=latest,enable=${{ github.ref == format('refs/heads/{0}', 'main') }} |  | ||||||
|           images: | |  | ||||||
|             ${{ env.DOCKER_REGISTRY }}/${{ env.DOCKER_IMAGE }} |  | ||||||
| 
 |  | ||||||
|       - name: Build and push |  | ||||||
|         uses: docker/build-push-action@v4 |  | ||||||
|         with: |  | ||||||
|           pull: true |  | ||||||
|           push: true |  | ||||||
|           tags: ${{ steps.docker_meta.outputs.tags }} |  | ||||||
|           labels: ${{ steps.docker_meta.outputs.labels }} |  | ||||||
|           # platforms: linux/amd64,linux/arm64,linux/arm/v7 |  | ||||||
|           cache-from: type=registry,ref=${{ env.DOCKER_REGISTRY }}/${{ env.DOCKER_IMAGE }}:latest |  | ||||||
		Reference in a new issue