Skip to content

Instantly share code, notes, and snippets.

Embed
What would you like to do?
HTTP error handling
update : Action -> Model -> ( Model, Effects Action )
update action model =
case action of
HandleResponse result ->
case result of
Ok movies ->
( { model | movies = movies }, Effects.none )
Err error ->
let
_ = reportError error
in
( model, Effects.none )
search : String -> Effects Action
search query =
let
url = "/movies?query=" ++ query
in
Http.get moviesDecoder url
|> Task.toResult
|> Task.map HandleResponse
|> Effects.task
reportError : Http.Error -> Http.Error
reportError error =
case error of
Http.Timeout ->
Debug.log "API timeout" error
Http.NetworkError ->
Debug.log "Network error contacting API" error
Http.UnexpectedPayload payload ->
Debug.log ("Unexpected payload from API: " ++ payload) error
Http.BadResponse status payload ->
Debug.log ("Unexpected status/payload from API: " ++ (toString status) ++ "/" ++ payload) error
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.