2023-12-17 21:13:49 -08:00
|
|
|
{
|
2023-12-19 17:42:41 -08:00
|
|
|
description = "Recount's server/backend, written in Go";
|
2023-12-17 21:13:49 -08:00
|
|
|
|
|
|
|
# Nixpkgs / NixOS version to use.
|
2024-01-12 15:48:31 -08:00
|
|
|
inputs = {
|
|
|
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
|
|
|
|
templ.url = "github:a-h/templ";
|
|
|
|
};
|
2023-12-17 21:13:49 -08:00
|
|
|
|
2024-01-12 15:48:31 -08:00
|
|
|
outputs = { self, nixpkgs, templ }:
|
2023-12-17 21:13:49 -08:00
|
|
|
let
|
|
|
|
# Generate a user-friendly version number.
|
|
|
|
version = builtins.substring 0 8 self.lastModifiedDate;
|
|
|
|
|
|
|
|
# System types to support.
|
|
|
|
supportedSystems = [ "x86_64-linux" "x86_64-darwin" "aarch64-linux" "aarch64-darwin" ];
|
|
|
|
|
|
|
|
# Helper function to generate an attrset '{ x86_64-linux = f "x86_64-linux"; ... }'.
|
|
|
|
forAllSystems = nixpkgs.lib.genAttrs supportedSystems;
|
|
|
|
|
|
|
|
# Nixpkgs instantiated for supported system types.
|
|
|
|
nixpkgsFor = forAllSystems (system: import nixpkgs { inherit system; });
|
|
|
|
|
2024-01-12 15:48:31 -08:00
|
|
|
templ_function = system: templ.packages.${system}.templ;
|
2023-12-17 21:13:49 -08:00
|
|
|
in
|
|
|
|
{
|
|
|
|
# Provide some binary packages for selected system types.
|
|
|
|
packages = forAllSystems (system:
|
|
|
|
let
|
2024-01-12 15:48:31 -08:00
|
|
|
inherit system;
|
2023-12-17 21:13:49 -08:00
|
|
|
pkgs = nixpkgsFor.${system};
|
|
|
|
in
|
|
|
|
{
|
|
|
|
# The default package for 'nix build'. This makes sense if the
|
|
|
|
# flake provides only one package or there is a clear "main"
|
|
|
|
# package.
|
|
|
|
default = pkgs.buildGoModule {
|
2023-12-17 21:21:29 -08:00
|
|
|
pname = "recount-server";
|
2023-12-17 21:13:49 -08:00
|
|
|
inherit version;
|
2024-01-12 15:48:31 -08:00
|
|
|
preBuild = ''
|
|
|
|
${templ_function system}/bin/templ generate
|
|
|
|
'';
|
2023-12-17 21:13:49 -08:00
|
|
|
# In 'nix develop', we don't need a copy of the source tree
|
|
|
|
# in the Nix store.
|
|
|
|
src = ./.;
|
|
|
|
|
|
|
|
# This hash locks the dependencies of this package. It is
|
|
|
|
# necessary because of how Go requires network access to resolve
|
|
|
|
# VCS. See https://www.tweag.io/blog/2021-03-04-gomod2nix/ for
|
|
|
|
# details. Normally one can build with a fake sha256 and rely on native Go
|
|
|
|
# mechanisms to tell you what the hash should be or determine what
|
|
|
|
# it should be "out-of-band" with other tooling (eg. gomod2nix).
|
|
|
|
# To begin with it is recommended to set this, but one must
|
|
|
|
# remeber to bump this hash when your dependencies change.
|
|
|
|
#vendorSha256 = pkgs.lib.fakeSha256;
|
|
|
|
|
|
|
|
vendorSha256 = "sha256-pQpattmS9VmO3ZIQUFn66az8GSmB4IvYhTTCFn6SUmo=";
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
# nix run
|
|
|
|
apps = forAllSystems (system: {
|
|
|
|
default = {
|
|
|
|
type = "app";
|
2023-12-17 21:21:29 -08:00
|
|
|
program = "${self.packages.${system}.default}/bin/recount-server";
|
2023-12-17 21:13:49 -08:00
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
devShells = forAllSystems (system:
|
2024-01-12 15:48:31 -08:00
|
|
|
let
|
|
|
|
inherit system;
|
|
|
|
pkgs = nixpkgsFor.${system};
|
2023-12-17 21:13:49 -08:00
|
|
|
in {
|
|
|
|
default = pkgs.mkShell {
|
2024-01-12 15:48:31 -08:00
|
|
|
buildInputs = with pkgs; [
|
|
|
|
air # live go app reloading
|
2024-01-17 19:58:31 -08:00
|
|
|
corepack # npm install for the web folder
|
2024-01-14 18:00:51 -08:00
|
|
|
dart-sass
|
2024-01-12 15:48:31 -08:00
|
|
|
go
|
|
|
|
gopls
|
|
|
|
gotools
|
|
|
|
go-tools
|
|
|
|
(templ_function system)
|
|
|
|
];
|
2023-12-17 21:13:49 -08:00
|
|
|
};
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|