]> git.ipfire.org Git - thirdparty/bind9.git/log
thirdparty/bind9.git
3 years agoDeduplicate allow-update definition in the ARM
Petr Špaček [Thu, 16 Jun 2022 14:45:09 +0000 (16:45 +0200)] 
Deduplicate allow-update definition in the ARM

3 years agoReference new named.conf description instead of man page
Ron Aitchison [Wed, 15 Jun 2022 12:06:37 +0000 (14:06 +0200)] 
Reference new named.conf description instead of man page

3 years agoRemove line numbering from config file examples
Ron Aitchison [Wed, 15 Jun 2022 12:04:33 +0000 (14:04 +0200)] 
Remove line numbering from config file examples

3 years agoChanged all references from clause to block
Ron Aitchison [Fri, 10 Jun 2022 14:49:01 +0000 (14:49 +0000)] 
Changed all references from clause to block

3 years agoRestructure introduction to named.conf in the ARM
Ron Aitchison [Fri, 17 Jun 2022 13:33:46 +0000 (15:33 +0200)] 
Restructure introduction to named.conf in the ARM

3 years agoAdd link anchors to statements and blocks in the ARM
Petr Špaček [Wed, 11 May 2022 13:45:57 +0000 (15:45 +0200)] 
Add link anchors to statements and blocks in the ARM

All statements now use .. namedconf:statement:: or
.. rndcconf:statement:: syntax provided by our Sphinx extension.

This has several consequences:
- It changes how statement headings are rendered
- Statements are indexed and show up as separate items in doc
  search results (in the HTML version)
- Statements can be linked to using either :any:`statement` or
  :namedconf:ref:`statement` syntax (not used in this commit)
- Statements can be categorized and printed using ..
  namedconf:statatementlist:: syntax (not used in this commit)

3 years agoMerge branch '3420-rrsetorder-update-status' into 'main'
Mark Andrews [Thu, 23 Jun 2022 07:24:53 +0000 (07:24 +0000)] 
Merge branch '3420-rrsetorder-update-status' into 'main'

rrsetorder: add missing update of status

Closes #3420

See merge request isc-projects/bind9!6466

3 years agoReplace expr's with $((expression)) shell constucts
Mark Andrews [Tue, 21 Jun 2022 02:42:21 +0000 (12:42 +1000)] 
Replace expr's with $((expression)) shell constucts

Also make indenting consistent.

3 years agoAdd missing update of status variable in rrsetorder system test
Mark Andrews [Thu, 23 Jun 2022 06:55:59 +0000 (16:55 +1000)] 
Add missing update of status variable in rrsetorder system test

3 years agoMerge branch '3143-add-a-note-to-the-arm-on-dnstap-and-resolver-traffic' into 'main'
Michał Kępień [Wed, 22 Jun 2022 13:11:51 +0000 (13:11 +0000)] 
Merge branch '3143-add-a-note-to-the-arm-on-dnstap-and-resolver-traffic' into 'main'

Add a note to the ARM on dnstap & resolver traffic

Closes #3143

See merge request isc-projects/bind9!6472

3 years agoCheck IPs in a dnstap capture of resolver traffic
Michał Kępień [Wed, 22 Jun 2022 13:09:43 +0000 (15:09 +0200)] 
Check IPs in a dnstap capture of resolver traffic

Add a system test that checks whether IP addresses are present in a
dnstap capture of resolver traffic if "query-source" is explicitly set.

3 years agoAdd a note to the ARM on dnstap & resolver traffic
Michał Kępień [Wed, 22 Jun 2022 13:09:43 +0000 (15:09 +0200)] 
Add a note to the ARM on dnstap & resolver traffic

Warn users that server-side IP addresses are not stored in dnstap
captures of resolver traffic unless "query-source(-v6)" is explicitly
set, explaining why it is so.

3 years agoMerge branch 'mnowak/add-system_gcc_bullseye_unstable_amd64-ci-job' into 'main'
Michal Nowak [Wed, 22 Jun 2022 12:49:07 +0000 (12:49 +0000)] 
Merge branch 'mnowak/add-system_gcc_bullseye_unstable_amd64-ci-job' into 'main'

Add system:gcc:bullseye:unstable:amd64 CI job

See merge request isc-projects/bind9!6461

3 years agoPut default-triggering-rules anchor in alphabetical order
Michal Nowak [Wed, 22 Jun 2022 08:49:04 +0000 (10:49 +0200)] 
Put default-triggering-rules anchor in alphabetical order

3 years agoRename schedules_tags_web_triggering_rules anchor
Michal Nowak [Mon, 20 Jun 2022 10:27:26 +0000 (12:27 +0200)] 
Rename schedules_tags_web_triggering_rules anchor

The schedules_tags_web_triggering_rules anchor name should match it's
content, hence api_schedules_tags_triggers_web_triggering_rules anchor
name.

3 years agoExtract API, schedules, triggers, and web triggering rules
Michal Nowak [Mon, 20 Jun 2022 10:22:09 +0000 (12:22 +0200)] 
Extract API, schedules, triggers, and web triggering rules

3 years agoAdd system:gcc:bullseye:unstable:amd64 CI job
Michal Nowak [Mon, 20 Jun 2022 10:17:07 +0000 (12:17 +0200)] 
Add system:gcc:bullseye:unstable:amd64 CI job

