(untested) http basic auth for outboard secrets
This commit is contained in:
parent
b56f121e04
commit
fe7b092075
@ -68,6 +68,8 @@ in rec {
|
|||||||
services.secrets = svc.secrets.outboard.build {
|
services.secrets = svc.secrets.outboard.build {
|
||||||
name = "secret-service";
|
name = "secret-service";
|
||||||
url = "http://10.0.0.1/liminix/examples/real-secrets.json";
|
url = "http://10.0.0.1/liminix/examples/real-secrets.json";
|
||||||
|
username = "demo";
|
||||||
|
password = "demo";
|
||||||
interval = 5;
|
interval = 5;
|
||||||
dependencies = [ services.wan-address-for-secrets ];
|
dependencies = [ services.wan-address-for-secrets ];
|
||||||
};
|
};
|
||||||
|
@ -26,6 +26,15 @@ in {
|
|||||||
description = "source url";
|
description = "source url";
|
||||||
type = types.strMatching "https?://.*";
|
type = types.strMatching "https?://.*";
|
||||||
};
|
};
|
||||||
|
username = mkOption {
|
||||||
|
description = "username for HTTP basic auth";
|
||||||
|
type = types.nullOr types.str;
|
||||||
|
};
|
||||||
|
password = mkOption {
|
||||||
|
description = "password for HTTP basic auth";
|
||||||
|
type = types.nullOr types.str;
|
||||||
|
};
|
||||||
|
|
||||||
name = mkOption {
|
name = mkOption {
|
||||||
description = "service name";
|
description = "service name";
|
||||||
type = types.str;
|
type = types.str;
|
||||||
|
@ -1,14 +1,19 @@
|
|||||||
{
|
{
|
||||||
liminix, lib, json-to-fstree, serviceFns
|
liminix, lib, json-to-fstree, serviceFns
|
||||||
}:
|
}:
|
||||||
{ name, url, interval } :
|
{ name, url, interval, username, password } :
|
||||||
let
|
let
|
||||||
inherit (liminix.services) oneshot longrun;
|
inherit (liminix.services) oneshot longrun;
|
||||||
|
inherit (lib) optionalString;
|
||||||
in longrun {
|
in longrun {
|
||||||
inherit name;
|
inherit name;
|
||||||
buildInputs = [ json-to-fstree ];
|
buildInputs = [ json-to-fstree ];
|
||||||
run = ''
|
run = ''
|
||||||
. ${serviceFns}
|
. ${serviceFns}
|
||||||
|
${optionalString (username != null) ''
|
||||||
|
export NETRC=$(mkstate ${name})/netrc
|
||||||
|
(echo default ; echo login ${username} ; echo password ${password} ) > $NETRC
|
||||||
|
''}
|
||||||
( in_outputs ${name}
|
( in_outputs ${name}
|
||||||
while : ; do
|
while : ; do
|
||||||
${json-to-fstree}/bin/json-to-fstree ${url} .
|
${json-to-fstree}/bin/json-to-fstree ${url} .
|
||||||
|
Loading…
Reference in New Issue
Block a user