-
Notifications
You must be signed in to change notification settings - Fork 25
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Rekeying zero secrets leads to error #37
Comments
I encountered the same error just after setting up a new host and trying to rekey. |
I've moved the directory creation to an earlier point in the script now, can you confirm whether this solves your issue? |
I updated agenix-rekey, removed the directory and ran agenix-rekey. It still failed unless I manually recreated the directory. |
The error comes from Nix itself due to this option: { nix.settings.extra-sandbox-paths = ["/tmp/agenix-rekey"]; } The error comes even when I'm doing nothing related to agenix, because on the current boot I haven't yet created the directory. Btw, could you somehow make the derivation hashes only dependent on the rekey target's system and public key and the encrypted secret, and fabricate it without using extra-sandbox-paths? Like a fetching from a custom store? Is there a way to do it without using trusted-users? |
Ah so I guess the real solution is that you'll have to add a
It already is only dependent on the things you write, otherwise you couldn't reproduce the same system from another machine (which you can). But there is no way to do it without sandbox paths, because rekeying is fundamentally impure, and we need a way to allow this impurity in nix. There's a section in the readme detailing this. The other solution is to use local storage mode, which doesn't have this limitation. I introduced it primarily to get rid of this sandboxing and some other things that don't always play nice with nix. But here we also need to get the rekeyed secrets into nix somehow, so it requires you to store them locally in a subfolder of the flake's git repository. |
This is because
rekeyedSecrets.cacheDir
is never mkdir'd if no secrets are rekeyed (no secrets exist or all are skipped).The text was updated successfully, but these errors were encountered: