mirror of
https://codeberg.org/leana8959/.files.git
synced 2026-02-01 22:49:41 +00:00
packages/manage: drop
This commit is contained in:
parent
f90dd5bde6
commit
c7c529693f
4 changed files with 0 additions and 144 deletions
|
|
@ -1,10 +0,0 @@
|
|||
{
|
||||
haskellPackages,
|
||||
haskell,
|
||||
}:
|
||||
let
|
||||
inherit (haskell.lib.compose) justStaticExecutables;
|
||||
|
||||
drv = haskellPackages.callCabal2nix "manage" ./src { };
|
||||
in
|
||||
justStaticExecutables drv
|
||||
1
nix/packages/by-name/manage/src/.gitignore
vendored
1
nix/packages/by-name/manage/src/.gitignore
vendored
|
|
@ -1 +0,0 @@
|
|||
dist-newstyle/
|
||||
|
|
@ -1,112 +0,0 @@
|
|||
#!/usr/bin/env runhaskell
|
||||
{-# LANGUAGE LambdaCase #-}
|
||||
{-# LANGUAGE ViewPatterns #-}
|
||||
|
||||
import Control.Monad
|
||||
import System.Environment
|
||||
import System.Exit
|
||||
import System.IO
|
||||
import System.Process
|
||||
|
||||
-- Note: to type check this code
|
||||
-- `ghc manage.hs -Werror=all -fno-code'
|
||||
|
||||
main :: IO ()
|
||||
main = do
|
||||
let showHelpOr args elseDo =
|
||||
if "--help" `elem` args then putStr help
|
||||
else elseDo
|
||||
|
||||
getArgs >>= \case
|
||||
( "os" : host : action
|
||||
: (partitionArgs -> (manageArgs, extraArgs))
|
||||
) ->
|
||||
manageArgs `showHelpOr` do
|
||||
nixpkgs <- readNixpkgsPath
|
||||
exitWith =<< transparentProcess "nixos-rebuild" (action : nixosRebuildArgs nixpkgs host <> extraArgs)
|
||||
|
||||
( "install" : host
|
||||
: (partitionArgs -> (manageArgs, extraArgs))
|
||||
) ->
|
||||
manageArgs `showHelpOr` do
|
||||
nixpkgs <- readNixpkgsPath
|
||||
exitWith =<< transparentProcess "nixos-install" (nixosInstallArgs nixpkgs host <> extraArgs)
|
||||
|
||||
_ -> putStr help >> exitFailure
|
||||
|
||||
newtype StorePath = StorePath { unStorePath :: String }
|
||||
|
||||
defaultNixosCmdArgs :: StorePath -> String -> [String]
|
||||
defaultNixosCmdArgs (unStorePath -> nixpkgsPath) hostname =
|
||||
[ "-I", "nixpkgs=" <> nixpkgsPath
|
||||
, "-I", "nixos-config=./nix/configurations/" <> hostname <> ".nix"
|
||||
, "--file", "./default.nix"
|
||||
, "--attr", "nixosConfigurations." <> hostname
|
||||
]
|
||||
|
||||
nixosInstallArgs :: StorePath -> String -> [String]
|
||||
nixosInstallArgs = defaultNixosCmdArgs
|
||||
|
||||
nixosRebuildArgs :: StorePath -> String -> [String]
|
||||
nixosRebuildArgs =
|
||||
defaultNixosCmdArgs
|
||||
-- This is not a nixos-install flag
|
||||
<> (\_ _ -> ["--no-reexec"])
|
||||
|
||||
help :: String
|
||||
help =
|
||||
unlines
|
||||
[ "Manage.hs"
|
||||
, ""
|
||||
, "Manage.hs is a thin wrapper to make nixos-{install,rebuild} easier to use."
|
||||
, "Black lives matter. Trans rights are human rights. No nazi bullsh*t."
|
||||
, ""
|
||||
, "Available commands:"
|
||||
, indent "os <hostname> <action>:" <> indent "run perhost action with nixos-rebuild"
|
||||
, indent "install <hostname>:" <> indent "run perhost action with nixos-install"
|
||||
, indent "--help:" <> indent "show this help menu"
|
||||
]
|
||||
where indent = ("\t" <>)
|
||||
|
||||
partitionArgs :: [String] -> ([String], [String])
|
||||
partitionArgs = finalize . span (/= "--")
|
||||
where finalize (xs, ys) = (xs, drop 1 ys)
|
||||
|
||||
quote :: String -> String
|
||||
quote x = "\"" <> x <> "\""
|
||||
|
||||
-- https://stackoverflow.com/a/70162369
|
||||
blueForeground :: String -> String
|
||||
blueForeground x = "\ESC[34m" <> x <> "\ESC[0m"
|
||||
|
||||
-- |
|
||||
-- Run with a shared std{in,out,err}
|
||||
transparentProcess :: String -> [String] -> IO ExitCode
|
||||
transparentProcess cmdName args = do
|
||||
hPutStrLn stderr
|
||||
$ "Executing: " <> (quote . blueForeground) (showCommandForUser cmdName args)
|
||||
(_, _, _, pid) <- createProcess
|
||||
( proc cmdName args
|
||||
) { std_in = UseHandle stdin
|
||||
, std_out = UseHandle stdout
|
||||
, std_err = UseHandle stderr
|
||||
}
|
||||
waitForProcess pid
|
||||
|
||||
readProcessFriendly :: String -> [String] -> String -> IO String
|
||||
readProcessFriendly cmdName args inp = do
|
||||
hPutStrLn stderr
|
||||
$ "Executing: " <> (quote . blueForeground) (showCommandForUser cmdName args)
|
||||
readProcess cmdName args inp
|
||||
|
||||
readNixpkgsPath :: IO StorePath
|
||||
readNixpkgsPath =
|
||||
StorePath . clean <$> readProcessFriendly
|
||||
"nix-instantiate"
|
||||
[ "--eval"
|
||||
, "-E"
|
||||
, "let sources = import ./npins; in sources.nixpkgs.outPath"
|
||||
]
|
||||
""
|
||||
where
|
||||
clean = filter (\c -> c /= '\n' && c /= '"')
|
||||
|
|
@ -1,21 +0,0 @@
|
|||
cabal-version: 3.0
|
||||
name: manage
|
||||
version: 0.1.0.0
|
||||
description: NixOS Helper
|
||||
author: Léana 江
|
||||
maintainer: leana.jiang+git@icloud.com
|
||||
build-type: Simple
|
||||
|
||||
common common
|
||||
ghc-options:
|
||||
-Wall -Wcompat -Widentities -Wincomplete-record-updates
|
||||
-Wincomplete-patterns -Wincomplete-uni-patterns
|
||||
-Wredundant-constraints -Werror=missing-fields
|
||||
build-depends: base
|
||||
default-language: Haskell2010
|
||||
|
||||
executable manage
|
||||
import: common
|
||||
main-is: ./Main.hs
|
||||
build-depends:
|
||||
process
|
||||
Loading…
Add table
Add a link
Reference in a new issue