services/proxy: add proxy module
This commit is contained in:
parent
1260c1b4af
commit
ece6d46b5b
5 changed files with 47 additions and 28 deletions
|
@ -4,8 +4,6 @@
|
||||||
|
|
||||||
(with profiles; [
|
(with profiles; [
|
||||||
networking.wireless
|
networking.wireless
|
||||||
|
|
||||||
services.privoxy
|
|
||||||
])
|
])
|
||||||
|
|
||||||
./hardware-configuration.nix
|
./hardware-configuration.nix
|
||||||
|
@ -43,6 +41,9 @@
|
||||||
gpu.intel = true;
|
gpu.intel = true;
|
||||||
form.laptop = true;
|
form.laptop = true;
|
||||||
};
|
};
|
||||||
|
services = {
|
||||||
|
proxy.enable = true;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
networking.interfaces.wlp170s0.useDHCP = true;
|
networking.interfaces.wlp170s0.useDHCP = true;
|
||||||
|
|
|
@ -6,8 +6,6 @@
|
||||||
networking.wireless
|
networking.wireless
|
||||||
|
|
||||||
btrfs
|
btrfs
|
||||||
|
|
||||||
# services.privoxy
|
|
||||||
])
|
])
|
||||||
|
|
||||||
./hardware-configuration.nix
|
./hardware-configuration.nix
|
||||||
|
@ -22,6 +20,7 @@
|
||||||
audio.enable = true;
|
audio.enable = true;
|
||||||
form.portable = true;
|
form.portable = true;
|
||||||
};
|
};
|
||||||
|
services.proxy.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
system.stateVersion = "21.11";
|
system.stateVersion = "21.11";
|
||||||
|
|
|
@ -7,8 +7,6 @@
|
||||||
networking.wireless
|
networking.wireless
|
||||||
|
|
||||||
btrfs
|
btrfs
|
||||||
|
|
||||||
# services.privoxy
|
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -25,6 +23,9 @@
|
||||||
gpu.amdgpu = true;
|
gpu.amdgpu = true;
|
||||||
wireless.enable = true;
|
wireless.enable = true;
|
||||||
};
|
};
|
||||||
|
services = {
|
||||||
|
proxy.enable = true;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
networking.interfaces.wlan0.useDHCP = true;
|
networking.interfaces.wlan0.useDHCP = true;
|
||||||
|
|
40
modules/modules/services/proxy.nix
Normal file
40
modules/modules/services/proxy.nix
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
{ config, lib, ... }:
|
||||||
|
with lib;
|
||||||
|
with lib.hlissner;
|
||||||
|
let
|
||||||
|
cfg = config.modules.services.proxy;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.modules.services.proxy = {
|
||||||
|
enable = mkBoolOpt false;
|
||||||
|
listen-address = mkOpt types.str "localhost:8118";
|
||||||
|
forwards = {
|
||||||
|
ssh = mkBoolOpt true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkMerge [
|
||||||
|
(mkIf cfg.enable {
|
||||||
|
services = {
|
||||||
|
privoxy = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
enable-edit-actions = true;
|
||||||
|
forward-socks5 = mkIf cfg.forwards.ssh "/ 127.0.0.1:49494 .";
|
||||||
|
listen-address = cfg.listen-address;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
ssh-tunnel = mkIf cfg.forwards.ssh {
|
||||||
|
enable = true;
|
||||||
|
server = "infinidoge@server.doge-inc.net -p 245 -S none -i /home/infinidoge/.ssh/id_ed25519 -v";
|
||||||
|
requiredBy = [ "privoxy.service" ];
|
||||||
|
forwards.dynamic = [ 49494 ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
networking.proxy.default = cfg.listen-address;
|
||||||
|
})
|
||||||
|
];
|
||||||
|
}
|
|
@ -1,22 +0,0 @@
|
||||||
{ pkgs, config, ... }: {
|
|
||||||
services = {
|
|
||||||
privoxy = {
|
|
||||||
enable = true;
|
|
||||||
|
|
||||||
settings = {
|
|
||||||
enable-edit-actions = true;
|
|
||||||
forward-socks5 = "/ 127.0.0.1:1337 .";
|
|
||||||
listen-address = "localhost:8118";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
ssh-tunnel = {
|
|
||||||
enable = true;
|
|
||||||
server = "infinidoge@server.doge-inc.net -p 245 -S none -i /home/infinidoge/.ssh/id_ed25519 -v";
|
|
||||||
requiredBy = [ "privoxy.service" ];
|
|
||||||
forwards.dynamic = [ 1337 ];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
networking.proxy.default = config.services.privoxy.settings.listen-address;
|
|
||||||
}
|
|
Loading…
Add table
Add a link
Reference in a new issue