code-remote
This commit is contained in:
parent
18488deb72
commit
a44486650a
|
@ -1,25 +1,29 @@
|
||||||
{ config, pkgs, lib, inputs, ... }:
|
{ config, pkgs, lib, inputs, ... }:
|
||||||
|
|
||||||
# TODO:
|
# TODO:
|
||||||
# * [x] generate a ssh key if not existing
|
# * [x] ~~generate a ssh key if not existing~~
|
||||||
# * [ ] automatically pull the repo on boot, do i need keys for that?
|
# * [ ] prompt to make a token using 'gh'?
|
||||||
|
# * [ ] possibly store some key using nix-sops
|
||||||
|
# * [ ] automatically pull the repo on first boot
|
||||||
# * [ ] customize the shit out of vscode
|
# * [ ] customize the shit out of vscode
|
||||||
# * [ ] don't ignore PDFs
|
# * [ ] don't ignore PDFs
|
||||||
|
# * [ ] fix the taskrunner
|
||||||
|
# * [ ] fix the markdown preview not opening when prompted
|
||||||
# * [ ] run the whole thing in a xvfb? should enable drawio and curv
|
# * [ ] run the whole thing in a xvfb? should enable drawio and curv
|
||||||
|
# * [ ] switch to openvscode-server? https://sourcegraph.com/github.com/bendlas/nixos-config/-/blob/code-server.container.nix?L39%3A26=
|
||||||
|
|
||||||
|
# https://github.com/coder/code-server/discussions/4267
|
||||||
|
|
||||||
let
|
let
|
||||||
domain = "${config.networking.hostName}.${config.networking.domain}";
|
|
||||||
mkDomain = subname: "${subname}.${domain}";
|
|
||||||
hostName = config.networking.hostName;
|
hostName = config.networking.hostName;
|
||||||
|
subdomain = "code-server.${config.networking.fqdn}";
|
||||||
container-name = "code-server-pandoc-papers";
|
container-name = "code-server-pandoc-papers";
|
||||||
container = config.containers.${container-name}.config;
|
container = config.containers.${container-name}.config;
|
||||||
in {
|
in {
|
||||||
networking.nat = {
|
networking.nat.enable = true;
|
||||||
enable = true;
|
networking.nat.internalInterfaces = ["ve-+"];
|
||||||
internalInterfaces = ["ve-+"];
|
networking.nat.externalInterface = "eno1"; # TODO: can i make this automatic?
|
||||||
externalInterface = "eno1"; # TODO: can i make this automatic?
|
#networking.nat.enableIPv6 = true;
|
||||||
#enableIPv6 = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
#imports = [
|
#imports = [
|
||||||
# "/home/pbsds/repos/nixpkgs-trees/containers-mkdir/nixos/modules/virtualisation/nixos-containers.nix"
|
# "/home/pbsds/repos/nixpkgs-trees/containers-mkdir/nixos/modules/virtualisation/nixos-containers.nix"
|
||||||
|
@ -37,30 +41,21 @@ in {
|
||||||
hostAddress = "10.240.100.2";
|
hostAddress = "10.240.100.2";
|
||||||
localAddress = "10.240.100.3";
|
localAddress = "10.240.100.3";
|
||||||
|
|
||||||
#forwardPorts = [
|
|
||||||
# {
|
|
||||||
# #hostAddress = "127.0.0.1"; # does not exist
|
|
||||||
# hostPort = 53754;
|
|
||||||
# containerPort = 53754;
|
|
||||||
# protocol = "tcp";
|
|
||||||
# }
|
|
||||||
#];
|
|
||||||
|
|
||||||
#bindMounts."/home" = {
|
|
||||||
# hostPath = "/var/lib/code-server";
|
|
||||||
# isReadOnly = false;
|
|
||||||
#};
|
|
||||||
config = { config, pkgs, lib, ... }: {
|
config = { config, pkgs, lib, ... }: {
|
||||||
system.stateVersion = "22.11";
|
system.stateVersion = "22.11";
|
||||||
|
|
||||||
#imports = [ <home-manager/nixos> ];
|
imports = [ inputs.home-manager.nixosModule ];
|
||||||
#home-manager.useGlobalPkgs = true; # brrr
|
home-manager.useGlobalPkgs = true; # brrr
|
||||||
#home-manager.useUserPackages = true; # requiredm installs user packages to /etc instead of ~/.nix-profile
|
home-manager.useUserPackages = true; # required, installs user packages to /etc instead of ~/.nix-profile
|
||||||
#home-manager.users.${config.services.code-server.user} = { pkgs, config, ... }: {
|
home-manager.users.${config.services.code-server.user} = { pkgs, config, ... }: {
|
||||||
# programs.git.enable = true;
|
home.stateVersion = "22.11";
|
||||||
# programs.git.userName = "Noximilien code-server";
|
programs.git.enable = true;
|
||||||
# programs.git.userEmail = "theotheo@ntnu.no";
|
programs.git.userName = "code-server";
|
||||||
#};
|
programs.git.userEmail = "pbsds@hotmail.com";
|
||||||
|
#programs.vscode.extensions
|
||||||
|
#programs.vscode.bindings
|
||||||
|
#programs.vscode.userSettings
|
||||||
|
};
|
||||||
|
|
||||||
systemd.services.initial-setup = {
|
systemd.services.initial-setup = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
@ -86,10 +81,16 @@ in {
|
||||||
test -d "$HOME/repo" || (
|
test -d "$HOME/repo" || (
|
||||||
set -x
|
set -x
|
||||||
cp -a ${inputs.pbsds-papers.outPath} "$HOME/repo"
|
cp -a ${inputs.pbsds-papers.outPath} "$HOME/repo"
|
||||||
chmod -R a+w "$HOME/repo"
|
chmod -R +w "$HOME/repo"
|
||||||
|
)
|
||||||
|
test -e "$HOME/repo/neural-intersection-fields/.vscode" || (
|
||||||
cd "$HOME/repo/neural-intersection-fields"
|
cd "$HOME/repo/neural-intersection-fields"
|
||||||
ln -s ../.vscode .
|
ln -s ../.vscode .
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if test -d "$HOME/repo/.git"; then
|
||||||
|
( cd $HOME/repo; git pull --rebase --autostash ) # TODO: somehow rollback if failed
|
||||||
|
fi
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -114,11 +115,11 @@ in {
|
||||||
passthru.executableName = "code-server";
|
passthru.executableName = "code-server";
|
||||||
passthru.longName = "Visual Studio Code Server";
|
passthru.longName = "Visual Studio Code Server";
|
||||||
});
|
});
|
||||||
#vscodeExtensions = with (import <nixos-unstable> {}).vscode-extensions; [
|
#vscodeExtensions = with pkgs.unstable.vscode-extensions; [
|
||||||
vscodeExtensions = with pkgs.vscode-extensions; [
|
vscodeExtensions = with pkgs.vscode-extensions; [
|
||||||
shd101wyy.markdown-preview-enhanced
|
shd101wyy.markdown-preview-enhanced
|
||||||
sanaajani.taskrunnercode
|
sanaajani.taskrunnercode # doesn't work?
|
||||||
tomoki1207.pdf
|
tomoki1207.pdf # no firefox?
|
||||||
] ++ pkgs.vscode-utils.extensionsFromVscodeMarketplace [
|
] ++ pkgs.vscode-utils.extensionsFromVscodeMarketplace [
|
||||||
{
|
{
|
||||||
name = "new-railscasts";
|
name = "new-railscasts";
|
||||||
|
@ -164,25 +165,28 @@ in {
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
extraPackages = let
|
extraPackages = (with pkgs; [
|
||||||
shellnix = import "${inputs.pbsds-papers}/shell.nix" { inherit pkgs; };
|
git gh hub
|
||||||
in (with pkgs; [ imagemagick ]) # for some reason it isn't passed from shell.nix
|
micro
|
||||||
++ shellnix.buildInputs
|
]) ++ (let
|
||||||
++ shellnix.nativeBuildInputs
|
shell = import "${inputs.pbsds-papers}/shell.nix" { inherit pkgs; };
|
||||||
++ shellnix.propagatedBuildInputs
|
in
|
||||||
++ shellnix.propagatedNativeBuildInputs;
|
(with pkgs; [ imagemagick librsvg ]) # for some reason it isn't picked up from from shell.nix?
|
||||||
|
++ shell.buildInputs
|
||||||
|
++ shell.nativeBuildInputs
|
||||||
|
++ shell.propagatedBuildInputs
|
||||||
|
++ shell.propagatedNativeBuildInputs
|
||||||
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
networking.firewall = {
|
networking.firewall.enable = true;
|
||||||
enable = true;
|
networking.firewall.allowedTCPPorts = [
|
||||||
allowedTCPPorts = [
|
|
||||||
config.services.code-server.port
|
config.services.code-server.port
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
|
||||||
|
|
||||||
services.nginx.virtualHosts.${mkDomain "code-server"} = {
|
services.nginx.virtualHosts.${subdomain} = {
|
||||||
forceSSL = true; # addSSL = true;
|
forceSSL = true; # addSSL = true;
|
||||||
enableACME = true; #useACMEHost = acmeDomain;
|
enableACME = true; #useACMEHost = acmeDomain;
|
||||||
locations."/" = {
|
locations."/" = {
|
||||||
|
|
Loading…
Reference in New Issue