flake: huge rework
Some checks failed
nix / check (push) Failing after 1m15s

flake: fix name conventions
flake: configurations -> lib.preconfiguredModules
flake.packages: rework platform dependency with convient module and
evaluator `lib.collectPackages`
packages.bonfire-docs: convient evaluators `nixosModulesDoc` and
`packagesDoc`
new: packages.postgresql: container image
new: packages.redis: container image
remove: packages.lego: needed dns provider was added to lego and nixpkgs
packages.netgen: broken
This commit is contained in:
L-Nafaryus 2024-07-18 15:49:05 +05:00
parent aced5139a1
commit a4d8f5232e
Signed by: L-Nafaryus
GPG Key ID: 553C97999B363D38
34 changed files with 744 additions and 354 deletions

View File

@ -1,6 +1,6 @@
<p align="center"> <p align="center">
<a href="https://github.com/L-Nafaryus/bonfire"> <a href="https://vcs.elnafo.ru/L-Nafaryus/bonfire">
<img src="https://raw.githubusercontent.com/L-Nafaryus/bonfire/master/etc/bonfire-logo.png" width="500px" alt="bonfire-logo"/> <img src="https://vcs.elnafo.ru/L-Nafaryus/bonfire/raw/branch/master/packages/bonfire-docs/bonfire-logo.png" width="500px" alt="bonfire-logo"/>
</a> </a>
</p> </p>

View File

@ -1,7 +0,0 @@
{
self,
inputs,
...
}: {
bonvim = ./bonvim.nix;
}

View File

@ -2,8 +2,14 @@
description = "Derivation lit"; description = "Derivation lit";
nixConfig = { nixConfig = {
extra-substituters = ["https://bonfire.cachix.org"]; extra-substituters = [
extra-trusted-public-keys = ["bonfire.cachix.org-1:mzAGBy/Crdf8NhKail5ciK7ZrGRbPJJobW6TwFb7WYM="]; "https://cache.elnafo.ru"
"https://bonfire.cachix.org"
];
extra-trusted-public-keys = [
"cache.elnafo.ru:j3VD+Hn+is2Qk3lPXDSdPwHJQSatizk7V82iJ2RP1yo="
"bonfire.cachix.org-1:mzAGBy/Crdf8NhKail5ciK7ZrGRbPJJobW6TwFb7WYM="
];
}; };
inputs = { inputs = {
@ -48,67 +54,28 @@
}; };
}; };
outputs = { outputs = {self, ...} @ inputs: let
self, lib = inputs.nixpkgs.lib;
nixpkgs,
home-manager, bonLib = import ./lib {inherit lib;};
nixos-mailserver, bonModules = self.nixosModules;
sops-nix, # no bonPkgs, it must be defined by appropriate system + skip a possible infinite recursion
crane,
fenix,
catppuccin,
oscuro,
...
} @ inputs: let
lib = import ./lib {inherit (nixpkgs) lib;};
in { in {
inherit lib; lib = bonLib;
nixosConfigurations = { packages = import ./packages {inherit lib bonLib self inputs;};
astora = nixpkgs.lib.nixosSystem {
system = "x86_64-linux"; nixosModules = import ./nixosModules {
modules = [ inherit lib bonLib self;
home-manager.nixosModules.home-manager check = false;
./nixosConfigurations/astora
self.nixosModules.bonfire
self.nixosModules.spoofdpi
(import ./nixosModules {
lib = nixpkgs.lib;
self = self;
})
.configModule
];
specialArgs = {inherit self inputs;};
}; };
catarina = nixpkgs.lib.nixosSystem { nixosConfigurations = import ./nixosConfigurations {inherit lib inputs bonModules bonLib self;};
system = "x86_64-linux";
modules = [
nixos-mailserver.nixosModules.mailserver
sops-nix.nixosModules.sops
oscuro.nixosModules.oscuro
./nixosConfigurations/catarina
self.nixosModules.bonfire
self.nixosModules.spoofdpi
self.nixosModules.papermc
self.nixosModules.qbittorrent-nox
(import ./nixosModules {
lib = nixpkgs.lib;
self = self;
})
.configModule
];
specialArgs = {inherit self;};
};
};
nixosModules = hydraJobs = {
lib.importNamedModules # filter broken packages ?
(import ./nixosModules { packages = lib.filterAttrsRecursive (name: value: !bonLib.isBroken value) self.packages;
lib = nixpkgs.lib; };
self = self;
})
.modules;
templates = { templates = {
rust = { rust = {
@ -117,16 +84,14 @@
}; };
}; };
packages = import ./packages {inherit self inputs;}; apps = import ./apps {
inherit self;
inherit (inputs) nixpkgs;
};
apps = import ./apps {inherit self nixpkgs;}; devShells = import ./devShells {
inherit self;
devShells = import ./devShells {inherit self nixpkgs;}; inherit (inputs) nixpkgs;
configurations = import ./configurations {inherit self inputs;};
hydraJobs = {
inherit (self) packages;
}; };
}; };
} }

View File

