2023-09-29 13:04:57 +02:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.programs.awscli;
|
|
|
|
iniFormat = pkgs.formats.ini { };
|
|
|
|
|
|
|
|
in {
|
|
|
|
meta.maintainers = [ lib.maintainers.anthonyroussel ];
|
|
|
|
|
|
|
|
options.programs.awscli = {
|
|
|
|
enable = lib.mkEnableOption "AWS CLI tool";
|
|
|
|
|
|
|
|
package = lib.mkOption {
|
|
|
|
type = lib.types.package;
|
|
|
|
default = pkgs.awscli2;
|
|
|
|
defaultText = lib.literalExpression "pkgs.awscli2";
|
|
|
|
description = "Package providing {command}`aws`.";
|
|
|
|
};
|
|
|
|
|
|
|
|
settings = lib.mkOption {
|
|
|
|
type = lib.types.submodule { freeformType = iniFormat.type; };
|
|
|
|
default = { };
|
|
|
|
example = lib.literalExpression ''
|
|
|
|
{
|
|
|
|
"default" = {
|
|
|
|
region = "eu-west-3";
|
|
|
|
output = "json";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
'';
|
|
|
|
description = "Configuration written to {file}`$HOME/.aws/config`.";
|
|
|
|
};
|
|
|
|
|
|
|
|
credentials = lib.mkOption {
|
|
|
|
type = lib.types.submodule { freeformType = iniFormat.type; };
|
|
|
|
default = { };
|
|
|
|
example = lib.literalExpression ''
|
|
|
|
{
|
|
|
|
"default" = {
|
|
|
|
"credential_process" = "${pkgs.pass}/bin/pass show aws";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
'';
|
|
|
|
description = ''
|
|
|
|
Configuration written to {file}`$HOME/.aws/credentials`.
|
|
|
|
|
|
|
|
For security reasons, never store cleartext passwords here.
|
|
|
|
We recommend that you use `credential_process` option to retrieve
|
|
|
|
the IAM credentials from your favorite password manager during runtime,
|
|
|
|
or use AWS IAM Identity Center to get short-term credentials.
|
|
|
|
|
|
|
|
See <https://docs.aws.amazon.com/cli/latest/userguide/cli-chap-authentication.html>.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
home.packages = [ cfg.package ];
|
|
|
|
|
2023-12-13 00:21:10 +01:00
|
|
|
home.file."${config.home.homeDirectory}/.aws/config" =
|
|
|
|
lib.mkIf (cfg.settings != { }) {
|
|
|
|
source =
|
|
|
|
iniFormat.generate "aws-config-${config.home.username}" cfg.settings;
|
|
|
|
};
|
2023-09-29 13:04:57 +02:00
|
|
|
|
2023-12-13 00:21:10 +01:00
|
|
|
home.file."${config.home.homeDirectory}/.aws/credentials" =
|
|
|
|
lib.mkIf (cfg.credentials != { }) {
|
|
|
|
source = iniFormat.generate "aws-credentials-${config.home.username}"
|
|
|
|
cfg.credentials;
|
|
|
|
};
|
2023-09-29 13:04:57 +02:00
|
|
|
};
|
|
|
|
}
|