IResult 1.0.2
dotnet add package IResult --version 1.0.2
NuGet\Install-Package IResult -Version 1.0.2
<PackageReference Include="IResult" Version="1.0.2" />
paket add IResult --version 1.0.2
#r "nuget: IResult, 1.0.2"
// Install IResult as a Cake Addin #addin nuget:?package=IResult&version=1.0.2 // Install IResult as a Cake Tool #tool nuget:?package=IResult&version=1.0.2
IResult
Simple set of generic structures when simple success?->message->data information is required.
Interfaces
There are two main interfaces for returning results:
IResult:
bool Success
string Message
string[] DiagnosticData //Not included when serialized into json or xml representation. Just for debugging purposes
IResult<T>:
// Same structure as IResult, but including the following property
T Object
DiagnosticData: Intended for technical purposes.
This data will not be serialized when using a Json or Xml serializer, so you can set any value for logging or debugging purposes without including sensitive information, specially when building API's responses.
When using helper methods, it is filled through the optional parameters (params array), so you can pass any number of data, which are serialized as json. If you pass an exception, it wont be serialized, instead, the Message property will be used, because exceptions are too big to be serialized quickly.
[System.Text.Json.Serialization.JsonIgnore]
[Newtonsoft.Json.JsonIgnore]
[XmlIgnore]
string[] DiagnosticData
Helper Methods
And some methods for making easy and simplified response constructions
IResult
// sets Success = false. More details can be found in the comments in the source code or via intellisense
IResult Error(Exception ex, params object[] optionalParams);
IResult Error(string message, params object[] optionalParams);
IResult Error(string message, Exception ex, params object[] optionalParams);
// sets Success = true. More details can be found in the comments in the source code or via intellisense
IResult Ok();
IResult Ok(string message);
IResult Ok(string message, params object[] optionalParams);
IResult<T>
// sets Success = false. More details can be found in the comments in the source code or via intellisense
IResult<T> Error(T obj);
IResult<T> Error(T obj, Exception ex);
IResult<T> Error(string message, T obj);
IResult<T> Error(string message, T obj, Exception ex, params object[] optionalParams);
// sets Success = true. More details can be found in the comments in the source code or via intellisense
IResult<T> Ok(T obj);
IResult<T> Ok(string message, T obj);
IResult<T> Ok(T obj, params object[] optionalParams);
IResult<T> Ok(string message, T obj, params object[] optionalParams);
ToString() Override
Both classes Result & Result<T> have a ToString() overridden method. The intention of this, is to get details quickly, as printing to the console or the output window.
An example of this:
Success: False
Message: Error test message
Object: {"Id":"c32426fe-f47f-4299-9a96-2914e1cd4307","Text":"Test text"}
DiagnosticData:
[0]: "uno"
[1]: "dos"
[2]: 3
[3]: 4
[4]: null
[5]: Exception error test message
Quick Examples
IResult examples:
object[] optionalParams = new object[] { "uno", "dos", 3, 4.0, null };
var msgEx = "Exception error test message";
var msg = "Error test message";
// Simple result with Success = true and Message = msg
IResult res = new Result().Ok(msg);
// Simple error result with success = false with message = msg
// and DiagnosticData filled with the exception.Message and each optionalParams values as Json data.
res = new Result().Error(msg, new InvalidOperationException(msgEx), optionalParams);
IResult<T> examples:
var msg = "Success";
var ex = new InvalidOperationException("Error");
object[] optionalParams = new object[] { "uno", "dos", 3, 4.0, null };
var data = new mockClass
{
Id = Guid.NewGuid(),
Text = "Test text"
};
// Result with Success=true, Message = msg, Object = data
// and DiagnosticData filled with each optionalParams values as Json data.
var res = new Result<mockClass>().Ok(msg, data, optionalParams);
// Result with Success=false, Object = data
// and DiagnosticData with the exception.Message
var res = new Result<mockClass>().Error(data, ex);
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. |
.NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.1 is compatible. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | 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.1
- Microsoft.Extensions.Logging.Abstractions (>= 6.0.1)
- Newtonsoft.Json (>= 13.0.1)
- System.Text.Json (>= 6.0.5)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version number fixed :P