The NetDuid
library was developed by the Production Tools Team at Sandia National Laboratories. The primary motivation behind this project is to provide a robust and efficient .NET representation of DHCP Unique Identifiers (DUIDs) as specified in RFC 8415, "Dynamic Host Configuration Protocol for IPv6 (DHCPv6)" and RFC 6355, "Definition of the UUID-Based DHCPv6 Unique Identifier (DUID-UUID)". DUIDs are essential in the context of DHCPv6, where they are used to uniquely identify clients and servers.
The main goals of this project are:
- Standards Compliance: Ensure full compliance with the relevant RFCs to accurately represent and manipulate DUIDs.
- Ease of Use: Provide a simple and intuitive API for developers to work with DUIDs in .NET applications.
- Performance: Optimize the library for performance, ensuring that it can handle large volumes of DUIDs efficiently.
- Cross-Platform and Target Support: Target multiple .NET versions to ensure compatibility across different platforms and environments.
- Parsing and Construction: Easily parse DUIDs from strings or construct them from byte arrays.
- Comparison and Equality: Implement comparison and equality operations for DUIDs.
- Formatting: Convert DUIDs to formatted string representations for display or logging.
This library is intended for use in various scenarios, including but not limited to:
- Network Configuration: Managing and configuring network devices that use DHCPv6.
- Logging and Monitoring: Tracking and logging DUIDs in network traffic for monitoring and analysis.
- Testing and Simulation: Simulating DHCPv6 clients and servers in test environments.
You are most likely to be interacting with the NetDuid.Duid
type.
The Duid
type implements IEquatable<Duid>
, IComparable<Duid>
, IFormattable
, ISerializable
, and for .NET 7 and greater IParsable<Duid>
.
The library "knows" RFC 8415 ("Link-layer address plus time", "Vendor-assigned unique ID based on Enterprise Number", and "Link-layer address") and RFC 6355 ("Universally Unique Identifier (UUID)") DUIDs, but can treat any valid byte
array (a minimum of 3 bytes, and maximum of 130 bytes per the RFCs) as a DUID. An unhandled DUID type will be treated as an "Undefined" type, but otherwise functionality is identical.
The most common way to create a DUID is to construct it via an array of byte
data.
var duidBytes = new byte[] { 0x00, 0x01, 0x02, 0x03 };
var duid = new Duid(duidBytes);
You can also parse a DUID from a string
using the TryParse
or Parse
methods.
The parsing methods expect either a string
of hexadecimal octet pairs optionally delimited by a single dash (-
), colon (:
) or space character. The leading 0
in a delimited pair may be omitted. Input strings will be trimmed prior to parsing, and casing is ignored.
if (Duid.TryParse("00:01:02:03", out var parsedDuid))
{
Console.WriteLine(parsedDuid.ToString());
}
or
var parsedDuidB = Duid.Parse("00:01:A2:b3");
var parsedDuidA = Duid.Parse("00-01-A2-b3");
var parsedDuidC = Duid.Parse("0001A2b3");
var parsedDuidD = Duid.Parse("0:1:A2:b3");
ToString()
and ToString(string format, IFormatProvider formatProvider)
Converts the DUID to a formatted string representation.
There exist three generally recognized DUID string formats with upper and lower case variants:
- Colon delimited e.g.
00:01:A2:B3
or00:01:a2:b3
. Note that upper cased colon delimited is the default format. - Dash delimited e.g.
00-01-A2-B3
or00-01-a2-b3
. - Non-delimited e.g.
0001A2B3
or0001a2b3
.
Simply calling ToString()
will return the default format of upper cased colon delimited string. However, as the Duid type implements IFormattable
there are other formatting options available as well.
Format String | Description | Example Output |
---|---|---|
null , empty string, : , U: |
Uppercase with colon delimiter (default) | 00:01:A2:B3 |
U- |
Uppercase with dash delimiter | 00-01-A2-B3 |
U |
Uppercase with no delimiter | 0001A2B3 |
L: |
Lowercase with colon delimiter | 00:01:a2:b3 |
L- |
Lowercase with dash delimiter | 00-01-a2-b3 |
L |
Lowercase with no delimiter | 0001a2b3 |
Calling GetBytes()
will return a read only collection of the underlying bytes of a DUID.
Accessing the Duid.Type
property will return a NetDuid.DuidType
enum based examining on the 2-octet type code of the DUID. The type code is the first two bytes of the DUID in big-endian order. It is generally recommended that a DUID is not interpreted outside of being an opaque array of bytes, as such the type is a best guess based on hints and should not be interpreted as definitive.
The DuidType
enum emits the following values
Enum Value | Description | RFC |
---|---|---|
Undefined |
Any DUID with a type code not specified in RFC 8415 or RFC 6355. | not applicable |
LinkLayerPlusTime |
Link-layer address plus time (DUID type code 0x0001 ). |
RFC 8415 |
VendorAssigned |
Vendor-assigned unique ID based on Enterprise Number (DUID type code 0x0002 ). |
RFC 8415 |
LinkLayer |
Link-layer address (DUID type code 0x0003 ). |
RFC 8415 |
Uuid |
Universally Unique Identifier (UUID) (DUID type code 0x0004 ). |
RFC 6355 |
The Duid
class implements IEquatable<Duid>
, IComparable<Duid>
, IComparable
and the standard Equality and Comparison operators.
The CompareTo
, and its operators, is not done in mathematical order or bytes, but rather first by byte length then by unsigned value. When using the comparison operators a null
value is considered less than any non-null
value.
This project was built with the aid of:
The project has no runtime library dependencies outside of Microsoft.Bcl.HashCode
when targeting .NET Standard 2.0.
This project uses Semantic Versioning
The project targets .NET Standard 2.0, .NET 6, .NET 7, and .NET 8. The test project similarly targets .NET 6, .NET 7, and .NET 8, but targets .NET Framework 4.8 for the .NET Standard 2.0 tests.
The project itself has a configured pre-commit git hook, via Husky.Net that automatically lints and formats code via dotnet format and csharpier.
Per the Husky.Net instructions
You can set the
HUSKY
environment variable to0
in order to disable husky in CI/CD pipelines.
On occasion a manual run is desired it may be done so via the src
directory and with the command
dotnet format style; dotnet format analyzers; dotnet csharpier .
These commands may be called independently, but order may matter.
After making changes tests should be run that include all targets
This project was built by the Production Tools Team at Sandia National Laboratories. Special thanks to all contributors and reviewers who helped shape and improve this library.
Including, but not limited to:
- Robert H. Engelhardt
- Drew Antonich
- Stephen Jackson
- Sterling Violette
Copyright 2024 National Technology & Engineering Solutions of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with NTESS, the U.S. Government retains certain rights in this software
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
This project is licensed under the terms of Contract DE-NA0003525 with NTESS. The U.S. Government retains certain rights in this software.