/** * Yobi, Project Hosting SW * * Copyright 2014 NAVER Corp. * http://yobi.io * * @author Wansoon Park, Keesun Baek * * 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. */ package actions; import controllers.UserApp; import controllers.annotation.AnonymousCheck; import controllers.routes; import play.mvc.Action; import play.mvc.Http.Context; import play.mvc.Result; import play.mvc.Result; import play.libs.F.Promise; import utils.AccessControl; import utils.AccessLogger; import utils.Constants; /** * After execute {@link actions.AbstractProjectCheckAction}, * If current user is anonymous, redirect to the login page. * * @author Wansoon Park, Keesun Beak * */ public class AnonymousCheckAction extends Action<AnonymousCheck> { @Override public Promise<Result> call(Context context) throws Throwable { if ((AccessControl.isAnonymousNotAllowed() || configuration.requiresLogin()) && UserApp.currentUser().isAnonymous()) { if (configuration.displaysFlashMessage()) { play.mvc.Controller.flash(Constants.WARNING, "user.login.alert"); } String loginFormUrl = routes.UserApp.loginForm().url(); loginFormUrl += "?redirectUrl=" + context.request().path(); Promise<Result> promise = Promise.pure(redirect(loginFormUrl)); AccessLogger.log(context.request(), promise, null); return promise; } return delegate.call(context); } }