mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 07:50:02 +02:00 
			
		
		
		
	Updated Github Actions, Fixed Dockerfile
- Updated the Github Actions to build just one binary with all DB Backends. - Created a hadolint workflow to check and verify Dockerfiles. - Fixed current hadolint errors. - Fixed a bug in the Dockerfile.j2 which prevented the correct libraries and tools to be installed on the Alpine images. - Deleted travis.yml since that is not used anymore
This commit is contained in:
		
							
								
								
									
										125
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										125
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,125 @@ | ||||
| name: Build | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     # Ignore when there are only changes done too one of these paths | ||||
|     paths-ignore: | ||||
|       - "**.md" | ||||
|       - "**.txt" | ||||
|       - "azure-pipelines.yml" | ||||
|       - "docker/**" | ||||
|       - "hooks/**" | ||||
|       - "tools/**" | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         channel: | ||||
|           - nightly | ||||
|           # - stable | ||||
|         target-triple: | ||||
|           - x86_64-unknown-linux-gnu | ||||
|           # - x86_64-unknown-linux-musl | ||||
|         include: | ||||
|           - target-triple: x86_64-unknown-linux-gnu | ||||
|             host-triple: x86_64-unknown-linux-gnu | ||||
|             features: "sqlite,mysql,postgresql" | ||||
|             channel: nightly | ||||
|             os: ubuntu-18.04 | ||||
|             ext: | ||||
|           # - target-triple: x86_64-unknown-linux-gnu | ||||
|           #   host-triple: x86_64-unknown-linux-gnu | ||||
|           #   features: "sqlite,mysql,postgresql" | ||||
|           #   channel: stable | ||||
|           #   os: ubuntu-18.04 | ||||
|           #   ext: | ||||
|           # - target-triple: x86_64-unknown-linux-musl | ||||
|           #   host-triple: x86_64-unknown-linux-gnu | ||||
|           #   features: "sqlite,postgresql" | ||||
|           #   channel: nightly | ||||
|           #   os: ubuntu-18.04 | ||||
|           #   ext: | ||||
|           # - target-triple: x86_64-unknown-linux-musl | ||||
|           #   host-triple: x86_64-unknown-linux-gnu | ||||
|           #   features: "sqlite,postgresql" | ||||
|           #   channel: stable | ||||
|           #   os: ubuntu-18.04 | ||||
|           #   ext: | ||||
|  | ||||
|     name: Building ${{ matrix.channel }}-${{ matrix.target-triple }} | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     steps: | ||||
|       # Checkout the repo | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       # End Checkout the repo | ||||
|  | ||||
|  | ||||
|       # Install musl-tools when needed | ||||
|       - name: Install musl tools | ||||
|         run: sudo apt-get update && sudo apt-get install -y --no-install-recommends musl-dev musl-tools cmake | ||||
|         if: matrix.target-triple == 'x86_64-unknown-linux-musl' | ||||
|       # End Install musl-tools when needed | ||||
|  | ||||
|  | ||||
|       # Install dependencies | ||||
|       - name: Install dependencies Ubuntu | ||||
|         run: sudo apt-get update && sudo apt-get install -y --no-install-recommends openssl sqlite build-essential libmariadb-dev-compat libpq-dev libssl-dev pkgconf | ||||
|         if: startsWith( matrix.os, 'ubuntu' ) | ||||
|       # End Install dependencies | ||||
|  | ||||
|  | ||||
|       # Enable Rust Caching | ||||
|       - uses: Swatinem/rust-cache@v1 | ||||
|       # End Enable Rust Caching | ||||
|  | ||||
|  | ||||
|       # Uses the rust-toolchain file to determine version | ||||
|       - name: 'Install ${{ matrix.channel }}-${{ matrix.host-triple }} for target: ${{ matrix.target-triple }}' | ||||
|         uses: actions-rs/toolchain@v1 | ||||
|         with: | ||||
|           profile: minimal | ||||
|           target: ${{ matrix.target-triple }} | ||||
|       # End Uses the rust-toolchain file to determine version | ||||
|  | ||||
|  | ||||
|       # Run cargo tests (In release mode to speed up cargo build afterwards) | ||||
|       - name: '`cargo test --release --features ${{ matrix.features }} --target ${{ matrix.target-triple }}`' | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         with: | ||||
|           command: test | ||||
|           args: --release --features ${{ matrix.features }} --target ${{ matrix.target-triple }} | ||||
|       # End Run cargo tests | ||||
|  | ||||
|  | ||||
|       # Build the binary | ||||
|       - name: '`cargo build --release --features ${{ matrix.features }} --target ${{ matrix.target-triple }}`' | ||||
|         uses: actions-rs/cargo@v1 | ||||
|         with: | ||||
|           command: build | ||||
|           args: --release --features ${{ matrix.features }} --target ${{ matrix.target-triple }} | ||||
|       # End Build the binary | ||||
|  | ||||
|  | ||||
|       # Upload artifact to Github Actions | ||||
|       - name: Upload artifact | ||||
|         uses: actions/upload-artifact@v2 | ||||
|         with: | ||||
|           name: bitwarden_rs-${{ matrix.target-triple }}${{ matrix.ext }} | ||||
|           path: target/${{ matrix.target-triple }}/release/bitwarden_rs${{ matrix.ext }} | ||||
|       # End Upload artifact to Github Actions | ||||
|  | ||||
|  | ||||
|       ## This is not used at the moment | ||||
|       ## We could start using this when we can build static binaries | ||||
|       # Upload to github actions release | ||||
|       # - name: Release | ||||
|       #   uses: Shopify/upload-to-release@1 | ||||
|       #   if: startsWith(github.ref, 'refs/tags/') | ||||
|       #   with: | ||||
|       #     name: bitwarden_rs-${{ matrix.target-triple }}${{ matrix.ext }} | ||||
|       #     path: target/${{ matrix.target-triple }}/release/bitwarden_rs${{ matrix.ext }} | ||||
|       #     repo-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|       # End Upload to github actions release | ||||
							
								
								
									
										34
									
								
								.github/workflows/hadolint.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								.github/workflows/hadolint.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| name: Hadolint | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     # Ignore when there are only changes done too one of these paths | ||||
