Calebs.Extensions 1.7.0

dotnet add package Calebs.Extensions --version 1.7.0                
NuGet\Install-Package Calebs.Extensions -Version 1.7.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="Calebs.Extensions" Version="1.7.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Calebs.Extensions --version 1.7.0                
#r "nuget: Calebs.Extensions, 1.7.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 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                

.github/workflows/dev-ci.yml .github/workflows/main-publish.yml NuGet NuGet .github/workflows/ci.yml

Extensions Logo

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 and DeleteDirectory to IFileIO
  • 1.5.0 - Added package logo and ToSafeString for ObjectExtensions
  • 1.6.0 - Added AddUnlessBlank to list extensions
  • 1.7.0 - Added IntExtensions and expanded IFileIO
Product 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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