@ -1,17 +1,97 @@
{lib, ...}: rec { {lib, ...}: rec {
maintainers = import ./maintainers.nix; maintainers = import ./maintainers.nix;
moduleName = path: nameFromPath = path:
if builtins.baseNameOf (toString path) == "default.nix" if builtins.baseNameOf (toString path) == "default.nix"
then builtins.baseNameOf (lib.removeSuffix "/default.nix" (toString path)) then builtins.baseNameOf (lib.removeSuffix "/default.nix" (toString path))
else builtins.baseNameOf (lib.removeSuffix ".nix" (toString path)); else builtins.baseNameOf (lib.removeSuffix ".nix" (toString path));
moduleNames = pathList: map (path: moduleName path) pathList; preconfiguredModules = lib.listToAttrs (map (path: {
name = nameFromPath path;
value = import path;
})
[
./preconfiguredModules/bonvim.nix
]);
importModules = pathList: map (path: import path) pathList; isBroken = derivation: derivation ? meta && derivation.meta ? broken && derivation.meta.broken;
importNamedModules = pathList: functionType = lib.types.mkOptionType {
lib.listToAttrs ( name = "function";
lib.zipListsWith (name: value: {inherit name value;}) (moduleNames pathList) (importModules pathList) check = value: builtins.isFunction value;
); };
platformType = lib.types.mkOptionType {
name = "platform";
check = value: builtins.isString value && lib.any (v: v == value) lib.platforms.all;
};
packageType = with lib;
types.submodule {
options = {
source = mkOption {
type = types.oneOf [types.path functionType];
description = "Path to file with expression to build derivation or expression";
};
platforms = mkOption {
type = types.listOf platformType;
description = "List of supported platforms";
};
builder = mkOption {
type = functionType;
description = "Function with platform specific inputs that call final build function";
example = "{pkgs, ...}: pkgs.callPackage";
};
extraArgs = mkOption {
type = types.attrs;
default = {};
description = "Extra arguments passed to builder inputs. Platform is not configured for this arguments";
};
};
};
packagesModuleOptions = {...}:
with lib; {
options = {
packages = mkOption {
type = types.attrsOf packageType;
default = {};
description = "Set of defined packages";
};
};
};
collectPackages = platformInputs: packagesAttrs: let
packages =
(lib.evalModules {
modules = [
packagesModuleOptions
({...}: {
packages = packagesAttrs;
})
];
})
.config
.packages;
packagesList = lib.attrsToList packages;
evaluateDerivation = system: name: package: let
platInputs =
if functionType.check platformInputs
then (platformInputs system) // package.extraArgs
else throw "`plaformInputs` must be a function: `system` -> {...}";
platformBuilder = package.builder platInputs;
derivation = platformBuilder package.source platInputs;
in {${name} = derivation;};
evaluatedPackages = map ({
name,
value,
}:
lib.genAttrs value.platforms (
system: evaluateDerivation system name value
))
packagesList;
in
lib.mapAttrs (name: value: lib.mergeAttrsList value) (lib.zipAttrs evaluatedPackages);
} }

View File

