cfdyndns: init at 0.0.1
This commit is contained in:
parent
3a538e674d
commit
c7571611dc
|
@ -69,6 +69,7 @@
|
||||||
coconnor = "Corey O'Connor <coreyoconnor@gmail.com>";
|
coconnor = "Corey O'Connor <coreyoconnor@gmail.com>";
|
||||||
codsl = "codsl <codsl@riseup.net>";
|
codsl = "codsl <codsl@riseup.net>";
|
||||||
codyopel = "Cody Opel <codyopel@gmail.com>";
|
codyopel = "Cody Opel <codyopel@gmail.com>";
|
||||||
|
colemickens = "Cole Mickens <cole.mickens@gmail.com>";
|
||||||
copumpkin = "Dan Peebles <pumpkingod@gmail.com>";
|
copumpkin = "Dan Peebles <pumpkingod@gmail.com>";
|
||||||
coroa = "Jonas Hörsch <jonas@chaoflow.net>";
|
coroa = "Jonas Hörsch <jonas@chaoflow.net>";
|
||||||
couchemar = "Andrey Pavlov <couchemar@yandex.ru>";
|
couchemar = "Andrey Pavlov <couchemar@yandex.ru>";
|
||||||
|
|
|
@ -248,6 +248,7 @@
|
||||||
matrix-synapse = 224;
|
matrix-synapse = 224;
|
||||||
rspamd = 225;
|
rspamd = 225;
|
||||||
rmilter = 226;
|
rmilter = 226;
|
||||||
|
cfdyndns = 227;
|
||||||
|
|
||||||
# When adding a uid, make sure it doesn't match an existing gid. And don't use uids above 399!
|
# When adding a uid, make sure it doesn't match an existing gid. And don't use uids above 399!
|
||||||
|
|
||||||
|
@ -473,6 +474,7 @@
|
||||||
matrix-synapse = 224;
|
matrix-synapse = 224;
|
||||||
rspamd = 225;
|
rspamd = 225;
|
||||||
rmilter = 226;
|
rmilter = 226;
|
||||||
|
cfdyndns = 227;
|
||||||
|
|
||||||
# When adding a gid, make sure it doesn't match an existing
|
# When adding a gid, make sure it doesn't match an existing
|
||||||
# uid. Users and groups with the same name should have equal
|
# uid. Users and groups with the same name should have equal
|
||||||
|
|
|
@ -201,6 +201,7 @@
|
||||||
./services/misc/bepasty.nix
|
./services/misc/bepasty.nix
|
||||||
./services/misc/canto-daemon.nix
|
./services/misc/canto-daemon.nix
|
||||||
./services/misc/calibre-server.nix
|
./services/misc/calibre-server.nix
|
||||||
|
./services/misc/cfdyndns.nix
|
||||||
./services/misc/cpuminer-cryptonight.nix
|
./services/misc/cpuminer-cryptonight.nix
|
||||||
./services/misc/cgminer.nix
|
./services/misc/cgminer.nix
|
||||||
./services/misc/confd.nix
|
./services/misc/confd.nix
|
||||||
|
|
70
nixos/modules/services/misc/cfdyndns.nix
Normal file
70
nixos/modules/services/misc/cfdyndns.nix
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
{ config, pkgs, lib, ... }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
cfg = config.services.cfdyndns;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options = {
|
||||||
|
services.cfdyndns = {
|
||||||
|
enable = mkEnableOption "Cloudflare Dynamic DNS Client";
|
||||||
|
|
||||||
|
email = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
description = ''
|
||||||
|
The email address to use to authenticate to CloudFlare.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
apikey = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
description = ''
|
||||||
|
The API Key to use to authenticate to CloudFlare.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
records = mkOption {
|
||||||
|
default = [];
|
||||||
|
example = [ "host.tld" ];
|
||||||
|
type = types.listOf types.str;
|
||||||
|
description = ''
|
||||||
|
The records to update in CloudFlare.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
systemd.services.cfdyndns = {
|
||||||
|
description = "CloudFlare Dynamic DNS Client";
|
||||||
|
after = [ "network.target" ];
|
||||||
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
startAt = "5 minutes";
|
||||||
|
serviceConfig = {
|
||||||
|
Type = "simple";
|
||||||
|
User = config.ids.uids.cfdyndns;
|
||||||
|
Group = config.ids.gids.cfdyndns;
|
||||||
|
ExecStart = "/bin/sh -c '${pkgs.cfdyndns}/bin/cfdyndns'";
|
||||||
|
};
|
||||||
|
environment = {
|
||||||
|
CLOUDFLARE_EMAIL="${cfg.email}";
|
||||||
|
CLOUDFLARE_APIKEY="${cfg.apikey}";
|
||||||
|
CLOUDFLARE_RECORDS="${concatStringsSep "," cfg.records}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
users.extraUsers = {
|
||||||
|
cfdyndns = {
|
||||||
|
group = "cfdyndns";
|
||||||
|
uid = config.ids.uids.cfdyndns;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
users.extraGroups = {
|
||||||
|
cfdyndns = {
|
||||||
|
gid = config.ids.gids.cfdyndns;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
30
pkgs/applications/networking/dyndns/cfdyndns/default.nix
Normal file
30
pkgs/applications/networking/dyndns/cfdyndns/default.nix
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
{ stdenv, fetchFromGitHub, rustPlatform, makeWrapper, openssl }:
|
||||||
|
|
||||||
|
with rustPlatform;
|
||||||
|
|
||||||
|
buildRustPackage rec {
|
||||||
|
name = "cfdyndns-${version}";
|
||||||
|
version = "0.0.1";
|
||||||
|
src = fetchFromGitHub {
|
||||||
|
owner = "colemickens";
|
||||||
|
repo = "cfdyndns";
|
||||||
|
rev = "v${version}";
|
||||||
|
sha256 = "1mcdjykrgh0jq6k6y664lai8sbgzk6j7k0r944f43vg63d1jql5b";
|
||||||
|
};
|
||||||
|
|
||||||
|
depsSha256 = "0whs3fgmpb6g1mjajs3qs9g613x5dal4x6ghzzkpl73a9pgydkpn";
|
||||||
|
|
||||||
|
buildInputs = [ makeWrapper openssl ];
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
mkdir -p $out/bin
|
||||||
|
cp -p target/release/cfdyndns $out/bin/
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = with stdenv.lib; {
|
||||||
|
description = "CloudFlare Dynamic DNS Client";
|
||||||
|
homepage = https://github.com/colemickens/cfdyndns;
|
||||||
|
license = stdenv.lib.licenses.mit;
|
||||||
|
maintainers = with maintainers; [ colemickens ];
|
||||||
|
};
|
||||||
|
}
|
|
@ -786,6 +786,8 @@ let
|
||||||
|
|
||||||
ccnet = callPackage ../tools/networking/ccnet { };
|
ccnet = callPackage ../tools/networking/ccnet { };
|
||||||
|
|
||||||
|
cfdyndns = callPackage ../applications/networking/dyndns/cfdyndns { };
|
||||||
|
|
||||||
ckbcomp = callPackage ../tools/X11/ckbcomp { };
|
ckbcomp = callPackage ../tools/X11/ckbcomp { };
|
||||||
|
|
||||||
cli53 = callPackage ../tools/admin/cli53 { };
|
cli53 = callPackage ../tools/admin/cli53 { };
|
||||||
|
|
Loading…
Reference in a new issue