1 package org.openecomp.sdc.itempermissions.dao.impl;
3 import org.openecomp.sdc.common.errors.CoreException;
4 import org.openecomp.sdc.common.errors.ErrorCategory;
5 import org.openecomp.sdc.common.errors.ErrorCode;
6 import org.openecomp.sdc.common.errors.Messages;
7 import org.openecomp.sdc.common.session.SessionContextProviderFactory;
8 import org.openecomp.sdc.itempermissions.ItemPermissionsManager;
9 import org.openecomp.sdc.itempermissions.PermissionsServices;
10 import org.openecomp.sdc.itempermissions.impl.types.PermissionTypes;
11 import org.openecomp.sdc.itempermissions.type.ItemPermissionsEntity;
12 import org.openecomp.sdc.logging.api.Logger;
13 import org.openecomp.sdc.logging.api.LoggerFactory;
14 import org.openecomp.sdc.notification.dtos.Event;
15 import org.openecomp.sdc.notification.services.NotificationPropagationManager;
16 import org.openecomp.sdc.notification.services.SubscriptionService;
17 import org.openecomp.sdc.versioning.ItemManager;
18 import org.openecomp.sdc.versioning.types.Item;
20 import java.util.Collection;
21 import java.util.HashMap;
25 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.ITEM_ID_PROP;
26 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.ITEM_NAME_PROP;
27 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.PERMISSION_CHANGED;
28 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.PERMISSION_GRANTED;
29 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.PERMISSION_ITEM;
30 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.PERMISSION_USER;
33 * Created by ayalaben on 6/18/2017.
35 public class ItemPermissionsManagerImpl implements ItemPermissionsManager {
37 private static final Logger LOGGER = LoggerFactory.getLogger(ItemPermissionsManagerImpl.class);
38 private static final String CHANGE_PERMISSIONS = "Change_Item_Permissions";
40 private PermissionsServices permissionsServices;
41 private ItemManager itemManager;
42 private NotificationPropagationManager notifier;
43 private SubscriptionService subscriptionService;
45 public ItemPermissionsManagerImpl(PermissionsServices permissionsServices,
46 ItemManager itemManager,
47 NotificationPropagationManager notificationPropagationManager,
48 SubscriptionService subscriptionService) {
49 this.permissionsServices = permissionsServices;
50 this.itemManager = itemManager;
51 this.notifier = notificationPropagationManager;
52 this.subscriptionService = subscriptionService;
56 public Collection<ItemPermissionsEntity> listItemPermissions(String itemId) {
58 return permissionsServices.listItemPermissions(itemId);
62 public void updateItemPermissions(String itemId, String permission, Set<String> addedUsersIds,
63 Set<String> removedUsersIds) {
66 SessionContextProviderFactory.getInstance().createInterface().get().getUser().getUserId();
68 if (!permissionsServices.isAllowed(itemId, currentUser, CHANGE_PERMISSIONS)) {
69 throw new CoreException(new ErrorCode.ErrorCodeBuilder()
70 .withMessage(Messages.PERMISSIONS_ERROR.getErrorMessage())
71 .withId(Messages.PERMISSIONS_ERROR.getErrorMessage())
72 .withCategory(ErrorCategory.SECURITY).build());
75 if (permission.equals(PermissionTypes.Owner.name()) ){
76 if (addedUsersIds.size() == 1){
77 itemManager.updateOwner(itemId,addedUsersIds.iterator().next());
79 throw new CoreException(new ErrorCode.ErrorCodeBuilder()
80 .withMessage(Messages.PERMISSIONS_OWNER_ERROR.getErrorMessage())
81 .withId(Messages.PERMISSIONS_OWNER_ERROR.getErrorMessage())
82 .withCategory(ErrorCategory.SECURITY).build());
87 .updateItemPermissions(itemId, permission, addedUsersIds, removedUsersIds);
89 sendNotifications(itemId, permission, addedUsersIds, removedUsersIds, currentUser);
92 private void sendNotifications(String itemId, String permission, Set<String> addedUsersIds,
93 Set<String> removedUsersIds, String userName) {
95 Item item = itemManager.get(itemId);
96 addedUsersIds.forEach(affectedUser -> {
97 notifyUser(userName, true, item.getName(), itemId, affectedUser, permission);
98 subscriptionService.subscribe(affectedUser, itemId);
100 removedUsersIds.forEach(affectedUser -> {
101 notifyUser(userName, false, item.getName(), itemId, affectedUser, permission);
102 subscriptionService.unsubscribe(affectedUser, itemId);
107 private void notifyUser(String userName, boolean granted, String itemName, String itemId,
108 String affectedUser, String permission) {
109 Map<String, Object> details = new HashMap<>();
110 details.put(PERMISSION_ITEM, permission);
111 details.put(ITEM_ID_PROP, itemId);
112 details.put(ITEM_NAME_PROP, itemName);
113 details.put(PERMISSION_GRANTED, granted);
114 details.put(PERMISSION_USER, userName);
115 PermissionEvent permissionEvent = new PermissionEvent(PERMISSION_CHANGED, affectedUser,
116 details, affectedUser);
119 notifier.directNotification(permissionEvent, affectedUser);
120 } catch (Exception e) {
121 LOGGER.error("Failed to send notification on permission changed for user '" +
128 public boolean isAllowed(String itemId, String userId, String action) {
129 return permissionsServices.isAllowed(itemId, userId, action);
133 public String getUserItemPermiission(String itemId, String userId) {
134 return permissionsServices.getUserItemPermiission(itemId, userId);
138 public void deleteItemPermissions(String itemId) {
139 permissionsServices.deleteItemPermissions(itemId);
142 private class PermissionEvent implements Event {
144 private String eventType;
145 private String originatorId;
146 private Map<String, Object> attributes;
147 private String entityId;
149 private PermissionEvent(String eventType, String originatorId,
150 Map<String, Object> attributes, String entityId) {
151 this.eventType = eventType;
152 this.originatorId = originatorId;
153 this.attributes = attributes;
154 this.entityId = entityId;
158 public String getEventType() {
163 public String getOriginatorId() {
168 public Map<String, Object> getAttributes() {
173 public String getEntityId() {