From 5aaffa6e32f9cfaf5c5fda588ce01c04a58fa580 Mon Sep 17 00:00:00 2001 From: Graham Christensen Date: Wed, 13 Nov 2024 17:33:50 -0500 Subject: [PATCH] Log in to flakehub if the machine is already installed --- dist/index.js | 21 ++++++++++++++------- src/index.ts | 26 ++++++++++++++++++-------- 2 files changed, 32 insertions(+), 15 deletions(-) diff --git a/dist/index.js b/dist/index.js index 0613d9d..0846373 100644 --- a/dist/index.js +++ b/dist/index.js @@ -102679,6 +102679,9 @@ ${stderrBuffer}` ); await this.executeUninstall(); } else { + if (this.determinate) { + await this.flakehubLogin(); + } await this.setGithubPath(); core.info("Nix was already installed, using existing install"); return; @@ -102893,13 +102896,17 @@ ${stderrBuffer}` } async setGithubPath() { try { - const nixVarNixProfilePath = "/nix/var/nix/profiles/default/bin"; - const homeNixProfilePath = `${process.env["HOME"]}/.nix-profile/bin`; - core.addPath(nixVarNixProfilePath); - core.addPath(homeNixProfilePath); - core.info( - `Added \`${nixVarNixProfilePath}\` and \`${homeNixProfilePath}\` to \`$GITHUB_PATH\`` - ); + const paths = [ + "/nix/var/nix/profiles/default/bin", + `${process.env["HOME"]}/.nix-profile/bin` + ]; + if (this.determinate) { + paths.push("/usr/local/bin"); + } + for (const p of paths) { + core.addPath(p); + core.debug(`Added \`${p}\` to \`$GITHUB_PATH\``); + } } catch { core.info( "Skipping setting $GITHUB_PATH in action, the `nix-installer` crate seems to have done this already. From `nix-installer` version 0.11.0 and up, this step is done in the action. Prior to 0.11.0, this was only done in the `nix-installer` binary." diff --git a/src/index.ts b/src/index.ts index 78d21ce..5ed2240 100644 --- a/src/index.ts +++ b/src/index.ts @@ -614,7 +614,11 @@ class NixInstallerAction extends DetSysAction { ); await this.executeUninstall(); } else { - // We're already installed, and not reinstalling, just set GITHUB_PATH and finish early + // We're already installed, and not reinstalling, just log in to FlakeHub, set GITHUB_PATH and finish early + if (this.determinate) { + await this.flakehubLogin(); + } + await this.setGithubPath(); actionsCore.info("Nix was already installed, using existing install"); return; @@ -859,13 +863,19 @@ class NixInstallerAction extends DetSysAction { async setGithubPath(): Promise { // Interim versions of the `nix-installer` crate may have already manipulated `$GITHUB_PATH`, as root even! Accessing that will be an error. try { - const nixVarNixProfilePath = "/nix/var/nix/profiles/default/bin"; - const homeNixProfilePath = `${process.env["HOME"]}/.nix-profile/bin`; - actionsCore.addPath(nixVarNixProfilePath); - actionsCore.addPath(homeNixProfilePath); - actionsCore.info( - `Added \`${nixVarNixProfilePath}\` and \`${homeNixProfilePath}\` to \`$GITHUB_PATH\``, - ); + const paths = [ + "/nix/var/nix/profiles/default/bin", + `${process.env["HOME"]}/.nix-profile/bin`, + ]; + + if (this.determinate) { + paths.push("/usr/local/bin"); + } + + for (const p of paths) { + actionsCore.addPath(p); + actionsCore.debug(`Added \`${p}\` to \`$GITHUB_PATH\``); + } } catch { actionsCore.info( "Skipping setting $GITHUB_PATH in action, the `nix-installer` crate seems to have done this already. From `nix-installer` version 0.11.0 and up, this step is done in the action. Prior to 0.11.0, this was only done in the `nix-installer` binary.",