@ -14,8 +14,16 @@
experimental-features = ["nix-command" "flakes" "repl-flake"]; experimental-features = ["nix-command" "flakes" "repl-flake"];
trusted-users = ["l-nafaryus"]; trusted-users = ["l-nafaryus"];
allowed-users = ["l-nafaryus"]; allowed-users = ["l-nafaryus"];
substituters = ["https://nix-community.cachix.org"]; substituters = [
trusted-public-keys = ["nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="]; "https://cache.elnafo.ru"
"https://bonfire.cachix.org"
"https://nix-community.cachix.org"
];
trusted-public-keys = [
"cache.elnafo.ru:j3VD+Hn+is2Qk3lPXDSdPwHJQSatizk7V82iJ2RP1yo="
"bonfire.cachix.org-1:mzAGBy/Crdf8NhKail5ciK7ZrGRbPJJobW6TwFb7WYM="
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
];
auto-optimise-store = true; auto-optimise-store = true;
}; };
gc = { gc = {

View File

@ -2,7 +2,7 @@
config, config,
pkgs, pkgs,
lib, lib,
self, bonPkgs,
inputs, inputs,
... ...
}: { }: {
@ -83,6 +83,8 @@
gxplugins-lv2 gxplugins-lv2
xtuner xtuner
aether-lv2 aether-lv2
aeolus
grandorgue
qbittorrent qbittorrent
transmission_3-qt transmission_3-qt
@ -91,7 +93,7 @@
onlyoffice-bin onlyoffice-bin
jdk jdk
self.packages.${pkgs.system}.ultimmc bonPkgs.ultimmc
liberation_ttf liberation_ttf
@ -120,7 +122,7 @@
wl-clipboard wl-clipboard
cliphist cliphist
tree tree
self.packages.${pkgs.system}.bonvim bonPkgs.bonvim
]; ];
xdg.portal = { xdg.portal = {

View File

@ -2,11 +2,9 @@
config, config,
pkgs, pkgs,
lib, lib,
self, bonPkgs,
... ...
}: let }: {
bonfire-pkgs = self.packages.${pkgs.system};
in {
system.stateVersion = "23.11"; system.stateVersion = "23.11";
imports = [ imports = [
@ -23,10 +21,12 @@ in {
trusted-users = ["l-nafaryus"]; trusted-users = ["l-nafaryus"];
allowed-users = ["l-nafaryus" "hydra" "hydra-www"]; allowed-users = ["l-nafaryus" "hydra" "hydra-www"];
substituters = [ substituters = [
"https://cache.elnafo.ru"
"https://bonfire.cachix.org" "https://bonfire.cachix.org"
"https://nix-community.cachix.org" "https://nix-community.cachix.org"
]; ];
trusted-public-keys = [ trusted-public-keys = [
"cache.elnafo.ru:j3VD+Hn+is2Qk3lPXDSdPwHJQSatizk7V82iJ2RP1yo="
"bonfire.cachix.org-1:mzAGBy/Crdf8NhKail5ciK7ZrGRbPJJobW6TwFb7WYM=" "bonfire.cachix.org-1:mzAGBy/Crdf8NhKail5ciK7ZrGRbPJJobW6TwFb7WYM="
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs=" "nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
]; ];
@ -139,7 +139,7 @@ in {
"bonfire.elnafo.ru" = { "bonfire.elnafo.ru" = {
forceSSL = true; forceSSL = true;
useACMEHost = "elnafo.ru"; useACMEHost = "elnafo.ru";
locations."/".root = "${bonfire-pkgs.bonfire-docs}"; locations."/".root = "${bonPkgs.bonfire-docs}";
}; };
"hydra.elnafo.ru" = { "hydra.elnafo.ru" = {

View File

@ -1,7 +1,6 @@
{ {
config, config,
pkgs, pkgs,
lib,
... ...
}: { }: {
# Users # Users

View File

@ -0,0 +1,33 @@
{
lib,
inputs,
bonModules,
bonLib,
self,
...
}: {
astora = lib.nixosSystem {
system = "x86_64-linux";
modules = with inputs; [
home-manager.nixosModules.home-manager
bonModules.bonfire
./astora
];
specialArgs = {
inherit inputs;
bonPkgs = self.packages.x86_64-linux;
};
};
catarina = lib.nixosSystem {
system = "x86_64-linux";
modules = with inputs; [
nixos-mailserver.nixosModules.mailserver
sops-nix.nixosModules.sops
oscuro.nixosModules.oscuro
bonModules.bonfire
./catarina
];
specialArgs = {bonPkgs = self.packages.x86_64-linux;};
};
}

View File

@ -1,10 +1,11 @@
{ {
lib, lib,
check ? true, bonLib,
self, self,
check ? true,
... ...
}: rec { }: let
modules = [ moduleList = [
./misc/bonfire/default.nix ./misc/bonfire/default.nix
./services/papermc.nix ./services/papermc.nix
./services/qbittorrent-nox.nix ./services/qbittorrent-nox.nix
@ -17,11 +18,38 @@
... ...
}: { }: {
config = { config = {
# Module type checking # module type checking
_module.check = check; _module.check = check;
#_module.args.baseModules = modules; # extra arguments
#_module.args.pkgs = lib.mkDefault pkgs; _module.args = {
_module.args.bonpkgs = self.packages.${pkgs.system}; bonPkgs = self.packages.${pkgs.system};
}; };
}; };
} };
importedModules =
map (path: {...}: {
# imports provide path for each module needed for documentation
# inject module configuration
imports = [path configModule];
})
moduleList;
importedModuleNames = map (path: bonLib.nameFromPath path) moduleList;
bonfireModule = {
config,
pkgs,
...
}: {
# collect all modules
imports = importedModules;
};
in
lib.listToAttrs (
lib.zipListsWith (name: value: {inherit name value;}) importedModuleNames importedModules
)
// {
bonfire = bonfireModule;
default = bonfireModule;
}

View File

@ -1,7 +1,7 @@
{ {
config, config,
lib, lib,
bonpkgs, bonPkgs,
... ...
}: }:
with lib; let with lib; let
@ -12,8 +12,8 @@ in {
package = mkOption { package = mkOption {
type = types.package; type = types.package;
default = bonpkgs.spoofdpi; default = bonPkgs.spoofdpi;
defaultText = literalExpression "bonpkgs.spoofdpi"; defaultText = literalExpression "bonPkgs.spoofdpi";
description = "The package to use."; description = "The package to use.";
}; };

View File

Before

Width:  |  Height:  |  Size: 58 KiB

After

Width:  |  Height:  |  Size: 58 KiB

View File

@ -14,3 +14,4 @@ no-section-label = true
git-repository-url = "https://vcs.elnafo.ru/L-Nafaryus/bonfire" git-repository-url = "https://vcs.elnafo.ru/L-Nafaryus/bonfire"
git-repository-icon = "fa-git" git-repository-icon = "fa-git"
cname = "elnafo.ru" cname = "elnafo.ru"
fold.enable = true

View File

@ -1,150 +1,39 @@
{ {
bonfire, bonLib,
bonModules,
self,
lib, lib,
pkgs, pkgs,
... ...
}: let }: let
version = bonfire.shortRev or bonfire.dirtyShortRev or "unknown"; version = "unknown";
projectPath = ../../.;
modulesPath = ../../nixosModules;
links = [ nixosModulesDoc = import ./nixosModulesDoc.nix {
inherit lib pkgs version;
modules = bonModules;
root = ../../.;
declarations = [
{ {
hostname = "vcs-elnafo"; name = "elnafo-vcs";
url = "https://vcs.elnafo.ru/L-Nafaryus/bonfire/src/branch/master"; url = "https://vcs.elnafo.ru/L-Nafaryus/bonfire/src/branch/master";
} }
{ {
hostname = "github"; name = "github";
url = "https://github.com/L-Nafaryus/bonfire/blob/master"; url = "https://github.com/L-Nafaryus/bonfire/blob/master";
} }
]; ];
projectName = "bonfire";
formatDeclaration = declaration: modulesPrefix = ../../nixosModules;
if lib.hasPrefix (toString modulesPath) (toString declaration)
then let
subpath = lib.removePrefix (toString projectPath + "/") (toString declaration);
in
map ({
hostname,
url,
}: {
url = "${url}/${subpath}";
name = "<${hostname}:bonfire/${subpath}>";
})
links
else
# skip external declarations
lib.singleton declaration;
nixosModules = import modulesPath {
inherit lib;
self = bonfire;
check = false;
}; };
evaluatedModules = lib.evalModules { packagesDoc = import ./packagesDoc.nix {
modules = nixosModules.modules ++ [nixosModules.configModule]; inherit lib pkgs;
packages = self.packages;
repoUrl = "https://vcs.elnafo.ru/L-Nafaryus/bonfire/src/branch/master";
hydraUrl = "https://hydra.elnafo.ru/job/bonfire/master";
}; };
optionsDoc = pkgs.nixosOptionsDoc {
options = builtins.removeAttrs evaluatedModules.options [
"_module"
"system"
];
transformOptions = option:
option
// {
declarations = lib.unique (
lib.flatten (map (declaration: formatDeclaration declaration) option.declarations)
++ option.declarations
);
};
documentType = "none";
revision = version;
};
systems = builtins.attrNames bonfire.packages;
derivations = lib.flatten (
map (packages: (
map (name: packages.${name}) (builtins.attrNames packages)
)) (map (system: bonfire.packages.${system}) systems)
);
renderMaintainers = maintainers:
lib.concatStringsSep ", " (
let
maintainer = mt:
if mt ? github
then "[${mt.name}](https://github.com/${mt.github})"
else mt.name;
email = mt:
if mt ? email
then "<[${mt.email}](mailto:${mt.email})>"
else "";
in
map (mt: maintainer mt + email mt) maintainers
);
renderPlatforms = platforms:
if platforms != lib.platforms.none
then
if platforms == lib.platforms.all
then "all"
else lib.concatStringsSep ", " (map (platform: "__${platform}__") platforms)
else "";
renderPackage = drv: ''
## ${drv.pname}
${lib.optionalString (drv.meta ? description) drv.meta.description}
${lib.optionalString (drv.meta ? homepage) "[Homepage](${drv.meta.homepage})"}
Version: __${drv.version}__
${lib.optionalString (drv.meta ? license) "License: [${drv.meta.license.fullName}](${drv.meta.license.url})"}
Outputs: ${lib.concatStringsSep ", " (map (o: "__${o}__") drv.outputs)}
${lib.optionalString (drv.meta ? mainProgram) "Provided programs: __${drv.meta.mainProgram}__"}
${lib.optionalString (drv.meta ? maintainers) "Maintainers: ${renderMaintainers drv.meta.maintainers}"}
${lib.optionalString (drv.meta ? platforms) "Platforms: ${renderPlatforms drv.meta.platforms}"}
'';
renderImage = drv: ''
## ${drv.imageName}
${lib.optionalString (drv.meta ? description) drv.meta.description}
${lib.optionalString (drv.meta ? homepage) "[Homepage](${drv.meta.homepage})"}
Tag: __${drv.imageTag}__
${lib.optionalString (drv.fromImage != null) "From: __${drv.fromImage.imageName}__"}
${lib.optionalString (drv.meta ? license) "License: ${
if lib.isList drv.meta.license
then (map (license: "[${drv.meta.license.fullName}](${drv.meta.license.url})") drv.meta.license)
else "[${drv.meta.license.fullName}](${drv.meta.license.url})"
}"}
${lib.optionalString (drv.meta ? maintainers) "Maintainers: ${renderMaintainers drv.meta.maintainers}"}
${lib.optionalString (drv.meta ? platforms) "Platforms: ${renderPlatforms drv.meta.platforms}"}
'';
packagesDoc =
pkgs.writeText "packages.md"
(lib.concatStringsSep "\n" (map (drv:
if drv ? imageTag
then renderImage drv
else if drv ? pname
then renderPackage drv
else "")
derivations));
in in
pkgs.stdenvNoCC.mkDerivation { pkgs.stdenvNoCC.mkDerivation {
pname = "bonfire-docs"; pname = "bonfire-docs";
@ -166,9 +55,15 @@ in
buildPhase = '' buildPhase = ''
runHook preBuild runHook preBuild
ln -s ${../../README.md} src/README.md ln -s ${../../README.md} src/README.md
ln -s ${optionsDoc.optionsCommonMark} src/options/modules.md
ln -s ${packagesDoc} src/packages/packages.md ${lib.concatStringsSep "\n" (map (module_: "ln -s ${module_.commonMarkdown} src/nixosModules/${module_.name}.md") nixosModulesDoc.documentation)}
substituteInPlace src/SUMMARY.md --replace '{{nixosModulesSummary}}' '${lib.concatStringsSep "\n" nixosModulesDoc.summary}'
${lib.concatStringsSep "\n" (map (package_: "ln -s ${package_.commonMarkdown} src/packages/${package_.name}.md") packagesDoc.documentation)}
substituteInPlace src/SUMMARY.md --replace '{{packagesSummary}}' '${lib.concatStringsSep "\n" packagesDoc.summary}'
mdbook build mdbook build
runHook postBuild runHook postBuild
''; '';
@ -188,9 +83,9 @@ in
}; };
meta = with lib; { meta = with lib; {
description = "Bonfire HTML documentation."; description = "Bonfire documentation.";
license = licenses.mit; license = licenses.mit;
maintainers = with bonfire.lib.maintainers; [L-Nafaryus]; maintainers = with bonLib.maintainers; [L-Nafaryus];
platforms = lib.platforms.all; platforms = lib.platforms.all;
}; };
} }

View File

@ -0,0 +1,64 @@
{
lib,
pkgs,
modules,
excludedModules ? ["default"],
root ? null,
declarations ? {},
projectName ? "",
modulesPrefix ? "",
version ? "unknown",
}: let
moduleNames = lib.filter (key: builtins.all (restricted: key != restricted) excludedModules) (lib.attrNames modules);
moduleValues = map (key: modules.${key}) moduleNames;
genDeclaration = storeDeclaration: declarations:
map (declaration: let
subpath = lib.removePrefix (toString root + "/") (toString storeDeclaration);
project =
if projectName != ""
then "${projectName}/"
else "";
in {
name = "<${declaration.name}:${project}${subpath}>";
url = "${declaration.url}/${subpath}";
})
declarations;
formatDeclaration = storeDeclaration:
if lib.hasPrefix (toString modulesPrefix) (toString storeDeclaration)
then genDeclaration storeDeclaration declarations
# skip external declarations
else lib.singleton storeDeclaration;
transformOptions = option:
option
// {
declarations = lib.unique (
lib.flatten (map (declaration: formatDeclaration declaration) option.declarations)
++ option.declarations
);
};
genDocumentation = module:
pkgs.nixosOptionsDoc {
options = builtins.removeAttrs (lib.evalModules {modules = [module];}).options [
"_module"
"system"
];
transformOptions = transformOptions;
documentType = "none";
revision = version;
};
in {
documentation =
lib.zipListsWith (name: moduleDocumentation: {
name = name;
commonMarkdown = moduleDocumentation.optionsCommonMark;
})
moduleNames
(map (module: genDocumentation module) moduleValues);
summary = map (name: " - [${name}](nixosModules/${name}.md)") moduleNames;
}

View File

@ -0,0 +1,137 @@
{
lib,
pkgs,
packages,
excludedPackages ? ["default"],
repoUrl ? null,
hydraUrl ? null,
}: let
supportedSystems = builtins.attrNames packages;
derivations = lib.flatten (
map (packages_: (
map (name: packages_.${name}) (builtins.attrNames packages_)
)) (map (system: packages.${system}) supportedSystems)
);
extractName = drv:
if drv ? pname
then drv.pname
else if drv ? imageName
then drv.imageName
else "unknown";
derivationNames = map (drv: extractName drv) derivations;
genDocumentation = drv: let
name = extractName drv;
type =
if drv ? pname
then "package"
else if drv ? imageTag
then "image"
else "unknown";
description = lib.optionalString (drv.meta ? description) drv.meta.description;
homepage = lib.optionalString (drv.meta ? homepage) "[Homepage](${drv.meta.homepage})";
source = lib.optionalString (repoUrl != null) "[Source](${repoUrl}/packages/${name}/default.nix)";
versionOrTag =
if type == "package"
then "Version: __${drv.version}__"
else if type == "image"
then "Tag: __${drv.imageTag}__"
else "";
license = lib.optionalString (drv.meta ? license) "License: ${
if lib.isList drv.meta.license
then (map (license: "[${drv.meta.license.fullName}](${drv.meta.license.url})") drv.meta.license)
else "[${drv.meta.license.fullName}](${drv.meta.license.url})"
}";
maintainers = let
maintainer = mt:
if mt ? github
then "[${mt.name}](https://github.com/${mt.github})"
else mt.name;
email = mt:
if mt ? email
then "<[${mt.email}](mailto:${mt.email})>"
else "";
in
lib.optionalString (drv.meta ? maintainers) ("Maintainers: "
+ lib.concatStringsSep ", " (
map (mt: maintainer mt + email mt) drv.meta.maintainers
));
platforms = lib.optionalString (drv.meta ? platforms && drv.meta.platforms != lib.platforms.none) (
let
# limit package platforms to supported by flake only
filteredPlatforms = lib.intersectLists drv.meta.platforms supportedSystems;
in
"Platforms: "
+ lib.concatStringsSep ", " (map (platform:
if hydraUrl != null
then "[${platform}](${hydraUrl}/packages.${platform}.${name})"
else "__${platform}__")
filteredPlatforms)
);
mainProgram = lib.optionalString (drv.meta ? mainProgram) "Main program: __${drv.meta.mainProgram}__";
outputs = lib.optionalString (drv ? outputs) ("Outputs: " + lib.concatStringsSep ", " (map (o: "__${o}__") drv.outputs));
fromImage = lib.optionalString (drv ? fromImage && drv.fromImage != null) "From: __${drv.fromImage.imageName}__";
stats = let
stats_ = [
(lib.optionalString
(drv.meta ? broken && drv.meta.broken)
" _broken_")
(lib.optionalString
(drv.meta ? unfree && drv.meta.unfree)
" _unfree_")
(lib.optionalString
(drv.meta ? unsupported && drv.meta.unsupported)
" _unsupported_")
(lib.optionalString
(drv.meta ? insecure && drv.meta.insecure)
" _insecure_")
];
in
lib.optionalString (builtins.any (s: s == true) stats_) "[ ${lib.concatStringsSep "," stats_} ]";
in {
commonMarkdown = pkgs.writeText "meta.md" ''
## ${name}
${stats}
${description}
${source} ${lib.optionalString (homepage != "") "| ${homepage}"}
${versionOrTag} ${fromImage}
${mainProgram}
${outputs}
${license}
${maintainers}
${platforms}
'';
};
in {
documentation =
lib.zipListsWith (name: packageDocumentation: {
name = name;
commonMarkdown = packageDocumentation.commonMarkdown;
})
derivationNames
(map (drv: genDocumentation drv) derivations);
summary = map (name: " - [${name}](packages/${name}.md)") derivationNames;
}

View File

@ -2,13 +2,17 @@
[Introduction](README.md) [Introduction](README.md)
# Outputs
- [Packages](packages/README.md) - [Packages](packages/README.md)
- [packages](packages/packages.md) {{packagesSummary}}
- [Module options](options/README.md) - [NixOS Modules](nixosModules/README.md)
- [nixosModules](options/modules.md) {{nixosModulesSummary}}
- [FAQ](faq.md) # Trivia
- [Side Notes](notes.md)
- [Contributing](contributing.md) - [Contributing](contributing.md)

View File

@ -1,4 +1,4 @@
# Module options # NixOS modules
First, you need to add this project to your flake inputs: First, you need to add this project to your flake inputs:
@ -21,6 +21,10 @@ After, you can use in a NixOS configuration like so
system = "x86_64-linux"; system = "x86_64-linux";
modules = [ modules = [
bonfire.nixosModules.bonfire bonfire.nixosModules.bonfire
# or default because bonfire is default module
bonfire.nixosModules.default
# or just standalone module
bonfire.nixosModules.bar
... ...
]; ];
}; };

View File

@ -1,4 +1,4 @@
# Frequently asked questions and hints # Side Notes
* How to update and push flake inputs: * How to update and push flake inputs:

View File

@ -0,0 +1,36 @@
# Packages
First, you need to add this project to your flake inputs:
```nix
{
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
bonfire.url = "github:L-Nafaryus/bonfire";
};
outputs = { nixpkgs, bonfire, ... }:
{ ... }
}
```
After, you can use in a NixOS configuration like so
```nix
{
nixosConfigurations.foo = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
specialArgs = { bonPkgs = bonfire.packages.x86_64-linux; };
modules = [
{ pkgs, bonPkgs, ... }: {
environment.systemPackages = [
pkgs.bar
bonPkgs.baz
];
}
...
];
};
# or pass in your devShells, nixosModules, etc
}
```

View File

@ -1,16 +1,31 @@
{ {
pkgs, pkgs,
nixvim-pkgs, nixvimPkgs,
bonconfigs, fenixPkgs,
fenix-pkgs, bonLib,
lib,
... ...
}: }: let
nixvim-pkgs.makeNixvimWithModule { drv = nixvimPkgs.makeNixvimWithModule {
pkgs = pkgs; pkgs = pkgs;
module = import bonconfigs.bonvim; module = bonLib.preconfiguredModules.bonvim;
extraSpecialArgs = { extraSpecialArgs = {
rustc = fenix-pkgs.complete.rustc; rustc = fenixPkgs.complete.rustc;
cargo = fenix-pkgs.complete.cargo; cargo = fenixPkgs.complete.cargo;
rust-analyzer = fenix-pkgs.complete.rust-analyzer; rust-analyzer = fenixPkgs.complete.rust-analyzer;
}; };
} };
in
drv
// {
pname = "bonvim";
version = "unknown";
meta = with lib;
drv.meta
// {
description = "NixVim distribution for NeoVim with a customized collection of plugins inspired by the LazyVim distribution.";
license = licenses.mit;
maintainers = with bonLib.maintainers; [L-Nafaryus];
platforms = platforms.linux;
};
}