|     paths: | ||||
|       - "docker/**" | ||||
|  | ||||
| jobs: | ||||
|   hadolint: | ||||
|     name: Validate Dockerfile syntax | ||||
|     runs-on: ubuntu-20.04 | ||||
|     steps: | ||||
|       # Checkout the repo | ||||
|       - name: Checkout | ||||
|         uses: actions/checkout@v2 | ||||
|       # End Checkout the repo | ||||
|  | ||||
|  | ||||
|       # Download hadolint | ||||
|       - name: Download hadolint | ||||
|         shell: bash | ||||
|         run: | | ||||
|           sudo curl -L https://github.com/hadolint/hadolint/releases/download/v$HADOLINT_VERSION/hadolint-$(uname -s)-$(uname -m) -o /usr/local/bin/hadolint && \ | ||||
|           sudo chmod +x /usr/local/bin/hadolint | ||||
|         env: | ||||
|           HADOLINT_VERSION: 1.19.0 | ||||
|       # End Download hadolint | ||||
|  | ||||
|       # Test Dockerfiles | ||||
|       - name: Run hadolint | ||||
|         shell: bash | ||||
|         run:  git ls-files --exclude='docker/*/Dockerfile*' --ignored | xargs hadolint | ||||
|       # End Test Dockerfiles | ||||
							
								
								
									
										148
									
								
								.github/workflows/workspace.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										148
									
								
								.github/workflows/workspace.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,148 +0,0 @@ | ||||
