summaryrefslogtreecommitdiff
path: root/modules/shared
diff options
context:
space:
mode:
authorseth <[email protected]>2023-08-23 21:13:01 -0400
committerseth <[email protected]>2023-08-24 04:21:43 -0400
commitf324d84bc86db1b4b81c447f536adc24f7731578 (patch)
tree9322d9911330ad1a2483d3809f5aae0b62a6c918 /modules/shared
parent29041baea2a5182281c7d4f0d50ab5d9c4c517aa (diff)
modules: merge some nixos/darwin modules
Diffstat (limited to 'modules/shared')
-rw-r--r--modules/shared/base/default.nix8
-rw-r--r--modules/shared/base/documentation.nix14
-rw-r--r--modules/shared/base/locale.nix14
-rw-r--r--modules/shared/base/nix.nix26
-rw-r--r--modules/shared/base/packages.nix21
-rw-r--r--modules/shared/default.nix5
6 files changed, 88 insertions, 0 deletions
diff --git a/modules/shared/base/default.nix b/modules/shared/base/default.nix
new file mode 100644
index 0000000..e18de58
--- /dev/null
+++ b/modules/shared/base/default.nix
@@ -0,0 +1,8 @@
+_: {
+ imports = [
+ ./documentation.nix
+ ./locale.nix
+ ./nix.nix
+ ./packages.nix
+ ];
+}
diff --git a/modules/shared/base/documentation.nix b/modules/shared/base/documentation.nix
new file mode 100644
index 0000000..ecc5813
--- /dev/null
+++ b/modules/shared/base/documentation.nix
@@ -0,0 +1,14 @@
+{
+ config,
+ lib,
+ ...
+}: let
+ cfg = config.base.documentation;
+ inherit (lib) mkEnableOption mkIf;
+in {
+ options.base.documentation.enable = mkEnableOption "base module documentation";
+
+ config = mkIf cfg.enable {
+ documentation.man.enable = true;
+ };
+}
diff --git a/modules/shared/base/locale.nix b/modules/shared/base/locale.nix
new file mode 100644
index 0000000..ecae786
--- /dev/null
+++ b/modules/shared/base/locale.nix
@@ -0,0 +1,14 @@
+{
+ config,
+ lib,
+ ...
+}: let
+ cfg = config.base.defaultLocale;
+ inherit (lib) mkEnableOption mkIf;
+in {
+ options.base.defaultLocale.enable = mkEnableOption "default locale";
+
+ config = mkIf cfg.enable {
+ time.timeZone = "America/New_York";
+ };
+}
diff --git a/modules/shared/base/nix.nix b/modules/shared/base/nix.nix
new file mode 100644
index 0000000..21af0e0
--- /dev/null
+++ b/modules/shared/base/nix.nix
@@ -0,0 +1,26 @@
+{
+ config,
+ lib,
+ pkgs,
+ ...
+}: let
+ cfg = config.base.nix-settings;
+ inherit (lib) mkDefault mkEnableOption mkIf;
+ inherit (pkgs.stdenv) isLinux;
+in {
+ options.base.nix-settings.enable = mkEnableOption "base nix settings";
+
+ config = mkIf cfg.enable {
+ nix = {
+ settings = {
+ auto-optimise-store = isLinux;
+ experimental-features = ["nix-command" "flakes" "auto-allocate-uids" "repl-flake"];
+ };
+
+ gc = {
+ automatic = mkDefault true;
+ options = mkDefault "--delete-older-than 7d";
+ };
+ };
+ };
+}
diff --git a/modules/shared/base/packages.nix b/modules/shared/base/packages.nix
new file mode 100644
index 0000000..38cd6e7
--- /dev/null
+++ b/modules/shared/base/packages.nix
@@ -0,0 +1,21 @@
+{
+ config,
+ lib,
+ pkgs,
+ ...
+}: let
+ cfg = config.base.defaultPackages;
+ inherit (lib) mkEnableOption mkIf;
+in {
+ options.base.defaultPackages.enable = mkEnableOption "base module default packages";
+
+ config = mkIf cfg.enable {
+ environment.systemPackages = with pkgs; [
+ python311
+ ];
+
+ programs = {
+ gnupg.agent.enable = true;
+ };
+ };
+}
diff --git a/modules/shared/default.nix b/modules/shared/default.nix
new file mode 100644
index 0000000..0199860
--- /dev/null
+++ b/modules/shared/default.nix
@@ -0,0 +1,5 @@
+_: {
+ imports = [
+ ./base
+ ];
+}