View File

@ -1,6 +1,6 @@
{ {
bonfire, bonLib,
crane-lib, craneLib,
lib, lib,
pkgs, pkgs,
version ? "v0.44.0", version ? "v0.44.0",
@ -34,12 +34,13 @@
description = "A cargo command for the shuttle platform"; description = "A cargo command for the shuttle platform";
license = licenses.asl20; license = licenses.asl20;
homepage = "https://shuttle.rs/"; homepage = "https://shuttle.rs/";
maintainers = with bonfire.lib.maintainers; [L-Nafaryus]; maintainers = with bonLib.maintainers; [L-Nafaryus];
platforms = platforms.x86_64;
}; };
}; };
in let in let
cargoArtifacts = crane-lib.buildDepsOnly pkg; cargoArtifacts = craneLib.buildDepsOnly pkg;
in in
crane-lib.buildPackage ( craneLib.buildPackage (
pkg // {inherit cargoArtifacts;} pkg // {inherit cargoArtifacts;}
) )

View File

@ -1,5 +1,5 @@
{ {
bonfire, bonLib,
stdenv, stdenv,
lib, lib,
pkgs, pkgs,
@ -58,7 +58,7 @@ pkgs.python3.pkgs.buildPythonPackage {
description = "Dear PyGui: A fast and powerful Graphical User Interface Toolkit for Python with minimal dependencies."; description = "Dear PyGui: A fast and powerful Graphical User Interface Toolkit for Python with minimal dependencies.";
license = licenses.mit; license = licenses.mit;
platforms = platforms.linux; platforms = platforms.linux;
maintainers = with bonfire.lib.maintainers; [L-Nafaryus]; maintainers = with bonLib.maintainers; [L-Nafaryus];
broken = pkgs.stdenv.isDarwin; broken = pkgs.stdenv.isDarwin;
}; };
} }

