phaseContext.setRequestMethod(getHttpMethod(request.getRequestMethod()));
String requestMethod = getEffectiveMethod(request);
HttpMethod httpMethod = getHttpMethod(requestMethod);
if(!plugin.isMethodAllowed(httpMethod))
throw new HyperionException(405,String.format("%s is not allowed.",httpMethod));
phaseContext.setEffectiveMethod(httpMethod);
// special case where version is in the URI
String version = uriRequestResult.getVersion();
if(version == null || version.length() == 0)
{
version = request.getFirstParameter(hyperionEndpointConfiguration.getVersionParameterName());
if(version == null || version.length() == 0)
version = request.getFirstHeader(hyperionEndpointConfiguration.getVersionHeaderName());
if(hyperionEndpointConfiguration.isRequireVersion() && httpMethod != HttpMethod.DELETE &&
(version == null || version.length()==0))
throw new BadRequestException(String.format("The %s parameter must be specified",hyperionEndpointConfiguration.getVersionParameterName()));
}
if(version != null)
{
try
{
phaseContext.setVersion(Integer.parseInt(version));
}
catch(NumberFormatException e)
{
throw new BadRequestException(String.format("%s is not a valid value for version.",version));
}
}
if(!validateMethod(httpMethod,uriRequestResult))
throw new HyperionException(405,"Not allowed.");
if(uriRequestResult.getId() != null)
phaseContext.setId(URLDecoder.decode(uriRequestResult.getId()));
phaseContext.setHistory(uriRequestResult.isHistory());
ApiVersionPlugin versionPlugin = plugin.getApiVersionRegistry().getPluginForVersion(phaseContext.getVersion());
phaseContext.setVersionPlugin(versionPlugin);
logRequestInformation(phaseContext);
if(phaseContext.getEffectiveMethod() == HttpMethod.GET)
{
response.setCacheMaxAge(plugin.getCacheMaxAge());
}
AuthorizationContext authorizationContext = authorizationProvider.authorize(phaseContext);
phaseContext.setAuthorizationContext(authorizationContext);
if(!authorizationContext.isAuthorized())
throw new HyperionException(403,"Not Authorized");
}