mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-31 17:39:05 +00:00
RM-579 (The records managment team can reject an unfiled record using an UI action)
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/modules/recordsmanagement/HEAD@45995 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -238,4 +238,20 @@
|
||||
<property name="index" value="60" />
|
||||
</bean>
|
||||
|
||||
<bean id="rmRejectRecordsCapability"
|
||||
parent="declarativeCapability">
|
||||
<property name="name" value="RejectRecords"/>
|
||||
<property name="private" value="true" />
|
||||
<property name="conditions">
|
||||
<map>
|
||||
<entry key="capabilityCondition.filling" value="true"/>
|
||||
<entry key="capabilityCondition.frozen" value="false"/>
|
||||
<entry key="capabilityCondition.cutoff" value="false"/>
|
||||
<entry key="capabilityCondition.closed" value="false"/>
|
||||
<entry key="capabilityCondition.declared" value="false"/>
|
||||
</map>
|
||||
</property>
|
||||
<property name="targetCapability" ref="rmFileRecordsCapability" />
|
||||
</bean>
|
||||
|
||||
</beans>
|
@@ -28,13 +28,15 @@ rm.action.no-open-record-folder=Unable to open record folder, because node is no
|
||||
rm.action.not-hold-type=Can not relinquish hold, because node is not of type {0}. (actionedUponNodeRef={1})
|
||||
rm.action.no-read-mime-message=Unable to read mime message, because {0}.
|
||||
rm.action.email-declared=Can not split email, because record has already been declared. (actionedUponNodeRef={0})
|
||||
rm.action.email-not-record=Can no split email, because node is not a record. (actionedUponNodeRef={0})
|
||||
rm.action.email-not-record=Can no split email, because node is not a record. (actionedUponNodeRef={0})
|
||||
rm.action.email-create-child-assoc=Unable to create custom child association.
|
||||
rm.action.node-already-transfer=Node is already being transfered.
|
||||
rm.action.node-not-transfer=Node is not a transfer object.
|
||||
rm.action.undo-not-last=Can not undo cut off, because last disposition action was not cut off.
|
||||
rm.action.records_only_undeclared=Only records can be undeclared.
|
||||
rm.action.event-not-undone=The event {0} can not be undone, because it is not defined on the disposition lifecycle.
|
||||
rm.action.reject-no-reason=Can not reject a record without a reason.
|
||||
rm.action.reject-only-unfiled-records=Can only reject unfiled records.
|
||||
#
|
||||
# i18n for Rule Actions
|
||||
#
|
||||
|
@@ -1149,6 +1149,16 @@
|
||||
</properties>
|
||||
</aspect>
|
||||
|
||||
<!-- Aspect to hold the information about reject reason of a record -->
|
||||
<aspect name="rma:rejectReasonRecord">
|
||||
<title>The reject reason of a record</title>
|
||||
<properties>
|
||||
<property name="rma:rejectReason">
|
||||
<type>d:text</type>
|
||||
</property>
|
||||
</properties>
|
||||
</aspect>
|
||||
|
||||
</aspects>
|
||||
|
||||
</model>
|
@@ -11,9 +11,9 @@
|
||||
</list>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<!-- Actions -->
|
||||
|
||||
|
||||
<bean id="rmAction" parent="action-executer" abstract="true">
|
||||
<property name="namespaceService" ref="namespaceService"/>
|
||||
<property name="transactionService" ref="transactionService"/>
|
||||
@@ -33,10 +33,10 @@
|
||||
<property name="freezeService" ref="freezeService"/>
|
||||
<property name="recordService" ref="recordService"/>
|
||||
</bean>
|
||||
|
||||
<bean id="rmProxyAction"
|
||||
class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean"
|
||||
init-method="registerAction"
|
||||
|
||||
<bean id="rmProxyAction"
|
||||
class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean"
|
||||
init-method="registerAction"
|
||||
abstract="true">
|
||||
<property name="runtimeActionService" ref="actionService"/>
|
||||
<property name="recordsManagementActionService" ref="recordsManagementActionService"/>
|
||||
@@ -47,7 +47,7 @@
|
||||
</list>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="actionSecurity" abstract="true">
|
||||
<property name="authenticationManager">
|
||||
<ref bean="authenticationManager"/>
|
||||
@@ -59,14 +59,14 @@
|
||||
<ref bean="afterInvocationManager"/>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="actionProxy" abstract="true">
|
||||
|
||||
|
||||
</bean>
|
||||
|
||||
<!-- Cutoff action -->
|
||||
|
||||
|
||||
|
||||
|
||||
<bean id="cutoff_proxy" parent="rmProxyAction" >
|
||||
<property name="target">
|
||||
<ref bean="cutoff"/>
|
||||
@@ -87,11 +87,11 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="cutoff" class="org.alfresco.module.org_alfresco_module_rm.action.impl.CutOffAction" parent="rmAction"/>
|
||||
|
||||
<!-- UnCutoff action -->
|
||||
|
||||
|
||||
<bean id="cutoff" class="org.alfresco.module.org_alfresco_module_rm.action.impl.CutOffAction" parent="rmAction"/>
|
||||
|
||||
<!-- UnCutoff action -->
|
||||
|
||||
<bean id="unCutoff_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="unCutoff"/>
|
||||
@@ -112,11 +112,11 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="unCutoff" class="org.alfresco.module.org_alfresco_module_rm.action.impl.UnCutoffAction" parent="rmAction" />
|
||||
|
||||
|
||||
<bean id="unCutoff" class="org.alfresco.module.org_alfresco_module_rm.action.impl.UnCutoffAction" parent="rmAction" />
|
||||
|
||||
<!-- Destroy -->
|
||||
|
||||
|
||||
<bean id="destroy_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="destroy"/>
|
||||
@@ -147,11 +147,11 @@
|
||||
<property name="ghostingEnabled">
|
||||
<value>${rm.ghosting.enabled}</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
</bean>
|
||||
|
||||
<!-- retain -->
|
||||
<!-- No permissoin?? : allow -->
|
||||
|
||||
|
||||
<bean id="retain_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="retain"/>
|
||||
@@ -172,11 +172,11 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="retain" class="org.alfresco.module.org_alfresco_module_rm.action.impl.RetainAction" parent="rmAction" depends-on="rmFileRecordsCapability"/>
|
||||
|
||||
|
||||
<!-- open record folder -->
|
||||
|
||||
|
||||
<bean id="openRecordFolder_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="openRecordFolder"/>
|
||||
@@ -197,11 +197,11 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="openRecordFolder" class="org.alfresco.module.org_alfresco_module_rm.action.impl.OpenRecordFolderAction" parent="rmAction" />
|
||||
|
||||
|
||||
<bean id="openRecordFolder" class="org.alfresco.module.org_alfresco_module_rm.action.impl.OpenRecordFolderAction" parent="rmAction" />
|
||||
|
||||
<!-- close record folder -->
|
||||
|
||||
|
||||
<bean id="closeRecordFolder_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="closeRecordFolder"/>
|
||||
@@ -222,11 +222,11 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="closeRecordFolder" class="org.alfresco.module.org_alfresco_module_rm.action.impl.CloseRecordFolderAction" parent="rmAction" />
|
||||
|
||||
|
||||
<bean id="closeRecordFolder" class="org.alfresco.module.org_alfresco_module_rm.action.impl.CloseRecordFolderAction" parent="rmAction" />
|
||||
|
||||
<!-- reviewed -->
|
||||
|
||||
|
||||
<bean id="reviewed_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="reviewed"/>
|
||||
@@ -247,11 +247,11 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="reviewed" class="org.alfresco.module.org_alfresco_module_rm.vital.ReviewedAction" parent="rmAction" depends-on="rmCycleVitalRecordsCapability" />
|
||||
|
||||
|
||||
<bean id="reviewed" class="org.alfresco.module.org_alfresco_module_rm.vital.ReviewedAction" parent="rmAction" depends-on="rmCycleVitalRecordsCapability" />
|
||||
|
||||
<!-- declare record -->
|
||||
|
||||
|
||||
<bean id="declareRecord_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="declareRecord"/>
|
||||
@@ -272,12 +272,12 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="declareRecord" class="org.alfresco.module.org_alfresco_module_rm.action.impl.DeclareRecordAction" parent="rmAction">
|
||||
</bean>
|
||||
|
||||
</bean>
|
||||
|
||||
<!-- undeclare record -->
|
||||
|
||||
|
||||
<bean id="undeclareRecord_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="undeclareRecord"/>
|
||||
@@ -298,9 +298,9 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="undeclareRecord" class="org.alfresco.module.org_alfresco_module_rm.action.impl.UndeclareRecordAction" parent="rmAction">
|
||||
</bean>
|
||||
</bean>
|
||||
|
||||
<!-- Freeze record -->
|
||||
|
||||
@@ -324,7 +324,7 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="freeze" class="org.alfresco.module.org_alfresco_module_rm.action.impl.FreezeAction" parent="rmAction" depends-on="rmExtendRetentionPeriodOrFreezeCapability" />
|
||||
|
||||
<!-- Unfreeze record -->
|
||||
@@ -349,9 +349,9 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="unfreeze" class="org.alfresco.module.org_alfresco_module_rm.action.impl.UnfreezeAction" parent="rmAction" />
|
||||
|
||||
|
||||
<!-- Relinquish Hold Action-->
|
||||
|
||||
<bean id="relinquishHold_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
@@ -364,9 +364,9 @@
|
||||
</list>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="relinquishHold" class="org.alfresco.module.org_alfresco_module_rm.action.impl.RelinquishHoldAction" parent="rmAction" />
|
||||
|
||||
|
||||
<!-- Edit hold reason -->
|
||||
|
||||
<bean id="editHoldReason_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
@@ -389,9 +389,9 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="editHoldReason" class="org.alfresco.module.org_alfresco_module_rm.action.impl.EditHoldReasonAction" parent="rmAction" />
|
||||
|
||||
|
||||
<bean id="editHoldReason" class="org.alfresco.module.org_alfresco_module_rm.action.impl.EditHoldReasonAction" parent="rmAction" />
|
||||
|
||||
<!-- Edit review as of date -->
|
||||
|
||||
<bean id="editReviewAsOfDate_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
@@ -414,9 +414,9 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="editReviewAsOfDate" class="org.alfresco.module.org_alfresco_module_rm.action.impl.EditReviewAsOfDateAction" parent="rmAction" />
|
||||
|
||||
|
||||
<bean id="editReviewAsOfDate" class="org.alfresco.module.org_alfresco_module_rm.action.impl.EditReviewAsOfDateAction" parent="rmAction" />
|
||||
|
||||
<!-- Edit disposition action as of date -->
|
||||
|
||||
<bean id="editDispositionActionAsOfDate_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
@@ -439,12 +439,12 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="editDispositionActionAsOfDate" class="org.alfresco.module.org_alfresco_module_rm.action.impl.EditDispositionActionAsOfDateAction" parent="rmAction" />
|
||||
|
||||
|
||||
<bean id="editDispositionActionAsOfDate" class="org.alfresco.module.org_alfresco_module_rm.action.impl.EditDispositionActionAsOfDateAction" parent="rmAction" />
|
||||
|
||||
<!-- broadcast vital record definition -->
|
||||
<!-- bound to policy: allow -->
|
||||
|
||||
|
||||
<bean id="broadcastVitalRecordDefinition_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="broadcastVitalRecordDefinition"/>
|
||||
@@ -465,13 +465,13 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="broadcastVitalRecordDefinition" class="org.alfresco.module.org_alfresco_module_rm.vital.BroadcastVitalRecordDefinitionAction"
|
||||
parent="rmAction" />
|
||||
|
||||
|
||||
<!-- broadcast disposition action definition update -->
|
||||
<!-- bound to policy: allow -->
|
||||
|
||||
|
||||
<bean id="broadcastDispositionActionDefinitionUpdate_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="broadcastDispositionActionDefinitionUpdate"/>
|
||||
@@ -492,16 +492,16 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="broadcastDispositionActionDefinitionUpdate"
|
||||
|
||||
<bean id="broadcastDispositionActionDefinitionUpdate"
|
||||
class="org.alfresco.module.org_alfresco_module_rm.action.impl.BroadcastDispositionActionDefinitionUpdateAction"
|
||||
parent="rmAction" >
|
||||
<property name="behaviourFilter" ref="policyBehaviourFilter"/>
|
||||
</bean>
|
||||
|
||||
|
||||
|
||||
|
||||
<!-- complete event -->
|
||||
|
||||
|
||||
<bean id="completeEvent_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="completeEvent"/>
|
||||
@@ -522,12 +522,12 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="completeEvent" class="org.alfresco.module.org_alfresco_module_rm.action.impl.CompleteEventAction" parent="rmAction">
|
||||
</bean>
|
||||
|
||||
</bean>
|
||||
|
||||
<!-- undo event -->
|
||||
|
||||
|
||||
<bean id="undoEvent_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="undoEvent"/>
|
||||
@@ -548,10 +548,10 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="undoEvent" class="org.alfresco.module.org_alfresco_module_rm.action.impl.UndoEventAction" parent="rmAction">
|
||||
</bean>
|
||||
|
||||
</bean>
|
||||
|
||||
<!-- transfer -->
|
||||
|
||||
<bean id="transfer_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
@@ -574,13 +574,13 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="transfer" class="org.alfresco.module.org_alfresco_module_rm.action.impl.TransferAction" parent="rmAction">
|
||||
<property name="isAccession" value="false"/>
|
||||
</bean>
|
||||
|
||||
</bean>
|
||||
|
||||
<!-- Transfer complete -->
|
||||
|
||||
|
||||
<bean id="transferComplete_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="transferComplete"/>
|
||||
@@ -591,12 +591,12 @@
|
||||
</list>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="transferComplete" class="org.alfresco.module.org_alfresco_module_rm.action.impl.TransferCompleteAction" parent="rmAction" >
|
||||
</bean>
|
||||
|
||||
</bean>
|
||||
|
||||
<!-- accession -->
|
||||
|
||||
|
||||
<bean id="accession_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="accession"/>
|
||||
@@ -617,13 +617,13 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="accession" class="org.alfresco.module.org_alfresco_module_rm.action.impl.TransferAction" parent="rmAction">
|
||||
<property name="isAccession" value="true"/>
|
||||
</bean>
|
||||
|
||||
</bean>
|
||||
|
||||
<!-- Accession complete -->
|
||||
|
||||
|
||||
<bean id="accessionComplete_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="accessionComplete"/>
|
||||
@@ -634,22 +634,22 @@
|
||||
</list>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
|
||||
<bean id="accessionComplete" class="org.alfresco.module.org_alfresco_module_rm.action.impl.TransferCompleteAction" parent="rmAction">
|
||||
</bean>
|
||||
|
||||
</bean>
|
||||
|
||||
<!-- Split Email -->
|
||||
<bean id="splitEmail" class="org.alfresco.module.org_alfresco_module_rm.action.impl.SplitEmailAction" parent="rmAction">
|
||||
</bean>
|
||||
|
||||
</bean>
|
||||
|
||||
<bean id="splitEmail_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="splitEmail"/>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<!-- Create disposition schedule -->
|
||||
|
||||
|
||||
<!-- Create disposition schedule -->
|
||||
|
||||
<bean id="createDispositionSchedule_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="createDispositionSchedule"/>
|
||||
@@ -670,10 +670,33 @@
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="createDispositionSchedule"
|
||||
class="org.alfresco.module.org_alfresco_module_rm.action.impl.CreateDispositionScheduleAction"
|
||||
|
||||
<bean id="createDispositionSchedule"
|
||||
class="org.alfresco.module.org_alfresco_module_rm.action.impl.CreateDispositionScheduleAction"
|
||||
parent="rmAction" />
|
||||
|
||||
|
||||
</beans>
|
||||
|
||||
<!-- Reject record -->
|
||||
|
||||
<bean id="reject_proxy" class="org.alfresco.module.org_alfresco_module_rm.capability.RMActionProxyFactoryBean" parent="rmProxyAction" init-method="registerAction">
|
||||
<property name="target">
|
||||
<ref bean="reject"/>
|
||||
</property>
|
||||
<property name="interceptorNames">
|
||||
<list>
|
||||
<idref bean="reject_security"/>
|
||||
</list>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="reject_security" class="org.alfresco.repo.security.permissions.impl.acegi.MethodSecurityInterceptor" parent="actionSecurity">
|
||||
<property name="objectDefinitionSource">
|
||||
<value>
|
||||
org.alfresco.module.org_alfresco_module_rm.action.RecordsManagementAction.execute=RM_ALLOW
|
||||
org.alfresco.module.org_alfresco_module_rm.action.RecordsManagementAction.*=RM_ALLOW
|
||||
org.alfresco.repo.action.executer.ActionExecuter.*=RM_ALLOW
|
||||
</value>
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="reject" class="org.alfresco.module.org_alfresco_module_rm.action.impl.RejectAction" parent="rmAction" />
|
||||
</beans>
|
@@ -675,4 +675,15 @@
|
||||
</property>
|
||||
</bean>
|
||||
|
||||
<bean id="jsonConversionComponent.reject"
|
||||
parent="jsonConversionComponent.baseAction">
|
||||
<property name="name" value="reject"/>
|
||||
<property name="kinds">
|
||||
<set>
|
||||
<value>RECORD</value>
|
||||
</set>
|
||||
</property>
|
||||
<property name="capability" value="RejectRecords" />
|
||||
</bean>
|
||||
|
||||
</beans>
|
||||
|
@@ -0,0 +1,92 @@
|
||||
/*
|
||||
* Copyright (C) 2005-2012 Alfresco Software Limited.
|
||||
*
|
||||
* This file is part of Alfresco
|
||||
*
|
||||
* 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/>.
|
||||
*/
|
||||
package org.alfresco.module.org_alfresco_module_rm.action.impl;
|
||||
|
||||
import java.io.Serializable;
|
||||
import java.util.Map;
|
||||
|
||||
import org.alfresco.error.AlfrescoRuntimeException;
|
||||
import org.alfresco.module.org_alfresco_module_rm.action.RMActionExecuterAbstractBase;
|
||||
import org.alfresco.service.cmr.action.Action;
|
||||
import org.alfresco.service.cmr.repository.NodeRef;
|
||||
import org.apache.commons.lang.StringUtils;
|
||||
import org.springframework.extensions.surf.util.I18NUtil;
|
||||
|
||||
/**
|
||||
* Reject action for an unfiled record
|
||||
*
|
||||
* @author Tuna Aksoy
|
||||
* @since 2.1
|
||||
*/
|
||||
public class RejectAction extends RMActionExecuterAbstractBase
|
||||
{
|
||||
/** Message properties */
|
||||
private static final String MSG_REJECT_NO_REASON = "rm.action.reject-no-reason";
|
||||
private static final String MSG_REJECT_ONLY_UNFILED_RECORDS = "rm.action.reject-only-unfiled-records";
|
||||
|
||||
/** Parameter names */
|
||||
public static final String PARAM_REASON = "reason";
|
||||
|
||||
/**
|
||||
* @see org.alfresco.repo.action.executer.ActionExecuterAbstractBase#executeImpl(org.alfresco.service.cmr.action.Action, org.alfresco.service.cmr.repository.NodeRef)
|
||||
*/
|
||||
@Override
|
||||
protected void executeImpl(Action action, NodeRef actionedUponNodeRef)
|
||||
{
|
||||
recordService.rejectRecord(actionedUponNodeRef, (String) action.getParameterValue(PARAM_REASON));
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.alfresco.module.org_alfresco_module_rm.action.RMActionExecuterAbstractBase#isExecutableImpl(org.alfresco.service.cmr.repository.NodeRef, java.util.Map, boolean)
|
||||
*/
|
||||
@Override
|
||||
protected boolean isExecutableImpl(NodeRef filePlanComponent,
|
||||
Map<String, Serializable> parameters, boolean throwException)
|
||||
{
|
||||
if (recordService.isRecord(filePlanComponent) == true && recordService.isFiled(filePlanComponent) == false)
|
||||
{
|
||||
if (parameters != null && StringUtils.isNotBlank((String) parameters.get(PARAM_REASON)))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (throwException)
|
||||
{
|
||||
throw new AlfrescoRuntimeException(I18NUtil.getMessage(MSG_REJECT_NO_REASON));
|
||||
}
|
||||
else
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (throwException)
|
||||
{
|
||||
throw new AlfrescoRuntimeException(I18NUtil.getMessage(MSG_REJECT_ONLY_UNFILED_RECORDS));
|
||||
}
|
||||
else
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
@@ -234,4 +234,8 @@ public interface RecordsManagementModel extends RecordsManagementCustomModel
|
||||
// Original location of a record
|
||||
public static final QName ASPECT_ORIGINAL_LOCATION = QName.createQName(RM_URI, "originalLocation");
|
||||
public static final QName PROP_ORIGINAL_LOCATION = QName.createQName(RM_URI, "orgLocation");
|
||||
|
||||
// Reject reason of a record
|
||||
public static final QName ASPECT_REJECT_REASON_RECORD = QName.createQName(RM_URI, "rejectReasonRecord");
|
||||
public static final QName PROP_REJECT_REASON = QName.createQName(RM_URI, "rejectReason");
|
||||
}
|
||||
|
@@ -26,7 +26,7 @@ import org.alfresco.service.namespace.QName;
|
||||
|
||||
/**
|
||||
* Record Service Interface.
|
||||
*
|
||||
*
|
||||
* @author Roy Wetherall
|
||||
* @since 2.1
|
||||
*/
|
||||
@@ -34,14 +34,14 @@ public interface RecordService
|
||||
{
|
||||
/**
|
||||
* Gets a list of all the record meta-data aspects
|
||||
*
|
||||
*
|
||||
* @return {@link Set}<{@link QName}> list of record meta-data aspects
|
||||
*/
|
||||
Set<QName> getRecordMetaDataAspects();
|
||||
|
||||
/**
|
||||
* Checks whether if the given node reference is a record or not
|
||||
*
|
||||
*
|
||||
* @param nodeRef node reference to be checked
|
||||
* @return boolean true if the node reference is a record, false otherwise
|
||||
*/
|
||||
@@ -49,36 +49,44 @@ public interface RecordService
|
||||
|
||||
/**
|
||||
* Indicates whether the record is declared
|
||||
*
|
||||
*
|
||||
* @param nodeRef node reference of the record for which the check would be performed
|
||||
* @return boolean true if record is declared, false otherwise
|
||||
*/
|
||||
boolean isDeclared(NodeRef nodeRef);
|
||||
boolean isDeclared(NodeRef nodeRef);
|
||||
|
||||
/**
|
||||
* Creates a new unfiled record from an existing node.
|
||||
* <p>
|
||||
* Note that the node reference of the record will be the same as the origional
|
||||
* document.
|
||||
*
|
||||
*
|
||||
* @param filePlan The filePlan in which the record should be placed
|
||||
* @param nodeRef The node from which the record will be created
|
||||
* @param isLinked indicates if the newly created record is linked to it's original location or not.
|
||||
*/
|
||||
void createRecord(NodeRef filePlan, NodeRef nodeRef, boolean isLinked);
|
||||
|
||||
|
||||
/**
|
||||
* Links the newly created record to it's original location.
|
||||
*
|
||||
*
|
||||
* @see #createRecord(NodeRef, NodeRef, boolean)
|
||||
*/
|
||||
void createRecord(NodeRef filePlan, NodeRef nodeRef);
|
||||
|
||||
|
||||
/**
|
||||
* Indicates whether the record is filed or not
|
||||
*
|
||||
*
|
||||
* @param nodeRef record
|
||||
* @return boolean true if filed, false otherwise
|
||||
*/
|
||||
boolean isFiled(NodeRef record);
|
||||
|
||||
/**
|
||||
* Rejects a node with the provided reason
|
||||
*
|
||||
* @param nodeRef node reference
|
||||
* @param reason reject reason
|
||||
*/
|
||||
void rejectRecord(NodeRef nodeRef, String reason);
|
||||
}
|
||||
|
@@ -23,6 +23,7 @@ import java.util.Calendar;
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
|
||||
@@ -90,7 +91,7 @@ public class RecordServiceImpl implements RecordService,
|
||||
|
||||
/** Disposition service */
|
||||
private DispositionService dispositionService;
|
||||
|
||||
|
||||
/** File plan service */
|
||||
private FilePlanService filePlanService;
|
||||
|
||||
@@ -167,7 +168,7 @@ public class RecordServiceImpl implements RecordService,
|
||||
{
|
||||
this.dispositionService = dispositionService;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param filePlanService file plan service
|
||||
*/
|
||||
@@ -268,7 +269,7 @@ public class RecordServiceImpl implements RecordService,
|
||||
{
|
||||
createRecord(filePlan, nodeRef, true);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @see org.alfresco.module.org_alfresco_module_rm.record.RecordService#createRecord(org.alfresco.service.cmr.repository.NodeRef, org.alfresco.service.cmr.repository.NodeRef, boolean)
|
||||
*/
|
||||
@@ -277,7 +278,7 @@ public class RecordServiceImpl implements RecordService,
|
||||
ParameterCheck.mandatory("filePlan", filePlan);
|
||||
ParameterCheck.mandatory("nodeRef", nodeRef);
|
||||
ParameterCheck.mandatory("isLinked", isLinked);
|
||||
|
||||
|
||||
if (nodeService.hasAspect(nodeRef, ASPECT_RECORD) == false)
|
||||
{
|
||||
// first we do a sanity check to ensure that the user has at least write permissions on the document
|
||||
@@ -322,10 +323,10 @@ public class RecordServiceImpl implements RecordService,
|
||||
makeRecord(nodeRef);
|
||||
|
||||
if (isLinked == true)
|
||||
{
|
||||
{
|
||||
// maintain the original primary location
|
||||
nodeService.addChild(parentAssoc.getParentRef(), nodeRef, parentAssoc.getTypeQName(), parentAssoc.getQName());
|
||||
|
||||
|
||||
// set the readers
|
||||
extendedSecurityService.setExtendedReaders(nodeRef, readers);
|
||||
}
|
||||
@@ -425,4 +426,54 @@ public class RecordServiceImpl implements RecordService,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void rejectRecord(final NodeRef nodeRef, String reason)
|
||||
{
|
||||
ParameterCheck.mandatory("NodeRef", nodeRef);
|
||||
ParameterCheck.mandatoryString("Reason", reason);
|
||||
|
||||
// do the work of rejecting the record as the system user
|
||||
AuthenticationUtil.runAsSystem(new RunAsWork<Void>()
|
||||
{
|
||||
@Override
|
||||
public Void doWork() throws Exception
|
||||
{
|
||||
// first remove the secondary link association
|
||||
NodeRef originalLocation = (NodeRef) nodeService.getProperty(nodeRef, PROP_ORIGINAL_LOCATION);
|
||||
List<ChildAssociationRef> parentAssocs = nodeService.getParentAssocs(nodeRef);
|
||||
for (ChildAssociationRef childAssociationRef : parentAssocs)
|
||||
{
|
||||
if (childAssociationRef.isPrimary() == false && childAssociationRef.getParentRef().equals(originalLocation))
|
||||
{
|
||||
nodeService.removeChildAssociation(childAssociationRef);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// remove the "record" and "file plan component" aspects
|
||||
nodeService.removeAspect(nodeRef, RecordsManagementModel.ASPECT_RECORD);
|
||||
nodeService.removeAspect(nodeRef, ASPECT_FILE_PLAN_COMPONENT);
|
||||
|
||||
// remove "identifier" property
|
||||
nodeService.removeProperty(nodeRef, PROP_IDENTIFIER);
|
||||
|
||||
// get the records primary parent association
|
||||
ChildAssociationRef parentAssoc = nodeService.getPrimaryParent(nodeRef);
|
||||
|
||||
// save the reject reason
|
||||
Map<QName, Serializable> aspectProperties = new HashMap<QName, Serializable>(1);
|
||||
aspectProperties.put(PROP_REJECT_REASON, (Serializable) parentAssoc.getParentRef());
|
||||
nodeService.addAspect(nodeRef, ASPECT_REJECT_REASON_RECORD, aspectProperties);
|
||||
|
||||
// move the record into the collaboration site
|
||||
nodeService.moveNode(nodeRef, originalLocation, ContentModel.ASSOC_CONTAINS, parentAssoc.getQName());
|
||||
|
||||
// remove all extended readers
|
||||
extendedSecurityService.removeAllExtendedReaders(nodeRef);
|
||||
|
||||
return null;
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user