Without this CI job long pytest jobs are not being run in the CI.

3 years agoMerge branch '3309-fix-destination-port-extraction-for-client-queries' into 'main'
Michał Kępień [Wed, 22 Jun 2022 11:46:25 +0000 (11:46 +0000)] 
Merge branch '3309-fix-destination-port-extraction-for-client-queries' into 'main'

Fix destination port extraction for client queries

Closes #3309

See merge request isc-projects/bind9!6191

3 years agoAdd CHANGES entry for GL #3309
Michał Kępień [Wed, 22 Jun 2022 11:45:46 +0000 (13:45 +0200)] 
Add CHANGES entry for GL #3309

3 years agoCheck that the UDP destination port is logged via dnstap
Mark Andrews [Wed, 22 Jun 2022 11:45:46 +0000 (13:45 +0200)] 
Check that the UDP destination port is logged via dnstap

3 years agoFix destination port extraction for client queries
Michał Kępień [Wed, 22 Jun 2022 11:45:46 +0000 (13:45 +0200)] 
Fix destination port extraction for client queries

The current logic for determining the address of the socket to which a
client sent its query is:

 1. Get the address:port tuple from the netmgr handle using
    isc_nmhandle_localaddr().

 2. Convert the address:port tuple from step 1 into an isc_netaddr_t
    using isc_netaddr_fromsockaddr().

 3. Convert the address from step 2 back into a socket address with the
    port set to 0 using isc_sockaddr_fromnetaddr().

Note that the port number (readily available in the netmgr handle) is
needlessly lost in the process, preventing it from being recorded in
dnstap captures of client traffic produced by named.

Fix by first storing the address:port tuple returned by
isc_nmhandle_localaddr() in client->destsockaddr and then creating an
isc_netaddr_t from that structure.  This allows the port number to be
retained in client->destsockaddr, which is what subsequently gets passed
to dns_dt_send().

3 years agoMerge branch '3320-rewrite-arm-dnssec-chapter' into 'main'
Michał Kępień [Wed, 22 Jun 2022 11:44:11 +0000 (11:44 +0000)] 
Merge branch '3320-rewrite-arm-dnssec-chapter' into 'main'

Rewrite DNSSEC ARM Chapter

Closes #3320

See merge request isc-projects/bind9!6296

3 years agoMention zone storage in the DNSSEC chapter
Petr Špaček [Tue, 21 Jun 2022 13:08:17 +0000 (15:08 +0200)] 
Mention zone storage in the DNSSEC chapter

Let's not duplicate texts, link to description elsewhere instead.

3 years agoMinor grammar improvements in the Signing chapter of the DNSSEC Guide
Suzanne Goldlust [Fri, 17 Jun 2022 15:06:23 +0000 (15:06 +0000)] 
Minor grammar improvements in the Signing chapter of the DNSSEC Guide

3 years agoAdd a section about key rollover
Matthijs Mekking [Thu, 16 Jun 2022 13:46:32 +0000 (15:46 +0200)] 
Add a section about key rollover

Describe how to do key rollovers with dnssec-policy. Update the
revert to unsigned recipe in the DNSSEC guide.

3 years agoDeduplicate Manual Signing between DNSSEC chapter and DNSSEC Guide
Petr Špaček [Thu, 16 Jun 2022 12:03:45 +0000 (14:03 +0200)] 
Deduplicate Manual Signing between DNSSEC chapter and DNSSEC Guide

The two procedures were essentially the same, but each instance was
missing some details from the other. They are now combined into one text
in the DNSSEC Guide and linked from DNSSEC chapter.

3 years agoDeduplicate key filename description in the DNSSEC Guide
Petr Špaček [Thu, 16 Jun 2022 11:48:55 +0000 (13:48 +0200)] 
Deduplicate key filename description in the DNSSEC Guide

Third time ...

3 years agoUse ECDSAP256SHA256 in DNSSEC signing examples
Petr Špaček [Thu, 16 Jun 2022 11:43:19 +0000 (13:43 +0200)] 
Use ECDSAP256SHA256 in DNSSEC signing examples

3 years agoUse code-block directive for complete command lines
Petr Špaček [Thu, 16 Jun 2022 11:13:03 +0000 (13:13 +0200)] 
Use code-block directive for complete command lines

Minor rendering nit, not really important.

3 years agoDeduplicate key filename description in the DNSSEC chapter
Petr Špaček [Thu, 16 Jun 2022 11:06:11 +0000 (13:06 +0200)] 
Deduplicate key filename description in the DNSSEC chapter

3 years agoMove Private Type Records in DNSSEC chapter to higher level
Petr Špaček [Thu, 16 Jun 2022 10:56:04 +0000 (12:56 +0200)] 
Move Private Type Records in DNSSEC chapter to higher level

Private Type Records are not specific to manually signing, so it is
better to move it to the end of the "Zone Signing" section shared by all
three methods.

3 years agoRewrite DNSSEC Validation subchapter in the ARM
Petr Špaček [Thu, 9 Jun 2022 09:53:13 +0000 (11:53 +0200)] 
Rewrite DNSSEC Validation subchapter in the ARM

Mostly deduplicating and linking information across the ARM.
Generally people should not touch it unless they what they are doing, so
let's try to discourage them a bit.

