Merge commit 'efcef47c37' into user

This commit is contained in:
Alejandro Soto 2026-03-23 19:25:02 -06:00
commit cf2823d14e
5 changed files with 44 additions and 43 deletions

View file

@ -5,11 +5,12 @@
doctrine, doctrine,
... ...
}: let }: let
releases = pkgs.${doctrine.prefix}.athena-bccr.override { athena =
inherit (cfg) mirror vendor; (pkgs.${doctrine.prefix}.athena-bccr.override {
inherit (cfg) mirror;
}).${
cfg.release
}; };
athena = releases.${cfg.release};
in { in {
home.packages = [ home.packages = [
athena.firmador athena.firmador

View file

@ -1,5 +1,12 @@
{lib, ...}: {lib, ...}:
with lib.types; let with lib.types; {
hm = {
gaudiHash = lib.mkOption {
type = nullOr str;
default = null;
description = "hash of the Gaudi client";
};
mirror = lib.mkOption { mirror = lib.mkOption {
type = nullOr str; type = nullOr str;
default = null; default = null;
@ -11,30 +18,25 @@ with lib.types; let
default = "latest"; default = "latest";
description = "pinned athena-bccr release tag"; description = "pinned athena-bccr release tag";
}; };
vendor = lib.mkOption {
type = enum ["athena" "idopte"];
default = "idopte";
description = "driver dvendor";
};
in {
hm = {
inherit mirror release vendor;
gaudiHash = lib.mkOption {
type = nullOr str;
default = null;
description = "hash of the Gaudi client";
};
}; };
sys = { sys = {
inherit mirror release vendor;
group = lib.mkOption { group = lib.mkOption {
type = str; type = str;
default = "users"; default = "users";
description = "user group with full access to the smartcard reader"; description = "user group with full access to the smartcard reader";
}; };
mirror = lib.mkOption {
type = nullOr str;
default = null;
description = "release zip mirror base URL, if null then the release zip must be manually added to the Nix store";
};
release = lib.mkOption {
type = str;
default = "latest";
description = "pinned athena-bccr release tag";
};
}; };
} }

View file

@ -6,15 +6,17 @@
doctrine, doctrine,
... ...
}: let }: let
releases = pkgs.${doctrine.prefix}.athena-bccr.override { athena =
inherit (cfg) mirror vendor; (pkgs.${doctrine.prefix}.athena-bccr.override {
inherit (cfg) mirror;
}).${
cfg.release
}; };
athena = releases.${cfg.release}; inherit (athena) vendor;
driver = athena.card-driver.lib; driver = athena.card-driver.lib;
scmiddleware = "${driver}/lib/SCMiddleware"; scmiddleware = "${driver}/lib/SCMiddleware";
inherit (cfg) vendor;
in { in {
environment = { environment = {
etc = etc =

View file

@ -2,14 +2,10 @@
callPackage, callPackage,
lib, lib,
mirror ? null, mirror ? null,
vendor ? "idopte",
}: let }: let
releases = lib.mapAttrs resolveRelease (import ./releases.nix).${vendor}; latest = "deb64-rev26.2";
resolveRelease = name: release: releases = lib.mapAttrs (name: release: release // {name = name;}) (import ./releases.nix);
if builtins.isString release
then releases.${release}
else release // {name = name;};
overrideUnwrapped = default: new: let overrideUnwrapped = default: new: let
args = default // new; args = default // new;
@ -23,7 +19,7 @@
pkgsForRelease = release: let pkgsForRelease = release: let
inherit (unwrapped) card-driver bccr-cacerts; inherit (unwrapped) card-driver bccr-cacerts;
unwrapped = overrideUnwrapped {inherit mirror release vendor;} {}; unwrapped = overrideUnwrapped {inherit mirror release;} {};
pkcs11-module = "${card-driver.lib}/${card-driver.pkcs11-path}"; pkcs11-module = "${card-driver.lib}/${card-driver.pkcs11-path}";
in { in {
inherit card-driver bccr-cacerts pkcs11-module; inherit card-driver bccr-cacerts pkcs11-module;
@ -33,4 +29,4 @@
firmador = callPackage ./firmador.nix {inherit pkcs11-module;}; firmador = callPackage ./firmador.nix {inherit pkcs11-module;};
}; };
in in
lib.mapAttrs (_: pkgsForRelease) releases lib.mapAttrs (_: pkgsForRelease) (releases // {latest = releases.${latest};})

View file

@ -27,7 +27,7 @@ in
./0001-Remove-CheckUpdatePlugin-from-default-list.patch ./0001-Remove-CheckUpdatePlugin-from-default-list.patch
]; ];
mvnHash = "sha256-QDjhwrKZK/cEQxRYUM+z1zMCNrTHyxRqAhUfNtubhhI="; mvnHash = "sha256-iqooTe8xTrkG0JxJXlAMHExt6D8n+msB/VrCNrSJ10c=";
nativeBuildInputs = [ nativeBuildInputs = [
makeWrapper makeWrapper