mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-09-10 14:11:58 +00:00
Compare commits
1 Commits
23.3.6.2
...
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