Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

DNS related changes #21999

Closed
wants to merge 7 commits into from
Closed

DNS related changes #21999

wants to merge 7 commits into from

Conversation

rnhmjoj
Copy link
Contributor

@rnhmjoj rnhmjoj commented Jan 20, 2017

Motivation for this change

I decided to migrate my homeserver to NixOS and found a few things still missing from nixpkgs.
This PR mainly focuses on the DNS stack, changes are:

  1. DNSChain: fixed the broken node package and improved the service
  2. PDNS Recursor: added a package and a nixos module
  3. Namecoind: modified the server so that it can run even with the default config
  4. DNScrypt: added a nixos module for the wrapper server and updated the proxy package
Things done
  • Tested using sandboxing (I tested individually each commits in a VM and the whole changes in a real machine)
  • Built on platform(s)
    • NixOS
    • macOS
    • Linux
  • Tested compilation of all pkgs that depend on this change using nix-shell -p nox --run "nox-review wip"
  • Tested execution of all binary files (usually in ./result/bin/)
  • Fits CONTRIBUTING.md.

I think it should be possible to pull these commits separately if you think it's too much for a single PR.

@rnhmjoj rnhmjoj changed the title Dns DNS related changes Jan 20, 2017
@jpierre03
Copy link
Contributor

@rnhmjoj usually distincts packages updates are splitted in multiple PR.

You PR mix package creation with package update and refactoring.

IMHO, your changeset could be merged faster splitted in 4 PR (dnschain, power dns, namecoind, dnscrypt)

'';
};

extraConfig = mkOption {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

An option to enable DNSSEC validation might be usefull https://doc.powerdns.com/md/recursor/dnssec/.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

From https://tools.ietf.org/html/rfc6761 section #6.1 Domain Name Reservation Considerations for Private Addresses

Some usual local address reverse zones should be provided :

       ...                  Instead, caching DNS servers SHOULD, by
default, generate immediate (positive or negative) responses for
all such queries.  This is to avoid unnecessary load on the root
name servers and other name servers.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I might be biased (as a DNS resolver dev for day-job), but "validate" seems a better default value.

@rnhmjoj
Copy link
Contributor Author

rnhmjoj commented Jan 22, 2017

Ok, thanks. I'll split the PR.

Copy link
Member

@layus layus left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Small nitpicks. I personally believe that these changes should be merged together.

port = ${toString cfg.api.port}
tlsPort = ${toString cfg.api.tlsPort}

[namecoin]
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The [namecoin] section should be added in dnschain config by assigning services.dnschain.extraConfig in nixos/modules/services/networking/namecoind.nix. There is no reason for nixos/modules/services/networking/dnschain.nix to use variables named cfg.namecoin.configFile and (above all) cfgs.namecoind.enable

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I haven't thought about this, it's definitely better.

};


namecoin.configFile = mkOption {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

as above, move to namecoind.nix


};

services.dnsmasq.resolveDNSChainQueries = mkOption {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

While technically possible, it is bad practice to have services.dnsmasq options defined in dnschain.nix. As first approximation, I would simply remove this option, and configure dnsmask unconditonnally. (see below).


services.namecoind.enable = true;
services.dnsmasq.servers = optionals cfgs.dnsmasq.resolveDNSChainQueries
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

as explained above. remove the cfgs.dnsmasq.resolveDNSChainQueries option and add this config snippet unconditionally.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't know, it doesn't look like a good idea to add these without the user knowing: it should be something optional. If it's really bad to have options defined in a different file then I may drop this entirely.

createHome = true;
};
services.dnschain.namecoin.configFile =
mkIf config.services.dnschain.enable configFile;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is no need to make this conditionnal.
The following snippet would be sufficient.

services.dnschain.extraConfig = ''
  [namecoin]
  config = ${configFile}
'';

If config.services.dnschain.enable is not true, then the extra config will not be used anyway.


let
np = nodePackages.override { generated = ./package.nix; self = np; };
in
nodePackages = callPackage (import ../../top-level/node-packages.nix) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why did you replace the previous expression by this import statement ? They are basically the same, but yours takes more space and uses top-level/node-packages.nix directly. Why not use nodePackages.override ?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

See #22041

@rnhmjoj rnhmjoj deleted the dns branch February 15, 2017 14:29
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants