NetDuid 1.1.0
dotnet add package NetDuid --version 1.1.0
NuGet\Install-Package NetDuid -Version 1.1.0
<PackageReference Include="NetDuid" Version="1.1.0" />
paket add NetDuid --version 1.1.0
#r "nuget: NetDuid, 1.1.0"
// 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
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
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 |
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 to0
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:
- Robert H. Engelhardt
- Drew Antonich
- Stephen Jackson
- Sterling Violette
- Madison Brewer
Copyright
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 | Versions 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. |
-
.NETStandard 2.0
- Microsoft.Bcl.HashCode (>= 6.0.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.