View File

@ -1,48 +1,98 @@
# self.packages.${system} # self.packages.${system}
# #
{ {
lib,
bonLib,
self, self,
inputs, inputs,
... ...
}: let }: let
forAllSystems = inputs.nixpkgs.lib.genAttrs ["x86_64-linux"]; platformInputs = system: rec {
nixpkgsFor = forAllSystems (system: import inputs.nixpkgs {inherit system;}); pkgs = inputs.nixpkgs.legacyPackages.${system};
lib = pkgs.lib;
inherit bonLib;
bonModules = self.nixosModules;
bonPkgs = self.packages.${system};
craneLib = inputs.crane.mkLib pkgs;
fenixPkgs = inputs.fenix.packages.${system};
nixvimPkgs = inputs.nixvim.legacyPackages.${system};
};
in in
forAllSystems (system: let bonLib.collectPackages platformInputs {
pkgs = nixpkgsFor.${system}; bonfire-docs = {
source = ./bonfire-docs;
platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.callPackage;
extraArgs = {inherit self;};
};
bonfire = self; netgen = {
bonlib = self.lib; source = ./netgen;
bonpkgs = self.packages.${system}; platforms = ["x86_64-linux"];
bonconfigs = self.configurations; builder = {pkgs, ...}: pkgs.callPackage;
};
crane = self.inputs.crane; dearpygui = {
crane-lib = self.inputs.crane.mkLib pkgs; source = ./dearpygui;
platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.callPackage;
};
fenix = self.inputs.fenix; openfoam = {
fenix-pkgs = self.inputs.fenix.packages.${system}; source = ./openfoam;
platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.callPackage;
};
nixvim-pkgs = self.inputs.nixvim.legacyPackages.${system}; spoofdpi = {
in { source = ./spoofdpi;
bonfire-docs = pkgs.callPackage ./bonfire-docs {inherit bonfire;}; platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.callPackage;
};
netgen = pkgs.callPackage ./netgen {inherit bonfire;}; ultimmc = {
source = ./ultimmc;
platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.libsForQt5.callPackage;
};
dearpygui = pkgs.callPackage ./dearpygui {inherit bonfire;}; cargo-shuttle = {
source = ./cargo-shuttle;
platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.callPackage;
};
openfoam = pkgs.callPackage ./openfoam {inherit bonfire;}; bonvim = {
source = ./bonvim;
platforms = ["x86_64-linux"];
builder = {...}: import;
};
spoofdpi = pkgs.callPackage ./spoofdpi {inherit bonfire;}; # Container images
lego = pkgs.callPackage ./lego {inherit bonfire;}; nix-minimal = {
source = ./nix-minimal;
platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.callPackage;
};
ultimmc = pkgs.libsForQt5.callPackage ./ultimmc {inherit bonfire;}; nix-runner = {
source = ./nix-runner;
platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.callPackage;
};
cargo-shuttle = pkgs.callPackage ./cargo-shuttle {inherit bonfire crane-lib;}; postgresql = {
source = ./postgresql;
platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.callPackage;
};
nix-minimal = pkgs.callPackage ./nix-minimal {inherit bonpkgs bonlib;}; redis = {
source = ./redis;
nix-runner = pkgs.callPackage ./nix-runner {inherit bonpkgs bonlib;}; platforms = ["x86_64-linux"];
builder = {pkgs, ...}: pkgs.callPackage;
bonvim = import ./bonvim {inherit nixvim-pkgs pkgs bonconfigs fenix-pkgs;}; };
}) }

