Welcome to ARSoft.Tools.Net library
This project contains a complete managed .Net SPF validation, SenderID validation and a dns client and dns server implementation written in C#.
If you use this library, please send me your feedback and add a link to this page.
In addition you can donate via Ko-fi, Paypal or send me a gift from my Amazon.de wishlist
The library is avaible on Nuget, too: http://nuget.org/packages/ARSoft.Tools.Net
RFC 4406 - Sender ID: Authenticating E-Mail
RFC 4408 - Sender Policy Framework (SPF)
RFC 7208 - Sender Policy Framework (SPF) for Authorizing Use of Domains in Email, Version 1
RFC 4648 - The Base16, Base32, and Base64 Data Encodings
DNS Client
Client for Link-Local Multicast Name Resolution
One-shot-client for Multicast DNS
(Multithreaded) DNS Server
Supports synchronous as well as asynchronous resolving
Discovery of local configured resolver dns servers on Windows and Linux
Different resolvers
Stub resolver
Recursive resolver
DNSSEC validating stub resolver
DNSSEC validating recursive resolver
UDP and TCP support
Full IPv6 support
DANE validation stream class
RFC 1034 - Domain Names - Concepts and Facilities
RFC 1035 - Domain Names - Implementation and Specification
RFC 1183 - New DNS RR Definitions
RFC 1348 - DNS NSAP RRs
RFC 1637 - DNS NSAP Resource Records
RFC 1706 - DNS NSAP Resource Records
RFC 1712 - DNS Encoding of Geographical Location
RFC 1876 - A Means for Expressing Location Information in the Domain Name System
RFC 1995 - Incremental Zone Transfer
RFC 1996 - A Mechanism for Prompt Notification of Zone Changes (DNS NOTIFY)
RFC 2136 - Dynamic Updates in the Domain Name System
RFC 2163 - Using the Internet DNS to Distribute MIXER Conformant Global Address Mapping (MCGAM)
RFC 2168 - Resolution of Uniform Resource Identifiers using the Domain Name System
RFC 2181 - Clarifications to the DNS Specification
RFC 2230 - Key Exchange Delegation Record for the DNS
RFC 2308 - Negative Caching of DNS Queries (DNS NCACHE)
RFC 2535 - Domain Name System Security Extensions
RFC 2536 - DSA KEYs and SIGs in the Domain Name System
RFC 2537 - RSA/MD5 KEYs and SIGs in the Domain Name System
RFC 2539 - Storage of Diffie-Hellman Keys in the Domain Name System
RFC 2671 - Extension Mechanisms for DNS (EDNS0)
RFC 2672 - Non-Terminal DNS Name Redirection
RFC 2673 - Binary Labels in the Domain Name System
RFC 2782 - A DNS RR for specifying the location of services (DNS SRV)
RFC 2845 - Secret Key Transaction Authentication for DNS (TSIG)
RFC 2915 - The Naming Authority Pointer (NAPTR) DNS Resource Record
RFC 2930 - Secret Key Establishment for DNS (TKEY RR)
RFC 2931 - DNS Request and Transaction Signatures (SIG(0)s) (Record parsing only)
RFC 3110 - RSA/SHA-1 SIGs and RSA KEYs in the Domain Name System
RFC 3123 - A DNS RR Type for Lists of Address Prefixes (APL RR)
RFC 3225 - Indicating Resolver Support of DNSSEC
RFC 3226 - DNSSEC and IPv6 A6 aware server/resolver message size requirements
RFC 3403 - Dynamic Delegation Discovery System (DDDS)
RFC 3425 - Obsoleting IQUERY
RFC 3596 - DNS Extensions to Support IP Version 6
RFC 3597 - Handling of Unknown DNS Resource Record (RR) Types
RFC 3658 - Delegation Signer (DS) Resource Record (RR)
RFC 3755 - Legacy Resolver Compatibility for Delegation Signer (DS)
RFC 3757 - Domain Name System KEY (DNSKEY) Resource Record (RR) Secure Entry Point (SEP) Flag
RFC 4025 - A Method for Storing IPsec Keying Material in DNS
RFC 4033 - DNS Security Introduction and Requirements
RFC 4034 - Resource Records for the DNS Security Extensions
RFC 4035 - Protocol Modifications for the DNS Security Extensions
RFC 4255 - Using DNS to Securely Publish Secure Shell (SSH) Key Fingerprints
RFC 4398 - Storing Certificates in the Domain Name System (DNS)
RFC 4431 - The DNSSEC Lookaside Validation (DLV) DNS Resource Record
RFC 4509 - Use of SHA-256 in DNSSEC Delegation Signer (DS) Resource Records (RRs)
RFC 4635 - HMAC SHA TSIG Algorithm Identifiers
RFC 4701 - A DNS Resource Record (RR) for Encoding Dynamic Host Configuration Protocol (DHCP) Information (DHCID RR)
RFC 4795 - Link-Local Multicast Name Resolution (LLMNR)
RFC 5001 - DNS Name Server Identifier (NSID) Option
RFC 5155 - DNS Security (DNSSEC) Hashed Authenticated Denial of Existence
RFC 5205 - Host Identity Protocol (HIP) Domain Name System (DNS) Extension
RFC 5452 - Measures for Making DNS More Resilient against Forged Answers
RFC 5702 - Use of SHA-2 Algorithms with RSA in DNSKEY and RRSIG Resource Records for DNSSEC
RFC 5864 - DNS SRV Resource Records for AFS
RFC 5933 - Use of GOST Signature Algorithms in DNSKEY and RRSIG Resource Records for DNSSEC
RFC 5936 - DNS Zone Transfer Protocol (AXFR)
RFC 5966 - DNS Transport over TCP - Implementation Requirements
RFC 6563 - Moving A6 to Historic Status
RFC 6594 - Use of the SHA-256 Algorithm with RSA, Digital Signature Algorithm (DSA), and Elliptic Curve DSA (ECDSA) in SSHFP Resource Records
RFC 6605 - Elliptic Curve Digital Signature Algorithm (DSA) for DNSSEC
RFC 6672 - DNAME Redirection in the DNS (Record parsing only)
RFC 6698 - The DNS-Based Authentication of Named Entities (DANE) Transport Layer Security (TLS) Protocol: TLSA
RFC 6742 - DNS Resource Records for the Identifier-Locator Network Protocol (ILNP)
RFC 6762 - Multicast DNS (One-shot queries only)
RFC 6840 - Clarifications and Implementation Notes for DNS Security (DNSSEC)
RFC 6844 - DNS Certification Authority Authorization (CAA) Resource Record
RFC 6891 - Extension Mechanisms for DNS (EDNS(0))
RFC 6975 - Signaling Cryptographic Algorithm Understanding in DNS Security Extensions (DNSSEC)
RFC 7043 - Resource Records for EUI-48 and EUI-64 Addresses in the DNS
RFC 7129 - Authenticated Denial of Existence in the DNS
RFC 7208 - Sender Policy Framework (SPF) for Authorizing Use of Domains in Email, Version 1
RFC 7218 - Adding Acronyms to Simplify Conversations about DNS-Based Authentication of Named Entities (DANE)
RFC 7314 - Extension Mechanisms for DNS (EDNS) EXPIRE Option
RFC 7344 - Automating DNSSEC Delegation Trust Maintenance
RFC 7477 - Child-to-Parent Synchronization in DNS
RFC 7479 - Using Ed25519 in SSHFP Resource Records
RFC 7553 - The Uniform Resource Identifier (URI) DNS Resource Record
RFC 7766 - DNS Transport over TCP - Implementation Requirements
RFC 7828 - The edns-tcp-keepalive EDNS0 Option (Option parsing only)
RFC 7830 - The EDNS(0) Padding Option
RFC 7858 - Specification for DNS over Transport Layer Security (TLS)
RFC 7871 - Client Subnet in DNS Queries (Option parsing only)
RFC 7873 - Domain Name System (DNS) Cookies (Option parsing only)
RFC 7929 - DNS-Based Authentication of Named Entities (DANE) Bindings for OpenPGP
RFC 8005 - Host Identity Protocol (HIP) Domain Name System (DNS) Extension
RFC 8080 - Edwards-Curve Digital Security Algorithm (EdDSA) for DNSSEC
RFC 8162 - Using Secure DNS to Associate Certificates with Domain Names for S/MIME
RFC 8427 - Representing DNS Messages in JSON
RFC 8484 - DNS Queries over HTTPS (DoH)
RFC 8749 - Moving DNSSEC Lookaside Validation (DLV) to Historic Status
RFC 8777 - DNS Reverse IP Automatic Multicast Tunneling (AMT) Discovery
RFC 8945 - Secret Key Transaction Authentication for DNS (TSIG)
RFC 8976 - Message Digest for DNS Zones
RFC 9210 - DNS Transport over TCP - Operational Requirements
RFC 9373 - EdDSA Value for IPSECKEY
draft-vixie-dnsext-dns0x20 - Use of Bit 0x20 in DNS Labels to Improve Transaction Identity
draft-sekar-dns-llq - DNS Long-Lived Queries
draft-sekar-dns-ul - Dynamic DNS Update Leases
draft-cheshire-edns0-owner-option - EDNS0 OWNER Option
draft-ietf-dnsop-svcb-https - Service binding and parameter specification via the DNS (DNS SVCB and HTTPS RRs) (Record parsing only)
The library is released under Apache License 2.0