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:
Jan Vonka
2010-09-24 11:33:06 +00:00
parent 44b1d5ff6f
commit 0466c42f00
3 changed files with 82 additions and 10 deletions

View File

@@ -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 -->

View File

@@ -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">

View File

@@ -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