3 years agoAdd hints about secure delegation to DNSSEC chapter of the ARM
Petr Špaček [Thu, 9 Jun 2022 07:04:24 +0000 (09:04 +0200)] 
Add hints about secure delegation to DNSSEC chapter of the ARM

Let's not duplicate texts from elsewhere, just point to different parts
of documentation.

3 years agoReorder chapters about Zone Signing in the DNSSEC chapter of ARM
Petr Špaček [Wed, 8 Jun 2022 16:05:56 +0000 (18:05 +0200)] 
Reorder chapters about Zone Signing in the DNSSEC chapter of ARM

Let's make more automated methods more prominent:
- KASP first
- dynamic updates second
- command-line tools only as last resort

3 years agoRewrite KASP section of DNSSEC chapter in the ARM
Petr Špaček [Wed, 8 Jun 2022 14:48:06 +0000 (16:48 +0200)] 
Rewrite KASP section of DNSSEC chapter in the ARM

The goal is simplicity. Copy&paste to do the right thing, or read
referenced material and make up your mind if you need specialities.

NSEC discussion is already present in the DNSSEC guide so I merged
KASP examples with example for NSEC3 and removed NSEC text from the
DNSSEC chapter.

3 years agoRewrite introduction for DNSSEC chapter of the ARM
Petr Špaček [Wed, 8 Jun 2022 13:45:35 +0000 (15:45 +0200)] 
Rewrite introduction for DNSSEC chapter of the ARM

I've attempted to drop most of DNSSEC-specific jargon from the intro
paragraph, and to convince readers to read on.

3 years agoUse NSEC3 guidance values in nsec3 config examples
Matthijs Mekking [Tue, 7 Jun 2022 08:23:47 +0000 (10:23 +0200)] 
Use NSEC3 guidance values in nsec3 config examples

Use best practice values in examples that follow new guidance from
draft-ietf-dnsop-nsec3-guidance:

   ; SHA-1, no extra iterations, empty salt:
   ;
   bcp.example. IN NSEC3PARAM 1 0 0 -

3 years agoMove "DNSSEC" chapter before "Advanced" and "Security"
Matthijs Mekking [Thu, 12 May 2022 09:23:42 +0000 (11:23 +0200)] 
Move "DNSSEC" chapter before "Advanced" and "Security"

DNSSEC is mainstream nowadays, so let's give it more attention.

3 years agoMove Dynamic Zones section up
Matthijs Mekking [Thu, 12 May 2022 09:19:03 +0000 (11:19 +0200)] 
Move Dynamic Zones section up

Move this section up so that DNSSEC signing topics are grouped together
(and not split by the DNSSEC Validation chapter).

3 years agoRewrite Dynamic Zones section
Matthijs Mekking [Thu, 12 May 2022 08:26:25 +0000 (10:26 +0200)] 
Rewrite Dynamic Zones section

Restructure the section about dynamic zones and automatic signing:
- Focus on dynamic zones with 'auto-dnssec allow;'.
- Add a section about multi-signer models.
- Move NSEC3 related topics into one section.
- Remove any text that does not concern dynamic zones (mostly duplicate
  text anyway).

3 years agoAdd a section about Denial of Existence
Matthijs Mekking [Wed, 11 May 2022 10:09:43 +0000 (12:09 +0200)] 
Add a section about Denial of Existence

Move bits from the "DNSSEC, Dynamic Zones, and Automatic Signing"
about denial of existence to a separate section below the "Key and
Signing Policy" section.

Add a brief introduction about denial of existence to this section.

3 years agoRewrap a paragraph in DNSSEC Validation section
Matthijs Mekking [Wed, 11 May 2022 09:10:04 +0000 (11:10 +0200)] 
Rewrap a paragraph in DNSSEC Validation section

No textual changes, just rewrapping to 80 characters.

3 years agoRewrite DNSSEC chapter - signing
Matthijs Mekking [Wed, 11 May 2022 09:04:47 +0000 (11:04 +0200)] 
Rewrite DNSSEC chapter - signing

Restructure the first part of the DNSSEC chapter that deals with zone
signing. Put dnssec-policy first. Mention Key and Signing Policy.
Only then talk about the DNSSEC tools.

3 years agoNit changes in introduction of DNSSEC chapter
Matthijs Mekking [Wed, 11 May 2022 07:39:44 +0000 (09:39 +0200)] 
Nit changes in introduction of DNSSEC chapter

DNSSEC-bis is an uncommon term. Other servers are typically resolvers
and they usually are configured with the root key.

3 years agoMerge branch 'ondrej-fix-out-of-tree-artifacts' into 'main'
Michał Kępień [Wed, 22 Jun 2022 11:01:25 +0000 (11:01 +0000)] 
Merge branch 'ondrej-fix-out-of-tree-artifacts' into 'main'

Move the out of tree directory into the project directory

See merge request isc-projects/bind9!6377

