Skip to content

Commit

Permalink
nixos/pay-respects: add aiIntegration option
Browse files Browse the repository at this point in the history
Signed-off-by: Fernando Rodrigues <[email protected]>
  • Loading branch information
SigmaSquadron committed Jan 3, 2025
1 parent adb35e1 commit 9966a1d
Showing 1 changed file with 89 additions and 2 deletions.
91 changes: 89 additions & 2 deletions nixos/modules/programs/pay-respects.nix
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
}:
let
inherit (lib)
concatStrings
getExe
literalExpression
maintainers
Expand All @@ -15,9 +16,19 @@ let
mkOption
mkPackageOption
optionalString
replaceChars
stringToCharacters
take
toLower
types
;
inherit (types) listOf str;
inherit (types)
bool
either
listOf
str
submodule
;

cfg = config.programs.pay-respects;

Expand Down Expand Up @@ -79,14 +90,90 @@ in
Each rule module should start with the `command` attribute that specifies the command name. See the [upstream documentation](https://codeberg.org/iff/pay-respects/src/branch/main/rules.md) for more information.
'';
};
aiIntegration = mkOption {
default = false;
example = {
url = "http://127.0.0.1:11434/v1/chat/completions";
model = "llama3";
locale = "nl-be";
};
description = ''
Whether to enable `pay-respects`' LLM integration. When there is no rule for a given error, `pay-respects` can query an OpenAI-compatible API endpoint for command corrections.
- If this is set to `false`, all LLM-related features are disabled.
- If this is set to `true`, the default OpenAI endpoint will be used, using upstream's API key. This default API key may be rate-limited.
- You can also set a custom API endpoint, large language model and locale for command corrections. Simply access the `aiIntegration.url`, `aiIntegration.model` and `aiIntegration.locale` options, as described in the example.
- Take a look at the [services.ollama](#opt-services.ollama.enable) NixOS module if you wish to host a local large language model for `pay-respects`.
For all of these methods, you can set a custom secret API key by using the `_PR_AI_API_KEY` environment variable.
'';
type = either bool (submodule {
options = {
url = mkOption {
default = "";
example = "https://api.openai.com/v1/chat/completions";
type = str;
description = "The OpenAI-compatible API endpoint that `pay-respects` will query for command corrections.";
};
model = mkOption {
default = "";
example = "llama3";
type = str;
description = "The model used by `pay-respects` to generate command corrections.";
};
locale = mkOption {
default = concatStrings (
toLower (replaceChars [ "_" ] [ "-" ] (take 5 (stringToCharacters config.i18n.defaultLocale)))
);
example = "nl-be";
type = str;
description = ''
The locale to be used for LLM responses.
The accepted format is a lowercase [`ISO 639-1` language code](https://en.wikipedia.org/wiki/List_of_ISO_639_language_codes), followed by a dash '-', followed by a lowercase [`ISO 3166-1 alpha-2` country code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2).
'';
};
};
});
};
};
};

config = mkIf cfg.enable {
assertions =
map
(attr: {
assertion = (!builtins.isBool cfg.aiIntegration) -> cfg.aiIntegration.${attr} != "";
message = ''
programs.pay-respects.aiIntegration is configured as a submodule, but you have not configured a value for programs.pay-respects.aiIntegration.${attr}!
'';
})
[
"url"
"model"
];
environment = mkMerge (
[
{
systemPackages = [ cfg.package ];
systemPackages = [
(
if cfg.aiIntegration != true then
(pkgs.runCommand "pay-respects-wrapper"
{
nativeBuildInputs = [ pkgs.makeBinaryWrapper ];
}
''
mkdir -p $out/bin
makeWrapper ${getExe cfg.package} $out/bin/${cfg.package.meta.mainProgram} \
${optionalString cfg.aiIntegration == false "--set _PR_AI_DISABLE true"}
${optionalString cfg.aiIntegration != false "--set _PR_AI_URL ${cfg.aiIntegration.url}"}
${optionalString cfg.aiIntegration != false "--set _PR_AI_MODEL ${cfg.aiIntegration.model}"}
${optionalString cfg.aiIntegration != false "--set _PR_AI_LOCALE ${cfg.aiIntegration.locale}"}
''
)
else
cfg.package
)
];
}
]
++ map (rule: {
Expand Down

0 comments on commit 9966a1d

Please sign in to comment.