mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
ALF-4875 - MT upgrade to 3.4 - fix patch sequence
- tenant attributes need to be migrated first git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@22686 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -308,7 +308,9 @@
|
|||||||
|
|
||||||
<!-- Bootstrap MT (multi-tenancy) if applicable -->
|
<!-- Bootstrap MT (multi-tenancy) if applicable -->
|
||||||
<bean id="multiTenantBootstrap" class="org.alfresco.repo.tenant.MultiTenantBootstrap" >
|
<bean id="multiTenantBootstrap" class="org.alfresco.repo.tenant.MultiTenantBootstrap" >
|
||||||
<property name="tenantAdminService" ref="tenantAdminService" />
|
<property name="tenantAdminService" ref="tenantAdminService"/>
|
||||||
|
<property name="patchService" ref="PatchService"/>
|
||||||
|
<property name="migrateAttrTenantsPatch" ref="patch.migrateAttrTenants"/>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<!-- Bootstrap any extensions -->
|
<!-- Bootstrap any extensions -->
|
||||||
|
@@ -2215,12 +2215,21 @@
|
|||||||
</property>
|
</property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Note: MT-specific (ALF-4875)
|
||||||
|
|
||||||
|
This patch will be applied directly (by MultiTenantBootstrap) before any tenants are started
|
||||||
|
and hence before any outstanding patches are applied (ie. prior to patch execution.
|
||||||
|
|
||||||
|
Hence, fixesToSchema/targetSchema is specified as 0/1 (rather than 4106/4107) to avoid error
|
||||||
|
that patch has already been applied.
|
||||||
|
-->
|
||||||
<bean id="patch.migrateAttrTenants" class="org.alfresco.repo.admin.patch.impl.MigrateAttrTenantsPatch" parent="basePatch">
|
<bean id="patch.migrateAttrTenants" class="org.alfresco.repo.admin.patch.impl.MigrateAttrTenantsPatch" parent="basePatch">
|
||||||
<property name="id"><value>patch.migrateAttrTenants</value></property>
|
<property name="id"><value>patch.migrateAttrTenants</value></property>
|
||||||
<property name="description"><value>patch.migrateAttrTenants.description</value></property>
|
<property name="description"><value>patch.migrateAttrTenants.description</value></property>
|
||||||
<property name="fixesFromSchema"><value>0</value></property>
|
<property name="fixesFromSchema"><value>0</value></property>
|
||||||
<property name="fixesToSchema"><value>4106</value></property>
|
<property name="fixesToSchema"><value>0</value></property>
|
||||||
<property name="targetSchema"><value>4107</value></property>
|
<property name="targetSchema"><value>1</value></property>
|
||||||
<property name="applyToTenants"><value>false</value></property>
|
<property name="applyToTenants"><value>false</value></property>
|
||||||
<property name="attributeService">
|
<property name="attributeService">
|
||||||
<ref bean="attributeService"/>
|
<ref bean="attributeService"/>
|
||||||
@@ -2228,6 +2237,11 @@
|
|||||||
<property name="patchDAO">
|
<property name="patchDAO">
|
||||||
<ref bean="patchDAO"/>
|
<ref bean="patchDAO"/>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="dependsOn" >
|
||||||
|
<list>
|
||||||
|
<ref bean="patch.db-V3.4-property-unique-ctx-value"/>
|
||||||
|
</list>
|
||||||
|
</property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<bean id="patch.migrateAttrAVMLocks" class="org.alfresco.repo.admin.patch.impl.MigrateAttrAVMLocksPatch" parent="basePatch">
|
<bean id="patch.migrateAttrAVMLocks" class="org.alfresco.repo.admin.patch.impl.MigrateAttrAVMLocksPatch" parent="basePatch">
|
||||||
@@ -2243,6 +2257,11 @@
|
|||||||
<property name="patchDAO">
|
<property name="patchDAO">
|
||||||
<ref bean="patchDAO"/>
|
<ref bean="patchDAO"/>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="dependsOn" >
|
||||||
|
<list>
|
||||||
|
<ref bean="patch.db-V3.4-property-unique-ctx-value"/>
|
||||||
|
</list>
|
||||||
|
</property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<bean id="patch.migrateAttrPropBackedBeans" class="org.alfresco.repo.admin.patch.impl.MigrateAttrPropBackedBeanPatch" parent="basePatch">
|
<bean id="patch.migrateAttrPropBackedBeans" class="org.alfresco.repo.admin.patch.impl.MigrateAttrPropBackedBeanPatch" parent="basePatch">
|
||||||
@@ -2258,6 +2277,11 @@
|
|||||||
<property name="patchDAO">
|
<property name="patchDAO">
|
||||||
<ref bean="patchDAO"/>
|
<ref bean="patchDAO"/>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="dependsOn" >
|
||||||
|
<list>
|
||||||
|
<ref bean="patch.db-V3.4-property-unique-ctx-value"/>
|
||||||
|
</list>
|
||||||
|
</property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<bean id="patch.migrateAttrChainingURS" class="org.alfresco.repo.admin.patch.impl.MigrateAttrChainingURSPatch" parent="basePatch">
|
<bean id="patch.migrateAttrChainingURS" class="org.alfresco.repo.admin.patch.impl.MigrateAttrChainingURSPatch" parent="basePatch">
|
||||||
@@ -2273,6 +2297,11 @@
|
|||||||
<property name="patchDAO">
|
<property name="patchDAO">
|
||||||
<ref bean="patchDAO"/>
|
<ref bean="patchDAO"/>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="dependsOn" >
|
||||||
|
<list>
|
||||||
|
<ref bean="patch.db-V3.4-property-unique-ctx-value"/>
|
||||||
|
</list>
|
||||||
|
</property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<bean id="patch.migrateAttrDelete" class="org.alfresco.repo.admin.patch.impl.MigrateAttrDeletePatch" parent="basePatch">
|
<bean id="patch.migrateAttrDelete" class="org.alfresco.repo.admin.patch.impl.MigrateAttrDeletePatch" parent="basePatch">
|
||||||
|
@@ -18,20 +18,26 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.repo.tenant;
|
package org.alfresco.repo.tenant;
|
||||||
|
|
||||||
import org.springframework.extensions.surf.util.AbstractLifecycleBean;
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.alfresco.repo.admin.patch.AppliedPatch;
|
||||||
|
import org.alfresco.repo.admin.patch.PatchService;
|
||||||
|
import org.alfresco.repo.admin.patch.impl.MigrateAttrTenantsPatch;
|
||||||
import org.alfresco.util.PropertyCheck;
|
import org.alfresco.util.PropertyCheck;
|
||||||
import org.springframework.context.ApplicationEvent;
|
import org.springframework.context.ApplicationEvent;
|
||||||
|
import org.springframework.extensions.surf.util.AbstractLifecycleBean;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This component is responsible for ensuring that patches are applied
|
* This component is responsible for starting the enabled tenants (if MT is enabled).
|
||||||
* at the appropriate time.
|
|
||||||
*
|
*
|
||||||
* @author Derek Hulley
|
* @author Derek Hulley, janv
|
||||||
*/
|
*/
|
||||||
public class MultiTenantBootstrap extends AbstractLifecycleBean
|
public class MultiTenantBootstrap extends AbstractLifecycleBean
|
||||||
{
|
{
|
||||||
private TenantAdminService tenantAdminService;
|
private TenantAdminService tenantAdminService;
|
||||||
|
private PatchService patchService;
|
||||||
|
private MigrateAttrTenantsPatch migrateAttrTenantsPatch;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param tenantAdminService the service that will perform the bootstrap
|
* @param tenantAdminService the service that will perform the bootstrap
|
||||||
*/
|
*/
|
||||||
@@ -39,12 +45,47 @@ public class MultiTenantBootstrap extends AbstractLifecycleBean
|
|||||||
{
|
{
|
||||||
this.tenantAdminService = tenantAdminService;
|
this.tenantAdminService = tenantAdminService;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setPatchService(PatchService patchService)
|
||||||
|
{
|
||||||
|
this.patchService = patchService;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setMigrateAttrTenantsPatch(MigrateAttrTenantsPatch migrateAttrTenantsPatch)
|
||||||
|
{
|
||||||
|
this.migrateAttrTenantsPatch = migrateAttrTenantsPatch;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onBootstrap(ApplicationEvent event)
|
protected void onBootstrap(ApplicationEvent event)
|
||||||
{
|
{
|
||||||
PropertyCheck.mandatory(this, "tenantAdminService", tenantAdminService);
|
PropertyCheck.mandatory(this, "tenantAdminService", tenantAdminService);
|
||||||
tenantAdminService.startTenants();
|
PropertyCheck.mandatory(this, "patchService", patchService);
|
||||||
|
|
||||||
|
if (tenantAdminService.isEnabled())
|
||||||
|
{
|
||||||
|
// Upgrade to 3.4 (chicken & egg)
|
||||||
|
if (tenantAdminService.getAllTenants().size() == 0)
|
||||||
|
{
|
||||||
|
boolean applied = false;
|
||||||
|
List<AppliedPatch> appliedPatches = patchService.getPatches(null, null);
|
||||||
|
for (AppliedPatch appliedPatch : appliedPatches)
|
||||||
|
{
|
||||||
|
if (appliedPatch.getId().equals("patch.migrateAttrTenants"))
|
||||||
|
{
|
||||||
|
applied = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! applied)
|
||||||
|
{
|
||||||
|
migrateAttrTenantsPatch.apply();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
tenantAdminService.startTenants();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Reference in New Issue
Block a user