diff --git a/hosts/hetzner-arm/hetzner-arm.nix b/hosts/hetzner-arm/hetzner-arm.nix index f9361f0..064f7a5 100644 --- a/hosts/hetzner-arm/hetzner-arm.nix +++ b/hosts/hetzner-arm/hetzner-arm.nix @@ -34,8 +34,6 @@ in { ./secrets.nix ]); - # TODO: environment.noXlibs = true; - nixpkgs.overlays = [ (_final: prev: { # So we don't need to build all Vault diff --git a/hosts/home-manager.nix b/hosts/home-manager.nix index 51c5fc7..4cddcfa 100644 --- a/hosts/home-manager.nix +++ b/hosts/home-manager.nix @@ -22,8 +22,6 @@ defaultModules = [ tree.profiles.home-manager.base - - tree.modules.home.vscode-mod-module ]; pkgsFor = system: diff --git a/modules/home/vscode-mod-module.nix b/modules/home/vscode-mod-module.nix deleted file mode 100644 index 7b65edd..0000000 --- a/modules/home/vscode-mod-module.nix +++ /dev/null @@ -1,238 +0,0 @@ -{ - config, - lib, - pkgs, - ... -}: -with lib; let - cfg = config.programs.vscode-mod; - - vscodePname = cfg.package.pname; - - jsonFormat = pkgs.formats.json {}; - - configDir = - { - "vscode" = "Code"; - "vscode-insiders" = "Code - Insiders"; - "vscodium" = "VSCodium"; - } - .${vscodePname}; - - extensionDir = - { - "vscode" = "vscode"; - "vscode-insiders" = "vscode-insiders"; - "vscodium" = "vscode-oss"; - } - .${vscodePname}; - - userDir = - if pkgs.stdenv.hostPlatform.isDarwin - then "Library/Application Support/${configDir}/User" - else "${config.xdg.configHome}/${configDir}/User"; - - configFilePath = "${userDir}/settings.json"; - tasksFilePath = "${userDir}/tasks.json"; - keybindingsFilePath = "${userDir}/keybindings.json"; - - # TODO: On Darwin where are the extensions? - extensionPath = ".${extensionDir}/extensions"; - - mergedUserSettings = - cfg.userSettings - // optionalAttrs (!cfg.enableUpdateCheck) {"update.mode" = "none";} - // optionalAttrs (!cfg.enableExtensionUpdateCheck) { - "extensions.autoCheckUpdates" = false; - }; -in { - options = { - programs.vscode-mod = { - enable = mkEnableOption "Visual Studio Code"; - - package = mkOption { - type = types.package; - default = pkgs.vscode; - example = literalExpression "pkgs.vscodium"; - description = '' - Version of Visual Studio Code to install. - ''; - }; - - enableUpdateCheck = mkOption { - type = types.bool; - default = true; - description = '' - Whether to enable update checks/notifications. - ''; - }; - - enableExtensionUpdateCheck = mkOption { - type = types.bool; - default = true; - description = '' - Whether to enable update notifications for extensions. - ''; - }; - - userSettings = mkOption { - inherit (jsonFormat) type; - default = {}; - example = literalExpression '' - { - "files.autoSave" = "off"; - "[nix]"."editor.tabSize" = 2; - } - ''; - description = '' - Configuration written to Visual Studio Code's - settings.json. - ''; - }; - - userTasks = mkOption { - inherit (jsonFormat) type; - default = {}; - example = literalExpression '' - { - version = "2.0.0"; - tasks = [ - { - type = "shell"; - label = "Hello task"; - command = "hello"; - } - ]; - } - ''; - description = '' - Configuration written to Visual Studio Code's - tasks.json. - ''; - }; - - keybindings = mkOption { - type = types.listOf (types.submodule { - options = { - key = mkOption { - type = types.str; - example = "ctrl+c"; - description = "The key or key-combination to bind."; - }; - - command = mkOption { - type = types.str; - example = "editor.action.clipboardCopyAction"; - description = "The VS Code command to execute."; - }; - - when = mkOption { - type = types.nullOr types.str; - default = null; - example = "textInputFocus"; - description = "Optional context filter."; - }; - - # https://code.visualstudio.com/docs/getstarted/keybindings#_command-arguments - args = mkOption { - type = types.nullOr jsonFormat.type; - default = null; - example = {direction = "up";}; - description = "Optional arguments for a command."; - }; - }; - }); - default = []; - example = literalExpression '' - [ - { - key = "ctrl+c"; - command = "editor.action.clipboardCopyAction"; - when = "textInputFocus"; - } - ] - ''; - description = '' - Keybindings written to Visual Studio Code's - keybindings.json. - ''; - }; - - extensions = mkOption { - type = types.listOf types.package; - default = []; - example = literalExpression "[ pkgs.vscode-extensions.bbenoist.nix ]"; - description = '' - The extensions Visual Studio Code should be started with. - ''; - }; - - mutableExtensionsDir = mkOption { - type = types.bool; - default = true; - example = false; - description = '' - Whether extensions can be installed or updated manually - or by Visual Studio Code. - ''; - }; - }; - }; - - config = mkIf cfg.enable { - home.packages = [cfg.package]; - - # make config changeable - home = { - activation = { - vscode-mod-copy = hm.dag.entryAfter ["writeBoundary"] '' - $DRY_RUN_CMD cat "${configFilePath}.source" > "${configFilePath}" - ''; - }; - }; - - home.file = mkMerge [ - (mkIf (mergedUserSettings != {}) { - # Don't install settings to actual config file path - # instead install to ${configFilePath}.source - "${configFilePath}.source".source = - jsonFormat.generate "vscode-user-settings" mergedUserSettings; - }) - - (mkIf (cfg.userTasks != {}) { - "${tasksFilePath}".source = - jsonFormat.generate "vscode-user-tasks" cfg.userTasks; - }) - (mkIf (cfg.keybindings != []) - (let - dropNullFields = filterAttrs (_: v: v != null); - in { - "${keybindingsFilePath}".source = - jsonFormat.generate "vscode-keybindings" - (map dropNullFields cfg.keybindings); - })) - (mkIf (cfg.extensions != []) (let - subDir = "share/vscode/extensions"; - - # Adapted from https://discourse.nixos.org/t/vscode-extensions-setup/1801/2 - toPaths = ext: - map (k: {"${extensionPath}/${k}".source = "${ext}/${subDir}/${k}";}) - ( - if ext ? vscodeExtUniqueId - then [ext.vscodeExtUniqueId] - else builtins.attrNames (builtins.readDir (ext + "/${subDir}")) - ); - in - if cfg.mutableExtensionsDir - then mkMerge (concatMap toPaths cfg.extensions) - else { - "${extensionPath}".source = let - combinedExtensionsDrv = pkgs.buildEnv { - name = "vscode-extensions"; - paths = cfg.extensions; - }; - in "${combinedExtensionsDrv}/${subDir}"; - })) - ]; - }; -} diff --git a/profiles/home-manager/programming/editors/vscode.nix b/profiles/home-manager/programming/editors/vscode.nix index 0dda812..e2b8c2b 100644 --- a/profiles/home-manager/programming/editors/vscode.nix +++ b/profiles/home-manager/programming/editors/vscode.nix @@ -2,7 +2,7 @@ home.sessionVariables = { DONT_PROMPT_WSL_INSTALL = 1; }; - programs.vscode-mod = { + programs.vscode = { enable = true; userSettings = { "terminal.integrated.shellIntegration.enabled" = false; diff --git a/profiles/home-manager/programming/languages/go.nix b/profiles/home-manager/programming/languages/go.nix index 9e5cc60..51da19a 100644 --- a/profiles/home-manager/programming/languages/go.nix +++ b/profiles/home-manager/programming/languages/go.nix @@ -1,4 +1,4 @@ {pkgs, ...}: { home.packages = with pkgs; [go gopls go-outline gotools]; - programs.vscode-mod.extensions = with pkgs; [vscode-extensions.golang.go]; + programs.vscode.extensions = with pkgs; [vscode-extensions.golang.go]; } diff --git a/profiles/home-manager/programming/languages/nix.nix b/profiles/home-manager/programming/languages/nix.nix index 0b1c222..42896ad 100644 --- a/profiles/home-manager/programming/languages/nix.nix +++ b/profiles/home-manager/programming/languages/nix.nix @@ -1,16 +1,16 @@ {pkgs, ...}: { home.packages = with pkgs; [alejandra deadnix statix]; - programs.vscode-mod.extensions = with pkgs; [ + programs.vscode.extensions = with pkgs; [ vscode-extensions.bbenoist.nix vscode-extensions.kamadorueda.alejandra ]; - programs.vscode-mod.userSettings."[nix]" = { + programs.vscode.userSettings."[nix]" = { "editor.defaultFormatter" = "kamadorueda.alejandra"; "editor.formatOnSave" = true; }; - programs.vscode-mod.userSettings = { + programs.vscode.userSettings = { "alejandra.program" = "alejandra"; }; diff --git a/profiles/home-manager/programming/languages/rust.nix b/profiles/home-manager/programming/languages/rust.nix index b33e400..1ad1f61 100644 --- a/profiles/home-manager/programming/languages/rust.nix +++ b/profiles/home-manager/programming/languages/rust.nix @@ -1,5 +1,5 @@ {pkgs, ...}: { - programs.vscode-mod.extensions = with pkgs; [vscode-extensions.rust-lang.rust-analyzer]; + programs.vscode.extensions = with pkgs; [vscode-extensions.rust-lang.rust-analyzer]; home.packages = with pkgs; [rustc cargo clippy rust-analyzer rustfmt]; home.sessionVariables = {RUST_SRC_PATH = pkgs.rustPlatform.rustLibSrc;}; } diff --git a/profiles/nixos/base/home.nix b/profiles/nixos/base/home.nix index 8010099..6372aaf 100644 --- a/profiles/nixos/base/home.nix +++ b/profiles/nixos/base/home.nix @@ -24,7 +24,7 @@ in { home-manager = { useGlobalPkgs = true; useUserPackages = true; - sharedModules = with tree; [modules.home.vscode-mod-module]; + sharedModules = with tree; []; }; systemd.tmpfiles.rules = mkIf config.boot.isContainer (flatten (forEach (builtins.attrNames config.home-manager.users) (user: [ "d /nix/var/nix/profiles/per-user/${user} - ${config.users.users."${user}".group} - - -" diff --git a/scripts/deploy/vault.sh b/scripts/deploy/vault.sh deleted file mode 100755 index 4927f21..0000000 --- a/scripts/deploy/vault.sh +++ /dev/null @@ -1,9 +0,0 @@ -#!/usr/bin/env bash - -SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd ) -cd $SCRIPT_DIR -cd $(git rev-parse --show-toplevel) - -DEFAULT_HOST="root@vault.servers.genderfucked.monster" -TARGET_HOST=${HOST:-${DEFAULT_HOST}} -nixos-rebuild switch --flake .#vault --target-host "$TARGET_HOST" --no-build-nix --fast --use-substitutes -s "$@" \ No newline at end of file