View File

@ -1,41 +0,0 @@
{
bonfire,
lib,
fetchFromGitHub,
buildGoModule,
nixosTests,
version ? "c847ac4a4c55d6a5a457f6ef494cf45a47299e01",
hash ? "sha256-g9OxhM+iNUrAZgM1we8qPsismPy5a0eN654tSYuM/No=",
vendorHash ? "sha256-wG0x86lptEY3x+7kVN7v1XZniliMOxaJ6Y95YS6ivJY=",
...
}:
buildGoModule rec {
pname = "lego";
inherit version;
src = fetchFromGitHub {
owner = "go-acme";
repo = "lego";
rev = version;
hash = hash;
};
inherit vendorHash;
doCheck = false;
subPackages = ["cmd/lego"];
ldflags = [
"-X main.version=${version}"
];
meta = with lib; {
description = "Let's Encrypt client and ACME library written in Go";
license = licenses.mit;
homepage = "https://go-acme.github.io/lego/";
maintainers = with bonfire.lib.maintainers; [L-Nafaryus];
};
passthru.tests.lego = nixosTests.acme;
}

View File

@ -1,5 +1,5 @@
{ {
bonfire, bonLib,
stdenv, stdenv,
lib, lib,
pkgs, pkgs,
@ -69,8 +69,8 @@
description = "NETGEN is an automatic 3d tetrahedral mesh generator"; description = "NETGEN is an automatic 3d tetrahedral mesh generator";
license = licenses.lgpl21Only; license = licenses.lgpl21Only;
platforms = platforms.linux; platforms = platforms.linux;
maintainers = with bonfire.lib.maintainers; [L-Nafaryus]; maintainers = with bonLib.maintainers; [L-Nafaryus];
broken = pkgs.stdenv.isDarwin; broken = true;
}; };
}; };
in in

