@standardize/result
v0.0.1
Published
AKA _Either_ _Left/Right_ _Operation_ _Result(Kotlin)_
Downloads
3
Readme
@standardize/result
AKA Either Left/Right Operation Result(Kotlin)
Why?
Exceptions are commonplace in most codebases, this class allows "dangerous"
operations to be wrapped in a Result<T, E>
which encapsulate the possible
errors or success states from a given method.
Typically the only time knowledge of an external package and its errors will be encoded is when the service is first written. By defining typed exceptions you encode information of possibly handleable errors you may otherwise feed directly to your users.
The async version of this monad AsyncResult<T, E>
is best described as a
promise with typed errors. The interface of the sync and async versions match
to simplify access and allow method chaining.
Result<T, E>
is not required in all of your code and should not be overused.
It is best used at boundaries between services where retries or API changes are
solid and infrequent.
// Async
await Result
.fromPromise<User, NotFoundError | PGError>(getUser(userId))
.map(setUser, logError);
// Sync
Result
.fromThrowable<User, NotFoundError | PGError>(() => getUserSync(userId))
.map(setUser, logError);
Public Interface
Instantiation Methods
fromThrowable
given a function that when invoked may throw, wraps the caught error as a
Fail<E>
and a successful completion as a Success<T>
Result.fromThrowable<User, NotFoundError>(getUserSync) // Result<User, NotFoundError>
fromPromise
Given a promise that rejects, will return a Fail<E>
or if it resolves a Success<T>
await Result.fromPromise<User, NotFoundError>(getUser) // Result<User, NotFoundError>
success
Instantiates a Success<T>
result
Result.success('Value')
fail
Instantiates a Fail<E>
result
Result.fail(new Error(''))
Transformation Methods
map
/ mapFailure
Apply the passed function to the wrapped successful or unsuccessful value and
returns a new Result<T, E>
of the result.
await Result.fromPromise(getUser).map(setUser, onError) // Result<void, void>
await Result.fromPromise(getUser).map(toViewUser).map(setUser) // Result<void, E>
swap
Swaps the types <T>
and <E>
. If a Result is a Success<T>
it will return a
Fail<T>
and vice versa.
Extraction Methods
getEither
Returns T | E
given Result<T, E>
. Useful to merge multiple promises.
await Result
.fromPromise(sendEmail)
.map(confirmEmailDelivery, rescheduleDelivery)
.getEither()
getOrThrowFailure
Returns T
or throws E
given Result<T, E>
. This essentially reverses the
value having been wrapped in a result as an AsyncResult
will be rejected and a Result
will throw