a68c2d89f9deb6c00ebc298441a6fea792333495
[sdc.git] /
1 /*
2  * Copyright © 2016-2018 European Support Limited
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *   http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 package org.openecomp.sdc.itempermissions.dao.impl;
18
19 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.ITEM_ID_PROP;
20 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.ITEM_NAME_PROP;
21 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.PERMISSION_CHANGED;
22 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.PERMISSION_GRANTED;
23 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.PERMISSION_ITEM;
24 import static org.openecomp.sdc.itempermissions.notifications.NotificationConstants.PERMISSION_USER;
25
26 import java.util.Collection;
27 import java.util.HashMap;
28 import java.util.Map;
29 import java.util.Set;
30 import org.openecomp.sdc.common.errors.CoreException;
31 import org.openecomp.sdc.common.errors.ErrorCategory;
32 import org.openecomp.sdc.common.errors.ErrorCode;
33 import org.openecomp.sdc.common.errors.Messages;
34 import org.openecomp.sdc.common.session.SessionContextProviderFactory;
35 import org.openecomp.sdc.itempermissions.ItemPermissionsManager;
36 import org.openecomp.sdc.itempermissions.PermissionsServices;
37 import org.openecomp.sdc.itempermissions.impl.types.PermissionTypes;
38 import org.openecomp.sdc.itempermissions.type.ItemPermissionsEntity;
39 import org.openecomp.sdc.logging.api.Logger;
40 import org.openecomp.sdc.logging.api.LoggerFactory;
41 import org.openecomp.sdc.notification.dtos.Event;
42 import org.openecomp.sdc.notification.services.NotificationPropagationManager;
43 import org.openecomp.sdc.notification.services.SubscriptionService;
44 import org.openecomp.sdc.versioning.AsdcItemManager;
45 import org.openecomp.sdc.versioning.types.Item;
46
47 /**
48  * Created by ayalaben on 6/18/2017.
49  */
50 public class ItemPermissionsManagerImpl implements ItemPermissionsManager {
51
52   private static final Logger LOGGER = LoggerFactory.getLogger(ItemPermissionsManagerImpl.class);
53   private static final String CHANGE_PERMISSIONS = "Change_Item_Permissions";
54
55   private PermissionsServices permissionsServices;
56   private AsdcItemManager asdcItemManager;
57   private NotificationPropagationManager notifier;
58   private SubscriptionService subscriptionService;
59
60   public ItemPermissionsManagerImpl(PermissionsServices permissionsServices,
61                                     AsdcItemManager asdcItemManager,
62                                     NotificationPropagationManager notificationPropagationManager,
63                                     SubscriptionService subscriptionService) {
64     this.permissionsServices = permissionsServices;
65     this.asdcItemManager = asdcItemManager;
66     this.notifier = notificationPropagationManager;
67     this.subscriptionService = subscriptionService;
68   }
69
70   @Override
71   public Collection<ItemPermissionsEntity> listItemPermissions(String itemId) {
72
73     return permissionsServices.listItemPermissions(itemId);
74   }
75
76   @Override
77   public void updateItemPermissions(String itemId, String permission, Set<String> addedUsersIds,
78                                     Set<String> removedUsersIds) {
79
80     String currentUser =
81         SessionContextProviderFactory.getInstance().createInterface().get().getUser().getUserId();
82
83     if (!permissionsServices.isAllowed(itemId, currentUser, CHANGE_PERMISSIONS)) {
84       throw new CoreException(new ErrorCode.ErrorCodeBuilder()
85           .withMessage(Messages.PERMISSIONS_ERROR.getErrorMessage())
86           .withId(Messages.PERMISSIONS_ERROR.getErrorMessage())
87           .withCategory(ErrorCategory.SECURITY).build());
88     }
89
90     if (permission.equals(PermissionTypes.Owner.name()) ){
91       if (addedUsersIds.size() == 1){
92         asdcItemManager.updateOwner(itemId,addedUsersIds.iterator().next());
93     } else {
94         throw new CoreException(new ErrorCode.ErrorCodeBuilder()
95             .withMessage(Messages.PERMISSIONS_OWNER_ERROR.getErrorMessage())
96             .withId(Messages.PERMISSIONS_OWNER_ERROR.getErrorMessage())
97             .withCategory(ErrorCategory.SECURITY).build());
98       }
99     }
100
101     permissionsServices
102         .updateItemPermissions(itemId, permission, addedUsersIds, removedUsersIds);
103
104     sendNotifications(itemId, permission, addedUsersIds, removedUsersIds, currentUser);
105   }
106
107   private void sendNotifications(String itemId, String permission, Set<String> addedUsersIds,
108                                    Set<String> removedUsersIds, String userName) {
109
110     Item item = asdcItemManager.get(itemId);
111     addedUsersIds.forEach(affectedUser -> {
112       notifyUser(userName, true, item.getName(), itemId, affectedUser, permission);
113       subscriptionService.subscribe(affectedUser, itemId);
114     });
115     removedUsersIds.forEach(affectedUser -> {
116       notifyUser(userName, false, item.getName(), itemId, affectedUser, permission);
117       subscriptionService.unsubscribe(affectedUser, itemId);
118     });
119
120   }
121
122   private void notifyUser(String userName, boolean granted, String itemName, String itemId,
123                           String affectedUser, String permission) {
124     Map<String, Object> details = new HashMap<>();
125     details.put(PERMISSION_ITEM, permission);
126     details.put(ITEM_ID_PROP, itemId);
127     details.put(ITEM_NAME_PROP, itemName);
128     details.put(PERMISSION_GRANTED, granted);
129     details.put(PERMISSION_USER, userName);
130     PermissionEvent permissionEvent = new PermissionEvent(PERMISSION_CHANGED, affectedUser,
131         details, affectedUser);
132
133     try {
134       notifier.directNotification(permissionEvent, affectedUser);
135     } catch (Exception e) {
136       LOGGER.error("Failed to send notification on permission changed for user '" +
137           affectedUser + "'");
138     }
139
140   }
141
142   @Override
143   public boolean isAllowed(String itemId, String userId, String action) {
144     return permissionsServices.isAllowed(itemId, userId, action);
145   }
146
147   @Override
148   public String getUserItemPermiission(String itemId, String userId) {
149     return permissionsServices.getUserItemPermiission(itemId, userId);
150   }
151
152   @Override
153   public void deleteItemPermissions(String itemId) {
154     permissionsServices.deleteItemPermissions(itemId);
155   }
156
157   private class PermissionEvent implements Event {
158
159     private String eventType;
160     private String originatorId;
161     private Map<String, Object> attributes;
162     private String entityId;
163
164     private PermissionEvent(String eventType, String originatorId,
165                             Map<String, Object> attributes, String entityId) {
166       this.eventType = eventType;
167       this.originatorId = originatorId;
168       this.attributes = attributes;
169       this.entityId = entityId;
170     }
171
172     @Override
173     public String getEventType() {
174       return eventType;
175     }
176
177     @Override
178     public String getOriginatorId() {
179       return originatorId;
180     }
181
182     @Override
183     public Map<String, Object> getAttributes() {
184       return attributes;
185     }
186
187     @Override
188     public String getEntityId() {
189       return entityId;
190     }
191   }
192 }