Compare commits
	
		
			No commits in common. "feat/simple-rolls" and "develop" have entirely different histories.
		
	
	
		
			feat/simpl
			...
			develop
		
	
		
							
								
								
									
										103
									
								
								.github/workflows/ci.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								.github/workflows/ci.yaml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,103 @@ | |||||||
|  | name: CI/CD Pipeline | ||||||
|  | 
 | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - develop | ||||||
|  |     tags: | ||||||
|  |       - 'v*' | ||||||
|  |   pull_request: | ||||||
|  |     types: [opened, synchronize, reopened] | ||||||
|  | 
 | ||||||
|  | env: | ||||||
|  |   REGISTRY: labs.phundrak.com | ||||||
|  |   IMAGE_NAME: phundrak/roll-one-ring | ||||||
|  | 
 | ||||||
|  | jobs: | ||||||
|  |   build-and-publish: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     permissions: | ||||||
|  |       contents: read | ||||||
|  |       packages: write | ||||||
|  |     steps: | ||||||
|  |     - name: Checkout repository | ||||||
|  |       uses: actions/checkout@v5 | ||||||
|  | 
 | ||||||
|  |     - name: Install Nix | ||||||
|  |       uses: cachix/install-nix-action@v31.6.0 | ||||||
|  | 
 | ||||||
|  |     - name: Setup Cachix | ||||||
|  |       uses: cachix/cachix-action@v16 | ||||||
|  |       with: | ||||||
|  |         name: roll-one-ring | ||||||
|  |         authToken: '${{ secrets.CACHIX_AUTH_TOKEN }}' | ||||||
|  |         skipPush: ${{ github.event_name == 'pull_request' }} | ||||||
|  | 
 | ||||||
|  |     - name: Log in to Docker Hub | ||||||
|  |       uses: docker/login-action@v3 | ||||||
|  |       with: | ||||||
|  |         registry: ${{ env.REGISTRY }} | ||||||
|  |         username: ${{ secrets.DOCKERHUB_USERNAME }} | ||||||
|  |         password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||||
|  | 
 | ||||||