3 years agoClean up convert-trs-to-junit.py invocations
Michał Kępień [Wed, 22 Jun 2022 10:59:33 +0000 (12:59 +0200)] 
Clean up convert-trs-to-junit.py invocations

  - Use absolute paths when invoking the convert-trs-to-junit.py script
    so that it also works correctly for out-of-tree and tarball-based
    test jobs.

  - Quote the variables used in convert-trs-to-junit.py invocations to
    future-proof the code.

  - Use "&&" instead of ";" in shell pipelines invoking the
    convert-trs-to-junit.py script in order to prevent "source" errors
    from being silently ignored.

  - Ensure convert-trs-to-junit.py is invoked from the correct directory
    for out-of-tree and tarball-based unit test jobs by adding
    appropriate "cd" invocations.

  - Ensure the convert-trs-to-junit.py invocations are always the last
    step in each 'after_script', in order to run that script from the
    correct directory for out-of-tree and tarball-based system test jobs
    and to ensure that any potential errors in that script do not
    prevent more important steps in the 'after_script' from being
    executed.

3 years agoMove out-of-tree workspace back to $CI_PROJECT_DIR
Michał Kępień [Wed, 22 Jun 2022 10:59:33 +0000 (12:59 +0200)] 
Move out-of-tree workspace back to $CI_PROJECT_DIR

Out-of-tree build & test jobs currently defined in GitLab CI use
/tmp/out_of_tree_workspace as the working directory.  This requires
juggling that directory around as it gets passed from the build job to
the test jobs and then again after the test jobs are finished, so that
artifacts can be collected for the purpose of investigating test
failures.  The original intention of doing this was to ensure that
bin/tests/system/run.sh does not rely on being executed from within a
Git working copy (which happens e.g. if the out-of-tree workspace is a
subdirectory of $CI_PROJECT_DIR, i.e. the path into which GitLab
Runner clones the project in each job).

However, even with these complications in place, not all possible
scenarios that should be handled properly by the system test framework
(e.g. invoking a given test one time after another from the same
out-of-tree build directory) are tested in GitLab CI anyway.  Meanwhile,
the requirement for moving the out-of-tree workspace into
$CI_PROJECT_DIR in the 'after_script' for each out-of-tree job makes
these jobs less robust than they could be; for example, if any step in
the 'after_script' returns a non-zero exit code, the job's artifacts
will not include the out-of-tree workspace, hindering troubleshooting.

Simplify job definitions in .gitlab-ci.yml by moving the workspace used
by out-of-tree build & test jobs back to a subdirectory of
$CI_PROJECT_DIR.  Whether the out-of-tree workspace exists within a Git
working copy or not does not matter for Autotools, so this is considered
to be a reasonable trade-off in terms of test coverage.

3 years agoMerge branch 'mnowak/ubuntu-22.04-jammy-jellyfish' into 'main'
Michal Nowak [Wed, 22 Jun 2022 08:57:40 +0000 (08:57 +0000)] 
Merge branch 'mnowak/ubuntu-22.04-jammy-jellyfish' into 'main'

Add Ubuntu 22.04 LTS (Jammy Jellyfish)

See merge request isc-projects/bind9!6446

3 years agoDo not run Ubuntu 18.04 jobs in MR-triggered pipelines
Michal Nowak [Wed, 15 Jun 2022 14:06:48 +0000 (16:06 +0200)] 
Do not run Ubuntu 18.04 jobs in MR-triggered pipelines

With the addition of Ubuntu 22.04 three more CI jobs were added. To
compensate for that, move Ubuntu 18.04 jobs out of MR-triggered
pipelines to schedule-triggered ones.

Also, move --disable-geoip ./configure options from Ubuntu 18.04 to
Ubuntu 20.04 jobs to keep these options in the more frequent
MR-triggered pipelines.

3 years agoAdd Ubuntu 22.04 LTS (Jammy Jellyfish)
Michal Nowak [Wed, 15 Jun 2022 14:00:35 +0000 (16:00 +0200)] 
Add Ubuntu 22.04 LTS (Jammy Jellyfish)

3 years agoMerge branch '3412-system-test-passthru-virtualenv-perl5lib' into 'main'
Matthijs Mekking [Wed, 22 Jun 2022 08:32:48 +0000 (08:32 +0000)] 
Merge branch '3412-system-test-passthru-virtualenv-perl5lib' into 'main'

System tests pass through virtualenv and perlmods

Closes #3412

See merge request isc-projects/bind9!6458

3 years agoSystem tests pass through virtualenv and perlmods
Matthijs Mekking [Fri, 17 Jun 2022 08:34:38 +0000 (10:34 +0200)] 
System tests pass through virtualenv and perlmods

Have system tests use required Python (dnspython) and PERL modules
(Digest::HMAC and Net::DNS) from user directories, avoid using
privileges.

Note: The pythonenv must be setup to use the same version of python as
the test uses, for example /usr/bin/python.

Thanks to Stacey Marshall.

3 years agoMerge branch '3416-document-key-lifetime-min-length' into 'main'
Matthijs Mekking [Tue, 21 Jun 2022 15:34:23 +0000 (15:34 +0000)] 
Merge branch '3416-document-key-lifetime-min-length' into 'main'

Document what is a too short key lifetime

Closes #3416

See merge request isc-projects/bind9!6460

3 years agoDocument what is a too short key lifetime
Matthijs Mekking [Mon, 20 Jun 2022 09:08:51 +0000 (11:08 +0200)] 
Document what is a too short key lifetime

To give a hint to users that get an error that the key lifetime is
shorter than the time it takes to do a rollover.

