Trivial 9.0.0-preview7
dotnet add package Trivial --version 9.0.0-preview7
NuGet\Install-Package Trivial -Version 9.0.0-preview7
<PackageReference Include="Trivial" Version="9.0.0-preview7" />
paket add Trivial --version 9.0.0-preview7
#r "nuget: Trivial, 9.0.0-preview7"
// Install Trivial as a Cake Addin #addin nuget:?package=Trivial&version=9.0.0-preview7&prerelease // Install Trivial as a Cake Tool #tool nuget:?package=Trivial&version=9.0.0-preview7&prerelease
Trivial
Includes utilities and services for tasks, security, JSON, etc.
Tasks
using Trivial.Tasks;
Interceptor
Set an action with a specific interceptor to control its execution.
Interceptor.Debounce
: Request to invoke a specific action several times in a short time but only the last one should be executed and previous ones should be ignored. A sample is real-time search suggestion.Interceptor.Throttle
: Raise actually only once in a short time even if invoke several times. A sample is the submit button in a form.Interceptor.Times
: The action can be only executed only when invoke in the specific times range and others will be ignored. A sample is double click.Interceptor.Multiple
: A handler to execute for the specific times and the state will be reset after a while.
// Set an action with interceptor.
var action = Interceptor.Debounce(() =>
{
// Do something...
}, TimeSpan.FromMilliseconds(200));
// Invoke somewhere.
action();
Retry
Create a linear retry policy by LinearRetryPolicy
or a customized one to process an action with the specific retry policy.
And you can use ObservableTask
to observe the state of an action processing.
Network
Contains the helper functions and extension functions for network, such as HTTP web client and its content.
using Trivial.Net;
Use JsonHttpClient
to serialize the JSON format response with additional retry policy.
And HttpUri
for HTTP URI fields accessing.
Security
using Trivial.Security;
Access token
Provide a set of tools for OAuth including following models.
TokenInfo
The access token and other properties.AppAccessingKey
The app identifier and secret key.OAuthClient
The token container with the ability to resolve the access token and create the JSON HTTP web client to access the resources required authentication.
Optional to implement the OAuthBasedClient
base class to create your own business HTTP web client factory with OAuth supports.
JWT
Create a JSON web token to get the string encoded by initializing a new instance of the JsonWebToken
class or the JsonWebTokenParser
class.
var sign = HashSignatureProvider.CreateHS512("a secret string");
var jwt = new JsonWebToken<JsonWebTokenPayload>(new JsonWebTokenPayload
{
Id = Guid.NewGuid().ToString("n"),
Issuer = "example"
}, sign);
// Get authenticiation header value.
var header = jwt.ToAuthenticationHeaderValue();
// Parse.
var jwtSame = JsonWebToken<Model>.Parse(jwtStr, sign); // jwtSame.ToEncodedString() == header.Parameter
RSA
Convert a PEM (OpenSSL RSA key) or an XML string to the RSAParameters
struct.
var parameters = RSAParametersConvert.Parse(pem);
And convert back by extension method ToPrivatePEMString
or ToPublicPEMString
.
Or to XML by extension method ToXElement
.
Symmetric & Hash
Use a symmetric algorithm to encrypt and decrypt a string by calling SymmetricUtilities.Encrypt
and SymmetricUtilities.DecryptText
functions.
For hash algorithm, you can call HashUtilities.ToHashString
function to get hash from a plain string and call HashUtilities.Verify
to verify.
Secure string
Convert the secret between SecureString
and String
/StringBuilder
/Byte[]
by the SecureStringExtensions
class.
And class RSASecretExchange
is used to transfer the secret by RSA encryption.
Text
using Trivial.Text;
JSON
Includes writable JSON DOM JsonObjectNode
and JsonArrayNode
.
And includes lots of useful converter like following.
JsonJavaScriptTicksConverter
and its fallback converters to convertDateTime
from/to JavaScript ticks number in JSON.JsonUnixTimestampConverter
and its fallback converters to convertDateTime
from/to Unix timestamp number in JSON.JsonNumberConverter
andJsonNumberConverter.NumberStringConverter
, to read number string in JSON.JsonStringListConverter
and its character separated converters (such asJsonStringListConverter.WhiteSpaceSeparatedConverter
) to convert a string list from/to a string in JSON.
CSV
Read CSV or TSV file into a list of the specific models.
For example, you have a model class CsvModel
with string properties A
and B
, now you can map to the CSV file.
var csv = new CsvParser("abcd,efg\nhijk,lmn");
foreach (var model in csv.ConvertTo<CsvModel>(new[] { "A", "B" }))
{
Console.WriteLine("{0},{1}", model.A, model.B);
}
Data
using Trivial.Data;
Cache
Save a number of model in memory cache by generic class DataCacheCollection
.
Drawing
using Trivial.Drawing;
Color calculator
Color adjustment, converter, parser and mixer.
var color = ColorCalculator.Parse("rgb(226, 37, 0xA8)");
color = ColorCalculator.Opacity(color, 0.9);
color = ColorCalculator.Saturate(color, RelativeSaturationLevels.High);
color = ColorCalculator.Mix(ColorMixTypes.Lighten, color, Color.FromArgb(0, 240, 0));
Mathematics
using Trivial.Maths;
Arithmetic
There are a lot of arithmetic functions.
Arithmetic.IsPrime(2147483647); // True
Arithmetic.Gcd(192, 128); // 64
Numerals
Get the number symbols as you want. And get the numerals in English.
EnglishNumerals.Default.ToString(12345.67);
// twelve thousand three hundred and forty-five point six seven
EnglishNumerals.Default.ToApproximationString(1234567);
// 1.2M
And ChineseNumerals
for Chinese and JapaneseNumerals
for Japanese.
Angle and polar point
Angle
Angle.PolarPoint
The point in polar coordinates.SphericalPoint
The point in spherical coordinates.
Set
NullableValueSimpleInterval<T>
Interval, such as[20, 100)
.
Rectangular coordinates
IntPoint1D
DoublePoint1D
The point in 1D (line) coordinates.IntPoint2D
DoublePoint2D
The point in 2D (flat) coordinates.IntPoint3D
DoublePoint3D
The point in 3D (stereoscophic) coordinates.SpacetimePoint
The point in 4D (spacetime) coordinates.
Further
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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 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 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. |
.NET Framework | net461 is compatible. net462 is compatible. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 is compatible. net481 was computed. |
-
.NETFramework 4.6.1
- System.Net.Http (>= 4.3.4)
- System.Text.Json (>= 6.0.11)
-
.NETFramework 4.6.2
- System.Net.Http (>= 4.3.4)
- System.Text.Json (>= 9.0.0)
-
.NETFramework 4.8
- System.Net.Http (>= 4.3.4)
- System.Text.Json (>= 9.0.0)
-
net6.0
- No dependencies.
-
net8.0
- No dependencies.
-
net9.0
- No dependencies.
NuGet packages (10)
Showing the top 5 NuGet packages that depend on Trivial:
Package | Downloads |
---|---|
Trivial.Console
The console utilities and rich user interface console. |
|
Trivial.WindowsKit
Some advanced visual controls and utilities for Windows app. |
|
NuScien
A core library of NuScien framework which provides a solution to build community and enterprise projects based on resource entity and accessories with ACL and CMS built-in. |
|
Trivial.Chemistry
A library with basic chemical models. |
|
Trivial.Web
A library for web API. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated | |
---|---|---|---|
9.0.0-preview7 | 18 | 11/22/2024 | |
9.0.0-preview6 | 84 | 11/13/2024 | |
9.0.0-preview5 | 52 | 11/1/2024 | |
9.0.0-preview4 | 39 | 10/30/2024 | |
9.0.0-preview3 | 68 | 10/27/2024 | |
9.0.0-preview2 | 89 | 9/8/2024 | |
9.0.0-preview1 | 124 | 8/21/2024 | |
8.0.0 | 1,027 | 6/12/2024 | |
8.0.0-preview8 | 141 | 4/13/2024 | |
8.0.0-preview7 | 111 | 3/7/2024 | |
8.0.0-preview6 | 113 | 3/6/2024 | |
8.0.0-preview5 | 96 | 3/1/2024 | |
8.0.0-preview4 | 126 | 2/29/2024 | |
8.0.0-preview3 | 110 | 2/28/2024 | |
8.0.0-preview2 | 109 | 2/27/2024 | |
8.0.0-preview1 | 138 | 2/21/2024 | |
7.2.0 | 2,566 | 11/16/2023 | |
7.2.0-preview1 | 450 | 8/1/2023 | |
7.1.2 | 1,362 | 5/10/2023 | |
7.1.1 | 426 | 5/10/2023 | |
7.1.0 | 590 | 5/8/2023 | |
7.0.0 | 1,402 | 1/20/2023 | |
6.6.0 | 3,686 | 11/9/2022 | |
6.5.6 | 1,295 | 10/10/2022 | |
6.5.5 | 640 | 10/9/2022 | |
6.5.4 | 1,032 | 8/10/2022 | |
6.5.0 | 710 | 6/17/2022 | |
6.4.0 | 2,835 | 4/14/2022 | |
6.3.0 | 2,016 | 3/8/2022 | |
6.2.0 | 4,643 | 1/30/2022 | |
6.1.0 | 1,919 | 1/23/2022 | |
6.0.0 | 1,458 | 1/1/2022 | |
5.2.0 | 4,962 | 12/15/2021 | |
5.1.1 | 629 | 12/3/2021 | |
5.1.0 | 1,392 | 12/2/2021 | |
5.0.0 | 1,413 | 11/27/2021 | |
4.0.0 | 1,123 | 11/9/2021 | |
3.9.0 | 1,449 | 12/15/2021 | |
3.8.0 | 1,262 | 11/9/2021 | |
3.7.2 | 9,462 | 4/22/2021 | |
3.7.0 | 1,642 | 3/17/2021 | |
3.6.2 | 949 | 3/17/2021 | |
3.6.0 | 7,037 | 11/12/2020 | |
3.5.2 | 7,777 | 4/13/2020 | |
3.5.1 | 1,498 | 4/12/2020 | |
3.5.0 | 1,484 | 4/1/2020 | |
3.4.3 | 1,422 | 3/20/2020 | |
3.4.2 | 1,384 | 3/12/2020 | |
3.4.1 | 1,427 | 2/25/2020 | |
3.4.0 | 1,722 | 2/20/2020 | |
3.3.0 | 1,804 | 2/14/2020 | |
3.2.0 | 2,120 | 1/22/2020 | |
3.1.0 | 2,185 | 12/30/2019 | |
3.0.1 | 2,027 | 12/26/2019 | |
2.2.0 | 1,193 | 2/19/2020 | |
2.1.0 | 1,719 | 12/24/2019 | |
2.0.3 | 1,575 | 12/3/2019 | |
1.2.0 | 31,200 | 5/20/2019 | |
1.1.0 | 2,160 | 5/8/2019 | |
1.0.0 | 4,189 | 5/1/2019 |