Sidub.Platform.NumberSequence
1.1.2
Prefix Reserved
dotnet add package Sidub.Platform.NumberSequence --version 1.1.2
NuGet\Install-Package Sidub.Platform.NumberSequence -Version 1.1.2
<PackageReference Include="Sidub.Platform.NumberSequence" Version="1.1.2" />
paket add Sidub.Platform.NumberSequence --version 1.1.2
#r "nuget: Sidub.Platform.NumberSequence, 1.1.2"
// Install Sidub.Platform.NumberSequence as a Cake Addin #addin nuget:?package=Sidub.Platform.NumberSequence&version=1.1.2 // Install Sidub.Platform.NumberSequence as a Cake Tool #tool nuget:?package=Sidub.Platform.NumberSequence&version=1.1.2
Sidub Platform - Number Sequence
This repository contains the number sequence module for the Sidub Platform. It provides the ability to generate and manage number sequences. Number sequences are structured sequences of characters that are used to generate unique identifiers and may be used for invoice numbers, order numbers, and other various identifiers.
Main Components
Number sequence service
The number sequence service (INumberSequenceService
) allows the retrieval of
a number sequence provider provided an options instance. An option class is
available for each of the available number sequence types - random, sequential,
GUID.
Usage
To use the Sidub Platform number sequence module, you can register it within your dependency injection container and use the provided interfaces and classes to work with number sequence providers.
public void ConfigureServices(IServiceCollection services)
{
services.AddSidubNumberSequence();
}
The AddSidubNumberSequence
method registers the required services and providers
within the containers.
Unique identifier (GUID)
The unique identifier number sequence provider returns number sequences as unique identifiers (GUIDs). The unique identifier may be retrieved as a Guid, byte[], or string.
public class MyService
{
private readonly IMetadataService _metadataService;
public MyService(IMetadataService metadataService)
{
_metadataService = metadataService;
}
public async Task Process()
{
var options = new GuidNumberSequenceOptions();
var provider = _numberSequenceService.GetProvider(options);
var guidSequence = await provider.GetValue<Guid>(options);
var byteSequence = await provider.GetValue<byte[]>(options);
var stringSequence = await provider.GetValue<string>(options);
Guid guidResult = guidSequence.Value;
byte[] byteResult = byteSequence.Value;
string stringResult = stringSequence.Value;
}
}
Sequential number sequence
The sequential number sequence provider returns number sequences as a sequence of characters. Integer, long, short, and string are supported sequence value types. These providers maintain state and state providers are used to maintain state; interally, in-memory state providers are available leaving the responsibility of the implementation to maintain the provider's state. Additional libraries extend the state provider to use a database or other storage mechanism.
The below example demonstates the integer and string implementations which vary slightly - the string implementation requires the configuraiton of the width of the sequence.
public class MyService
{
private readonly IMetadataService _metadataService;
public MyService(IMetadataService metadataService)
{
_metadataService = metadataService;
}
public async Task ProcessInteger()
{
var sequentialProvider = new SequentialNumberSequenceInMemoryIntStateProvider();
var options = new SequentialNumberSequenceOptions<int>(sequentialProvider);
var provider = _numberSequenceService.GetProvider(options);
// retrieve number sequence...
var sequenceValue = await provider.GetValue<int>(options);
int result = result.Value; // 0
sequenceValue = await provider.GetValue<int>(options);
result = result.Value; // 1
}
public async Task ProcessString()
{
// configure an in-memory state provider for the sequential number provider,
// set width to 5...
var sequentialProvider = new SequentialNumberSequenceInMemoryStringStateProvider(5);
var options = new SequentialNumberSequenceOptions<string>(sequentialProvider);
var provider = _numberSequenceService.GetProvider(options);
// retrieve number sequence value...
var sequenceValue = await provider.GetValue<string>(options);
string result = result.Value; // "00000"
sequenceValue = await provider.GetValue<string>(options);
result = result.Value; // "00001"
}
}
Random number sequence
The random number sequence provider determines the number sequence using randomness and currently does not guarantee uniqueness; maintaining state may be introduced in the future to support this. Random number sequences may be retrieved as an integer, long, short, or string and are configured using a length parameter on the options. The length defines the number of characters in the sequence.
Be wary of the length and data type combinations as the length may exceed the maximum value supported of the data type. For example, an integer has a maximum value of 2,147,483,647 and a length of 10 could exceed this value and a length of 11 would. This limitation only exists for numeric types and tends not to be an issue for string types.
public class MyService
{
private readonly IMetadataService _metadataService;
public MyService(IMetadataService metadataService)
{
_metadataService = metadataService;
}
public async Task Process()
{
var options = new RandomNumberSequenceOptions(10);
var provider = _numberSequenceService.GetProvider(options);
var stringSequence = await provider.GetValue<string>(options);
string stringResult = stringSequence.Value; // i.e., "d8k30lo42w"
var intSequence = await provider.GetValue<int>(options);
int intResult = intSequence.Value; // i.e., 1136863213
}
}
License
This project is dual-licensed under the AGPL v3 or a proprietary license. For details, see https://sidub.ca/licensing or the LICENSE.txt file.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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 was computed. 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 was computed. 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 was computed. 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.Extensions.DependencyInjection.Abstractions (>= 8.0.0)
- Microsoft.SourceLink.AzureRepos.Git (>= 8.0.0)
- Sidub.Platform.Core (>= 1.7.13)
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.2 | 149 | 3/16/2024 |