3 years agoMerge branch '3397-document-interaction-dnssec-update-config-options' into 'main'
Matthijs Mekking [Mon, 20 Jun 2022 12:12:50 +0000 (12:12 +0000)] 
Merge branch '3397-document-interaction-dnssec-update-config-options' into 'main'

Document where updates and DNSSEC records are stored

Closes #3397

See merge request isc-projects/bind9!6457

3 years agoAdd comment on DNSSEC signing zone configuration
Matthijs Mekking [Fri, 17 Jun 2022 08:29:51 +0000 (10:29 +0200)] 
Add comment on DNSSEC signing zone configuration

I was slightly confused here, so IMO it can use a comment.

3 years agoDocument where updates and DNSSEC records are stored
Matthijs Mekking [Fri, 17 Jun 2022 08:21:15 +0000 (10:21 +0200)] 
Document where updates and DNSSEC records are stored

Make clear that inline-signing stores DNSSEC records in a signed
version of the zone, using the zone's filename plus ".signed" extension.

Tell that dynamic zones store updates in the zone's filename.

DNSSEC records for dynamic zones also go in the zone's filename, unless
inline-signing is enabled.

Then, dnssec-policy assumes inline-signing, but only if the zone is
not dynamic.

4 years agoMerge branch 'mnowak/bump-clang-to-version-14' into 'main'
Michal Nowak [Thu, 16 Jun 2022 16:14:32 +0000 (16:14 +0000)] 
Merge branch 'mnowak/bump-clang-to-version-14' into 'main'

Update clang to version 14

See merge request isc-projects/bind9!6368

4 years agoExtract Clang version to $CLANG_VERSION
Michal Nowak [Wed, 15 Jun 2022 17:17:38 +0000 (19:17 +0200)] 
Extract Clang version to $CLANG_VERSION

Extracting Clang version helps with updating Clang version in one place
and not missing one of its instances.

4 years agoFix external_symbolizer_path on Fedora
Michal Nowak [Wed, 15 Jun 2022 17:05:56 +0000 (19:05 +0200)] 
Fix external_symbolizer_path on Fedora

The external_symbolizer_path was wrong on Fedora since moving gcc:tsan
jobs from Debian to Fedora.

4 years agoUpdate clang to version 14
Michal Nowak [Tue, 31 May 2022 14:55:01 +0000 (16:55 +0200)] 
Update clang to version 14

4 years agoMerge branch 'mnowak/checkds-pylint-implicit-str-concat-fixes' into 'main'
Michal Nowak [Thu, 16 Jun 2022 11:40:27 +0000 (11:40 +0000)] 
Merge branch 'mnowak/checkds-pylint-implicit-str-concat-fixes' into 'main'

Fix implicit string concatenation in tests-checkds.py

See merge request isc-projects/bind9!6452

4 years agoFix implicit string concatenation in tests-checkds.py
Michal Nowak [Thu, 16 Jun 2022 09:25:43 +0000 (11:25 +0200)] 
Fix implicit string concatenation in tests-checkds.py

pylint 2.14.2 reports the following warnings:

    bin/tests/system/checkds/tests-checkds.py:265:0: W1404: Implicit string concatenation found in call (implicit-str-concat)
    bin/tests/system/checkds/tests-checkds.py:273:0: W1404: Implicit string concatenation found in call (implicit-str-concat)

4 years agoMerge branch 'tkrizek/pytest-skipped-reason' into 'main'
Tom Krizek [Thu, 16 Jun 2022 07:17:37 +0000 (07:17 +0000)] 
Merge branch 'tkrizek/pytest-skipped-reason' into 'main'

Report reasons for skipped/xfailed system pytests

See merge request isc-projects/bind9!6441

4 years agoReport reasons for skipped/xfailed system pytests
Tom Krizek [Wed, 15 Jun 2022 13:00:27 +0000 (15:00 +0200)] 
Report reasons for skipped/xfailed system pytests

If skip/xfail is used in pytest, it can have a reason string associated
with it. When evaluating these tests, it can be useful to be able to
differentiate the reason why the test was skipped/xfailed/xpassed,
because there might be multiple possible reasons for that.

The extra options passed to pytest ensure that the string with the
reason appears in the test summary and thus we're able to find the
string with the reason in the log output.

See https://docs.pytest.org/en/7.1.x/how-to/skipping.html for more info

4 years agoMerge branch 'pspacek/nsec3-doc-update' into 'main'
Petr Špaček [Wed, 15 Jun 2022 15:56:53 +0000 (15:56 +0000)] 
Merge branch 'pspacek/nsec3-doc-update' into 'main'

Update NSEC3 guidance to match draft-ietf-dnsop-nsec3-guidance-10

See merge request isc-projects/bind9!6413

4 years agoUpdate NSEC3 guidance to match draft-ietf-dnsop-nsec3-guidance-10
Petr Špaček [Thu, 9 Jun 2022 17:26:40 +0000 (19:26 +0200)] 
Update NSEC3 guidance to match draft-ietf-dnsop-nsec3-guidance-10

https://datatracker.ietf.org/doc/html/draft-ietf-dnsop-nsec3-guidance-10
is on it's way to become RFC, so let's update our recommendations in the
docs to be in line with it.

