Skip to content

Commit

Permalink
darwin: Introduce home manager, configure ssh hosts
Browse files Browse the repository at this point in the history
  • Loading branch information
juanibiapina committed May 8, 2024
1 parent ae45beb commit 605335f
Show file tree
Hide file tree
Showing 4 changed files with 137 additions and 14 deletions.
45 changes: 33 additions & 12 deletions flake.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

17 changes: 15 additions & 2 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -33,13 +33,18 @@
inputs.nixpkgs.follows = "nixpkgs";
};

home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};

sub = {
url = "github:juanibiapina/sub";
inputs.nixpkgs.follows = "nixpkgs";
};
};

outputs = inputs@{ self, nixpkgs, nixpkgs_pcloud_working, neovim-nightly-overlay, nix-darwin, sub, systems, devenv, ... }: {
outputs = inputs@{ self, nixpkgs, nixpkgs_pcloud_working, neovim-nightly-overlay, nix-darwin, sub, systems, devenv, home-manager, ... }: {
nixosConfigurations.desktop = nixpkgs.lib.nixosSystem rec {
system = "x86_64-linux";

Expand Down Expand Up @@ -85,7 +90,15 @@
inherit self;
};

modules = [ ./nix/hosts/babbel/configuration.nix ];
modules = [
./nix/hosts/babbel/configuration.nix

home-manager.darwinModules.home-manager {
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.users.jibiapina = import ./nix/hosts/babbel/jibiapina.nix;
}
];
};

devShells = nixpkgs.lib.genAttrs (import systems) (system:
Expand Down
3 changes: 3 additions & 0 deletions nix/hosts/babbel/configuration.nix
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,9 @@
'';
};

# Configure user account
users.users.jibiapina.home = "/Users/jibiapina";

environment.systemPackages = with pkgs; [
(callPackage ../../packages/nvim.nix {})
vim
Expand Down
86 changes: 86 additions & 0 deletions nix/hosts/babbel/jibiapina.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
{ config, pkgs, ... }:

{
# Home Manager required configuration
home.username = "jibiapina";

# This value determines the Home Manager release that your configuration is
# compatible with. This helps avoid breakage when a new Home Manager release
# introduces backwards incompatible changes.
#
# You should not change this value, even if you update Home Manager. If you do
# want to update the value, then make sure to first check the Home Manager
# release notes.
home.stateVersion = "23.11"; # Please read the comment before changing.

# Configure ssh aliases
programs.ssh = {
enable = true;

extraConfig = ''
Host desktop
User juan
HostName 192.168.188.109
Host mini
User juan
HostName 192.168.188.30
'';
};

# The home.packages option allows you to install Nix packages into your
# environment.
home.packages = [
# # Adds the 'hello' command to your environment. It prints a friendly
# # "Hello, world!" when run.
# pkgs.hello

# # It is sometimes useful to fine-tune packages, for example, by applying
# # overrides. You can do that directly here, just don't forget the
# # parentheses. Maybe you want to install Nerd Fonts with a limited number of
# # fonts?
# (pkgs.nerdfonts.override { fonts = [ "FantasqueSansMono" ]; })

# # You can also create simple shell scripts directly inside your
# # configuration. For example, this adds a command 'my-hello' to your
# # environment:
# (pkgs.writeShellScriptBin "my-hello" ''
# echo "Hello, ${config.home.username}!"
# '')
];

# Home Manager is pretty good at managing dotfiles. The primary way to manage
# plain files is through 'home.file'.
home.file = {
# # Building this configuration will create a copy of 'dotfiles/screenrc' in
# # the Nix store. Activating the configuration will then make '~/.screenrc' a
# # symlink to the Nix store copy.
# ".screenrc".source = dotfiles/screenrc;

# # You can also set the file content immediately.
# ".gradle/gradle.properties".text = ''
# org.gradle.console=verbose
# org.gradle.daemon.idletimeout=3600000
# '';
};

# Home Manager can also manage your environment variables through
# 'home.sessionVariables'. These will be explicitly sourced when using a
# shell provided by Home Manager. If you don't want to manage your shell
# through Home Manager then you have to manually source 'hm-session-vars.sh'
# located at either
#
# ~/.nix-profile/etc/profile.d/hm-session-vars.sh
#
# or
#
# ~/.local/state/nix/profiles/profile/etc/profile.d/hm-session-vars.sh
#
# or
#
# /etc/profiles/per-user/jibiapina/etc/profile.d/hm-session-vars.sh
#
home.sessionVariables = {
# EDITOR = "emacs";
};
}

0 comments on commit 605335f

Please sign in to comment.