| name: Workflow | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     paths-ignore: | ||||
|       - "**.md" | ||||
|   #pull_request: | ||||
|   #  paths-ignore: | ||||
|   #    - "**.md" | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     name: Build | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         db-backend: [sqlite, mysql, postgresql] | ||||
|         target: | ||||
|           - x86_64-unknown-linux-gnu | ||||
|           # - x86_64-unknown-linux-musl | ||||
|           # - x86_64-apple-darwin | ||||
|           # - x86_64-pc-windows-msvc | ||||
|         include: | ||||
|           - target: x86_64-unknown-linux-gnu | ||||
|             os: ubuntu-latest | ||||
|             ext: | ||||
|           # - target: x86_64-unknown-linux-musl | ||||
|           #   os: ubuntu-latest | ||||
|           #   ext: | ||||
|           # - target: x86_64-apple-darwin | ||||
|           #   os: macOS-latest | ||||
|           #   ext: | ||||
|           # - target: x86_64-pc-windows-msvc | ||||
|           #   os: windows-latest | ||||
|           #   ext: .exe | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     steps: | ||||
|     - uses: actions/checkout@v1 | ||||
|  | ||||
|     # - name: Cache choco cache | ||||
|     #   uses: actions/cache@v1.0.3 | ||||
|     #   if: matrix.os == 'windows-latest' | ||||
|     #   with: | ||||
|     #     path: ~\AppData\Local\Temp\chocolatey | ||||
|     #     key: ${{ runner.os }}-choco-cache-${{ matrix.db-backend }} | ||||
|  | ||||
|     - name: Cache vcpkg installed | ||||
|       uses: actions/cache@v1.0.3 | ||||
|       if: matrix.os == 'windows-latest' | ||||
|       with: | ||||
|         path: $VCPKG_ROOT/installed | ||||
|         key: ${{ runner.os }}-vcpkg-cache-${{ matrix.db-backend }} | ||||
|       env: | ||||
|         VCPKG_ROOT: 'C:\vcpkg' | ||||
|  | ||||
|     - name: Cache vcpkg downloads | ||||
|       uses: actions/cache@v1.0.3 | ||||
|       if: matrix.os == 'windows-latest' | ||||
|       with: | ||||
|         path: $VCPKG_ROOT/downloads | ||||
|         key: ${{ runner.os }}-vcpkg-cache-${{ matrix.db-backend }} | ||||
|       env: | ||||
|         VCPKG_ROOT: 'C:\vcpkg' | ||||
|  | ||||
|     # - name: Cache homebrew | ||||
|     #   uses: actions/cache@v1.0.3 | ||||
|     #   if: matrix.os == 'macOS-latest' | ||||
|     #   with: | ||||
|     #     path: ~/Library/Caches/Homebrew | ||||
|     #     key: ${{ runner.os }}-brew-cache | ||||
|  | ||||
|     # - name: Cache apt | ||||
|     #   uses: actions/cache@v1.0.3 | ||||
|     #   if: matrix.os == 'ubuntu-latest' | ||||
|     #   with: | ||||
|     #     path: /var/cache/apt/archives | ||||
|     #     key: ${{ runner.os }}-apt-cache | ||||
|  | ||||
|     # Install dependencies | ||||
|     - name: Install dependencies macOS | ||||
|       run: brew update; brew install openssl sqlite libpq mysql | ||||
|       if: matrix.os == 'macOS-latest' | ||||
|  | ||||
|     - name: Install dependencies Ubuntu | ||||
|       run: sudo apt-get update && sudo apt-get install --no-install-recommends openssl sqlite libpq-dev libmysql++-dev | ||||
|       if: matrix.os == 'ubuntu-latest' | ||||
|  | ||||
|     - name: Install dependencies Windows | ||||
|       run: vcpkg integrate install; vcpkg install sqlite3:x64-windows openssl:x64-windows libpq:x64-windows libmysql:x64-windows | ||||
|       if: matrix.os == 'windows-latest' | ||||
|       env: | ||||
|         VCPKG_ROOT: 'C:\vcpkg' | ||||
|     # End Install dependencies | ||||
|  | ||||
|     # Install rust nightly toolchain | ||||
|     - name: Cache cargo registry | ||||
|       uses: actions/cache@v1.0.3 | ||||
|       with: | ||||
|         path: ~/.cargo/registry | ||||
|         key: ${{ runner.os }}-${{matrix.db-backend}}-cargo-registry-${{ hashFiles('**/Cargo.lock') }} | ||||
|     - name: Cache cargo index | ||||
|       uses: actions/cache@v1.0.3 | ||||
|       with: | ||||
|         path: ~/.cargo/git | ||||
|         key: ${{ runner.os }}-${{matrix.db-backend}}-cargo-index-${{ hashFiles('**/Cargo.lock') }} | ||||
|     - name: Cache cargo build | ||||
|       uses: actions/cache@v1.0.3 | ||||
|       with: | ||||
|         path: target | ||||
|         key: ${{ runner.os }}-${{matrix.db-backend}}-cargo-build-target-${{ hashFiles('**/Cargo.lock') }} | ||||
|  | ||||
|     - name: Install latest nightly | ||||
|       uses: actions-rs/toolchain@v1.0.5 | ||||
|       with: | ||||
|         # Uses rust-toolchain to determine version | ||||
|         profile: minimal | ||||
|         target: ${{ matrix.target }} | ||||
|  | ||||
|     # Build | ||||
|     - name: Build Win | ||||
|       if: matrix.os == 'windows-latest' | ||||
|       run: cargo.exe build --features ${{ matrix.db-backend }} --release --target ${{ matrix.target }} | ||||
|       env: | ||||
|         RUSTFLAGS: -Ctarget-feature=+crt-static | ||||
|         VCPKG_ROOT: 'C:\vcpkg' | ||||
|  | ||||
|     - name: Build macOS / Ubuntu | ||||
|       if: matrix.os == 'macOS-latest' || matrix.os == 'ubuntu-latest' | ||||
|       run: cargo build --verbose --features ${{ matrix.db-backend }} --release --target ${{ matrix.target }} | ||||
|  | ||||
|     # Test | ||||
|     - name: Run tests | ||||
|       run: cargo test --features ${{ matrix.db-backend }} | ||||
|  | ||||
|     # Upload & Release | ||||
|     - name: Upload artifact | ||||
|       uses: actions/upload-artifact@v1.0.0 | ||||
|       with: | ||||
|         name: bitwarden_rs-${{ matrix.db-backend }}-${{ matrix.target }}${{ matrix.ext }} | ||||
|         path: target/${{ matrix.target }}/release/bitwarden_rs${{ matrix.ext }} | ||||
|  | ||||
|     - name: Release | ||||
|       uses: Shopify/upload-to-release@1.0.0 | ||||
|       if: startsWith(github.ref, 'refs/tags/') | ||||
|       with: | ||||
|         name: bitwarden_rs-${{ matrix.db-backend }}-${{ matrix.target }}${{ matrix.ext }} | ||||
|         path: target/${{ matrix.target }}/release/bitwarden_rs${{ matrix.ext }} | ||||
|         repo-token: ${{ secrets.GITHUB_TOKEN }} | ||||
		Reference in New Issue
	
	Block a user