diff options
author | Mario Rodas <marsam@users.noreply.github.com> | 2019-12-03 04:42:50 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-12-03 04:42:50 -0500 |
commit | 93ff0446ca70ef2795b8cc5e804feaf01e709142 (patch) | |
tree | 5e514dbe4d957377c06d607d7c25939261bf0bfa /nixos | |
parent | a72d15df15c190defc2c314216d8b501eaecf081 (diff) | |
parent | 899d38170cfedc567da0b11d346a9f47f65e0a86 (diff) | |
download | nixpkgs-93ff0446ca70ef2795b8cc5e804feaf01e709142.tar nixpkgs-93ff0446ca70ef2795b8cc5e804feaf01e709142.tar.gz nixpkgs-93ff0446ca70ef2795b8cc5e804feaf01e709142.tar.bz2 nixpkgs-93ff0446ca70ef2795b8cc5e804feaf01e709142.tar.lz nixpkgs-93ff0446ca70ef2795b8cc5e804feaf01e709142.tar.xz nixpkgs-93ff0446ca70ef2795b8cc5e804feaf01e709142.tar.zst nixpkgs-93ff0446ca70ef2795b8cc5e804feaf01e709142.zip |
Merge pull request #66089 from servalcatty/v2ray
v2ray: init at 4.21.3
Diffstat (limited to 'nixos')
-rw-r--r-- | nixos/modules/module-list.nix | 1 | ||||
-rw-r--r-- | nixos/modules/services/networking/v2ray.nix | 81 |
2 files changed, 82 insertions, 0 deletions
diff --git a/nixos/modules/module-list.nix b/nixos/modules/module-list.nix index 076e1654818..8e373550bb3 100644 --- a/nixos/modules/module-list.nix +++ b/nixos/modules/module-list.nix @@ -722,6 +722,7 @@ ./services/networking/tvheadend.nix ./services/networking/unbound.nix ./services/networking/unifi.nix + ./services/networking/v2ray.nix ./services/networking/vsftpd.nix ./services/networking/wakeonlan.nix ./services/networking/websockify.nix diff --git a/nixos/modules/services/networking/v2ray.nix b/nixos/modules/services/networking/v2ray.nix new file mode 100644 index 00000000000..a1774cdffbb --- /dev/null +++ b/nixos/modules/services/networking/v2ray.nix @@ -0,0 +1,81 @@ +{ config, lib, pkgs, ... }: + +with lib; + +{ + options = { + + services.v2ray = { + enable = mkOption { + type = types.bool; + default = false; + description = '' + Whether to run v2ray server. + + Either <literal>configFile</literal> or <literal>config</literal> must be specified. + ''; + }; + + configFile = mkOption { + type = types.nullOr types.str; + default = null; + example = "/etc/v2ray/config.json"; + description = '' + The absolute path to the configuration file. + + Either <literal>configFile</literal> or <literal>config</literal> must be specified. + + See <link xlink:href="https://v2ray.com/en/configuration/overview.html"/>. + ''; + }; + + config = mkOption { + type = types.nullOr (types.attrsOf types.unspecified); + default = null; + example = { + inbounds = [{ + port = 1080; + listen = "127.0.0.1"; + protocol = "http"; + }]; + outbounds = [{ + protocol = "freedom"; + }]; + }; + description = '' + The configuration object. + + Either `configFile` or `config` must be specified. + + See <link xlink:href="https://v2ray.com/en/configuration/overview.html"/>. + ''; + }; + }; + + }; + + config = let + cfg = config.services.v2ray; + configFile = if cfg.configFile != null + then cfg.configFile + else (pkgs.writeText "v2ray.json" (builtins.toJSON cfg.config)); + + in mkIf cfg.enable { + assertions = [ + { + assertion = (cfg.configFile == null) != (cfg.config == null); + message = "Either but not both `configFile` and `config` should be specified for v2ray."; + } + ]; + + systemd.services.v2ray = { + description = "v2ray Daemon"; + after = [ "network.target" ]; + wantedBy = [ "multi-user.target" ]; + path = [ pkgs.v2ray ]; + script = '' + exec v2ray -config ${configFile} + ''; + }; + }; +} |