View File

@ -1,7 +1,7 @@
{ {
pkgs, pkgs,
lib, lib,
bonlib, bonLib,
extraPaths ? [], extraPaths ? [],
... ...
}: let }: let
@ -145,6 +145,6 @@ in
''; '';
platforms = platforms.linux; platforms = platforms.linux;
license = licenses.lgpl21Plus; license = licenses.lgpl21Plus;
maintainers = with bonlib.maintainers; [L-Nafaryus]; maintainers = with bonLib.maintainers; [L-Nafaryus];
}; };
} }

View File

@ -1,15 +1,14 @@
{ {
pkgs, pkgs,
lib, lib,
bonpkgs, bonPkgs,
bonlib,
extraPaths ? [], extraPaths ? [],
... ...
}: }:
pkgs.dockerTools.buildImage { pkgs.dockerTools.buildImage {
name = "nix-runner"; name = "nix-runner";
tag = "latest"; tag = "latest";
fromImage = bonpkgs.nix-minimal; fromImage = bonPkgs.nix-minimal;
copyToRoot = pkgs.buildEnv { copyToRoot = pkgs.buildEnv {
name = "image-root"; name = "image-root";
@ -27,7 +26,7 @@ pkgs.dockerTools.buildImage {
} }
// { // {
meta = meta =
bonpkgs.nix-minimal.meta bonPkgs.nix-minimal.meta
// { // {
description = "Image for action runners with a Nix package manager"; description = "Image for action runners with a Nix package manager";
longDescription = '' longDescription = ''

View File

@ -1,5 +1,5 @@
{ {
bonfire, bonLib,
stdenv, stdenv,
lib, lib,
pkgs, pkgs,
@ -79,7 +79,7 @@ in let
description = "OpenFOAM is a free, open source CFD software released and developed by OpenFOAM Foundation"; description = "OpenFOAM is a free, open source CFD software released and developed by OpenFOAM Foundation";
license = licenses.gpl3; license = licenses.gpl3;
platforms = platforms.linux; platforms = platforms.linux;
maintainers = with bonfire.lib.maintainers; [L-Nafaryus]; maintainers = with bonLib.maintainers; [L-Nafaryus];
broken = pkgs.stdenv.isDarwin; broken = pkgs.stdenv.isDarwin;
}; };
}; };

View File

@ -0,0 +1,58 @@
{
pkgs,
lib,
bonLib,
extraPaths ? [],
...
}: let
user = "postgres";
dataDir = "/var/lib/postgresql";
entryPoint = pkgs.writeTextDir "entrypoint.sh" ''
initdb -U ${user}
postgres -k ${dataDir}
'';
in
pkgs.dockerTools.buildImage {
name = "postgresql";
tag = "latest";
copyToRoot = pkgs.buildEnv {
name = "image-root";
pathsToLink = ["/bin" "/etc" "/"];
paths = with pkgs;
[
bash
postgresql
entryPoint
]
++ extraPaths;
};
runAsRoot = with pkgs; ''
#!${runtimeShell}
${dockerTools.shadowSetup}
groupadd -r ${user}
useradd -r -g ${user} --home-dir=${dataDir} ${user}
mkdir -p ${dataDir}
chown -R ${user}:${user} ${dataDir}
'';
config = {
Entrypoint = ["bash" "/entrypoint.sh"];
StopSignal = "SIGINT";
User = "${user}:${user}";
Env = ["PGDATA=${dataDir}"];
WorkingDir = dataDir;
ExposedPorts = {
"5432/tcp" = {};
};
};
}
// {
meta = with lib; {
homepage = "https://www.postgresql.org";
description = "A powerful, open source object-relational database system.";
platforms = platforms.linux;
license = licenses.postgresql;
maintainers = with bonLib.maintainers; [L-Nafaryus];
};
}

