diff --git a/.github/workflows/build-and-cache.yaml b/.github/workflows/build-and-cache.yaml index 54e8782..d0b223b 100644 --- a/.github/workflows/build-and-cache.yaml +++ b/.github/workflows/build-and-cache.yaml @@ -28,16 +28,23 @@ jobs: build: strategy: matrix: - os: [ubuntu-latest, macos-latest, macos-13] + os: [ ubuntu-latest, macos-latest, macos-13 ] packages: - - [holochain, hc, hc-run-local-services, hc-sandbox, hcterm] - - [lair-keystore] - - [hc-launch] - - [hc-scaffold] + - [ holochain, hc, hc-run-local-services, hc-sandbox, hcterm ] + - [ lair-keystore ] + - [ hc-launch ] + - [ hc-scaffold ] + include: + - os: ubuntu-latest + template: holonix-default fail-fast: false runs-on: ${{ matrix.os }} + permissions: + contents: read + id-token: write + steps: - name: Print platform information run: uname -ms @@ -57,6 +64,19 @@ jobs: run: | echo '${{ toJSON(matrix.packages) }}' | jq -r '.[]' | xargs -I% nix run .#% -- --version + - name: Extract branch name + shell: bash + run: echo "branch=${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}}" >> $GITHUB_OUTPUT + id: extract_branch + + - name: Init from template + if: ${{ matrix.os == 'ubuntu-latest' }} + run: | + cd $(mktemp -d) + echo "Fetching template from branch ${{ steps.extract_branch.outputs.branch }}" + nix flake init -t "github:holochain/holonix/${{ steps.extract_branch.outputs.branch }}#${{ matrix.template }}" + nix develop -c holochain --version + # - name: Setup tmate session # if: failure() # uses: mxschmitt/action-tmate@v3 diff --git a/.gitignore b/.gitignore index b2be92b..275f0b9 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,3 @@ result + +templates/*/flake.lock diff --git a/flake.nix b/flake.nix index 1de242f..5233ee4 100644 --- a/flake.nix +++ b/flake.nix @@ -48,235 +48,245 @@ # outputs that this flake should produce outputs = inputs @ { self, nixpkgs, flake-parts, rust-overlay, crane, ... }: # refer to flake-parts docs https://flake.parts/ - flake-parts.lib.mkFlake { inherit inputs; } { - # systems that his flake can be used on - systems = [ "aarch64-darwin" "x86_64-linux" "x86_64-darwin" ]; - - # for each system... - perSystem = { config, pkgs, system, ... }: - let - # include Rust overlay in nixpkgs - overlays = [ (import rust-overlay) ]; - pkgs = import nixpkgs { - inherit system overlays; - }; - - rustVersion = "1.78.0"; - - # define Rust toolchain version and targets to be used in this flake - rust = (pkgs.rust-bin.stable.${rustVersion}.minimal.override - { - targets = [ "wasm32-unknown-unknown" ]; - }); - - # instruct crane to use Rust toolchain specified above - craneLib = (crane.mkLib pkgs).overrideToolchain rust; - - # define how to build Holochain binaries - holochain = - let - # Crane filters out all non-cargo related files. Define include filter with files needed for build. - nonCargoBuildFiles = path: _type: builtins.match ".*(json|sql|wasm.gz)$" path != null; - includeFilesFilter = path: type: - (craneLib.filterCargoSources path type) || (nonCargoBuildFiles path type); - - # Crane doesn't know which version to select from a workspace, so we tell it where to look - crateInfo = craneLib.crateNameFromCargoToml { cargoToml = inputs.holochain + "/crates/holochain/Cargo.toml"; }; - in - craneLib.buildPackage { - pname = "holochain"; - version = crateInfo.version; - # Use Holochain sources as defined in input dependencies and include only those files defined in the - # filter previously. - src = pkgs.lib.cleanSourceWith { - src = inputs.holochain; - filter = includeFilesFilter; - }; - # additional packages needed for build - buildInputs = [ - pkgs.go - pkgs.perl - ]; - # do not check built package as it either builds successfully or not - doCheck = false; + flake-parts.lib.mkFlake { inherit inputs; } + { + # systems that his flake can be used on + systems = [ "aarch64-darwin" "x86_64-linux" "x86_64-darwin" ]; + + # for each system... + perSystem = { config, pkgs, system, ... }: + let + # include Rust overlay in nixpkgs + overlays = [ (import rust-overlay) ]; + pkgs = import nixpkgs { + inherit system overlays; }; - # define how to build Lair keystore binary - lair-keystore = - let - # Crane filters out all non-cargo related files. Define include filter with files needed for build. - nonCargoBuildFiles = path: _type: builtins.match ".*(sql|md)$" path != null; - includeFilesFilter = path: type: - (craneLib.filterCargoSources path type) || (nonCargoBuildFiles path type); - - # Crane doesn't know which version to select from a workspace, so we tell it where to look - crateInfo = craneLib.crateNameFromCargoToml { cargoToml = inputs.lair-keystore + "/crates/lair_keystore/Cargo.toml"; }; - in - craneLib.buildPackage { - pname = "lair-keystore"; - version = crateInfo.version; - # only build lair-keystore binary - cargoExtraArgs = "--bin lair-keystore"; - # Use Lair keystore sources as defined in input dependencies and include only those files defined in the - # filter previously. - src = pkgs.lib.cleanSourceWith { - src = inputs.lair-keystore; - filter = includeFilesFilter; - }; - # additional packages needed for build - # perl needed for openssl on all platforms - buildInputs = [ pkgs.perl ] - ++ (pkgs.lib.optionals pkgs.stdenv.isDarwin [ - # additional packages needed for darwin platforms - pkgs.libiconv - pkgs.darwin.apple_sdk.frameworks.Security - # additional packages needed for darwin platforms on x86_64 - pkgs.darwin.apple_sdk_11_0.frameworks.CoreFoundation - ]); - # do not check built package as it either builds successfully or not - doCheck = false; - }; + rustVersion = "1.78.0"; + + # define Rust toolchain version and targets to be used in this flake + rust = (pkgs.rust-bin.stable.${rustVersion}.minimal.override + { + targets = [ "wasm32-unknown-unknown" ]; + }); - # define how to build hc-launch binary - hc-launch = - let - # Crane filters out all non-cargo related files. Define include filter with files needed for build. - nonCargoBuildFiles = path: _type: builtins.match ".*(js|json|png)$" path != null; - includeFilesFilter = path: type: - (craneLib.filterCargoSources path type) || (nonCargoBuildFiles path type); - - # Crane doesn't know which version to select from a workspace, so we tell it where to look - crateInfo = craneLib.crateNameFromCargoToml { cargoToml = inputs.hc-launch + "/crates/hc_launch/src-tauri/Cargo.toml"; }; - - # Use consistent version of Apple SDK throughout. Without this, building on x86_64-darwin fails. - # See below. - apple_sdk = - if system == "x86_64-darwin" - then pkgs.darwin.apple_sdk_10_12 - else pkgs.darwin.apple_sdk_11_0; - - commonArgs = { - pname = "hc-launch"; + # instruct crane to use Rust toolchain specified above + craneLib = (crane.mkLib pkgs).overrideToolchain rust; + + # define how to build Holochain binaries + holochain = + let + # Crane filters out all non-cargo related files. Define include filter with files needed for build. + nonCargoBuildFiles = path: _type: builtins.match ".*(json|sql|wasm.gz)$" path != null; + includeFilesFilter = path: type: + (craneLib.filterCargoSources path type) || (nonCargoBuildFiles path type); + + # Crane doesn't know which version to select from a workspace, so we tell it where to look + crateInfo = craneLib.crateNameFromCargoToml { cargoToml = inputs.holochain + "/crates/holochain/Cargo.toml"; }; + in + craneLib.buildPackage { + pname = "holochain"; version = crateInfo.version; - # Use hc-launch sources as defined in input dependencies and include only those files defined in the + # Use Holochain sources as defined in input dependencies and include only those files defined in the # filter previously. src = pkgs.lib.cleanSourceWith { - src = inputs.hc-launch; + src = inputs.holochain; filter = includeFilesFilter; }; - # Only build hc-launch command - cargoExtraArgs = "--bin hc-launch"; - - # commands required at build time - nativeBuildInputs = ( - if pkgs.stdenv.isLinux then [ pkgs.pkg-config ] - else [ ] - ); - - # build inputs required for linking to execute at runtime + # additional packages needed for build buildInputs = [ + pkgs.go pkgs.perl - ] - ++ (pkgs.lib.optionals pkgs.stdenv.isLinux - [ - pkgs.glib - pkgs.go - pkgs.webkitgtk.dev - ]) - ++ pkgs.lib.optionals pkgs.stdenv.isDarwin - [ - apple_sdk.frameworks.AppKit - apple_sdk.frameworks.WebKit - - (if pkgs.system == "x86_64-darwin" then - pkgs.darwin.apple_sdk_11_0.stdenv.mkDerivation - { - name = "go"; - nativeBuildInputs = with pkgs; [ - makeBinaryWrapper - go - ]; - dontBuild = true; - dontUnpack = true; - installPhase = '' - makeWrapper ${pkgs.go}/bin/go $out/bin/go - ''; - } - else pkgs.go) - ]; + ]; + # do not check built package as it either builds successfully or not + doCheck = false; + }; + # define how to build Lair keystore binary + lair-keystore = + let + # Crane filters out all non-cargo related files. Define include filter with files needed for build. + nonCargoBuildFiles = path: _type: builtins.match ".*(sql|md)$" path != null; + includeFilesFilter = path: type: + (craneLib.filterCargoSources path type) || (nonCargoBuildFiles path type); + + # Crane doesn't know which version to select from a workspace, so we tell it where to look + crateInfo = craneLib.crateNameFromCargoToml { cargoToml = inputs.lair-keystore + "/crates/lair_keystore/Cargo.toml"; }; + in + craneLib.buildPackage { + pname = "lair-keystore"; + version = crateInfo.version; + # only build lair-keystore binary + cargoExtraArgs = "--bin lair-keystore"; + # Use Lair keystore sources as defined in input dependencies and include only those files defined in the + # filter previously. + src = pkgs.lib.cleanSourceWith { + src = inputs.lair-keystore; + filter = includeFilesFilter; + }; + # additional packages needed for build + # perl needed for openssl on all platforms + buildInputs = [ pkgs.perl ] + ++ (pkgs.lib.optionals pkgs.stdenv.isDarwin [ + # additional packages needed for darwin platforms + pkgs.libiconv + pkgs.darwin.apple_sdk.frameworks.Security + # additional packages needed for darwin platforms on x86_64 + pkgs.darwin.apple_sdk_11_0.frameworks.CoreFoundation + ]); # do not check built package as it either builds successfully or not doCheck = false; }; - # derivation building all dependencies - deps = craneLib.buildDepsOnly commonArgs; - in - # derivation with the main crates - craneLib.buildPackage - (commonArgs // { - cargoArtifacts = deps; - - # Override stdenv Apple SDK packages. It's unclear why this is needed, but building on x86_64-darwin - # fails without it. - # https://discourse.nixos.org/t/need-help-from-darwin-users-syntax-errors-in-library-frameworks-foundation-framework-headers/30467/3 - stdenv = - if pkgs.stdenv.isDarwin then - pkgs.overrideSDK pkgs.stdenv "11.0" - else - pkgs.stdenv; - }); + # define how to build hc-launch binary + hc-launch = + let + # Crane filters out all non-cargo related files. Define include filter with files needed for build. + nonCargoBuildFiles = path: _type: builtins.match ".*(js|json|png)$" path != null; + includeFilesFilter = path: type: + (craneLib.filterCargoSources path type) || (nonCargoBuildFiles path type); + + # Crane doesn't know which version to select from a workspace, so we tell it where to look + crateInfo = craneLib.crateNameFromCargoToml { cargoToml = inputs.hc-launch + "/crates/hc_launch/src-tauri/Cargo.toml"; }; + + # Use consistent version of Apple SDK throughout. Without this, building on x86_64-darwin fails. + # See below. + apple_sdk = + if system == "x86_64-darwin" + then pkgs.darwin.apple_sdk_10_12 + else pkgs.darwin.apple_sdk_11_0; + + commonArgs = { + pname = "hc-launch"; + version = crateInfo.version; + # Use hc-launch sources as defined in input dependencies and include only those files defined in the + # filter previously. + src = pkgs.lib.cleanSourceWith { + src = inputs.hc-launch; + filter = includeFilesFilter; + }; + # Only build hc-launch command + cargoExtraArgs = "--bin hc-launch"; + + # commands required at build time + nativeBuildInputs = ( + if pkgs.stdenv.isLinux then [ pkgs.pkg-config ] + else [ ] + ); + + # build inputs required for linking to execute at runtime + buildInputs = [ + pkgs.perl + ] + ++ (pkgs.lib.optionals pkgs.stdenv.isLinux + [ + pkgs.glib + pkgs.go + pkgs.webkitgtk.dev + ]) + ++ pkgs.lib.optionals pkgs.stdenv.isDarwin + [ + apple_sdk.frameworks.AppKit + apple_sdk.frameworks.WebKit + + (if pkgs.system == "x86_64-darwin" then + pkgs.darwin.apple_sdk_11_0.stdenv.mkDerivation + { + name = "go"; + nativeBuildInputs = with pkgs; [ + makeBinaryWrapper + go + ]; + dontBuild = true; + dontUnpack = true; + installPhase = '' + makeWrapper ${pkgs.go}/bin/go $out/bin/go + ''; + } + else pkgs.go) + ]; + + # do not check built package as it either builds successfully or not + doCheck = false; + }; - hc-scaffold = - craneLib.buildPackage { - pname = "hc-scaffold"; - src = craneLib.cleanCargoSource inputs.hc-scaffold; + # derivation building all dependencies + deps = craneLib.buildDepsOnly commonArgs; + in + # derivation with the main crates + craneLib.buildPackage + (commonArgs // { + cargoArtifacts = deps; + + # Override stdenv Apple SDK packages. It's unclear why this is needed, but building on x86_64-darwin + # fails without it. + # https://discourse.nixos.org/t/need-help-from-darwin-users-syntax-errors-in-library-frameworks-foundation-framework-headers/30467/3 + stdenv = + if pkgs.stdenv.isDarwin then + pkgs.overrideSDK pkgs.stdenv "11.0" + else + pkgs.stdenv; + }); + + hc-scaffold = + craneLib.buildPackage { + pname = "hc-scaffold"; + src = craneLib.cleanCargoSource inputs.hc-scaffold; - doCheck = false; + doCheck = false; - buildInputs = [ - pkgs.go - pkgs.perl - ]; + buildInputs = [ + pkgs.go + pkgs.perl + ]; + }; + in + { + # Configure a formatter so that `nix fmt` can be used to format this file. + formatter = pkgs.nixpkgs-fmt; + + packages = { + inherit holochain; + inherit lair-keystore; + inherit hc-launch; + inherit hc-scaffold; + inherit rust; }; - in - { - # Configure a formatter so that `nix fmt` can be used to format this file. - formatter = pkgs.nixpkgs-fmt; - - packages = { - inherit holochain; - inherit lair-keystore; - inherit hc-launch; - inherit hc-scaffold; - inherit rust; - }; - # Define runnable applications for use with `nix run`. - # These can be used like `nix run "github:holochain/holonix#hc-scaffold" -- --version`. - # https://flake.parts/options/flake-parts.html?highlight=perSystem.apps#opt-perSystem.apps - apps = { - holochain.program = "${holochain}/bin/holochain"; - hc.program = "${holochain}/bin/hc"; - hc-run-local-services.program = "${holochain}/bin/hc-run-local-services"; - hc-sandbox.program = "${holochain}/bin/hc-sandbox"; - hcterm.program = "${holochain}/bin/hcterm"; - lair-keystore.program = "${lair-keystore}/bin/lair-keystore"; - hc-launch.program = "${hc-launch}/bin/hc-launch"; - hc-scaffold.program = "${hc-scaffold}/bin/hc-scaffold"; - }; + # Define runnable applications for use with `nix run`. + # These can be used like `nix run "github:holochain/holonix#hc-scaffold" -- --version`. + # https://flake.parts/options/flake-parts.html?highlight=perSystem.apps#opt-perSystem.apps + apps = { + holochain.program = "${holochain}/bin/holochain"; + hc.program = "${holochain}/bin/hc"; + hc-run-local-services.program = "${holochain}/bin/hc-run-local-services"; + hc-sandbox.program = "${holochain}/bin/hc-sandbox"; + hcterm.program = "${holochain}/bin/hcterm"; + lair-keystore.program = "${lair-keystore}/bin/lair-keystore"; + hc-launch.program = "${hc-launch}/bin/hc-launch"; + hc-scaffold.program = "${hc-scaffold}/bin/hc-scaffold"; + }; - devShells = { - default = pkgs.mkShell { - packages = [ - holochain - lair-keystore - hc-launch - hc-scaffold - rust - ]; + devShells = { + default = pkgs.mkShell { + packages = [ + holochain + lair-keystore + hc-launch + hc-scaffold + rust + ]; + }; }; }; + } // { + # Add content which is not platform specific after using flake-parts to generate platform specific content. + templates = { + # A template that can be used to create a flake that depends on this flake, with recommended defaults. + holonix-default = { + path = ./templates/default; + description = "Holonix default template"; }; + }; }; } diff --git a/templates/default/flake.nix b/templates/default/flake.nix new file mode 100644 index 0000000..26e2d13 --- /dev/null +++ b/templates/default/flake.nix @@ -0,0 +1,33 @@ +{ + description = "Flake for Holochain app development"; + + inputs = { + holonix.url = "github:holochain/holonix/main"; + + nixpkgs.follows = "holonix/nixpkgs"; + flake-parts.follows = "holonix/flake-parts"; + }; + + outputs = inputs@{ flake-parts, ... }: flake-parts.lib.mkFlake { inherit inputs; } { + systems = builtins.attrNames inputs.holonix.devShells; + perSystem = { inputs', pkgs, ... }: { + formatter = pkgs.nixpkgs-fmt; + + devShells.default = pkgs.mkShell { + inputsFrom = [ inputs'.holonix.devShells ]; + + packages = (with inputs'.holonix.packages; [ + holochain + lair-keystore + hc-launch + hc-scaffold + rust # For Rust development, with the WASM target included for zome builds + ]) ++ (with pkgs; [ + nodejs_20 # For UI development + binaryen # For WASM optimisation + # Add any other packages you need here + ]); + }; + }; + }; +}