|  |     - name: Get version from Cargo.toml | ||||||
|  |       id: get-version | ||||||
|  |       run: | | ||||||
|  |         VERSION=$(nix run .#version 2>/dev/null || echo "unknown") | ||||||
|  |         echo "version=$VERSION" >> $GITHUB_OUTPUT | ||||||
|  | 
 | ||||||
|  |     - name: Determine tags | ||||||
|  |       id: determine-tags | ||||||
|  |       run: | | ||||||
|  |         TAGS="" | ||||||
|  | 
 | ||||||
|  |         if [[ "${{ github.event_name }}" == "push" ]]; then | ||||||
|  |           if [[ "${{ github.ref }}" == "refs/heads/develop" ]]; then | ||||||
|  |             # Push to develop branch | ||||||
|  |             TAGS="${{ env.IMAGE_NAME }}:develop" | ||||||
|  |           elif [[ "${{ github.ref }}" == refs/tags/* ]]; then | ||||||
|  |             # Tag push | ||||||
|  |             VERSION_TAG=${GITHUB_REF#refs/tags/} | ||||||
|  |             # Remove 'v' prefix if present | ||||||
|  |             VERSION_TAG=${VERSION_TAG#v} | ||||||
|  |             TAGS="${{ env.IMAGE_NAME }}:latest,${{ env.IMAGE_NAME }}:${VERSION_TAG}" | ||||||
|  |           fi | ||||||
|  |         elif [[ "${{ github.event_name }}" == "pull_request" ]]; then | ||||||
|  |           # Pull request | ||||||
|  |           PR_NUMBER=${{ github.event.number }} | ||||||
|  |           TAGS="${{ env.IMAGE_NAME }}:pr${PR_NUMBER}" | ||||||
|  |         fi | ||||||
|  | 
 | ||||||
|  |         echo "tags=$TAGS" >> $GITHUB_OUTPUT | ||||||
|  |         echo "Tags to build: $TAGS" | ||||||
|  | 
 | ||||||
|  |     - name: Build Docker image with Nix | ||||||
|  |       run: | | ||||||
|  |         echo "Building Docker image..." | ||||||
|  |         nix build .#docker | ||||||
|  | 
 | ||||||
|  |         # Load the image into Docker | ||||||
|  |         docker load < result | ||||||
|  | 
 | ||||||
|  |         # Get the image ID that was just loaded | ||||||
|  |         IMAGE_ID=$(docker images --format "table {{.Repository}}:{{.Tag}}\t{{.ID}}" | grep "${{ env.IMAGE_NAME }}:latest" | awk '{print $2}' | head -1) | ||||||
|  |         echo "Loaded image ID: $IMAGE_ID" | ||||||
|  |         echo "image_id=$IMAGE_ID" >> $GITHUB_ENV | ||||||
|  | 
 | ||||||
|  |     - name: Tag and push Docker image | ||||||
|  |       run: | | ||||||
|  |         TAGS="${{ steps.determine-tags.outputs.tags }}" | ||||||
|  | 
 | ||||||
|  |         if [ -n "$TAGS" ]; then | ||||||
|  |           IFS=',' read -ra TAG_ARRAY <<< "$TAGS" | ||||||
|  |           for tag in "${TAG_ARRAY[@]}"; do | ||||||
|  |             echo "Tagging and pushing: $tag" | ||||||
|  |             docker tag ${{ env.image_id }} "$tag" | ||||||
|  |             docker push "$tag" | ||||||
|  |           done | ||||||
|  |         fi | ||||||
|  | 
 | ||||||
|  |     - name: Output image tags | ||||||
|  |       run: | | ||||||
|  |         echo "Built and pushed the following tags:" | ||||||
|  |         echo "${{ steps.determine-tags.outputs.tags }}" | ||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -62,3 +62,4 @@ Desktop.ini | |||||||
| .Spotlight-V100 | .Spotlight-V100 | ||||||
| .Trashes | .Trashes | ||||||
| ._* | ._* | ||||||
|  | result | ||||||
|  | |||||||
							
								
								
									
										31
									
								
								flake.nix
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								flake.nix
									
									
									
									
									
								
							| @ -17,28 +17,45 @@ | |||||||
|           cargo = rustVersion; |           cargo = rustVersion; | ||||||
|           rustc = rustVersion; |           rustc = rustVersion; | ||||||
|         }; |         }; | ||||||
|  | 
 | ||||||
|         appName = "roll-one-ring"; |         appName = "roll-one-ring"; | ||||||
|  |         cargoToml = builtins.fromTOML (builtins.readFile ./Cargo.toml); | ||||||
|  |         version = cargoToml.package.version; | ||||||
|         appRustBuild = rustPlatform.buildRustPackage { |         appRustBuild = rustPlatform.buildRustPackage { | ||||||
|           pname = appName; |           pname = appName; | ||||||
|           version = "0.1.0"; |           version = version; | ||||||
|           src = ./.; |           src = ./.; | ||||||
|           cargoLock.lockFile = ./Cargo.lock; |           cargoLock.lockFile = ./Cargo.lock; | ||||||
|         }; |         }; | ||||||
|         dockerImage = pkgs.dockerTools.buildLayeredImage { | 
 | ||||||
|           name = appName; |         makeDockerImage = tag: pkgs.dockerTools.buildLayeredImage { | ||||||
|  |           name = "phundrak/${appName}"; | ||||||
|  |           inherit tag; | ||||||
|           config = { |           config = { | ||||||
|             Entrypoint = ["${appRustBuild}/bin/${appName}"]; |             Entrypoint = ["${appRustBuild}/bin/${appName}"]; | ||||||
|             Env = [ "SSL_CERT_FILE=${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt" ]; |             Env = [ "SSL_CERT_FILE=${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt" ]; | ||||||
|             Tag = "latest"; |  | ||||||
|           }; |           }; | ||||||
|           content = [appRustBuild pkgs.cacert]; |           contents = [appRustBuild pkgs.cacert]; | ||||||
|         }; |         }; | ||||||
|  | 
 | ||||||
|  |         dockerImageLatest = makeDockerImage "latest"; | ||||||
|  |         dockerImageVersioned = makeDockerImage version; | ||||||
|  | 
 | ||||||
|       in { |       in { | ||||||
|         packages = { |         packages = { | ||||||
|           rustPackage = appRustBuild; |           rustPackage = appRustBuild; | ||||||
|           docker = dockerImage; |           docker = dockerImageLatest; | ||||||
|  |           docker-versioned = dockerImageVersioned; | ||||||
|  |         }; | ||||||
|  |         defaultPackage = dockerImageLatest; | ||||||
|  |         apps = { | ||||||
|  |           version = { | ||||||
|  |             type = "app"; | ||||||
|  |             program = "${pkgs.writeShellScript "version" '' | ||||||
|  |               echo "${version}" | ||||||
|  |             ''}"; | ||||||
|  |           }; | ||||||
|         }; |         }; | ||||||
|         defaultPackage = dockerImage; |  | ||||||
|         devShell = with pkgs; mkShell { |         devShell = with pkgs; mkShell { | ||||||
|           buildInputs = [ |           buildInputs = [ | ||||||
|             bacon |             bacon | ||||||
|  | |||||||
| @ -38,7 +38,7 @@ impl From<Roll> for RollResult { | |||||||
|         let all_main_dice: Vec<u8> = if value.advantage == Advantage::None { |         let all_main_dice: Vec<u8> = if value.advantage == Advantage::None { | ||||||
|             vec![roll_main_dice()] |             vec![roll_main_dice()] | ||||||
|         } else { |         } else { | ||||||
|             (0..value.mastery).map(|_| roll_mastery_dice()).collect() |             (0..2).map(|_| roll_mastery_dice()).collect() | ||||||
|         }; |         }; | ||||||
|         let mastery: Vec<u8> = std::iter::repeat_with(roll_mastery_dice) |         let mastery: Vec<u8> = std::iter::repeat_with(roll_mastery_dice) | ||||||
|             .take(value.mastery.into()) |             .take(value.mastery.into()) | ||||||
|  | |||||||
| @ -8,7 +8,6 @@ impl Success { | |||||||
|     pub fn new(main_dice: u8, result: u8, sr: u8, mastery: &[u8]) -> Self { |     pub fn new(main_dice: u8, result: u8, sr: u8, mastery: &[u8]) -> Self { | ||||||
|         let success_level = SuccessLevel::from(mastery); |         let success_level = SuccessLevel::from(mastery); | ||||||
|         match main_dice { |         match main_dice { | ||||||
|             0 => Self::Failure, |  | ||||||
|             11 => Self::Success(success_level), |             11 => Self::Success(success_level), | ||||||
|             _ => { |             _ => { | ||||||
|                 if result >= sr { |                 if result >= sr { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user