wisemapping-open-source/wise-webapp/src/main/java/com/wisemapping/security/aop/UpdateSecurityAdvise.java

53 lines
1.9 KiB
Java
Raw Normal View History

/*
* Copyright [2011] [wisemapping]
*
2011-01-24 01:03:12 +01:00
* Licensed under WiseMapping Public License, Version 1.0 (the "License").
* It is basically the Apache License, Version 2.0 (the "License") plus the
* "powered by wisemapping" text requirement on every single page;
* you may not use this file except in compliance with the License.
* You may obtain a copy of the license at
*
* http://www.wisemapping.org/license
*
* 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.
*/
2009-06-07 20:59:43 +02:00
package com.wisemapping.security.aop;
2012-06-09 20:49:19 +02:00
import com.wisemapping.model.CollaborationRole;
2009-06-07 20:59:43 +02:00
import com.wisemapping.model.User;
import com.wisemapping.model.MindMap;
import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;
2012-06-06 05:48:46 +02:00
import org.jetbrains.annotations.NotNull;
2009-06-07 20:59:43 +02:00
public class UpdateSecurityAdvise
2012-06-06 05:48:46 +02:00
extends BaseSecurityAdvice
implements MethodInterceptor {
2009-06-07 20:59:43 +02:00
public Object invoke(MethodInvocation methodInvocation) throws Throwable {
checkRole(methodInvocation);
return methodInvocation.proceed();
}
2012-06-06 05:48:46 +02:00
protected boolean isAllowed(@NotNull User user, @NotNull MindMap map) {
boolean result;
2012-06-12 16:23:47 +02:00
if (map.getCreator() == null) {
2012-06-06 05:48:46 +02:00
// This means that the map is new and is an add operation.
result = true;
} else {
2012-06-12 16:23:47 +02:00
result = getMindmapService().hasPermissions(user, map, CollaborationRole.EDITOR);
2012-06-06 05:48:46 +02:00
}
return result;
2009-06-07 20:59:43 +02:00
}
2012-06-06 05:48:46 +02:00
protected boolean isAllowed(User user, int mapId) {
2012-06-12 16:23:47 +02:00
return getMindmapService().hasPermissions(user, mapId, CollaborationRole.EDITOR);
2009-06-07 20:59:43 +02:00
}
}