/*
|
* Copyright 2011 gitblit.com.
|
*
|
* 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 com.gitblit.wicket;
|
|
import org.apache.wicket.Component;
|
import org.apache.wicket.RestartResponseException;
|
import org.apache.wicket.authorization.IUnauthorizedComponentInstantiationListener;
|
import org.apache.wicket.authorization.strategies.page.AbstractPageAuthorizationStrategy;
|
import org.apache.wicket.markup.html.WebPage;
|
|
import com.gitblit.IStoredSettings;
|
import com.gitblit.Keys;
|
import com.gitblit.models.UserModel;
|
import com.gitblit.wicket.pages.BasePage;
|
|
public class AuthorizationStrategy extends AbstractPageAuthorizationStrategy implements
|
IUnauthorizedComponentInstantiationListener {
|
|
IStoredSettings settings;
|
Class<? extends WebPage> homepageClass;
|
|
public AuthorizationStrategy(IStoredSettings settings, Class<? extends WebPage> homepageClass) {
|
this.settings = settings;
|
this.homepageClass = homepageClass;
|
}
|
|
@SuppressWarnings({ "unchecked", "rawtypes" })
|
@Override
|
protected boolean isPageAuthorized(Class pageClass) {
|
if (homepageClass.equals(pageClass)) {
|
// allow all requests to get to the HomePage with its inline
|
// authentication form
|
return true;
|
}
|
|
if (BasePage.class.isAssignableFrom(pageClass)) {
|
boolean authenticateView = settings.getBoolean(Keys.web.authenticateViewPages, true);
|
boolean authenticateAdmin = settings.getBoolean(Keys.web.authenticateAdminPages, true);
|
boolean allowAdmin = settings.getBoolean(Keys.web.allowAdministration, true);
|
|
GitBlitWebSession session = GitBlitWebSession.get();
|
if (authenticateView && !session.isLoggedIn()) {
|
// authentication required
|
session.cacheRequest(pageClass);
|
return false;
|
}
|
|
UserModel user = session.getUser();
|
if (pageClass.isAnnotationPresent(RequiresAdminRole.class)) {
|
// admin page
|
if (allowAdmin) {
|
if (authenticateAdmin) {
|
// authenticate admin
|
if (user != null) {
|
return user.canAdmin();
|
}
|
return false;
|
} else {
|
// no admin authentication required
|
return true;
|
}
|
} else {
|
// admin prohibited
|
return false;
|
}
|
}
|
}
|
return true;
|
}
|
|
@Override
|
public void onUnauthorizedInstantiation(Component component) {
|
|
if (component instanceof BasePage) {
|
throw new RestartResponseException(homepageClass);
|
}
|
}
|
}
|