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; [
|
||||
networking.wireless
|
||||
|
||||
services.privoxy
|
||||
])
|
||||
|
||||
./hardware-configuration.nix
|
||||
|
@ -43,6 +41,9 @@
|
|||
gpu.intel = true;
|
||||
form.laptop = true;
|
||||
};
|
||||
services = {
|
||||
proxy.enable = true;
|
||||
};
|
||||
};
|
||||
|
||||
networking.interfaces.wlp170s0.useDHCP = true;
|
||||
|
|
|
@ -6,8 +6,6 @@
|
|||
networking.wireless
|
||||
|
||||
btrfs
|
||||
|
||||
# services.privoxy
|
||||
])
|
||||
|
||||
./hardware-configuration.nix
|
||||
|
@ -22,6 +20,7 @@
|
|||
audio.enable = true;
|
||||
form.portable = true;
|
||||
};
|
||||
services.proxy.enable = true;
|
||||
};
|
||||
|
||||
system.stateVersion = "21.11";
|
||||
|
|
|
@ -7,8 +7,6 @@
|
|||
networking.wireless
|
||||
|
||||
btrfs
|
||||
|
||||
# services.privoxy
|
||||
];
|
||||
};
|
||||
|
||||
|
@ -25,6 +23,9 @@
|
|||
gpu.amdgpu = true;
|
||||
wireless.enable = true;
|
||||
};
|
||||
services = {
|
||||
proxy.enable = 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