Escribo la aplicación Scala/Play 2.0 y deseo que mi código devuelva una página diferente según lo solicite. Aquí está mi código:¿Cómo validar los parámetros de una manera funcional?
// 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(...)
}
}
El problema surge cuando la petición está mal formado y algunas cabeceras se encuentra, entonces NoSuchElementException se lanza.
En lenguaje imperativo, me validar cada paso de esta manera:
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")
...
pero lo que hay que hacer para resolver ese problema de una manera funcional?
Gracias, es exactamente lo que estaba buscando. – lambdas