4 years agoMerge tag 'v9_19_2'
Michał Kępień [Wed, 15 Jun 2022 13:53:59 +0000 (15:53 +0200)] 
Merge tag 'v9_19_2'

BIND 9.19.2

4 years agoMerge branch 'artem-tlsdns-do-not-call-acceptcb-twice' into 'main'
Artem Boldariev [Wed, 15 Jun 2022 12:29:35 +0000 (12:29 +0000)] 
Merge branch 'artem-tlsdns-do-not-call-acceptcb-twice' into 'main'

TLS DNS: do not call accept callback twice

See merge request isc-projects/bind9!6439

4 years agoTLS DNS: do not call accept callback twice
Artem Boldariev [Wed, 15 Jun 2022 10:57:52 +0000 (13:57 +0300)] 
TLS DNS: do not call accept callback twice

Before the changes from this commit were introduced, the accept
callback function will get called twice when accepting connection
during two of these stages:

* when accepting the TCP connection;
* when handshake has completed.

That is clearly an error, as it should have been called only once. As
far as I understand it the mistake is a result of TLS DNS transport
being essentially a fork of TCP transport, where calling the accept
callback immediately after accepting TCP connection makes sense.

This commit fixes this mistake. It did not have any very serious
consequences because in BIND the accept callback only checks an ACL
and updates stats.

4 years agoMerge branch 'pspacek/doc-cleanup-dnssec-prereq' into 'main'
Petr Špaček [Tue, 14 Jun 2022 16:11:54 +0000 (16:11 +0000)] 
Merge branch 'pspacek/doc-cleanup-dnssec-prereq' into 'main'

Update intro texts in the DNSSEC Guide

See merge request isc-projects/bind9!6418

4 years agoUpdate FAQ in the DNSSEC Guide
Petr Špaček [Mon, 13 Jun 2022 16:05:27 +0000 (18:05 +0200)] 
Update FAQ in the DNSSEC Guide

Mention DoT/DoH, update stats, remove mentions of early stages of
deployment.

4 years agoUpdate Authoritative Server Hardware requirements in DNSSEC Guide
Petr Špaček [Mon, 13 Jun 2022 15:34:37 +0000 (17:34 +0200)] 
Update Authoritative Server Hardware requirements in DNSSEC Guide

Based on measurements done on BIND v9_19_2 using bank. TLD and a
synthetitc fullly signed zone, using RSASHA256 and ECDSAP256SHA256
algorithms with NSEC and NSEC3 without opt-out.

4 years agoUpdate DNSSEC validation deployment stats in DNSSEC Guide
Petr Špaček [Mon, 13 Jun 2022 08:31:36 +0000 (10:31 +0200)] 
Update DNSSEC validation deployment stats in DNSSEC Guide

4 years agoRewrite Recursive Server Hardware requirements in DNSSEC Guide
Petr Špaček [Fri, 10 Jun 2022 12:40:17 +0000 (14:40 +0200)] 
Rewrite Recursive Server Hardware requirements in DNSSEC Guide

This section was completely out of date. Current measurements on dataset
Telco EU 2022-02 and BIND 9.19.1 indicate absolutely different results
than described in the old version of the text.

4 years agoRemove outdated software requirements from DNSSEC Guide
Petr Špaček [Fri, 10 Jun 2022 11:43:14 +0000 (13:43 +0200)] 
Remove outdated software requirements from DNSSEC Guide

Guide in this repo is tied to latest version anyway, so let's not even
mention ancient versions of BIND.

This also solves the OpenSSL question because it is now mandatory for
build, which subsequently removes the entropy problem - so let's not
mention it either.

4 years agoMerge branch '3401-race-condition-in-route_connected' into 'main'
Arаm Sаrgsyаn [Tue, 14 Jun 2022 15:31:40 +0000 (15:31 +0000)] 
Merge branch '3401-race-condition-in-route_connected' into 'main'

Resolve "race condition in route_connected() leads to crash on startup/shutdown"

Closes #3401

See merge request isc-projects/bind9!6429