View File

@ -0,0 +1,58 @@
{
pkgs,
lib,
bonLib,
extraPaths ? [],
...
}: let
user = "redis";
dataDir = "/var/lib/redis";
entryPoint = pkgs.writeTextDir "entrypoint.sh" ''
redis-server \
--daemonize no \
--dir "${dataDir}"
'';
in
pkgs.dockerTools.buildImage {
name = "redis";
tag = "latest";
copyToRoot = pkgs.buildEnv {
name = "image-root";
pathsToLink = ["/bin" "/etc" "/"];
paths = with pkgs;
[
bash
redis
entryPoint
]
++ extraPaths;
};
runAsRoot = with pkgs; ''
#!${runtimeShell}
${dockerTools.shadowSetup}
groupadd -r ${user}
useradd -r -g ${user} --home-dir=${dataDir} ${user}
mkdir -p ${dataDir}
chown -R ${user}:${user} ${dataDir}
'';
config = {
Entrypoint = ["bash" "/entrypoint.sh"];
StopSignal = "SIGINT";
User = "${user}:${user}";
WorkingDir = dataDir;
ExposedPorts = {
"6379/tcp" = {};
};
};
}
// {
meta = with lib; {
homepage = "https://redis.io";
description = "An open source, advanced key-value store.";
platforms = platforms.linux;
license = licenses.bsd3;
maintainers = with bonLib.maintainers; [L-Nafaryus];
};
}

View File

@ -1,5 +1,5 @@
{ {
bonfire, bonLib,
lib, lib,
pkgs, pkgs,
version ? "0.8", version ? "0.8",
@ -28,7 +28,7 @@ pkgs.buildGoModule {
homepage = "https://github.com/xvzc/SpoofDPI"; homepage = "https://github.com/xvzc/SpoofDPI";
description = "A simple and fast anti-censorship tool written in Go"; description = "A simple and fast anti-censorship tool written in Go";
license = licenses.asl20; license = licenses.asl20;
maintainers = with bonfire.lib.maintainers; [L-Nafaryus]; maintainers = with bonLib.maintainers; [L-Nafaryus];
broken = false; broken = false;
mainProgram = "spoof-dpi"; mainProgram = "spoof-dpi";
}; };

View File

@ -1,5 +1,5 @@
{ {
bonfire, bonLib,
lib, lib,
stdenv, stdenv,
fetchFromGitHub, fetchFromGitHub,
@ -13,6 +13,7 @@
xorg, xorg,
libpulseaudio, libpulseaudio,
libGL, libGL,
...
}: }:
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
version = "faf3c966c43465d6f6c245ed78556222240398ee"; version = "faf3c966c43465d6f6c245ed78556222240398ee";
@ -78,6 +79,6 @@ stdenv.mkDerivation rec {
description = "Cracked Minecraft Launcher"; description = "Cracked Minecraft Launcher";
license = licenses.asl20; license = licenses.asl20;
platforms = platforms.linux; platforms = platforms.linux;
maintainers = with bonfire.lib.maintainers; [L-Nafaryus]; maintainers = with bonLib.maintainers; [L-Nafaryus];
}; };
} }