traverseTask
Option.traverseTask
Namespace: FsToolkit.ErrorHandling
Function Signature:
('a -> Task<'b>) -> 'a option -> Task<'b option>
Note that traverse
is the same as map >> sequence
. See also Option.sequenceTask.
See also Scott Wlaschin's Understanding traverse and sequence.
Examples
Example 1
Let's assume we have a type Customer
:
type Customer = {
Id : int
Email : string
}
And we have a function called getCustomerByEmail
that retrieves a Customer
by email address asynchronously from some external source -- a database, a web service, etc:
// string -> Task<Customer>
let getCustomerByEmail email : Task<Customer> = task {
return { Id = 1; Email = "test@test.com" } // return a constant for simplicity
}
If we have a value of type string option
and want to call the getCustomerByEmail
function, we can achieve it using the traverseTask
function as below:
Some "test@test.com" |> Option.traverseTask getCustomerByEmail
// task { return Some { Id = 1; Email = "test@test.com" } }
None |> Option.traverseTask getCustomerByEmail
// task { return None }
Last updated