mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			25.1.0.44
			...
			rm-7187-ev
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 3875f0b170 | 
| @@ -175,6 +175,14 @@ | |||||||
|        <property name="nodesModelFactory" ref="nodesModelFactory" /> |        <property name="nodesModelFactory" ref="nodesModelFactory" /> | ||||||
|     </bean> |     </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 --> |    <!-- extended sites bean definition --> | ||||||
|    <bean id="rm.sites" class="org.alfresco.rm.rest.api.impl.RMSitesImpl" parent="sites"> |    <bean id="rm.sites" class="org.alfresco.rm.rest.api.impl.RMSitesImpl" parent="sites"> | ||||||
|         <property name="siteSurfConfig" ref="rm.siteSurfConfig" /> |         <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.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.module.org_alfresco_module_rm.record.RecordCreationException" value="422" /> | ||||||
|                 <entry key="org.alfresco.service.cmr.model.FileExistsException" value="409" /> |                 <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> |             </map> | ||||||
|         </property> |         </property> | ||||||
|    </bean> |    </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.InvalidSelect=An invalid {1} query was received. {0} | ||||||
| framework.exception.NotFound={0} was not found | framework.exception.NotFound={0} was not found | ||||||
| framework.exception.EntityNotFound=The entity with id: {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.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.PermissionDenied=Permission was denied | ||||||
| framework.exception.StaleEntity=Attempt to update a stale entity | framework.exception.StaleEntity=Attempt to update a stale entity | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user