graphql-engine/v3/flake.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

183 lines
5.5 KiB
Nix
Raw Normal View History

{
description = "DDN Engine";
inputs = {
Use Nix to build and publish Docker images. (#664) ## Description We can use Nix to build Docker images, which gives us a few advantages: 1. the images will be cached a little better 2. aarch64 builds become easy 3. Samir is happy because the Nixification continues ## Changelog - Add a changelog entry (in the "Changelog entry" section below) if the changes in this PR have any user-facing impact. See [changelog guide](https://github.com/hasura/graphql-engine-mono/wiki/Changelog-Guide). - If no changelog is required ignore/remove this section and add a `no-changelog-required` label to the PR. ### Product _(Select all products this will be available in)_ - [x] community-edition - [ ] cloud <!-- product : end : DO NOT REMOVE --> ### Type <!-- See changelog structure: https://github.com/hasura/graphql-engine-mono/wiki/Changelog-Guide#structure-of-our-changelog --> _(Select only one. In case of multiple, choose the most appropriate)_ - [ ] highlight - [x] enhancement - [ ] bugfix - [ ] behaviour-change - [ ] performance-enhancement - [ ] security-fix <!-- type : end : DO NOT REMOVE --> ### Changelog entry <!-- - Add a user understandable changelog entry - Include all details needed to understand the change. Try including links to docs or issues if relevant - For Highlights start with a H4 heading (#### <entry title>) - Get the changelog entry reviewed by your team --> The v3 engine and dev-auth-webhook Docker images are now published for both x86_64 (`amd64`) and aarch64 (`arm64`) architectures. <!-- changelog-entry : end : DO NOT REMOVE --> <!-- changelog : end : DO NOT REMOVE --> Co-Authored-By: Philip Carlsen <philip@hasura.io> Co-Authored-By: Gil Mizrahi <gil@hasura.io> V3_GIT_ORIGIN_REV_ID: ae6fec45dee62a21f03b5258b57d841a16542c72
2024-06-04 17:14:54 +03:00
nixpkgs.url = "github:NixOS/nixpkgs";
flake-utils.url = "github:numtide/flake-utils";
crane = {
url = "github:ipetkov/crane";
};
rust-overlay = {
url = "github:oxalica/rust-overlay";
inputs = {
nixpkgs.follows = "nixpkgs";
};
};
};
outputs = { self, nixpkgs, flake-utils, crane, rust-overlay }:
flake-utils.lib.eachDefaultSystem (localSystem:
let
version = pkgs.lib.strings.fileContents ./nix/version;
Use Nix to build and publish Docker images. (#664) ## Description We can use Nix to build Docker images, which gives us a few advantages: 1. the images will be cached a little better 2. aarch64 builds become easy 3. Samir is happy because the Nixification continues ## Changelog - Add a changelog entry (in the "Changelog entry" section below) if the changes in this PR have any user-facing impact. See [changelog guide](https://github.com/hasura/graphql-engine-mono/wiki/Changelog-Guide). - If no changelog is required ignore/remove this section and add a `no-changelog-required` label to the PR. ### Product _(Select all products this will be available in)_ - [x] community-edition - [ ] cloud <!-- product : end : DO NOT REMOVE --> ### Type <!-- See changelog structure: https://github.com/hasura/graphql-engine-mono/wiki/Changelog-Guide#structure-of-our-changelog --> _(Select only one. In case of multiple, choose the most appropriate)_ - [ ] highlight - [x] enhancement - [ ] bugfix - [ ] behaviour-change - [ ] performance-enhancement - [ ] security-fix <!-- type : end : DO NOT REMOVE --> ### Changelog entry <!-- - Add a user understandable changelog entry - Include all details needed to understand the change. Try including links to docs or issues if relevant - For Highlights start with a H4 heading (#### <entry title>) - Get the changelog entry reviewed by your team --> The v3 engine and dev-auth-webhook Docker images are now published for both x86_64 (`amd64`) and aarch64 (`arm64`) architectures. <!-- changelog-entry : end : DO NOT REMOVE --> <!-- changelog : end : DO NOT REMOVE --> Co-Authored-By: Philip Carlsen <philip@hasura.io> Co-Authored-By: Gil Mizrahi <gil@hasura.io> V3_GIT_ORIGIN_REV_ID: ae6fec45dee62a21f03b5258b57d841a16542c72
2024-06-04 17:14:54 +03:00
targetSystems = flake-utils.lib.defaultSystems;
dockerArchitectures = {
"x86_64-linux" = "amd64";
"aarch64-linux" = "arm64";
};
pkgs = import nixpkgs {
system = localSystem;
overlays = [ rust-overlay.overlays.default ];
};
rust = pkgs.lib.attrsets.genAttrs targetSystems (crossSystem: import ./nix/rust.nix {
inherit nixpkgs rust-overlay crane localSystem crossSystem;
});
binaries = [
"engine"
"custom-connector"
"dev-auth-webhook"
];
binaryPackages = {
};
defaultBinary = "engine";
dockerConfig = {
"engine" = {
ExposedPorts = { "3000/tcp" = { }; };
};
"custom-connector" = {
ExposedPorts = { "8102/tcp" = { }; };
};
"dev-auth-webhook" = {
ExposedPorts = { "3050/tcp" = { }; };
};
};
in
{
formatter = pkgs.nixpkgs-fmt;
# Generate packages in a tree structure.
#
# The path is of the form:
#
# local system -> binary name -> target system -> output
#
# For example, to cross-compile the engine to aarch64-linux on a
# x86_64-linux machine, you will want to access:
#
# targets.x86_64-linux.engine.aarch64-linux.binary
#
# Docker images are named "docker", and live next to the binaries. They
# are not provided for all systems; if there is no Docker image, the
# value will be `null`.
#
# The tree looks something like this:
#
# targets
# - x86_64-linux
# - engine
# - x86_64-linux
# - binary
# - docker
# - aarch64-linux
# - binary
# - docker
# - x86_64-darwin
# - binary
# - docker = null
# - aarch64-darwin
# - binary
# - docker = null
# - custom-connector
# - ...
# - aarch64-linux
# - ...
# - x86_64-darwin
# - ...
# - aarch64-darwin
# - ...
targets = pkgs.lib.attrsets.genAttrs binaries (binaryName:
pkgs.lib.attrsets.genAttrs targetSystems (targetSystem: {
binary = rust.${targetSystem}.callPackage ./nix/app.nix {
inherit version;
pname = binaryName;
packageName = binaryPackages.${binaryName} or binaryName;
};
docker =
if dockerArchitectures ? ${targetSystem}
then
pkgs.callPackage ./nix/docker.nix
{
package = self.targets.${localSystem}.${binaryName}.${targetSystem}.binary;
architecture = dockerArchitectures.${targetSystem};
image-name = "build.internal/${binaryName}-${targetSystem}";
extraConfig = dockerConfig.${binaryName} or { };
}
else null;
})
);
packages =
# binaries for the local system
pkgs.lib.attrsets.genAttrs binaries (binaryName: self.targets.${localSystem}.${binaryName}.${localSystem}.binary) // {
# `nix build` will build the default binary
default = self.packages.${localSystem}.${defaultBinary};
# a handy script to publish Docker images
Use Nix to build and publish Docker images. (#664) ## Description We can use Nix to build Docker images, which gives us a few advantages: 1. the images will be cached a little better 2. aarch64 builds become easy 3. Samir is happy because the Nixification continues ## Changelog - Add a changelog entry (in the "Changelog entry" section below) if the changes in this PR have any user-facing impact. See [changelog guide](https://github.com/hasura/graphql-engine-mono/wiki/Changelog-Guide). - If no changelog is required ignore/remove this section and add a `no-changelog-required` label to the PR. ### Product _(Select all products this will be available in)_ - [x] community-edition - [ ] cloud <!-- product : end : DO NOT REMOVE --> ### Type <!-- See changelog structure: https://github.com/hasura/graphql-engine-mono/wiki/Changelog-Guide#structure-of-our-changelog --> _(Select only one. In case of multiple, choose the most appropriate)_ - [ ] highlight - [x] enhancement - [ ] bugfix - [ ] behaviour-change - [ ] performance-enhancement - [ ] security-fix <!-- type : end : DO NOT REMOVE --> ### Changelog entry <!-- - Add a user understandable changelog entry - Include all details needed to understand the change. Try including links to docs or issues if relevant - For Highlights start with a H4 heading (#### <entry title>) - Get the changelog entry reviewed by your team --> The v3 engine and dev-auth-webhook Docker images are now published for both x86_64 (`amd64`) and aarch64 (`arm64`) architectures. <!-- changelog-entry : end : DO NOT REMOVE --> <!-- changelog : end : DO NOT REMOVE --> Co-Authored-By: Philip Carlsen <philip@hasura.io> Co-Authored-By: Gil Mizrahi <gil@hasura.io> V3_GIT_ORIGIN_REV_ID: ae6fec45dee62a21f03b5258b57d841a16542c72
2024-06-04 17:14:54 +03:00
publish-docker-image = pkgs.writeShellApplication {
name = "publish-docker-image";
runtimeInputs = with pkgs; [ coreutils skopeo ];
text = builtins.readFile ./.github/scripts/deploy.sh;
};
};
# build an app per binary
apps = pkgs.lib.attrsets.genAttrs binaries
(binaryName:
flake-utils.lib.mkApp {
drv = self.packages.${localSystem}.${binaryName};
name = binaryName;
}
) // {
# the default app is the app wrapping the default binary
default = self.apps.${localSystem}.${defaultBinary};
};
devShells = {
default = pkgs.mkShell {
# include dependencies of the default package
inputsFrom = [ self.packages.${localSystem}.default ];
# build-time inputs
nativeBuildInputs = [
# Development
pkgs.just
pkgs.moreutils
pkgs.nixpkgs-fmt
pkgs.nodejs_22
# Rust
pkgs.bacon
pkgs.cargo-audit
pkgs.cargo-edit
pkgs.cargo-expand
pkgs.cargo-flamegraph
pkgs.cargo-insta
pkgs.cargo-machete
pkgs.cargo-nextest
pkgs.cargo-watch
rust.${localSystem}.rustToolchain
];
};
};
});
}