4 years agoAdd CHANGES note for [GL #3401]
Aram Sargsyan [Tue, 14 Jun 2022 10:54:24 +0000 (10:54 +0000)] 
Add CHANGES note for [GL #3401]

4 years agoFix a race condition between shutdown and route_connected()
Aram Sargsyan [Tue, 14 Jun 2022 10:49:04 +0000 (10:49 +0000)] 
Fix a race condition between shutdown and route_connected()

When shutting down, the interface manager can be destroyed
before the `route_connected()` callback is called, which is
unexpected for the latter and can cause a crash.

Move the interface manager attachment code from the callback
to the place before the callback is registered using
`isc_nm_routeconnect()` function, which will make sure that
the interface manager will live at least until the callback
is called.

Make sure to detach the interface manager if the
`isc_nm_routeconnect()` function is not implemented, or when
the callback is called with a result value which differs from
`ISC_R_SUCCESS`.

4 years agoDo not use the interface manager until it is ready
Aram Sargsyan [Tue, 14 Jun 2022 10:42:28 +0000 (10:42 +0000)] 
Do not use the interface manager until it is ready

The `ns_interfacemgr_create()` function, when calling
`isc_nm_routeconnect()`, uses the newly created `ns_interfacemgr_t`
instance before initializing its reference count and the magic value.

Defer the `isc_nm_routeconnect()` call until the initializations
are complete.

4 years agoMerge branch '3207-dig-nssearch-crash-fix' into 'main'
Arаm Sаrgsyаn [Tue, 14 Jun 2022 14:03:04 +0000 (14:03 +0000)] 
Merge branch '3207-dig-nssearch-crash-fix' into 'main'

Resolve "dig +nssearch org crashes when network is unreachable"

Closes #3207

See merge request isc-projects/bind9!6343

4 years agoAdd CHANGES note for [GL #3207]
Aram Sargsyan [Thu, 19 May 2022 21:05:16 +0000 (21:05 +0000)] 
Add CHANGES note for [GL #3207]

4 years agoFix a crash in dig NS search mode
Aram Sargsyan [Thu, 19 May 2022 20:44:32 +0000 (20:44 +0000)] 
Fix a crash in dig NS search mode

In special NS search mode, after the initial lookup, dig starts the
followup lookup with discovered NS servers in the queries list. If one
of those queries then fail, dig, as usual, tries to start the next query
in the list, which results in a crash, because the NS search mode is
special in a way that the queries are running in parallel, so the next
query is usually already started.

Apply some special logic in `recv_done()` function to deal with the
described situation when handling the query result for the NS search
mode. Particularly, print a warning message for the failed query,
and do not try to start the next query in the list. Also, set a non-zero
exit code if all the queries in the followup lookup fail.

4 years agoMerge branch '3138-capture-scripts-to-coverity-scan' into 'main'
Michal Nowak [Tue, 14 Jun 2022 12:18:12 +0000 (12:18 +0000)] 
Merge branch '3138-capture-scripts-to-coverity-scan' into 'main'

Capture scripts for Coverity Scan analysis

Closes #3138

See merge request isc-projects/bind9!5984

4 years agoCapture scripts for Coverity Scan analysis
Michal Nowak [Thu, 10 Feb 2022 10:05:46 +0000 (11:05 +0100)] 
Capture scripts for Coverity Scan analysis

With the recent Coverity Scan 2021.12 version, Python 3 scripts are
being analyzed in addition to C files. The --fs-capture-search option
scripts for Coverity Scan analysis should be added to leverage this
feature.

4 years agoDownload Coverity Scan analysis tool to /tmp
Michal Nowak [Tue, 15 Feb 2022 10:24:01 +0000 (11:24 +0100)] 
Download Coverity Scan analysis tool to /tmp

Downloading and unpacking Coverity Scan analysis tool tarball
(cov-analysis-linux64.tgz) to $CI_PROJECT_DIR interferes with the
execution of the analysis tool when the --fs-capture-search option is
used because the tool starts to analyze some of its Javascript files.
(There's the --fs-capture-search-exclude-regex <path> option, but I
failed to find a way to make it work.)

4 years agoDrop coverity cache feature
Michal Nowak [Mon, 14 Feb 2022 20:06:31 +0000 (21:06 +0100)] 
Drop coverity cache feature

The coverity CI job cache feature is used to ensure that the 1 GB
cov-analysis-linux64.tgz file is being cached on GitLab CI runner, where
it was downloaded in the past. This feature does not seem to work
anymore; given that the proper solution to creating distributed cache is
complicated, better to drop the feature altogether.

4 years agoMerge branch '3168-5-tidy-check_recursionquota' into 'main'
Michał Kępień [Tue, 14 Jun 2022 11:44:56 +0000 (11:44 +0000)] 
Merge branch '3168-5-tidy-check_recursionquota' into 'main'

[5/5] Tidy check_recursionquota()

Closes #3168

See merge request isc-projects/bind9!5886

4 years agoMerge branch '3168-4-refactor-recursion-quota-handling' into 'main'
Michał Kępień [Tue, 14 Jun 2022 11:43:14 +0000 (11:43 +0000)] 
Merge branch '3168-4-refactor-recursion-quota-handling' into 'main'

[4/5] Refactor recursion quota handling

See merge request isc-projects/bind9!5885

4 years agoMerge branch '3168-3-separate-all-recursions' into 'main'
Michał Kępień [Tue, 14 Jun 2022 11:42:21 +0000 (11:42 +0000)] 
Merge branch '3168-3-separate-all-recursions' into 'main'

[3/5] Separate all recursions

See merge request isc-projects/bind9!5884

4 years agoMerge branch '3168-2-untangle-prefetch-and-rpz' into 'main'
Michał Kępień [Tue, 14 Jun 2022 11:41:09 +0000 (11:41 +0000)] 
Merge branch '3168-2-untangle-prefetch-and-rpz' into 'main'

[2/5] Untangle prefetch and RPZ code

See merge request isc-projects/bind9!5883

4 years agoMerge branch '3168-1-add-recursionquota-helper-functions' into 'main'
Michał Kępień [Tue, 14 Jun 2022 11:39:15 +0000 (11:39 +0000)] 
Merge branch '3168-1-add-recursionquota-helper-functions' into 'main'

[1/5] Add recursionquota_*() helper functions

See merge request isc-projects/bind9!5882

4 years agoAssert on unknown isc_quota_attach() return values
Michał Kępień [Tue, 14 Jun 2022 11:13:32 +0000 (13:13 +0200)] 
Assert on unknown isc_quota_attach() return values

The only values that the isc_quota_attach() function (called from
check_recursionquota() via recursionquotatype_attach_soft()) can
currently return are: ISC_R_SUCCESS, ISC_R_SOFTQUOTA, and ISC_R_QUOTA.
Instead of just propagating any other (unexpected) error up the call
stack, assert immediately, so that if the isc_quota_* API gets updated
in the future to return values currently matching the "default"
statement, check_recursionquota() can be promptly updated to handle such
new return values as desired.

4 years agoAdd CHANGES entry for GL #3168
Michał Kępień [Tue, 14 Jun 2022 11:13:32 +0000 (13:13 +0200)] 
Add CHANGES entry for GL #3168

4 years agoEnsure ns_query_cancel() handles all recursions
Michał Kępień [Tue, 14 Jun 2022 11:13:32 +0000 (13:13 +0200)] 
Ensure ns_query_cancel() handles all recursions

Previously, multiple code paths reused client->query.fetch, so it was
enough for ns_query_cancel() to issue a single call to
dns_resolver_cancelfetch() with that fetch as an argument.  Now, since
each slot in the 'recursions' array can hold a reference to a separate
resolver fetch, ns_query_cancel() needs to handle all of them, so that
all recursion callbacks get a chance to clean up the associated
resources when a query is canceled.

4 years agoSeparate prefetch handling from RPZ fetch handling
Michał Kępień [Tue, 14 Jun 2022 11:13:32 +0000 (13:13 +0200)] 
Separate prefetch handling from RPZ fetch handling

Both prefetch code and RPZ code ignore recursion results (caching the
response notwithstanding).  RPZ code has been (ab)using that fact since
commit 08e36aa5a5c7697a839f83831fccf8fb3f792848 by employing
prefetch_done() as the fetch completion callback.  This is only
seemingly a simplification as it makes the code harder to follow ("why
is prefetch code used for handling RPZ-triggered recursion?").

Turn prefetch_done() into a new function whose name clearly conveys its
purpose.  Add a parameter to its prototype in order to allow callers to
specify which slot in the 'recursions' array it should use.  Reintroduce
prefetch_done() as a wrapper for that function.  Add rpzfetch_done(), an
RPZ-exclusive wrapper for that function (using a distinct recursion
type).

Since each slot in the 'recursions' array needs to be initialized before
getting cleaned up when recursion completes, rework fetch_and_forget()
so that it takes recursion type rather than extra fetch options as the
last parameter and make it use the requested slot in the 'recursions'
array rather than a fixed slot (RECTYPE_PREFETCH) for all callers.  This
makes fetch_and_forget() a logical complement of cleanup_after_fetch().

Collectively, these changes make prefetch and RPZ code logically
separate (except for reusing client->recursionquota, which will be
refactored later).

4 years agoAdd recursionquota_attach*()
Ondřej Surý [Tue, 14 Jun 2022 11:13:32 +0000 (13:13 +0200)] 
Add recursionquota_attach*()

Add a set of new helper functions for attaching to the recursion quota
in order to reduce code duplication and to ensure that the recursive
clients counter is always adjusted properly.  Since some callers
(query_prefetch(), query_rpzfetch()) treat exceeding the soft quota as
an error while others (check_recursionquota()) do not, also add two
wrapper functions whose names help convey their purpose, in order to
improve code readability.

4 years agoUse a switch statement in check_recursionquota()
Michał Kępień [Tue, 14 Jun 2022 11:13:32 +0000 (13:13 +0200)] 
Use a switch statement in check_recursionquota()

Improve readability of the check_recursionquota() function by replacing
a sequence of conditional statements with a switch statement.

4 years agoRemove redundant recursion quota pointer checks
Michał Kępień [Tue, 14 Jun 2022 11:13:32 +0000 (13:13 +0200)] 
Remove redundant recursion quota pointer checks

When the client->recursionquota pointer was overloaded by different
features, each of those features had to be aware of that fact and handle
any updates of that pointer gracefully.  Example: prefetch code
initiates recursion, attaching to client->recursionquota, then query
processing restarts due to a CNAME being encountered, then that CNAME is
not found in the cache, so another recursion is triggered, but
client->recursionquota is already attached to; even though it is not
CNAME chaining code that attached to that pointer, that code still has
to handle such a situation gracefully.

However, all features that can initiate recursion have now been updated
to use separate slots in the 'recursions' array, so keeping the old
checks in place means masking future programming errors that could
otherwise be caught - and should be caught because each feature needs to
properly maintain its own quota reference.

Remove outdated recursion quota pointer checks to enable the assertions
in isc_quota_*() functions to detect programming errors in code paths
that can start recursion.  Remove an outdated comment to prevent
confusion.

4 years agoDrop the 'fetchhandle' and 'fetch' fields
Michał Kępień [Tue, 14 Jun 2022 11:13:32 +0000 (13:13 +0200)] 
Drop the 'fetchhandle' and 'fetch' fields

Drop the 'fetchhandle' field from ns_client_t as all code using it has
been migrated to use the recursion-type-specific HANDLE_RECTYPE_*()
macros.

Drop the 'fetch' field from ns_query_t as all code using it has been
migrated to use the recursion-type-specific FETCH_RECTYPE_*() macros.