NetDuid 1.1.0

dotnet add package NetDuid --version 1.1.0                
NuGet\Install-Package NetDuid -Version 1.1.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="NetDuid" Version="1.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add NetDuid --version 1.1.0                
#r "nuget: NetDuid, 1.1.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install NetDuid as a Cake Addin
#addin nuget:?package=NetDuid&version=1.1.0

// Install NetDuid as a Cake Tool
#tool nuget:?package=NetDuid&version=1.1.0                

NetDuid

GitHub Actions Workflow Status NuGet Version GitHub Release GitHub Tag Targets

About the Project

Background

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.

Goals

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.

Features

  • 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.

Use Cases

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.

Getting Started

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.

Creating a DUID

Via Constructor

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);
Parsing a string to a DUID

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");

Formatting

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 or 00:01:a2:b3. Note that upper cased colon delimited is the default format.
  • Dash delimited e.g. 00-01-A2-B3 or 00-01-a2-b3.
  • Non-delimited e.g. 0001A2B3 or 0001a2b3.

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

Gathering Information about a DUID

Bytes

Calling GetBytes() will return a read only collection of the underlying bytes of a DUID.

DUID Types

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

Equality and Comparison

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.

Developer Notes

Built With

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.

Versioning

This project uses Semantic Versioning

Targeting

The project targets .NET Standard 2.0, .NET 6, .NET 7, .NET 8, and .NET 9. The test project similarly targets .NET 6, .NET 7, .NET 8, .NET 9, but targets .NET Framework 4.8 for the .NET Standard 2.0 tests.

Commit Hook

The project itself has a configured pre-commit git hook, via Husky.Net that automatically lints and formats code via dotnet format and csharpier.

Disable husky in CI/CD pipelines

Per the Husky.Net instructions

You can set the HUSKY environment variable to 0 in order to disable husky in CI/CD pipelines.

Manual Linting and Formatting

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.

Testing

After making changes tests should be run that include all targets

Acknowledgments

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:

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

License

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.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 is compatible.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETStandard 2.0

  • net6.0

    • No dependencies.
  • net7.0

    • No dependencies.
  • net8.0

    • No dependencies.
  • net9.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.1.0 44 1/17/2025
1.0.0 49 1/8/2025