package act.handler.builtin.controller; /*- * #%L * ACT Framework * %% * Copyright (C) 2014 - 2017 ActFramework * %% * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * #L% */ import act.app.ActionContext; import act.controller.CacheSupportMetaInfo; import act.handler.builtin.controller.impl.ReflectedHandlerInvoker; import act.security.CORS; import act.security.CSRF; import act.util.MissingAuthenticationHandler; import act.view.ActNotFound; import org.osgl.mvc.result.NotFound; import org.osgl.mvc.result.Result; /** * Dispatch request to real controller action method */ public class ControllerAction extends ActionHandler<ControllerAction> { private ActionHandlerInvoker handlerInvoker; public ControllerAction(ActionHandlerInvoker invoker) { super(-1); this.handlerInvoker = invoker; } public CacheSupportMetaInfo cacheSupport() { return handlerInvoker.cacheSupport(); } @Override public Result handle(ActionContext actionContext) throws Exception { return handlerInvoker.handle(actionContext); } public NotFound notFoundOnMethod(String message) { if (handlerInvoker instanceof ReflectedHandlerInvoker) { return ((ReflectedHandlerInvoker) handlerInvoker).notFoundOnMethod(message); } return ActNotFound.create(); } @Override public CORS.Spec corsSpec() { return handlerInvoker.corsSpec(); } public CSRF.Spec csrfSpec() { return handlerInvoker.csrfSpec(); } @Override public boolean sessionFree() { return handlerInvoker.sessionFree(); } public MissingAuthenticationHandler missingAuthenticationHandler() { return handlerInvoker.missingAuthenticationHandler(); } public MissingAuthenticationHandler csrfFailureHandler() { return handlerInvoker.csrfFailureHandler(); } @Override public boolean express() { return handlerInvoker.express(); } @Override public void accept(Visitor visitor) { handlerInvoker.accept(visitor.invokerVisitor()); } @Override protected void releaseResources() { handlerInvoker.destroy(); handlerInvoker = null; } }