Calebs.Extensions
1.7.0
dotnet add package Calebs.Extensions --version 1.7.0
NuGet\Install-Package Calebs.Extensions -Version 1.7.0
<PackageReference Include="Calebs.Extensions" Version="1.7.0" />
paket add Calebs.Extensions --version 1.7.0
#r "nuget: Calebs.Extensions, 1.7.0"
// Install Calebs.Extensions as a Cake Addin #addin nuget:?package=Calebs.Extensions&version=1.7.0 // Install Calebs.Extensions as a Cake Tool #tool nuget:?package=Calebs.Extensions&version=1.7.0
Calebs.Extensions
Useful extension methods and attributes for working with enums, strings and lists. The majority of these extensions were born out of working with various models while building micro services.
Installing Calebs.Extensions
You should install Extensions with NuGet:
Install-Package Calebs.Extensions
Or via the .NET Core command line interface:
dotnet add package Calebs.Extensions
Either command, from Package Manager Console or .NET Core CLI, will download and install Calebs.Extensions and all required dependencies.
.NET 7
These extensions target .NET 6 and .NET 7. With .NET 7 the Calebs.Extensions.Validators
include EnumStringValidator<T>
. The ability for Attributes to support <T> was added with .NET 7.
Helpers - not really extensions
EnumStringValidator
Used for string properties in models that are supposed to conform to an enum value. The philosophy of my micro-services have been to be liberal in what you accept and conservative in what you send.
Let's propose a scenario:
- you are recieving a message (model) that represents an account
with a field accountType
. Now, in this scenarios accountType
could be Standard, Silver or Gold
values. The easy way to restrict this is with en enum. The problem is - that if the incoming message doesn't exactly have one of those values (say "AccountStatus":"Gold-Status"
is passed in instead of "AccountStatus":"Gold"
), and if you are leveraging Microsoft Web API
with model binding - then it is likely that model binding will fail and you will return a 400 - Bad Request
by default. This is the correct response, but you might want to log what was actually sent, or add additional context like an error message stating what field or fields were incorrect and what values are supported for that field. This makes for a much more developer friendly API.
So instead of having your model directly bind to an enum - and throw a Bad Request exception - you can accept a string
in that field, and use the Calebs.Extensions.Validators.EnumStringValidatorAttribute
to perform model validation and then decide how to handle the errors.
SystemIO
IFileIO
A collection of thin shims for common File IO opperations. Helpful when you want to mock out the File IO opperations for testing.
The interface IFileIO
- every method is so slim that they each have a default implementaion. The default implementation FileIO
jump implements the Interface, but doesn't need to implement any of the methods.
To use this helper - register IFileIO
is your DI
with FileIO
as the implmentation. For unit tests use something like nSubstitute
to mock out and intercept interactions through IFileIO
methods.
- GetFiles(path, filter) // returns a string []
- GetFileInfo(path)
- GetFileAttributes(path)
- DirectoryExists(path)
- GetDirectoryName(path)
- ReadAllText (path)
- FileExists(path)
- WriteAllLines(path, lines)
- DeleteFile(path)
- CreateDirectory (path)
- DeleteDirectory (path)
Extension Methods
EnumExtensions
- ToList<D> -
- ToList(Type)
- Description (enum)
- Description<ToDesc>(Enum)
- Parse<T>
- Parse <T, D>
IntExtensions
- RandomText // For integers between 1 and 1000 -- returns a random string with that length
StringExtensions
- IsNotNullOrEmpty
- IsNullOrEmpty
- Compare
- string?.ValueOrEmpty()
ObjectExtensions
- ToSafeString()
ListExtensions
- ToDelimitedList
- ToUpper
- AddRange -
IList<T>.AddRange(IList<T>)
- AddUnlessBlank IList<string>.AddUnlessBlank(string)
JsonExtensions
For both of these extension methods I'm using the Newtonsoft.Json
library. I'm planning on migrating to System.Text.Json
as soon as it is viable. Right now, Newtonsoft is easeir to serialize enums to thier ToString() value rather than index, and to deserialize the same. For example, by default - an enum is serialized to the index of the value. So an enum with (High, Med, Low) values would otherwise be serialiezed to a 2, instead of to "Med". Serializing to "Med" is my prefered behavior. I will continue to evailuate System.Text.Json
against these unit tests and most likely migrate at some point.
- ToJson<T>
- FromJson
Versioning
This package follow semantic versioning as much as possible.
Contributions
Please submit PR's to the develop
branch.
Merges to deveoper
automtically run all unit tests and publish a nuget package with the postfix -ci-build_number
Merges to main
publish to nuget as a major release.
Change Log
- 1.1.0 - added IList.AddRange extension method
- 1.2.0 - never published - only preview
- 1.3.0 - added
IFileIO
- an interface + implementation for making common filesystem opperations easier to test - 1.3.1 - suppressed some test warnings and updated the GH workflows
- 1.4.0 - added
CreatedDiretory
andDeleteDirectory
toIFileIO
- 1.5.0 - Added package logo and
ToSafeString
forObjectExtensions
- 1.6.0 - Added AddUnlessBlank to list extensions
- 1.7.0 - Added
IntExtensions
and expandedIFileIO
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 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 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. |
-
net6.0
- Newtonsoft.Json (>= 13.0.3)
-
net7.0
- Newtonsoft.Json (>= 13.0.3)
-
net8.0
- Newtonsoft.Json (>= 13.0.3)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on Calebs.Extensions:
Package | Downloads |
---|---|
Calebs.KeyValueRepo
a library abstraction for KeyValue data stores. |
|
Calebs.KeyValueRepo.SQLite
a SQLite implementation of the KeyValueRepo abstraction for KeyValue data stores. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.7.0 | 117 | 11/11/2024 |
1.7.0-ci-68 | 80 | 11/10/2024 |
1.6.0 | 168 | 1/21/2024 |
1.6.0-ci-67 | 96 | 1/20/2024 |
1.5.0 | 365 | 1/2/2024 |
1.5.0-ci-66 | 96 | 1/2/2024 |
1.5.0-ci-65 | 118 | 1/2/2024 |
1.5.0-ci-64 | 115 | 1/2/2024 |
1.5.0-ci-62 | 316 | 11/29/2023 |
1.4.0 | 186 | 9/8/2023 |
1.4.0-ci-61 | 145 | 9/8/2023 |
1.3.1 | 174 | 9/4/2023 |
1.3.1-ci-60 | 133 | 9/4/2023 |
1.3.1-ci-59 | 133 | 9/4/2023 |
1.3.1-ci-58 | 130 | 9/4/2023 |
1.3.1-ci-57 | 139 | 9/4/2023 |
1.3.1-ci-54 | 150 | 9/4/2023 |
1.3.1-ci-49 | 153 | 9/3/2023 |
1.3.0 | 165 | 9/3/2023 |
1.3.0-ci-48 | 138 | 9/3/2023 |
1.3.0-ci-47 | 135 | 9/3/2023 |
1.3.0-ci-46 | 134 | 9/3/2023 |
1.3.0-ci-45 | 129 | 9/2/2023 |
1.3.0-ci-44 | 141 | 9/2/2023 |
1.3.0-ci-43 | 136 | 9/2/2023 |
1.3.0-ci-42 | 147 | 9/1/2023 |
1.2.0-ci-41 | 139 | 9/1/2023 |
1.2.0-ci-39 | 442 | 5/30/2023 |
1.1.0-ci-38 | 138 | 5/30/2023 |
1.1.0-ci-37 | 143 | 5/28/2023 |
1.0.1-ci-36 | 160 | 4/23/2023 |
1.0.1-ci-35 | 148 | 4/23/2023 |
1.0.1-ci-33 | 156 | 4/4/2023 |
1.0.0 | 403 | 4/1/2023 |
1.0.0-ci-34 | 157 | 4/23/2023 |
1.0.0-ci-32 | 157 | 4/4/2023 |
1.0.0-ci-31 | 160 | 4/3/2023 |
1.0.0-ci-30 | 179 | 4/3/2023 |
1.0.0-ci-29 | 158 | 4/3/2023 |
1.0.0-ci-28 | 152 | 4/3/2023 |
1.0.0-ci-27 | 164 | 4/3/2023 |
1.0.0-ci-26 | 158 | 4/1/2023 |
1.0.0-ci-25 | 168 | 4/1/2023 |
1.0.0-ci-24 | 162 | 4/1/2023 |
1.0.0-ci-23 | 164 | 4/1/2023 |
1.0.0-ci-22 | 167 | 4/1/2023 |
1.0.0-ci-21 | 173 | 4/1/2023 |
1.0.0-ci-16 | 158 | 3/31/2023 |
1.0.0-beta-ci-17 | 156 | 3/31/2023 |
0.1.0-ci-15 | 170 | 3/31/2023 |