50 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| name: Create OCI image(s)
 | |
| 
 | |
| on:
 | |
|   workflow_dispatch:
 | |
|   push:
 | |
|     branches:
 | |
|       - main
 | |
| 
 | |
| env:
 | |
|   registry: git.amarth.cloud
 | |
|   owner: amarth
 | |
|   image: default
 | |
|   tag: latest
 | |
| 
 | |
| jobs:
 | |
|   build:
 | |
|     name: Build and push images
 | |
|     runs-on: default
 | |
|     steps:
 | |
|       - name: Install nodejs
 | |
|         run: nix-env -iA nixpkgs.nodejs
 | |
| 
 | |
|       - uses: actions/checkout@v4
 | |
| 
 | |
|       - name: Prepare podman
 | |
|         run: |
 | |
|           # configure container policy to accept insecure registry
 | |
|           nix-env -iA nixpkgs.podman nixpkgs.kvmtool
 | |
| 
 | |
|           # configure container policy to accept insecure registry
 | |
|           mkdir -p ~/.config/containers
 | |
|           echo '{ "default": [ {"type":"insecureAcceptAnything"} ] }' > ~/.config/containers/policy.json
 | |
| 
 | |
|       - name: Log into registry
 | |
|         run: |
 | |
|           podman login --username "${{ forge.actor }}" --password "${{ PACKAGE_TOKEN }}" ${{ env.registry }}
 | |
| 
 | |
|           echo "~/.config/containers.auth.json"
 | |
|           [ -f ~/.config/containers.auth.json ] && cat ~/.config/containers.auth.json || echo "file doesn't exist"
 | |
| 
 | |
|       - name: Create image
 | |
|         run: |
 | |
|           nix-build src/default.nix
 | |
|           podman load < result
 | |
| 
 | |
|       - name: Push image
 | |
|         run: >-
 | |
|           podman push
 | |
|           localhost/default:latest
 | |
|           ${{ env.registry }}/${{ env.owner }}/${{ env.image }}:${{ env.tag }}
 |