Sto scrivendo un'applicazione Scala/Play 2.0 e desidero che il mio codice restituisca una pagina diversa a seconda della richiesta. Ecco il mio codice:Come convalidare i parametri in modo funzionale?
// Validate client and return temporary credentials
def requestToken = Action { request =>
// Authorization header may present or not
val authHeader = parseHeaders(request headers AUTHORIZATION)
// Authorization header may contain such keys or not
val clientKey = authHeader("oauth_consumer_key")
val signature = authHeader("oauth_signature")
if (authenticateClient(clientKey, signature)) {
...
Ok(...)
} else {
Unauthorized(...)
}
}
Il problema si pone quando richiesta non è valido e alcune intestazioni sono mancante, quindi NoSuchElementException viene generata.
Nel linguaggio imperativo, vorrei validare ogni passo in questo modo:
if (!request.headers.contains(AUTHORIZATION))
return Unathorized
val authHeader = parseHeaders(request headers AUTHORIZATION)
if (!authHeader.contains("oauth_consumer_key") || !authHeader.contains("oauth_signature"))
return Unathorized
val clientKey = authHeader("oauth_consumer_key")
val signature = authHeader("oauth_signature")
...
ma cosa devo fare per risolvere tale problema in modo funzionale?
Grazie, è esattamente quello che stavo cercando. – lambdas