mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			23.4.0.18
			...
			rm-7187-ev
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 3875f0b170 | 
| @@ -175,6 +175,14 @@ | ||||
|        <property name="nodesModelFactory" ref="nodesModelFactory" /> | ||||
|     </bean> | ||||
|  | ||||
|     <bean class="org.alfresco.rm.rest.api.events.EventEntityResource"> | ||||
|         <property name="recordsManagementEventService" ref="RecordsManagementEventService" /> | ||||
|     </bean> | ||||
|  | ||||
|     <bean class="org.alfresco.rm.rest.api.events.EventTypeEntityResource"> | ||||
|         <property name="recordsManagementEventService" ref="RecordsManagementEventService" /> | ||||
|     </bean> | ||||
|  | ||||
|    <!-- extended sites bean definition --> | ||||
|    <bean id="rm.sites" class="org.alfresco.rm.rest.api.impl.RMSitesImpl" parent="sites"> | ||||
|         <property name="siteSurfConfig" ref="rm.siteSurfConfig" /> | ||||
| @@ -209,6 +217,8 @@ | ||||
|                 <entry key="org.alfresco.service.cmr.attributes.DuplicateAttributeException" value="#{T(org.springframework.extensions.webscripts.Status).STATUS_CONFLICT}" /> | ||||
|                 <entry key="org.alfresco.module.org_alfresco_module_rm.record.RecordCreationException" value="422" /> | ||||
|                 <entry key="org.alfresco.service.cmr.model.FileExistsException" value="409" /> | ||||
|                 <entry key="org.alfresco.rest.framework.core.exceptions.EventAlreadyExistsException" value="409" /> | ||||
|                 <entry key="org.alfresco.rest.framework.core.exceptions.EntityNotFoundException" value="404" /> | ||||
|             </map> | ||||
|         </property> | ||||
|    </bean> | ||||
|   | ||||
| @@ -0,0 +1,222 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2022 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
|  | ||||
| package org.alfresco.rm.rest.api.events; | ||||
|  | ||||
| import org.alfresco.error.AlfrescoRuntimeException; | ||||
| import org.alfresco.module.org_alfresco_module_rm.event.RecordsManagementEvent; | ||||
| import org.alfresco.module.org_alfresco_module_rm.event.RecordsManagementEventService; | ||||
| import org.alfresco.rest.framework.WebApiDescription; | ||||
| import org.alfresco.rest.framework.WebApiParam; | ||||
| import org.alfresco.rest.framework.core.ResourceParameter; | ||||
| import org.alfresco.rest.framework.core.exceptions.EntityNotFoundException; | ||||
| import org.alfresco.rest.framework.core.exceptions.EventAlreadyExistsException; | ||||
| import org.alfresco.rest.framework.resource.EntityResource; | ||||
| import org.alfresco.rest.framework.resource.actions.interfaces.EntityResourceAction; | ||||
| import org.alfresco.rest.framework.resource.parameters.CollectionWithPagingInfo; | ||||
| import org.alfresco.rest.framework.resource.parameters.Paging; | ||||
| import org.alfresco.rest.framework.resource.parameters.Parameters; | ||||
| import org.alfresco.rm.rest.api.model.EventBody; | ||||
| import org.alfresco.rm.rest.api.model.EventInfo; | ||||
| import org.alfresco.util.GUID; | ||||
| import org.apache.commons.lang3.StringUtils; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.List; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| import static org.alfresco.util.ParameterCheck.mandatory; | ||||
|  | ||||
| /** | ||||
|  * Event entity resource | ||||
|  */ | ||||
| @EntityResource(name = "events", title = "Events") | ||||
| public class EventEntityResource implements EntityResourceAction.Read<EventInfo>, | ||||
|                                             EntityResourceAction.ReadById<EventInfo>, | ||||
|                                             EntityResourceAction.Update<EventBody>, | ||||
|                                             EntityResourceAction.Create<EventBody> { | ||||
|  | ||||
|     private RecordsManagementEventService recordsManagementEventService; | ||||
|  | ||||
|     /** | ||||
|      * Set the records management event service | ||||
|      * | ||||
|      * @param rmEventService | ||||
|      */ | ||||
|     public void setRecordsManagementEventService(RecordsManagementEventService rmEventService) | ||||
|     { | ||||
|         this.recordsManagementEventService = rmEventService; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     @WebApiDescription(title = "Return a single event identified by 'eventId'") | ||||
|     @WebApiParam(name = "eventId", title = "The event id", kind = ResourceParameter.KIND.URL_PATH) | ||||
|     public EventInfo readById(String eventId, Parameters parameters) throws EntityNotFoundException | ||||
|     { | ||||
|         mandatory("eventId", eventId); | ||||
|  | ||||
|         RecordsManagementEvent event = null; | ||||
|         if (eventExists(eventId)) | ||||
|         { | ||||
|             // Get the event | ||||
|             event = recordsManagementEventService.getEvent(eventId); | ||||
|         } | ||||
|  | ||||
|         return EventInfo.fromRecordsManagementEvent(event); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     @WebApiDescription(title = "Return a list of events") | ||||
|     public CollectionWithPagingInfo<EventInfo> readAll(Parameters params) | ||||
|     { | ||||
|         Paging paging = params.getPaging(); | ||||
|  | ||||
|         List<EventInfo> eventInfoList = recordsManagementEventService.getEvents().stream() | ||||
|                 .map(EventInfo::fromRecordsManagementEvent) | ||||
|                 .collect(Collectors.toList()); | ||||
|  | ||||
|         int totalCount = eventInfoList.size(); | ||||
|         boolean hasMoreItems = paging.getSkipCount() + paging.getMaxItems() < totalCount; | ||||
|         return CollectionWithPagingInfo.asPaged(paging, eventInfoList.stream() | ||||
|                 .skip(paging.getSkipCount()) | ||||
|                 .limit(paging.getMaxItems()) | ||||
|                 .collect(Collectors.toList()), hasMoreItems, totalCount); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     @WebApiDescription(title = "Create a new event") | ||||
|     public List<EventBody> create(List<EventBody> eventBodyList, Parameters parameters) | ||||
|     { | ||||
|         //TODO: 403 User not allowed to update event error still needs to be implemented | ||||
|         mandatory("eventBodyList", eventBodyList); | ||||
|         for (EventBody eventBody : eventBodyList) { | ||||
|             mandatory("eventName", eventBody.getName()); | ||||
|             mandatory("eventType", eventBody.getType()); | ||||
|         } | ||||
|  | ||||
|         List<EventBody> responseEventBodyList = new ArrayList<>(); | ||||
|         for (EventBody eventBody : eventBodyList) { | ||||
|             String eventId = GUID.generate(); | ||||
|             String eventName = eventBody.getName(); | ||||
|             String eventType = eventBody.getType(); | ||||
|  | ||||
|             if(canCreateEvent(eventId, eventName)) { | ||||
|                 RecordsManagementEvent event = recordsManagementEventService.addEvent(eventType, eventId, eventName); | ||||
|                 responseEventBodyList.add(EventBody.fromRecordsManagementEvent(event)); | ||||
|             } | ||||
|         } | ||||
|         return responseEventBodyList; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     @WebApiDescription(title = "Update a single event identified by 'eventId'") | ||||
|     @WebApiParam(name = "eventId", title = "The event id", kind = ResourceParameter.KIND.URL_PATH) | ||||
|     public EventBody update(String eventId, EventBody eventBody, Parameters parameters) | ||||
|     { | ||||
|         //TODO: 403 User not allowed to update event error still needs to be implemented | ||||
|         mandatory("eventId", eventId); | ||||
|         mandatory("eventName", eventBody.getName()); | ||||
|         mandatory("eventType", eventBody.getType()); | ||||
|  | ||||
|         RecordsManagementEvent event = null; | ||||
|         if (canEditEvent(eventBody.getName(), eventId, eventBody.getType())) | ||||
|         { | ||||
|             // Create event | ||||
|             event = recordsManagementEventService.addEvent(eventBody.getType(), eventId, eventBody.getName()); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             // Get event | ||||
|             event = recordsManagementEventService.getEvent(eventId); | ||||
|         } | ||||
|  | ||||
|         return EventBody.fromRecordsManagementEvent(event); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Helper method for checking if an event exists or not. Throws an | ||||
|      * error if the event does not exist. | ||||
|      * | ||||
|      * @param eventId The id of the event | ||||
|      */ | ||||
|     private boolean eventExists(String eventId) | ||||
|     { | ||||
|         boolean eventExists = true; | ||||
|  | ||||
|         // Check the event exists | ||||
|         if (!recordsManagementEventService.existsEvent(eventId)) | ||||
|         { | ||||
|             throw new EntityNotFoundException(eventId); | ||||
|         } | ||||
|  | ||||
|         return eventExists; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Helper method for checking if an event can be created or not. Throws an | ||||
|      * error if the event already exists. | ||||
|      * | ||||
|      * @param eventId The id of the event | ||||
|      * @param eventName The name of the event | ||||
|      */ | ||||
|     private boolean canCreateEvent(String eventId, String eventName) | ||||
|     { | ||||
|         boolean canCreateEvent = true; | ||||
|  | ||||
|         if (!recordsManagementEventService.canCreateEvent(eventName, eventId)) | ||||
|         { | ||||
|             throw new EventAlreadyExistsException("framework.exception.CreateEventAlreadyExists", new Object[] {eventName}); | ||||
|         } | ||||
|  | ||||
|         return canCreateEvent; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Helper method for checking if an event can be edited or not. Throws an | ||||
|      * error if an event with the same display label already exists. | ||||
|      * | ||||
|      * @param eventName The name of the event | ||||
|      * @param eventId The id of the event | ||||
|      * @param eventType The type of the event | ||||
|      * @return true if the event can be edited, false otherwise | ||||
|      */ | ||||
|     private boolean canEditEvent(String eventName, String eventId, String eventType) | ||||
|     { | ||||
|         boolean canEditEvent = false; | ||||
|         if (eventExists(eventId)) { | ||||
|             try | ||||
|             { | ||||
|                 canEditEvent = recordsManagementEventService.canEditEvent(eventName, eventId, eventType); | ||||
|             } | ||||
|             catch (AlfrescoRuntimeException are) | ||||
|             { | ||||
|                 throw new EventAlreadyExistsException("framework.exception.UpdateEventAlreadyExists", new Object[] {eventName}); | ||||
|             } | ||||
|         } | ||||
|         return canEditEvent; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,76 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2022 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
|  | ||||
| package org.alfresco.rm.rest.api.events; | ||||
|  | ||||
| import org.alfresco.module.org_alfresco_module_rm.event.RecordsManagementEventService; | ||||
| import org.alfresco.rest.framework.WebApiDescription; | ||||
| import org.alfresco.rest.framework.resource.EntityResource; | ||||
| import org.alfresco.rest.framework.resource.actions.interfaces.EntityResourceAction; | ||||
| import org.alfresco.rest.framework.resource.parameters.CollectionWithPagingInfo; | ||||
| import org.alfresco.rest.framework.resource.parameters.Paging; | ||||
| import org.alfresco.rest.framework.resource.parameters.Parameters; | ||||
| import org.alfresco.rm.rest.api.model.EventTypeInfo; | ||||
|  | ||||
| import java.util.List; | ||||
| import java.util.stream.Collectors; | ||||
|  | ||||
| /** | ||||
|  * Event Type entity resource | ||||
|  */ | ||||
| @EntityResource(name = "event-types", title = "Event Types") | ||||
| public class EventTypeEntityResource implements EntityResourceAction.Read<EventTypeInfo> { | ||||
|     private RecordsManagementEventService recordsManagementEventService; | ||||
|  | ||||
|     /** | ||||
|      * Set the records management event service | ||||
|      * @param rmEventService | ||||
|      */ | ||||
|     public void setRecordsManagementEventService(RecordsManagementEventService rmEventService) | ||||
|     { | ||||
|         this.recordsManagementEventService = rmEventService; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     @WebApiDescription(title = "Return a list of different event types") | ||||
|     public CollectionWithPagingInfo<EventTypeInfo> readAll(Parameters params) | ||||
|     { | ||||
|         // TODO: AssociationName and ActionOnAssociatedNode properties still need to be assigned. | ||||
|         Paging paging = params.getPaging(); | ||||
|  | ||||
|         List<EventTypeInfo> eventTypeInfoList = recordsManagementEventService.getEventTypes().stream() | ||||
|                 .map(EventTypeInfo::fromRecordsManagementEventType) | ||||
|                 .collect(Collectors.toList()); | ||||
|  | ||||
|         int totalCount = eventTypeInfoList.size(); | ||||
|         boolean hasMoreItems = paging.getSkipCount() + paging.getMaxItems() < totalCount; | ||||
|         return CollectionWithPagingInfo.asPaged(paging, eventTypeInfoList.stream() | ||||
|                 .skip(paging.getSkipCount()) | ||||
|                 .limit(paging.getMaxItems()) | ||||
|                 .collect(Collectors.toList()), hasMoreItems, totalCount); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,34 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2016 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * Package info that defines the Information Governance Events REST API | ||||
|  */ | ||||
| @WebApi(name="gs", scope=Api.SCOPE.PUBLIC, version=1) | ||||
| package org.alfresco.rm.rest.api.events; | ||||
| import org.alfresco.rest.framework.Api; | ||||
| import org.alfresco.rest.framework.WebApi; | ||||
| @@ -0,0 +1,71 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2022 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
|  | ||||
| package org.alfresco.rm.rest.api.model; | ||||
|  | ||||
|  | ||||
| import org.alfresco.module.org_alfresco_module_rm.event.RecordsManagementEvent; | ||||
|  | ||||
| /** | ||||
|  * The EventBody model to be exposed through REST API. | ||||
|  */ | ||||
| public class EventBody { | ||||
|     private String name; | ||||
|     private String type; | ||||
|  | ||||
|     public static EventBody fromRecordsManagementEvent(RecordsManagementEvent event) | ||||
|     { | ||||
|         EventBody eventBody = new EventBody(); | ||||
|         if(event != null) { | ||||
|             eventBody.setName(event.getDisplayLabel()); | ||||
|             eventBody.setType(event.getType()); | ||||
|         } | ||||
|         return eventBody; | ||||
|     } | ||||
|  | ||||
|     public EventBody() {} | ||||
|  | ||||
|     public String getName() | ||||
|     { | ||||
|         return name; | ||||
|     } | ||||
|  | ||||
|     public void setName(String name) | ||||
|     { | ||||
|         this.name = name; | ||||
|     } | ||||
|  | ||||
|     public String getType() | ||||
|     { | ||||
|         return type; | ||||
|     } | ||||
|  | ||||
|     public void setType(String type) | ||||
|     { | ||||
|         this.type = type; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,82 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2022 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
|  | ||||
| package org.alfresco.rm.rest.api.model; | ||||
|  | ||||
| import org.alfresco.module.org_alfresco_module_rm.event.RecordsManagementEvent; | ||||
|  | ||||
| /** | ||||
|  * The EventInfo model to be exposed through REST API. | ||||
|  */ | ||||
| public class EventInfo { | ||||
|     private String id; | ||||
|     private String name; | ||||
|     private String type; | ||||
|  | ||||
|     public static EventInfo fromRecordsManagementEvent(RecordsManagementEvent event) | ||||
|     { | ||||
|         EventInfo eventInfo = new EventInfo(); | ||||
|         if (event != null) { | ||||
|             eventInfo.setName(event.getDisplayLabel()); | ||||
|             eventInfo.setId(event.getName()); | ||||
|             eventInfo.setType(event.getType()); | ||||
|         } | ||||
|         return eventInfo; | ||||
|     } | ||||
|  | ||||
|     public EventInfo() {} | ||||
|  | ||||
|     public String getId() | ||||
|     { | ||||
|         return id; | ||||
|     } | ||||
|  | ||||
|     public void setId(String id) | ||||
|     { | ||||
|         this.id = id; | ||||
|     } | ||||
|  | ||||
|     public String getName() | ||||
|     { | ||||
|         return name; | ||||
|     } | ||||
|  | ||||
|     public void setName(String name) | ||||
|     { | ||||
|         this.name = name; | ||||
|     } | ||||
|  | ||||
|     public String getType() | ||||
|     { | ||||
|         return type; | ||||
|     } | ||||
|  | ||||
|     public void setType(String type) | ||||
|     { | ||||
|         this.type = type; | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,105 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Records Management Module | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2022 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * - | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * - | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * - | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * - | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
|  | ||||
| package org.alfresco.rm.rest.api.model; | ||||
|  | ||||
| import org.alfresco.module.org_alfresco_module_rm.event.RecordsManagementEventType; | ||||
|  | ||||
| /** | ||||
|  * The EventTypeInfo model to be exposed through REST API. | ||||
|  */ | ||||
| public class EventTypeInfo { | ||||
|     private String id; | ||||
|     private String name; | ||||
|     private boolean isAutomatic; | ||||
|     private String associationName; | ||||
|     private String actionOnAssociatedNode; | ||||
|  | ||||
|     public static EventTypeInfo fromRecordsManagementEventType(RecordsManagementEventType eventType) | ||||
|     { | ||||
|         EventTypeInfo eventTypeInfo = new EventTypeInfo(); | ||||
|         if (eventType != null) { | ||||
|             eventTypeInfo.setName(eventType.getDisplayLabel()); | ||||
|             eventTypeInfo.setId(eventType.getName()); | ||||
|             eventTypeInfo.setAutomatic(eventType.isAutomaticEvent()); | ||||
|         } | ||||
|         return eventTypeInfo; | ||||
|     } | ||||
|  | ||||
|     public EventTypeInfo() {} | ||||
|  | ||||
|     public String getId() | ||||
|     { | ||||
|         return id; | ||||
|     } | ||||
|  | ||||
|     public void setId(String id) | ||||
|     { | ||||
|         this.id = id; | ||||
|     } | ||||
|  | ||||
|     public String getName() | ||||
|     { | ||||
|         return name; | ||||
|     } | ||||
|  | ||||
|     public void setName(String name) | ||||
|     { | ||||
|         this.name = name; | ||||
|     } | ||||
|  | ||||
|     public boolean isAutomatic() | ||||
|     { | ||||
|         return isAutomatic; | ||||
|     } | ||||
|  | ||||
|     public void setAutomatic(boolean automatic) | ||||
|     { | ||||
|         isAutomatic = automatic; | ||||
|     } | ||||
|  | ||||
|     public String getAssociationName() | ||||
|     { | ||||
|         return associationName; | ||||
|     } | ||||
|  | ||||
|     public void setAssociationName(String associationName) | ||||
|     { | ||||
|         this.associationName = associationName; | ||||
|     } | ||||
|  | ||||
|     public String getActionOnAssociatedNode() | ||||
|     { | ||||
|         return actionOnAssociatedNode; | ||||
|     } | ||||
|  | ||||
|     public void setActionOnAssociatedNode(String actionOnAssociatedNode) | ||||
|     { | ||||
|         this.actionOnAssociatedNode = actionOnAssociatedNode; | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -0,0 +1,39 @@ | ||||
| /* | ||||
|  * #%L | ||||
|  * Alfresco Remote API | ||||
|  * %% | ||||
|  * Copyright (C) 2005 - 2016 Alfresco Software Limited | ||||
|  * %% | ||||
|  * This file is part of the Alfresco software. | ||||
|  * If the software was purchased under a paid Alfresco license, the terms of | ||||
|  * the paid license agreement will prevail.  Otherwise, the software is | ||||
|  * provided under the following open source license terms: | ||||
|  * | ||||
|  * Alfresco is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Lesser General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * Alfresco is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Lesser General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU Lesser General Public License | ||||
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>. | ||||
|  * #L% | ||||
|  */ | ||||
|  | ||||
| package org.alfresco.rest.framework.core.exceptions; | ||||
|  | ||||
| /** | ||||
|  * The addressed Relationship Resource was not found | ||||
|  */ | ||||
| public class EventAlreadyExistsException extends ApiException { | ||||
|  | ||||
|     private static final long serialVersionUID = -3675294374348951929L; | ||||
|  | ||||
|     public EventAlreadyExistsException(String msgId, Object[] msgParams) { | ||||
|         super(msgId, msgParams); | ||||
|     } | ||||
| } | ||||
| @@ -7,6 +7,8 @@ framework.exception.InvalidQuery=An invalid WHERE query was received. {0} | ||||
| framework.exception.InvalidSelect=An invalid {1} query was received. {0} | ||||
| framework.exception.NotFound={0} was not found | ||||
| framework.exception.EntityNotFound=The entity with id: {0} was not found | ||||
| framework.exception.CreateEventAlreadyExists=Cannot create event. An event with name: {0} already exists | ||||
| framework.exception.UpdateEventAlreadyExists=Cannot update event. An event with name: {0} already exists | ||||
| framework.exception.RelationshipNotFound=The relationship resource was not found for the entity with id: {0} and a relationship id of {1} | ||||
| framework.exception.PermissionDenied=Permission was denied | ||||
| framework.exception.StaleEntity=Attempt to update a stale entity | ||||
|   | ||||
		Reference in New Issue
	
	Block a user