think
This commit is contained in:
parent
4fb8253e57
commit
a9ddd78482
92
THOUGHTS.txt
92
THOUGHTS.txt
@ -5564,9 +5564,97 @@ but the necessary rules for escaping might vary. How about
|
|||||||
having shell() or json() or ? (what else? html?) functions that
|
having shell() or json() or ? (what else? html?) functions that
|
||||||
format and escape per the encoding rules for that language?
|
format and escape per the encoding rules for that language?
|
||||||
|
|
||||||
myenv = {
|
|
||||||
|
|
||||||
|
|
||||||
string.gsub(template_string, "%{%[.-%]%}", function(x)
|
string.gsub(template_string, "%{%[.-%]%}", function(x)
|
||||||
load(x, x, "t", myenv)
|
load(x, x, "t", myenv)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Sat Aug 10 23:43:15 BST 2024
|
||||||
|
|
||||||
|
Every service that can be configured with secrets (at least, that uses
|
||||||
|
a configuration file) will need to be altered to interpolate at
|
||||||
|
startup
|
||||||
|
|
||||||
|
Any service that passes params on the command line may be able to
|
||||||
|
use the "$(output " syntax still, but it does feel brittle (it always did)
|
||||||
|
|
||||||
|
will we see any kind of pattern emerge so that we can provide
|
||||||
|
secrets-interpolation for config files in one place instead of
|
||||||
|
everywhere?
|
||||||
|
|
||||||
|
svc.secret-watcher.build {
|
||||||
|
source = config.services.secret-service;
|
||||||
|
watch = ["wlan" "telent5"];
|
||||||
|
service = svc.hostapd.build {
|
||||||
|
params = {
|
||||||
|
# ....
|
||||||
|
wpa_passphrase = "{{ $(output secret-watcher "wlan/telent5/wpa_passphrase")";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
how does the watcher communicate to the inner service that it needs secrets
|
||||||
|
from x place?
|
||||||
|
|
||||||
|
svc.secret-watcher.build {
|
||||||
|
source = config.services.secret-service;
|
||||||
|
watch = "wlan/telent5";
|
||||||
|
service = svc.hostapd.build {
|
||||||
|
secrets = config.services.secret-service;
|
||||||
|
params = {
|
||||||
|
# ....
|
||||||
|
wpa_passphrase = "{{ $(output secret-watcher "wlan/telent5/wpa_passphrase")";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
or something like
|
||||||
|
|
||||||
|
let
|
||||||
|
secret = name: get-output config.services.secret-service name;
|
||||||
|
in svc.secret-watcher.build {
|
||||||
|
watch = "wlan/telent5";
|
||||||
|
service = svc.hostapd.build {
|
||||||
|
params = {
|
||||||
|
# ....
|
||||||
|
wpa_passphrase = secret "wlan/telent5/wpa_passphrase";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
which is transformed into some kind of attrset that the service can
|
||||||
|
interrogate and figure out how to interpolate? this would be an improvement
|
||||||
|
as the knowledge of what kind of quoting to use is within the service
|
||||||
|
|
||||||
|
A reasonable question would be what happens if we reference outputs
|
||||||
|
from more than one service. Honestly I'd be happy to not support it
|
||||||
|
but it's made quite easy by this form of syntax
|
||||||
|
|
||||||
|
Mon Aug 12 19:42:48 BST 2024
|
||||||
|
|
||||||
|
what about if when we build the output template we'd have something
|
||||||
|
like this:
|
||||||
|
|
||||||
|
wpa_passphrase={{
|
||||||
|
json_quote(output("/nix/store/eeeee-servicename/.outputs", "foo/bar"))
|
||||||
|
}}
|
||||||
|
|
||||||
|
which it will get partly from its own knowledge and partly from
|
||||||
|
the thing that called it
|
||||||
|
|
||||||
|
|
||||||
|
let
|
||||||
|
literal_or_output = o:
|
||||||
|
if builtins.typeOf(o) == "string"
|
||||||
|
then builtins.toJSON o
|
||||||
|
else "output(${builtins.toJSON o.service}, ${builtins.toJSON o.path})"
|
||||||
|
in
|
||||||
|
''
|
||||||
|
wpa_passphrase={{
|
||||||
|
json_quote(${literal_or_output(wpa_passphrase)$})
|
||||||
|
}}
|
||||||
|
''
|
||||||
|
|
||||||
|
builtins.toJSON is not the "correct" quoting regime for Lua strings,
|
||||||
|
but it's sufficient for printable ascii, and using unprintable
|
||||||
|
characters in Nix strings is asking for trouble in the first place
|
||||||
|
Loading…
Reference in New Issue
Block a user