mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-31 17:39:05 +00:00
24662: 3.4.1 bug fix branch 24718: Merged V3.3 to V3.4-BUG-FIX 24717: Fix ALF-5555: It is impossible to edit review date from record's details page 24719: Fix for ALF-6106: Error on Check In operation with % symbol (SPP) 24733: Better fix for ALF-6106: Error on Check In operation with % symbol 24734: Fix for ALF-6089: Incorrect order of fields at 'Create Series', 'Create Category' and 'Create Folder' forms The name, title and description fields are now placed in their own group on the server, all other non custom rm fields are put in an 'other' group, the client side config then declares a set for each group and orders them appropriately. 24752: Merged V3.4 to V3.4-BUG-FIX 24751: Merged V3.3-BUG-FIX to V3.4 (RECORD ONLY) Restored V3.3-BUG-FIX mergeinfo, somehow truncated in revision 24274 24753: Merged V3.3-BUG-FIX to V3.4-BUG-FIX 23870: Merge Dev to V3.3_BUG_FIX ALF-4243: F5 load-balancer sending regular HTTP requests to Alfresco server causing Faces Servlet to throw java.lang.NullPointerException (MyFaces upgrade to from 1.1.5 to 1.1.7) 23897: Additional fixes and tweaks since introduction of MyFaces 1.1.7 library. 23919: More JSF component id related fixes. 23945: More MyFaces1.1.7 JSF page fix ups 23959: Another MyFaces 1.1.7 dup id issue fixed. 24008: ALF-4243 - Upgraded MyFaces from 1.1.7 to 1.1.8 to fix a bug seen in 1.1.7 - Added handling for the fact that valuebound properties that result in null now cause an exception where-as they were perfectly valid in 1.1.5. 24419: Merge from V3.3 to V3.3-BUG-FIX r.24418 Fix for ALF-6075. Running out of /tmp space on the server is causing uploads to fail. 24768: Fixes ALF-6295: Allows MySQL to not be installed via unattended installer invocation 24771: Merged BRANCHES/V3.4 to BRANCHES/DEV/V3.4-BUG-FIX: 24767: Merged BRANCHES/V3.3 to BRANCHES/V3.4: 24765: ALF-6547: fix intermittent test failure (AssetServiceImplTest renameFile/renameFolder) - fallout from ALF-1948 24779: Merge V3.3 to V3.4-BUG-FIX 24497 : ALF-3092 - deployment service - catch Throwable from Begin. 24684 : Merge DEV/BELARUS/V3.3-BUG-FIX-2010_10_04 to V3.3 23498 : ALF-5498 In Windows XP, placing a Folder with a Name that already Exists Removes all Content of the Existing Folder 24749 : ALF-6174 - Transfer Service fails with double peer assoc custom content type 24766 : ALF-5603 - It is impossible to assign workflow from workflow console to non-admin user 24802: Merged BRANCHES/V3.4 to BRANCHES/DEV/V3.4-BUG-FIX: 24801: Fix for ALF-3055: "SecurityTestSuite hangs when run in DOD5015 context - failed authentication audit hangs on DB connection" - do failed audits in a separate thread (from a thread pool) 24812: Fix ALF-6316: A new "spoof" multivalue text property (cm:tagScopeSummary) is now made available for TagScope nodes when accessed via the getProperty or getProperties operations on the standard node service. The values of this property take the form "<tagname>=<tagcount>". A new interceptor has been added to the node service to do this (TagScopePropertyMethodInterceptor). WQS has been tweaked to make use of this new property, and the now defunct behaviour has been removed. 24820: Work in progress refactoring transaction handling of transfer unit tests. 24822: Merged BRANCHES/V3.4 to BRANCHES/DEV/V3.4-BUG-FIX: 24821: Fix for ALF-3055: "SecurityTestSuite hangs when run in DOD5015 context - failed authentication audit hangs on DB connection" - fix up unit tests 24834: ALF-6468 - Update the scheduled actions folder bootstrap to use localisable names and descriptions, following the normal pattern 24836: Added system property 'system.cache.disableImmutableSharedCaches' (false by default) - Equivalent to disabling Hibernate L2 cache for *immutable* entities - Allows distinction between mutable and immutable cache entries 24850: Fix ALF-6562: Moved property that is used to label the WQS dashlet on the "configure site dashboard" page out of the Slingshot project and into the WQS Share Module project. Corrected its value to "Web Quick Start" rather than "WCM Quick Start". 24857: Merged V3.4 to V3.4-BUG-FIX 24853: Merged V3.3 to V3.4 24852: Fixed ALF-6573 "Incorrect name of subgroups on "Groups" page" 24870: Removed svn:mergeinfo from root 24873: Merged V3.3 to V3.4-BUG-FIX (RECORD ONLY) 21789: ALF-4333: Fix - Updated RepoPrimaryManifestProcessorImpl so it can handle deletions that are reported by either pre-delete noderef or archived noderef (previously only handled the latter). - Updated TransferManifestNodeFactory so that it handles the case where the status of the node to transfer is "deleted". - Updated UnitTestTransferManifestNodeFactory so that it handles the change to TransferManifestNodeFactory above. - Added new tests for deletion cases. 23259: Merged HEAD to V3.3 23256: Fix ALF-4573: Start Workflow action is absent for edited document and working copy in Share 23346: Brought WebQS module in (including build process but not installer elements yet) 23371: "Simply" added wcmqs to installer 23391: ALF-5367: Copy dlls into tomcat/bin as appropriate. 23485: Merged V3.4 to V3.3 (fix backported for V3.3.x lines) 23472: Fixed ALF-5408: SQL Server missing ON DELETE CASCADE declarations 23515: Merged PATCHES/V3.2.0 to V3.3 23514: ALF-5554: Merged HEAD to V3.2.0 23153: When updating tag scopes following system shutdown/restore, be smarter about quickly skipping tag scopes that another (new) thread is currently working on 23283: More debugging level logging for tagging updates, to help identify the problem with periodic multi-threaded test failures on bamboo 23535: Merged V3.4 to V3.3 (complements 23517: ALF-5552) 23508: Fixed ALF-5559: Permission interceptors can fail if Lucene returns invalid NodeRefs 23564: ALF-5600: Merged V3.4 to V3.3 23424: Fixes: ALF-2989 - Incorrect sideId reference in URL for event in Site Calendar Dashlet Adds support for displaying events that start in the past but finish in the future (previously only events that start in the future were shown) 23586: MERGED V3.4 to V3.3 22864: Fix for ALF-5005: "Create and edit functions on AWE become "confused"" 23042: Fix ALF-5127: Impossible to create an article/blog (WCMQS) [Must clear panel hideEvent handler if manually hiding a YUI panel] 23561: Fixes: ALF-4569 - Removes universal override of input width box and switches the editor form panel to adjust it's width based on content rather than window size. Fixes: ALF-4570 - Adds an override for the CSS 'top' property of the form dialogue to ensure it's always below the ribbon. (Was being set automatically by the YUI widget.panel call) 23569: Fixes: ALF-5606 - Ribbon wasn't resizing correctly after the form events. 23630: Backport of installer 23631: Added 64-bit & deployment installers 23664: Fixes ALF-5691: TransferService: Multi-byte characters are not encoded correctly 23681: Fixes ALF-5699: TransferService: Snapshot file from source repo never contains complete MLText properties 23695: Fixed bug exposed after fixing ALF-5699. Parsing of MLText properties out of the transfer snapshot file was incorrect, and that was causing multi-lingual property values to be duplicated 23709: ALF-5699: Fix NPE in ManifestIntegrationTest 23734: Merged V3.4 to V3.3 23731: Fixes for ALF-3098 and ALF-3097 - Share - Security check on Personal Dashboard - only the owning user can view a user dashboard page - Share - Security issue on Customize Site Dashboard - private and moderated site dashboard pages no longer visible to non-members, customise site and dashboard pages only accessible to SiteManager 23747: ALF-5696: Merged V3.4 to V3.3 23585: Fixed ALF-5372 "JavaScript error on Groups management dialog with IE8 : document.getElementById is null" 23790: Fixed ALF-3823 "Share: RSS feed can't be read: http://cds-srv.sun.com:8700/rss/update/public/sunalert_update.xml - ok with other RSS client." 23883: Fixes ALF-5759: WQS: Attempt to copy a website section fails 23907: Merged DEV/BELARUS/V3.3-BUG-FIX-2010_09_20 to V33 22750: ALF-4846: Update rules are firing on inbound actions 23931: Undid rev 23907 (Reverse-merged /alfresco/BRANCHES/DEV/BELARUS/V3.3-BUG-FIX-2010_09_20:r22750) 23961: Fixed ALF-5686 "Incorrect behaviour of "All" filter in "My Tasks" dashlet" - Variables assigned in a <#macro> shall always be assigned using <#local> (using <#assign> makes them globally available which might cause naming collisions) 24132: Disable intermittent failing unit test 24148: ALF-6007: Merged HEAD to V3.3 23049: Fixed ALF-5099: Error when trying to go back in Create Web Content Wizard (only with certain XSDs) 24263: Merged from V3.3-BUG-FIX to V3.3 24264: V3.3-BUG-FIX to V3.3 24262: Stress test code for ALF-5025: Support background processing of archiving 24287: Added missing import 24336: Merged V3.4 to V3.3 23205: Fix for ALF-2111 - Download URLS are different on different pages, authentication fails when URL sent 24353: Merged V3.4 to V3.3 24352: Fix SQL fallout from ALF-6078 24510: Merged V3.4 to V3.3 21960: First round of date refactoring: Document Library pages now expect XML dates (ISO8601) from Share data webscripts 21961: Share client-side I18N utility now emulates sever-side handling of doubled-up single quotes. 24526: Merged V3.4 to V3.3 24402: Fix for performance degredation related to ALF-3823. RSS feed processing in JavaScript relies on Rhino impl of regex - this is extreemly slow as Rhino regex is by far the slowest component of the library. Switched code to use the Java Regex libraries to improve performance and reduce memory usage. 24587: Merged V3.4 to V3.3 24564: Fix for ALF-3727: Custom permissions aren't visible in Explorer UI 24604: Merged V3.4 to V3.3 24602: Build fix for RM permission model loading - collateral damage for R 24564 24774: Merged BRANCHES/V3.4 to BRANCHES/V3.3: 23492: Fixed ALF-5550: DB2: Unable to insert values into alf_string_value 24813: Merged BRANCHES/V3.4 to BRANCHES/V3.3: 24750: Limit installer builds to 2 threads 24874: Merged V3.4 to V3.4-BUG-FIX 24667: Resolve ALF-6202 - MT: fix offline edit (Share) 24672: Fixes from Gloria for: ALF-6339 and ALF-6337 24673: Merge V3.3 to V3.4 24668 : Upgrade of large repository to latest 3.3 fails on excession of mysql table lock size 24674: Fixes ALF-6294: Remove illegal CLI option 24675: Fix ALF-6099: CLONE - IE6: Sometimes errors occur on almost actions in Office Add-ins. Removed linebreaks from JSON response template & prevented "undefined" entries in URL. 24680: ALF-6120 : Version notes are lost for versioned items migrated from 2.2 to 3.4.0 24681: Merged BRANCHES/DEV/BELARUS/V3.4-2010_12_14 to BRANCHES/V3.4: 24609: MT - ALF-3563 24640: MT - ALF-3563 (merged w/ minor improvement) 24685: Fixes ALF-6403: Change installer window height on Linux 24688: Fix ALF-6029 (part II) - MT: cannot "Show Folders" for "Data Dictionary" in Afresco Share - part II adds patch and removes workaround 24689: Fixes: ALF-6219 - Incorrectly formatted variable in translation 24691: MT: ALF-3263 - Explorer login now fails with consistent error message ("Unable to login - unknown username/password.") if tenant does not exist or is disabled 24692: Fixes: ALF-6370 and ALF-6225 among others - sweep of FR and DE resource bundles for quote escaping. 24694: Fixes ALF-6424. Erased erroneous equals sign 24695: Fixes: ALF-6320 - removed the country specific portion of the language pack suffixes for French, German and Spanish. This enables speakers of those languages outside of those countries to benefit from the language packs. 24696: Fix for ALF-6299: XSS attack on editing blog post with XSS data in IE6&IE7 24700: Swaps _it_IT for _it to make Italian language pack available to Italian speakers outside of Italy. 24703: Avoid DB2 query failure if someone passes in a made-up UUID - Test RunningActionRestApiTest was making up a long node UUID - DB2 fails to set the parameter with SQLSTATE=22001 24706: Merged V3.4-BUG-FIX to V3.4 24705: Fix for ALF-6365, ALF-6335 24708: Fix ALF-6386: View Details and Edit Metadata icons are incorrect for folder 24709: Missing first/last name handling. 24711: Merged V3.3 to V3.4 24710: ALF-5535 - Fix to correctly format json number values (not as numeric human readable strings) 24713: Fix ALF-5404: It is now possible to configure who receives notifications of "Contact Us" requests by setting a configuration property on the WQS website node, such as "feedbackAssignee.Contact Request=brian" Also added missing Spring MVC source to 3rd Party. 24715: Fix for ALF-6412. OOoDirect always tries to connect to port 8100. Formerly the ooo.port property did not exist for the OOoDirect connector. It was added in r.23182 for the soffice process, but not for the connector bean. Now added for the connector too. 24721: Fix for ALF-6351 - Simple search breaks if override config is used and does not contain new 'repository-search' element 24728: Fixes: ALF-5685 - Incorrect encoding of Japanese Characters 24732: Fixes ALF-6381 and others - calendar strings appearing incorrectly. Problem was an unicode encoded comma preventing the property string being broken up into different days of the weeks or months. 24739: Fix ALF-6545: DB2: SQLCODE=-302, SQLSTATE=22001 (testCreateMultiLingualCategoryRoots) - Shortened Japanese name to 14 characters 24740: Fixes: ALF-6413 (with some translations still pending). 24742: Update readmes. 24744: Merged HEAD to BRANCHES/V3.4: 24137: Fixes: ALF-5642, ALF-3892, ALF-5043 & Brings Add Event dialog in line with other forms in share by disabling the popup validation error box. 24746: Build/test fix: PostgreSQL -AssetServiceImplTest.renameFolder 24755: Merged V3.3 to V3.4 (RECORD ONLY) 21789: ALF-4333: Fix - Updated RepoPrimaryManifestProcessorImpl so it can handle deletions that are reported by either pre-delete noderef or archived noderef (previously only handled the latter). - Updated TransferManifestNodeFactory so that it handles the case where the status of the node to transfer is "deleted". - Updated UnitTestTransferManifestNodeFactory so that it handles the change to TransferManifestNodeFactory above. - Added new tests for deletion cases. 23259: Merged HEAD to V3.3 23256: Fix ALF-4573: Start Workflow action is absent for edited document and working copy in Share 23346: Brought WebQS module in (including build process but not installer elements yet) 23371: "Simply" added wcmqs to installer 23391: ALF-5367: Copy dlls into tomcat/bin as appropriate. 23485: Merged V3.4 to V3.3 (fix backported for V3.3.x lines) 23472: Fixed ALF-5408: SQL Server missing ON DELETE CASCADE declarations 23515: Merged PATCHES/V3.2.0 to V3.3 23514: ALF-5554: Merged HEAD to V3.2.0 23153: When updating tag scopes following system shutdown/restore, be smarter about quickly skipping tag scopes that another (new) thread is currently working on 23283: More debugging level logging for tagging updates, to help identify the problem with periodic multi-threaded test failures on bamboo 23535: Merged V3.4 to V3.3 (complements 23517: ALF-5552) 23508: Fixed ALF-5559: Permission interceptors can fail if Lucene returns invalid NodeRefs 23564: ALF-5600: Merged V3.4 to V3.3 23424: Fixes: ALF-2989 - Incorrect sideId reference in URL for event in Site Calendar Dashlet Adds support for displaying events that start in the past but finish in the future (previously only events that start in the future were shown) 23586: MERGED V3.4 to V3.3 22864: Fix for ALF-5005: "Create and edit functions on AWE become "confused"" 23042: Fix ALF-5127: Impossible to create an article/blog (WCMQS) [Must clear panel hideEvent handler if manually hiding a YUI panel] 23561: Fixes: ALF-4569 - Removes universal override of input width box and switches the editor form panel to adjust it's width based on content rather than window size. Fixes: ALF-4570 - Adds an override for the CSS 'top' property of the form dialogue to ensure it's always below the ribbon. (Was being set automatically by the YUI widget.panel call) 23569: Fixes: ALF-5606 - Ribbon wasn't resizing correctly after the form events. 23630: Backport of installer 23631: Added 64-bit & deployment installers 23664: Fixes ALF-5691: TransferService: Multi-byte characters are not encoded correctly 23681: Fixes ALF-5699: TransferService: Snapshot file from source repo never contains complete MLText properties 23695: Fixed bug exposed after fixing ALF-5699. Parsing of MLText properties out of the transfer snapshot file was incorrect, and that was causing multi-lingual property values to be duplicated 23709: ALF-5699: Fix NPE in ManifestIntegrationTest 23734: Merged V3.4 to V3.3 23731: Fixes for ALF-3098 and ALF-3097 - Share - Security check on Personal Dashboard - only the owning user can view a user dashboard page - Share - Security issue on Customize Site Dashboard - private and moderated site dashboard pages no longer visible to non-members, customise site and dashboard pages only accessible to SiteManager 23747: ALF-5696: Merged V3.4 to V3.3 23585: Fixed ALF-5372 "JavaScript error on Groups management dialog with IE8 : document.getElementById is null" 23790: Fixed ALF-3823 "Share: RSS feed can't be read: http://cds-srv.sun.com:8700/rss/update/public/sunalert_update.xml - ok with other RSS client." 23883: Fixes ALF-5759: WQS: Attempt to copy a website section fails 23907: Merged DEV/BELARUS/V3.3-BUG-FIX-2010_09_20 to V33 - 22750: ALF-4846: Update rules are firing on inbound actions 23931: Undid rev 23907 (Reverse-merged /alfresco/BRANCHES/DEV/BELARUS/V3.3-BUG-FIX-2010_09_20:r22750) 23961: Fixed ALF-5686 "Incorrect behaviour of "All" filter in "My Tasks" dashlet" - Variables assigned in a <#macro> shall always be assigned using <#local> (using <#assign> makes them globally available which might cause naming collisions) 24132: Disable intermittent failing unit test 24148: ALF-6007: Merged HEAD to V3.3 23049: Fixed ALF-5099: Error when trying to go back in Create Web Content Wizard (only with certain XSDs) 24263: Merged from V3.3-BUG-FIX to V3.3 24264: Merged V3.3-BUG-FIX to V3.3 24262: Stress test code for ALF-5025: Support background processing of archiving 24287: Added missing import 24336: Merged V3.4 to V3.3 23205: Fix for ALF-2111 - Download URLS are different on different pages, authentication fails when URL sent 24353: Merged V3.4 to V3.3 24352: Fix SQL fallout from ALF-6078 24510: Merged V3.4 to V3.3 21960: First round of date refactoring: Document Library pages now expect XML dates (ISO8601) from Share data webscripts 21961: Share client-side I18N utility now emulates sever-side handling of doubled-up single quotes. 24526: Merged V3.4 to V3.3 24402: Fix for performance degredation related to ALF-3823. RSS feed processing in JavaScript relies on Rhino impl of regex - this is extreemly slow as Rhino regex is by far the slowest component of the library. Switched code to use the Java Regex libraries to improve performance and reduce memory usage. 24587: Merged V3.4 to V3.3 24564: Fix for ALF-3727: Custom permissions aren't visible in Explorer UI 24604: Merged V3.4 to V3.3 24602: Build fix for RM permission model loading - collateral damage for R 24564 24775: Merged BRANCHES/V3.3 to BRANCHES/V3.4: (RECORD-ONLY) - already in V3.4 24774: (RECORD-ONLY) Merged BRANCHES/V3.4 to BRANCHES/V3.3: 23492: Fixed ALF-5550: DB2: Unable to insert values into alf_string_value 24788: Add evaluation use message for OSX installer 24790: Removed svn:mergeinfo on root 24791: Fixed ALF-6560: MIME type not detected (set to application/octet-stream) when content written via FileFolderService - First access of content on a new file (FileFolderService.getWriter) guesses a mimetype - The initial mimetype guess *was* done during create, but that was expensive. - Added unit test to cover regression 24803: Merged BRANCHES/DEV/dwebster/ to BRANCHES/V3.4: 24773: DE bug fixes received from translators 10th Jan. 24776: ES files received from translators 10th Jan 24793: FR files received from translators 10th Jan 24792: IT files received from translators 10th Jan 24804: Temporarily removing Japanese language bundle 24856: Merged BRANCHES/DEV/dwebster/ to BRANCHES/V3.4: 24848: Latest Language updates from Translators 24863: ALF-6029 (MT Share - repo' view after upg) 24880: Merged V3.3 to V3.4-BUG-FIX 24463: Fixed ALF-4398 "Path to rule set is not displayed" ($html alias was missing from a merge) 24465: Merge V3.3 to V3.4 (RECORD ONLY) 24463: Fixed ALF-4398 "Path to rule set is not displayed" ($html alias was missing from a merge) 24493: Fix for Mac OS X CIFS logon problem, change UID to start at one as zero has special meaning, plus other minor fixes. JLAN-112. 24569: Fix for ALF-5333: Webdav - Online editing of files in a folder with German umlauts does not report correct characters 24611: Fix broken build due to merge #fail (r24460 / ALF-4015) 24668: ALF-4557 - Upgrade of large repository to latest 3.3 fails on excession of mysql table lock size 24707: Fix for handling of null first/last name in wiki page list 24710: ALF-5535 - Fix to correctly format json number values (not as numeric human readable strings) 24794: Fix for ALF-4984 - Outdated custom-slingshot-application-context.xml.sample file for share 24798: Fix for ALF-5806: Lucene query does not return expected result. - Alfresco FTS now supports the prefixes ~ and = for phrase queries 24814: Build fix after r24798: Fix for ALF-5806: Lucene query does not return expected result. 24823: Synchronization improvements to RemoteClient and http proxy hosts 24825: Fixed #3 of ALF-6308 "Share data issues" - Share falls back to use "html uploader" (in all browsers except IE) when "JSESSIONID" cookie is unreachable from javascript (like when "HttpOnly cookies" is activated on the server. 24835: Fixed ALF-5484: Check-in does not update association - Copy code when copying over an existing target node was NOT processing associations - Fallout from refactor and subsequent fixes related to ALF-958 (Target associations aren't copied) - Some commented-out unit tests reintroduced 24842: Fix for ALF-6308 item #4 - validate the redirect URL to ensure it is a relative url 24845: Merged DEV/DAVEW/SAP to V3.3 23874: ALF-5822: Correct Lucene throttling mechanism to prevent build up of excessive committed deltas - Also correct BatchProcessor's mechanism for single-threading batches with cross dependencies - Single-threaded batches must be sequenced in order 23876: ALF-5822: Default lucene.indexer.mergerTargetOverlaysBlockingFactor to 2 for better write performance under load 24022: ALF-5822: Refinement of fix - Don't block a thread that has already entered the prepare phase with another indexer (e.g. a cross-store commit). Otherwise it could block indefinitely and never enter the commit phase - Also added extra debug diagnostics and handle all Throwables on failure 24023: ALF-5822: Minor correction to debug log message 24421: ALF-6134: Do not export org.hibernate.jmx.StatisticsService through JMX to avoid excessive blocking under load 24422: ALF-6135: Remove lock contention from concurrent Lucene searches - Added a RW Lock and Thread local-based solution to org.apache.lucene.store.FSDirectory.FSIndexInput.readInternal() to avoid contention during multiple parallel Lucene searches. This is already recognized as a bottleneck by the Lucene developers, who offer NIOFSDirectory as an alternative, which unfortunately doesn't work on Windows. - Added RW lock to org.apache.lucene.index.TermInfosReader.ensureIndexIsRead() - Threads no longer hanging in lucene searches during load tests. Woohoo! 24423: ALF-6136: Don't call through to org.apache.log4j.NDC unless debug is enabled as it's heavily synchronized. Also avoid dynamic method invocation by using a delegate. 24426: ALF-6138 (SURF - PARTIAL): 'Warm' the java.beans.Introspector cache for key Freemarker accessible bean classes on loading in static initializers 24428: ALF-6139 (SURF - PARTIAL): First log in to Share is expensive due to 'lazy' dashboard creation and excessive synchronization - Added AVMRemoteStore.createDocuments() for creating multiple XML documents at once, all embedded within the same master XML document in the request body - Added corresponding saveDocuments() methods to Store, RemoteStore, Model, ModelObjectManager and ModelObjectPersister on the Surf side - Used this in PresetsManager - Removed excessive synchronization from StoreModelObjectPersister 24429: ALF-6140 (SURF - PARTIAL): Surf tweaks to allow concurrent execution of web scripts - Use StrongCacheStorage instead of MruCacheStorage in RepositoryTemplateProcessor to avoid use of a synchronized cache - Tweak cache sizes in FreeMarkerProcessor - Use thread local object wrapper delegates in QNameAwareObjectWrapper and PresentationTemplateProcessor to work around synchronization in DefaultObjectWrapper - Swap in the same object wrapper to WrappingTemplateModel - Use a concurrent HashMap in ModelObjectCache and ModelHelper and remove excessive synchronization - Use RW locks rather than synchronized blocks in AbstractWebScript 24431: ALF-6141: Improvements to IBatis DAO performance under load - Use lazyLoadingEnabled="false", enhancementEnabled="false" to avoid unnecessary blocking and generation of CGI proxies in IBATIS DAOs - Use useTransactionAwareDataSource="false" to prevent Spring from agressively unwrapping DBCP connections and bypassing the prepared statement cache 24432: ALF-6142: Remove dependency between RepositoryAuthenticationDAO and Lucene - Reworked RepositoryAuthenticationDAO to use a node service lookup by child association QName - This required adding a patch to 'upgrade' the qnames of existing authentication nodes, which previously all had the same QName 24433: ALF-6143: Remove net.sf.ehcache.use.classic.lru setting from EhCacheManagerFactoryBean and InternalEhCacheManagerFactoryBean to prevent serialization of accesses to shared caches by multiple executing threads 24434: ALF-6144: DirtySessionMethodInterceptor was causing contention between multiple threads calling the same DAO. - Unfortunately method.getAnnotation() is a synchronized call, and thus causes concurrent calls to the same method to contended with each other. - Added a non-blocking cache so that DAOs can be accessed in multiple threads without contending. 24435: ALF-6145: Use RW Locks in Subsystem Framework - The operations relied on by the dynamic proxies wrapping subsystems were synchronized and thus caused contention when multiple threads were calling in to the same subsystem - Replaced synchronized blocks with use of read write locks, thus allowing multiple concurrent readers 24436: ALF-6146: Regulate PermissionModel accesses with RW locks, rather than synchronized blocks and an excessive number of concurrent hashmaps. 24438: ALF-6136: Fix build classpath 24439: ALF-6142: Fixed seeding of admin user password 24444: ALF-6142: Fix unit test fallout - InviteServiceTest needs a transaction - RepositoryAuthenticationDao must listen for Person username changes and update authentication node qname accordingly - Correction to MT handling in RepositoryAuthenticationDao - Repository Authentication Component must 'normalize' the username before passing it through the DAO 24445: ALF-6145: Correction to lock handling when propagating destroy() events 24446: ALF-6142: Add new dependencies to unit test 24448: ALF-6142: Further fix ups 24461: ALF-6142: Fix unit test 24664: ALF-6408: Prevent possible deadlock during reindexing - waitForHeadOfQueue() now only called in beforeCommit() phase rather than afterCommit() to prevent deadlocking with Lucene throttler - indexes are also flushed beforehand in beforeCommit() so that indexing work can still be parallelized - also prevent potential deadlock caused by clearing of IndexInfo.thisThreadPreparing in a nested transaction 24810: ALF-6653: Use read write lock in Hibernate ReadWriteCache to avoid needless contention on L2 cache reads 24817: ALF-4725: Avoid excessive lock contention in dbcp by upgrading to 1.4 - also upgraded commons pool 24818: ALF-6658: Remove synchronization from LockService - transaction local collections used anyway 24844: ALF-6681: Don't let the PostLookup job stack up in multiple threads - Now only executes in one thread at a time and skips scheduled slots where it is already running 24864: Fix for ALF-5904: Explorer - Space model rights not duplicated when creating a space based on a template - copy service no longer uses hasPermission - added tests for permission copy scenarios with assorted rights - this fix assumed there is nothing special about templates - ie that they should always carry permissions and is the "default" copy behaviour to copy permissions if possible 24865: ALF-6145: Fix failing unit test 24878: ALF-6146: Correction to write lock around requiredPermissionsCache 24881: Increment version revision git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@26792 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
1112 lines
40 KiB
SQL
1112 lines
40 KiB
SQL
--
|
|
-- Title: Apply schema modifications to upgrade from 2.1
|
|
-- Database: MySQL
|
|
-- Since: V2.2 Schema 91
|
|
-- Author: Derek Hulley
|
|
--
|
|
-- In order to streamline the upgrade, all modifications to large tables need to
|
|
-- be handled in as few steps as possible. This usually involves as few ALTER TABLE
|
|
-- statements as possible. The general approach is:
|
|
-- Create a table with the correct structure, including indexes and CONSTRAINTs
|
|
-- Copy pristine data into the new table
|
|
-- Drop the old table
|
|
-- Rename the new table
|
|
--
|
|
-- Please contact support@alfresco.com if you need assistance with the upgrade.
|
|
--
|
|
|
|
-- -------------------------------
|
|
-- Build Namespaces and QNames --
|
|
-- -------------------------------
|
|
|
|
CREATE TABLE alf_namespace
|
|
(
|
|
id BIGINT NOT NULL AUTO_INCREMENT,
|
|
version BIGINT NOT NULL,
|
|
uri VARCHAR(100) NOT NULL,
|
|
PRIMARY KEY (id),
|
|
UNIQUE (uri)
|
|
) ENGINE=InnoDB;
|
|
|
|
CREATE TABLE alf_qname
|
|
(
|
|
id BIGINT NOT NULL AUTO_INCREMENT,
|
|
version BIGINT NOT NULL,
|
|
ns_id BIGINT NOT NULL,
|
|
local_name VARCHAR(200) NOT NULL,
|
|
INDEX fk_alf_qname_ns (ns_id),
|
|
CONSTRAINT fk_alf_qname_ns FOREIGN KEY (ns_id) REFERENCES alf_namespace (id),
|
|
PRIMARY KEY (id),
|
|
UNIQUE (ns_id, local_name)
|
|
) ENGINE=InnoDB;
|
|
|
|
-- Create temporary table to hold static QNames
|
|
CREATE TABLE t_qnames
|
|
(
|
|
qname VARCHAR(255) NOT NULL,
|
|
namespace VARCHAR(100),
|
|
localname VARCHAR(200),
|
|
qname_id BIGINT,
|
|
INDEX tidx_tqn_qn (qname),
|
|
INDEX tidx_tqn_ns (namespace),
|
|
INDEX tidx_tqn_ln (localname)
|
|
) ENGINE=InnoDB;
|
|
|
|
-- Populate the table with all known static QNames
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.type_qname FROM alf_node s LEFT OUTER JOIN t_qnames t ON (s.type_qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.qname FROM alf_node_aspects s LEFT OUTER JOIN t_qnames t ON (s.qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.qname FROM alf_node_properties s LEFT OUTER JOIN t_qnames t ON (s.qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.qname FROM avm_aspects s LEFT OUTER JOIN t_qnames t ON (s.qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.name FROM avm_aspects_new s LEFT OUTER JOIN t_qnames t ON (s.name = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.qname FROM avm_node_properties s LEFT OUTER JOIN t_qnames t ON (s.qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.qname FROM avm_node_properties_new s LEFT OUTER JOIN t_qnames t ON (s.qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.qname FROM avm_store_properties s LEFT OUTER JOIN t_qnames t ON (s.qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.type_qname FROM alf_node_assoc s LEFT OUTER JOIN t_qnames t ON (s.type_qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.type_qname FROM alf_child_assoc s LEFT OUTER JOIN t_qnames t ON (s.type_qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
INSERT INTO t_qnames (qname)
|
|
(
|
|
SELECT DISTINCT s.type_qname FROM alf_permission s LEFT OUTER JOIN t_qnames t ON (s.type_qname = t.qname) WHERE t.qname IS NULL
|
|
);
|
|
|
|
-- Extract the namespace and localnames from the QNames
|
|
UPDATE t_qnames SET namespace = CONCAT('FILLER-', SUBSTR(SUBSTRING_INDEX(qname, '}', 1), 2));
|
|
UPDATE t_qnames SET localname = SUBSTRING(qname, INSTR(qname, '}')+1);
|
|
|
|
-- Move the Namespaces to their new home
|
|
INSERT INTO alf_namespace (uri, version)
|
|
(
|
|
SELECT
|
|
distinct(x.namespace), 1
|
|
FROM
|
|
(
|
|
SELECT t.namespace, n.uri FROM t_qnames t LEFT OUTER JOIN alf_namespace n ON (n.uri = t.namespace)
|
|
) x
|
|
WHERE
|
|
x.uri IS NULL
|
|
);
|
|
|
|
-- Move the Localnames to their new home
|
|
INSERT INTO alf_qname (ns_id, local_name, version)
|
|
(
|
|
SELECT
|
|
x.ns_id, x.t_localname, 1
|
|
FROM
|
|
(
|
|
SELECT n.id AS ns_id, t.localname AS t_localname, q.local_name AS q_localname
|
|
FROM t_qnames t
|
|
JOIN alf_namespace n ON (n.uri = t.namespace)
|
|
LEFT OUTER JOIN alf_qname q ON (q.local_name = t.localname)
|
|
) x
|
|
WHERE
|
|
q_localname IS NULL
|
|
GROUP BY x.ns_id, x.t_localname
|
|
);
|
|
|
|
-- Record the new qname IDs
|
|
UPDATE t_qnames t SET t.qname_id =
|
|
(
|
|
SELECT q.id FROM alf_qname q
|
|
JOIN alf_namespace ns ON (q.ns_id = ns.id)
|
|
WHERE ns.uri = t.namespace AND q.local_name = t.localname
|
|
);
|
|
|
|
-- ----------------------------
|
|
-- SHORTCUT:
|
|
-- Up to this point, we have been extracting static data. The data can be dumped and loaded
|
|
-- to do faster testing of the ugprades:
|
|
-- mysqldump derek1 alf_qname alf_namespace t_qnames > extracted-qnames.sql
|
|
-- Load the dump file and continue from this point
|
|
-- ----------------------------
|
|
|
|
-- Create temporary table for dynamic (child) QNames
|
|
CREATE TABLE t_qnames_dyn
|
|
(
|
|
qname VARCHAR(255) NOT NULL,
|
|
namespace VARCHAR(100),
|
|
namespace_id BIGINT,
|
|
local_name VARCHAR(255),
|
|
INDEX tidx_qnd_qn (qname),
|
|
INDEX tidx_qnd_ns (namespace)
|
|
) ENGINE=InnoDB;
|
|
|
|
-- Populate the table with the child association paths
|
|
-- Query OK, 415312 rows affected (1 min 11.91 sec)
|
|
INSERT INTO t_qnames_dyn (qname)
|
|
(
|
|
SELECT distinct(qname) FROM alf_child_assoc
|
|
);
|
|
|
|
-- Extract the Namespace
|
|
-- Query OK, 415312 rows affected (20.03 sec)
|
|
UPDATE t_qnames_dyn SET namespace = CONCAT('FILLER-', SUBSTR(SUBSTRING_INDEX(qname, '}', 1), 2));
|
|
|
|
-- Extract the Localname
|
|
-- Query OK, 415312 rows affected (16.22 sec)
|
|
UPDATE t_qnames_dyn SET local_name = SUBSTRING(qname, INSTR(qname, '}')+1);
|
|
|
|
-- Move the namespaces to the their new home
|
|
-- Query OK, 4 rows affected (34.59 sec)
|
|
INSERT INTO alf_namespace (uri, version)
|
|
(
|
|
SELECT
|
|
distinct(x.namespace), 1
|
|
FROM
|
|
(
|
|
SELECT t.namespace, n.uri FROM t_qnames_dyn t LEFT OUTER JOIN alf_namespace n ON (n.uri = t.namespace)
|
|
) x
|
|
WHERE
|
|
x.uri IS NULL
|
|
);
|
|
|
|
-- Record the new namespace IDs
|
|
-- Query OK, 415312 rows affected (10.41 sec)
|
|
UPDATE t_qnames_dyn t SET t.namespace_id = (SELECT ns.id FROM alf_namespace ns WHERE ns.uri = t.namespace);
|
|
|
|
-- Recoup some storage
|
|
ALTER TABLE t_qnames_dyn DROP COLUMN namespace;
|
|
OPTIMIZE TABLE t_qnames_dyn;
|
|
|
|
-- ----------------------------
|
|
-- Populate the Permissions --
|
|
-- ----------------------------
|
|
|
|
-- This is a small table so we change it in place
|
|
ALTER TABLE alf_permission
|
|
DROP INDEX type_qname,
|
|
ADD COLUMN type_qname_id BIGINT NULL AFTER id
|
|
;
|
|
UPDATE alf_permission p SET p.type_qname_id =
|
|
(
|
|
SELECT q.id
|
|
FROM alf_qname q
|
|
JOIN alf_namespace ns ON (q.ns_id = ns.id)
|
|
WHERE CONCAT('{', SUBSTR(ns.uri, 8), '}', q.local_name) = p.type_qname
|
|
);
|
|
ALTER TABLE alf_permission
|
|
DROP COLUMN type_qname,
|
|
MODIFY COLUMN type_qname_id BIGINT NOT NULL AFTER id,
|
|
ADD UNIQUE (type_qname_id, name),
|
|
ADD INDEX fk_alf_perm_tqn (type_qname_id),
|
|
ADD CONSTRAINT fk_alf_perm_tqn FOREIGN KEY (type_qname_id) REFERENCES alf_qname (id)
|
|
;
|
|
|
|
-- -------------------
|
|
-- Build new Store --
|
|
-- -------------------
|
|
|
|
CREATE TABLE t_alf_store
|
|
(
|
|
id BIGINT NOT NULL AUTO_INCREMENT,
|
|
version BIGINT NOT NULL,
|
|
protocol VARCHAR(50) NOT NULL,
|
|
identifier VARCHAR(100) NOT NULL,
|
|
root_node_id BIGINT,
|
|
PRIMARY KEY (id),
|
|
UNIQUE (protocol, identifier)
|
|
) ENGINE=InnoDB;
|
|
|
|
-- --------------------------
|
|
-- Populate the ADM nodes --
|
|
-- --------------------------
|
|
|
|
CREATE TABLE t_alf_node (
|
|
id BIGINT NOT NULL AUTO_INCREMENT,
|
|
version BIGINT NOT NULL,
|
|
store_id BIGINT NOT NULL,
|
|
uuid VARCHAR(36) NOT NULL,
|
|
transaction_id BIGINT NOT NULL,
|
|
node_deleted bit NOT NULL,
|
|
type_qname_id BIGINT NOT NULL,
|
|
acl_id BIGINT,
|
|
audit_creator VARCHAR(255),
|
|
audit_created VARCHAR(30),
|
|
audit_modifier VARCHAR(255),
|
|
audit_modified VARCHAR(30),
|
|
audit_accessed VARCHAR(30),
|
|
INDEX idx_alf_node_del (node_deleted),
|
|
INDEX fk_alf_node_acl (acl_id),
|
|
INDEX fk_alf_node_tqn (type_qname_id),
|
|
INDEX fk_alf_node_txn (transaction_id),
|
|
INDEX fk_alf_node_store (store_id),
|
|
CONSTRAINT fk_alf_node_acl FOREIGN KEY (acl_id) REFERENCES alf_access_control_list (id),
|
|
CONSTRAINT fk_alf_node_tqn FOREIGN KEY (type_qname_id) REFERENCES alf_qname (id),
|
|
CONSTRAINT fk_alf_node_txn FOREIGN KEY (transaction_id) REFERENCES alf_transaction (id),
|
|
CONSTRAINT fk_alf_node_store FOREIGN KEY (store_id) REFERENCES t_alf_store (id),
|
|
PRIMARY KEY (id),
|
|
UNIQUE (store_id, uuid)
|
|
) ENGINE=InnoDB;
|
|
|
|
-- Fill the store table
|
|
INSERT INTO t_alf_store (version, protocol, identifier, root_node_id)
|
|
SELECT 1, protocol, identifier, root_node_id FROM alf_store
|
|
;
|
|
|
|
-- Summarize the alf_node_status table
|
|
CREATE TABLE t_summary_nstat
|
|
(
|
|
node_id BIGINT(20) NOT NULL,
|
|
transaction_id BIGINT(20) DEFAULT NULL,
|
|
PRIMARY KEY (node_id)
|
|
) ENGINE=InnoDB;
|
|
--FOREACH alf_node_status.node_id system.upgrade.t_summary_nstat.batchsize
|
|
INSERT INTO t_summary_nstat (node_id, transaction_id)
|
|
SELECT node_id, transaction_id
|
|
FROM alf_node_status
|
|
WHERE node_id IS NOT NULL
|
|
AND node_id >= ${LOWERBOUND} AND node_id <= ${UPPERBOUND};
|
|
|
|
-- Copy data over
|
|
--FOREACH alf_node.id system.upgrade.t_alf_node.batchsize
|
|
INSERT INTO t_alf_node
|
|
(
|
|
id, version, store_id, uuid, transaction_id, node_deleted, type_qname_id, acl_id,
|
|
audit_creator, audit_created, audit_modifier, audit_modified, audit_accessed
|
|
)
|
|
SELECT STRAIGHT_JOIN
|
|
n.id, 1, s.id, n.uuid, nstat.transaction_id, false, q.qname_id, n.acl_id,
|
|
null, null, null, null, null
|
|
FROM
|
|
alf_node n
|
|
JOIN t_qnames q ON (q.qname = n.type_qname)
|
|
JOIN t_summary_nstat nstat ON (nstat.node_id = n.id)
|
|
JOIN t_alf_store s ON (s.protocol = n.protocol AND s.identifier = n.identifier)
|
|
WHERE
|
|
n.id >= ${LOWERBOUND} AND n.id <= ${UPPERBOUND}
|
|
;
|
|
DROP TABLE t_summary_nstat;
|
|
|
|
-- Hook the store up to the root node
|
|
ALTER TABLE t_alf_store
|
|
ADD INDEX fk_alf_store_root (root_node_id),
|
|
ADD CONSTRAINT fk_alf_store_root FOREIGN KEY (root_node_id) REFERENCES t_alf_node (id)
|
|
;
|
|
|
|
-- -----------------------------
|
|
-- Populate Version Counter --
|
|
-- -----------------------------
|
|
|
|
CREATE TABLE t_alf_version_count
|
|
(
|
|
id BIGINT NOT NULL AUTO_INCREMENT,
|
|
version BIGINT NOT NULL,
|
|
store_id BIGINT NOT NULL UNIQUE,
|
|
version_count INTEGER NOT NULL,
|
|
INDEX fk_alf_vc_store (store_id),
|
|
CONSTRAINT fk_alf_vc_store FOREIGN KEY (store_id) REFERENCES t_alf_store (id),
|
|
PRIMARY KEY (id)
|
|
) ENGINE=InnoDB;
|
|
|
|
INSERT INTO t_alf_version_count
|
|
(
|
|
version, store_id, version_count
|
|
)
|
|
SELECT
|
|
1, s.id, vc.version_count
|
|
FROM
|
|
alf_version_count vc
|
|
JOIN t_alf_store s ON (s.protocol = vc.protocol AND s.identifier = vc.identifier)
|
|
;
|
|
|
|
DROP TABLE alf_version_count;
|
|
ALTER TABLE t_alf_version_count RENAME TO alf_version_count;
|
|
|
|
-- -----------------------------
|
|
-- Populate the Child Assocs --
|
|
-- -----------------------------
|
|
|
|
CREATE TABLE t_alf_child_assoc
|
|
(
|
|
id BIGINT NOT NULL AUTO_INCREMENT,
|
|
version BIGINT NOT NULL,
|
|
parent_node_id BIGINT NOT NULL,
|
|
type_qname_id BIGINT NOT NULL,
|
|
child_node_name_crc BIGINT NOT NULL,
|
|
child_node_name VARCHAR(50) NOT NULL,
|
|
child_node_id BIGINT NOT NULL,
|
|
qname_ns_id BIGINT NOT NULL,
|
|
qname_localname VARCHAR(255) NOT NULL,
|
|
is_primary BIT,
|
|
assoc_index INTEGER,
|
|
INDEX idx_alf_cass_qnln (qname_localname),
|
|
INDEX fk_alf_cass_pnode (parent_node_id),
|
|
INDEX fk_alf_cass_cnode (child_node_id),
|
|
INDEX fk_alf_cass_tqn (type_qname_id),
|
|
INDEX fk_alf_cass_qnns (qname_ns_id),
|
|
INDEX idx_alf_cass_pri (parent_node_id, is_primary, child_node_id),
|
|
CONSTRAINT fk_alf_cass_pnode foreign key (parent_node_id) REFERENCES t_alf_node (id),
|
|
CONSTRAINT fk_alf_cass_cnode foreign key (child_node_id) REFERENCES t_alf_node (id),
|
|
CONSTRAINT fk_alf_cass_tqn foreign key (type_qname_id) REFERENCES alf_qname (id),
|
|
CONSTRAINT fk_alf_cass_qnns foreign key (qname_ns_id) REFERENCES alf_namespace (id),
|
|
PRIMARY KEY (id),
|
|
UNIQUE (parent_node_id, type_qname_id, child_node_name_crc, child_node_name)
|
|
) ENGINE=InnoDB;
|
|
|
|
--FOREACH alf_child_assoc.id system.upgrade.t_alf_child_assoc.batchsize
|
|
INSERT INTO t_alf_child_assoc
|
|
(
|
|
id, version,
|
|
parent_node_id,
|
|
type_qname_id,
|
|
child_node_name_crc, child_node_name,
|
|
child_node_id,
|
|
qname_ns_id, qname_localname,
|
|
is_primary, assoc_index
|
|
)
|
|
SELECT STRAIGHT_JOIN
|
|
ca.id, 1,
|
|
ca.parent_node_id,
|
|
tqn.qname_id,
|
|
ca.child_node_name_crc, ca.child_node_name,
|
|
ca.child_node_id,
|
|
tqndyn.namespace_id, tqndyn.local_name,
|
|
ca.is_primary, ca.assoc_index
|
|
FROM
|
|
alf_child_assoc ca
|
|
JOIN t_qnames_dyn tqndyn ON (ca.qname = tqndyn.qname)
|
|
JOIN t_qnames tqn ON (ca.type_qname = tqn.qname)
|
|
WHERE
|
|
ca.id >= ${LOWERBOUND} AND ca.id <= ${UPPERBOUND}
|
|
;
|
|
|
|
-- Clean up
|
|
DROP TABLE t_qnames_dyn;
|
|
DROP TABLE alf_child_assoc;
|
|
ALTER TABLE t_alf_child_assoc RENAME TO alf_child_assoc;
|
|
|
|
-- ----------------------------
|
|
-- Populate the Node Assocs --
|
|
-- ----------------------------
|
|
|
|
CREATE TABLE t_alf_node_assoc
|
|
(
|
|
id BIGINT NOT NULL AUTO_INCREMENT,
|
|
version BIGINT NOT NULL,
|
|
source_node_id BIGINT NOT NULL,
|
|
target_node_id BIGINT NOT NULL,
|
|
type_qname_id BIGINT NOT NULL,
|
|
INDEX fk_alf_nass_snode (source_node_id),
|
|
INDEX fk_alf_nass_tnode (target_node_id),
|
|
INDEX fk_alf_nass_tqn (type_qname_id),
|
|
CONSTRAINT fk_alf_nass_snode FOREIGN KEY (source_node_id) REFERENCES t_alf_node (id),
|
|
CONSTRAINT fk_alf_nass_tnode FOREIGN KEY (target_node_id) REFERENCES t_alf_node (id),
|
|
CONSTRAINT fk_alf_nass_tqn FOREIGN KEY (type_qname_id) REFERENCES alf_qname (id),
|
|
PRIMARY KEY (id),
|
|
UNIQUE (source_node_id, target_node_id, type_qname_id)
|
|
) ENGINE=InnoDB;
|
|
|
|
--FOREACH alf_node_assoc.id system.upgrade.t_alf_node_assoc.batchsize
|
|
INSERT INTO t_alf_node_assoc
|
|
(
|
|
id, version,
|
|
source_node_id, target_node_id,
|
|
type_qname_id
|
|
)
|
|
SELECT STRAIGHT_JOIN
|
|
na.id, 1,
|
|
na.source_node_id, na.target_node_id,
|
|
tqn.qname_id
|
|
FROM
|
|
alf_node_assoc na
|
|
JOIN t_qnames tqn ON (na.type_qname = tqn.qname)
|
|
WHERE
|
|
na.id >= ${LOWERBOUND} AND na.id <= ${UPPERBOUND}
|
|
;
|
|
|
|
-- Clean up
|
|
DROP TABLE alf_node_assoc;
|
|
ALTER TABLE t_alf_node_assoc RENAME TO alf_node_assoc;
|
|
|
|
-- -----------------------------
|
|
-- Populate the Node Aspects --
|
|
-- -----------------------------
|
|
|
|
CREATE TABLE t_alf_node_aspects
|
|
(
|
|
node_id BIGINT NOT NULL,
|
|
qname_id BIGINT NOT NULL,
|
|
INDEX fk_alf_nasp_n (node_id),
|
|
INDEX fk_alf_nasp_qn (qname_id),
|
|
CONSTRAINT fk_alf_nasp_n FOREIGN KEY (node_id) REFERENCES t_alf_node (id),
|
|
CONSTRAINT fk_alf_nasp_qn FOREIGN KEY (qname_id) REFERENCES alf_qname (id),
|
|
PRIMARY KEY (node_id, qname_id)
|
|
) ENGINE=InnoDB;
|
|
|
|
--FOREACH alf_node_aspects.node_id system.upgrade.t_alf_node_aspects.batchsize
|
|
-- Note the omission of sys:referencable. This is implicit.
|
|
INSERT INTO t_alf_node_aspects
|
|
(
|
|
node_id, qname_id
|
|
)
|
|
SELECT
|
|
na.node_id,
|
|
tqn.qname_id
|
|
FROM
|
|
alf_node_aspects na
|
|
JOIN t_qnames tqn ON (na.qname = tqn.qname)
|
|
WHERE
|
|
tqn.qname != '{http://www.alfresco.org/model/system/1.0}referenceable'
|
|
AND na.node_id >= ${LOWERBOUND} AND na.node_id <= ${UPPERBOUND}
|
|
;
|
|
|
|
-- Clean up
|
|
DROP TABLE alf_node_aspects;
|
|
ALTER TABLE t_alf_node_aspects RENAME TO alf_node_aspects;
|
|
|
|
-- ---------------------------------
|
|
-- Populate the AVM Node Aspects --
|
|
-- ---------------------------------
|
|
|
|
CREATE TABLE t_avm_aspects
|
|
(
|
|
node_id BIGINT NOT NULL,
|
|
qname_id BIGINT NOT NULL,
|
|
INDEX fk_avm_nasp_n (node_id),
|
|
INDEX fk_avm_nasp_qn (qname_id),
|
|
CONSTRAINT fk_avm_nasp_n FOREIGN KEY (node_id) REFERENCES avm_nodes (id),
|
|
CONSTRAINT fk_avm_nasp_qn FOREIGN KEY (qname_id) REFERENCES alf_qname (id),
|
|
PRIMARY KEY (node_id, qname_id)
|
|
) ENGINE=InnoDB;
|
|
|
|
--FOREACH avm_aspects.node_id system.upgrade.t_avm_aspects.batchsize
|
|
INSERT INTO t_avm_aspects
|
|
(
|
|
node_id, qname_id
|
|
)
|
|
SELECT
|
|
aspects_old.node_id,
|
|
tqn.qname_id
|
|
FROM
|
|
avm_aspects aspects_old
|
|
JOIN t_qnames tqn ON (aspects_old.qname = tqn.qname)
|
|
WHERE
|
|
aspects_old.node_id >= ${LOWERBOUND} AND aspects_old.node_id <= ${UPPERBOUND}
|
|
;
|
|
--FOREACH avm_aspects_new.id system.upgrade.t_avm_aspects.batchsize
|
|
INSERT INTO t_avm_aspects
|
|
(
|
|
node_id, qname_id
|
|
)
|
|
SELECT
|
|
anew.id,
|
|
tqn.qname_id
|
|
FROM
|
|
avm_aspects_new anew
|
|
JOIN t_qnames tqn ON (anew.name = tqn.qname)
|
|
LEFT JOIN avm_aspects aold ON (anew.id = aold.node_id AND anew.name = aold.qname)
|
|
WHERE
|
|
aold.id IS NULL
|
|
AND anew.id >= ${LOWERBOUND} AND anew.id <= ${UPPERBOUND}
|
|
;
|
|
|
|
-- Clean up
|
|
DROP TABLE avm_aspects;
|
|
DROP TABLE avm_aspects_new;
|
|
ALTER TABLE t_avm_aspects RENAME TO avm_aspects;
|
|
|
|
-- ----------------------------------
|
|
-- Migrate Sundry Property Tables --
|
|
-- ----------------------------------
|
|
|
|
-- Create temporary mapping for property types
|
|
CREATE TABLE t_prop_types
|
|
(
|
|
type_name VARCHAR(15) NOT NULL,
|
|
type_id INTEGER NOT NULL,
|
|
PRIMARY KEY (type_name)
|
|
);
|
|
INSERT INTO t_prop_types values ('NULL', 0);
|
|
INSERT INTO t_prop_types values ('BOOLEAN', 1);
|
|
INSERT INTO t_prop_types values ('INTEGER', 2);
|
|
INSERT INTO t_prop_types values ('LONG', 3);
|
|
INSERT INTO t_prop_types values ('FLOAT', 4);
|
|
INSERT INTO t_prop_types values ('DOUBLE', 5);
|
|
INSERT INTO t_prop_types values ('STRING', 6);
|
|
INSERT INTO t_prop_types values ('DATE', 7);
|
|
INSERT INTO t_prop_types values ('DB_ATTRIBUTE', 8);
|
|
INSERT INTO t_prop_types values ('SERIALIZABLE', 9);
|
|
INSERT INTO t_prop_types values ('MLTEXT', 10);
|
|
INSERT INTO t_prop_types values ('CONTENT', 11);
|
|
INSERT INTO t_prop_types values ('NODEREF', 12);
|
|
INSERT INTO t_prop_types values ('CHILD_ASSOC_REF', 13);
|
|
INSERT INTO t_prop_types values ('ASSOC_REF', 14);
|
|
INSERT INTO t_prop_types values ('QNAME', 15);
|
|
INSERT INTO t_prop_types values ('PATH', 16);
|
|
INSERT INTO t_prop_types values ('LOCALE', 17);
|
|
INSERT INTO t_prop_types values ('VERSION_NUMBER', 18);
|
|
|
|
-- Modify the avm_store_properties table
|
|
CREATE TABLE t_avm_store_properties
|
|
(
|
|
id BIGINT NOT NULL AUTO_INCREMENT,
|
|
avm_store_id BIGINT,
|
|
qname_id BIGINT NOT NULL,
|
|
actual_type_n integer NOT NULL,
|
|
persisted_type_n integer NOT NULL,
|
|
multi_valued bit NOT NULL,
|
|
boolean_value bit,
|
|
long_value BIGINT,
|
|
float_value float,
|
|
double_value DOUBLE PRECISION,
|
|
string_value TEXT,
|
|
serializable_value blob,
|
|
INDEX fk_avm_sprop_store (avm_store_id),
|
|
INDEX fk_avm_sprop_qname (qname_id),
|
|
CONSTRAINT fk_avm_sprop_store FOREIGN KEY (avm_store_id) REFERENCES avm_stores (id),
|
|
CONSTRAINT fk_avm_sprop_qname FOREIGN KEY (qname_id) REFERENCES alf_qname (id),
|
|
PRIMARY KEY (id)
|
|
) ENGINE=InnoDB;
|
|
--FOREACH avm_store_properties.avm_store_id system.upgrade.t_avm_store_properties.batchsize
|
|
INSERT INTO t_avm_store_properties
|
|
(
|
|
avm_store_id,
|
|
qname_id,
|
|
actual_type_n, persisted_type_n,
|
|
multi_valued, boolean_value, long_value, float_value, double_value, string_value, serializable_value
|
|
)
|
|
SELECT
|
|
p.avm_store_id,
|
|
tqn.qname_id,
|
|
ptypes_actual.type_id, ptypes_persisted.type_id,
|
|
p.multi_valued, p.boolean_value, p.long_value, p.float_value, p.double_value, p.string_value, p.serializable_value
|
|
FROM
|
|
avm_store_properties p
|
|
JOIN t_qnames tqn ON (p.qname = tqn.qname)
|
|
JOIN t_prop_types ptypes_actual ON (ptypes_actual.type_name = p.actual_type)
|
|
JOIN t_prop_types ptypes_persisted ON (ptypes_persisted.type_name = p.persisted_type)
|
|
WHERE
|
|
p.avm_store_id >= ${LOWERBOUND} AND p.avm_store_id <= ${UPPERBOUND}
|
|
;
|
|
DROP TABLE avm_store_properties;
|
|
ALTER TABLE t_avm_store_properties RENAME TO avm_store_properties;
|
|
|
|
-- Modify the avm_node_properties_new table
|
|
CREATE TABLE t_avm_node_properties
|
|
(
|
|
node_id BIGINT NOT NULL,
|
|
qname_id BIGINT NOT NULL,
|
|
actual_type_n INTEGER NOT NULL,
|
|
persisted_type_n INTEGER NOT NULL,
|
|
multi_valued BIT NOT NULL,
|
|
boolean_value BIT,
|
|
long_value BIGINT,
|
|
float_value FLOAT,
|
|
double_value DOUBLE PRECISION,
|
|
string_value TEXT,
|
|
serializable_value BLOB,
|
|
INDEX fk_avm_nprop_n (node_id),
|
|
INDEX fk_avm_nprop_qn (qname_id),
|
|
CONSTRAINT fk_avm_nprop_n FOREIGN KEY (node_id) REFERENCES avm_nodes (id),
|
|
CONSTRAINT fk_avm_nprop_qn FOREIGN KEY (qname_id) REFERENCES alf_qname (id),
|
|
PRIMARY KEY (node_id, qname_id)
|
|
) ENGINE=InnoDB;
|
|
--FOREACH avm_node_properties_new.node_id system.upgrade.t_avm_node_properties.batchsize
|
|
INSERT INTO t_avm_node_properties
|
|
(
|
|
node_id,
|
|
qname_id,
|
|
actual_type_n, persisted_type_n,
|
|
multi_valued, boolean_value, long_value, float_value, double_value, string_value, serializable_value
|
|
)
|
|
SELECT
|
|
p.node_id,
|
|
tqn.qname_id,
|
|
ptypes_actual.type_id, ptypes_persisted.type_id,
|
|
p.multi_valued, p.boolean_value, p.long_value, p.float_value, p.double_value, p.string_value, p.serializable_value
|
|
FROM
|
|
avm_node_properties_new p
|
|
JOIN t_qnames tqn ON (p.qname = tqn.qname)
|
|
JOIN t_prop_types ptypes_actual ON (ptypes_actual.type_name = p.actual_type)
|
|
JOIN t_prop_types ptypes_persisted ON (ptypes_persisted.type_name = p.persisted_type)
|
|
WHERE
|
|
p.node_id >= ${LOWERBOUND} AND p.node_id <= ${UPPERBOUND}
|
|
;
|
|
--FOREACH avm_node_properties.node_id system.upgrade.t_avm_node_properties.batchsize
|
|
INSERT INTO t_avm_node_properties
|
|
(
|
|
node_id,
|
|
qname_id,
|
|
actual_type_n, persisted_type_n,
|
|
multi_valued, boolean_value, long_value, float_value, double_value, string_value, serializable_value
|
|
)
|
|
SELECT
|
|
p.node_id,
|
|
tqn.qname_id,
|
|
ptypes_actual.type_id, ptypes_persisted.type_id,
|
|
p.multi_valued, p.boolean_value, p.long_value, p.float_value, p.double_value, p.string_value, p.serializable_value
|
|
FROM
|
|
avm_node_properties p
|
|
JOIN t_qnames tqn ON (p.qname = tqn.qname)
|
|
JOIN t_prop_types ptypes_actual ON (ptypes_actual.type_name = p.actual_type)
|
|
JOIN t_prop_types ptypes_persisted ON (ptypes_persisted.type_name = p.persisted_type)
|
|
LEFT OUTER JOIN t_avm_node_properties tanp ON (tqn.qname_id = tanp.qname_id)
|
|
WHERE
|
|
tanp.qname_id IS NULL
|
|
AND p.node_id >= ${LOWERBOUND} AND p.node_id <= ${UPPERBOUND}
|
|
;
|
|
|
|
DROP TABLE avm_node_properties_new;
|
|
DROP TABLE avm_node_properties;
|
|
ALTER TABLE t_avm_node_properties RENAME TO avm_node_properties;
|
|
|
|
|
|
-- -----------------
|
|
-- Build Locales --
|
|
-- -----------------
|
|
|
|
CREATE TABLE alf_locale
|
|
(
|
|
id BIGINT NOT NULL AUTO_INCREMENT,
|
|
version BIGINT NOT NULL DEFAULT 1,
|
|
locale_str VARCHAR(20) NOT NULL,
|
|
PRIMARY KEY (id),
|
|
UNIQUE (locale_str)
|
|
) ENGINE=InnoDB;
|
|
|
|
INSERT INTO alf_locale (id, locale_str) VALUES (1, '.default');
|
|
|
|
-- Locales come from the attribute table which was used to support MLText persistence
|
|
-- Query OK, 0 rows affected (17.22 sec)
|
|
--FOREACH alf_attributes.id system.upgrade.alf_attributes.batchsize
|
|
INSERT INTO alf_locale (locale_str)
|
|
SELECT DISTINCT(ma.mkey)
|
|
FROM alf_node_properties np
|
|
JOIN alf_attributes a1 ON (np.attribute_value = a1.id)
|
|
JOIN alf_map_attribute_entries ma ON (ma.map_id = a1.id)
|
|
LEFT OUTER JOIN alf_locale l ON (ma.mkey = l.locale_str)
|
|
WHERE l.locale_str IS NULL
|
|
AND a1.id >= ${LOWERBOUND} AND a1.id <= ${UPPERBOUND}
|
|
;
|
|
|
|
-- -------------------------------
|
|
-- Migrate ADM Property Tables --
|
|
-- -------------------------------
|
|
|
|
CREATE TABLE t_alf_node_properties
|
|
(
|
|
node_id BIGINT NOT NULL,
|
|
qname_id BIGINT NOT NULL,
|
|
locale_id BIGINT NOT NULL,
|
|
list_index smallint NOT NULL,
|
|
actual_type_n INTEGER NOT NULL,
|
|
persisted_type_n INTEGER NOT NULL,
|
|
boolean_value BIT,
|
|
long_value BIGINT,
|
|
float_value FLOAT,
|
|
double_value DOUBLE PRECISION,
|
|
string_value TEXT,
|
|
serializable_value BLOB,
|
|
INDEX fk_alf_nprop_n (node_id),
|
|
INDEX fk_alf_nprop_qn (qname_id),
|
|
INDEX fk_alf_nprop_loc (locale_id),
|
|
CONSTRAINT fk_alf_nprop_n FOREIGN KEY (node_id) REFERENCES t_alf_node (id),
|
|
CONSTRAINT fk_alf_nprop_qn FOREIGN KEY (qname_id) REFERENCES alf_qname (id),
|
|
CONSTRAINT fk_alf_nprop_loc FOREIGN KEY (locale_id) REFERENCES alf_locale (id),
|
|
PRIMARY KEY (node_id, qname_id, list_index, locale_id)
|
|
) ENGINE=InnoDB;
|
|
|
|
-- Copy values over
|
|
--FOREACH alf_node_properties.node_id system.upgrade.t_alf_node_properties.batchsize
|
|
INSERT INTO t_alf_node_properties
|
|
(
|
|
node_id, qname_id, locale_id, list_index,
|
|
actual_type_n, persisted_type_n,
|
|
boolean_value, long_value, float_value, double_value,
|
|
string_value,
|
|
serializable_value
|
|
)
|
|
SELECT
|
|
np.node_id, tqn.qname_id, 1, -1,
|
|
ptypes_actual.type_id, ptypes_persisted.type_id,
|
|
np.boolean_value, np.long_value, np.float_value, np.double_value,
|
|
np.string_value,
|
|
np.serializable_value
|
|
FROM
|
|
alf_node_properties np
|
|
JOIN t_qnames tqn ON (np.qname = tqn.qname)
|
|
JOIN t_prop_types ptypes_actual ON (ptypes_actual.type_name = np.actual_type)
|
|
JOIN t_prop_types ptypes_persisted ON (ptypes_persisted.type_name = np.persisted_type)
|
|
WHERE
|
|
np.attribute_value IS NULL
|
|
AND np.node_id >= ${LOWERBOUND} AND np.node_id <= ${UPPERBOUND}
|
|
;
|
|
|
|
-- Update cm:auditable properties on the nodes
|
|
--FOREACH t_alf_node.id system.upgrade.t_alf_node.batchsize
|
|
UPDATE t_alf_node n SET audit_creator =
|
|
(
|
|
SELECT
|
|
string_value
|
|
FROM
|
|
t_alf_node_properties np
|
|
JOIN alf_qname qn ON (np.qname_id = qn.id)
|
|
JOIN alf_namespace ns ON (qn.ns_id = ns.id)
|
|
WHERE
|
|
np.node_id = n.id AND
|
|
ns.uri = 'FILLER-http://www.alfresco.org/model/content/1.0' AND
|
|
qn.local_name = 'creator'
|
|
)
|
|
WHERE n.id >= ${LOWERBOUND} AND n.id <= ${UPPERBOUND};
|
|
|
|
--FOREACH t_alf_node.id system.upgrade.t_alf_node.batchsize
|
|
UPDATE t_alf_node n SET audit_created =
|
|
(
|
|
SELECT
|
|
string_value
|
|
FROM
|
|
t_alf_node_properties np
|
|
JOIN alf_qname qn ON (np.qname_id = qn.id)
|
|
JOIN alf_namespace ns ON (qn.ns_id = ns.id)
|
|
WHERE
|
|
np.node_id = n.id AND
|
|
ns.uri = 'FILLER-http://www.alfresco.org/model/content/1.0' AND
|
|
qn.local_name = 'created'
|
|
)
|
|
WHERE n.id >= ${LOWERBOUND} AND n.id <= ${UPPERBOUND};
|
|
|
|
--FOREACH t_alf_node.id system.upgrade.t_alf_node.batchsize
|
|
UPDATE t_alf_node n SET audit_modifier =
|
|
(
|
|
SELECT
|
|
string_value
|
|
FROM
|
|
t_alf_node_properties np
|
|
JOIN alf_qname qn ON (np.qname_id = qn.id)
|
|
JOIN alf_namespace ns ON (qn.ns_id = ns.id)
|
|
WHERE
|
|
np.node_id = n.id AND
|
|
ns.uri = 'FILLER-http://www.alfresco.org/model/content/1.0' AND
|
|
qn.local_name = 'modifier'
|
|
)
|
|
WHERE n.id >= ${LOWERBOUND} AND n.id <= ${UPPERBOUND};
|
|
|
|
--FOREACH t_alf_node.id system.upgrade.t_alf_node.batchsize
|
|
UPDATE t_alf_node n SET audit_modified =
|
|
(
|
|
SELECT
|
|
string_value
|
|
FROM
|
|
t_alf_node_properties np
|
|
JOIN alf_qname qn ON (np.qname_id = qn.id)
|
|
JOIN alf_namespace ns ON (qn.ns_id = ns.id)
|
|
WHERE
|
|
np.node_id = n.id AND
|
|
ns.uri = 'FILLER-http://www.alfresco.org/model/content/1.0' AND
|
|
qn.local_name = 'modified'
|
|
)
|
|
WHERE n.id >= ${LOWERBOUND} AND n.id <= ${UPPERBOUND};
|
|
-- Remove the unused cm:auditable properties
|
|
-- SHORTCUT:
|
|
-- The qname_id values can be determined up front
|
|
-- SELECT * FROM
|
|
-- alf_qname
|
|
-- JOIN alf_namespace ON (alf_qname.ns_id = alf_namespace.id)
|
|
-- WHERE
|
|
-- alf_namespace.uri = 'FILLER-http://www.alfresco.org/model/content/1.0' AND
|
|
-- alf_qname.local_name IN ('creator', 'created', 'modifier', 'modified')
|
|
-- ;
|
|
-- DELETE t_alf_node_properties
|
|
-- FROM t_alf_node_properties
|
|
-- WHERE
|
|
-- qname_id IN (13, 14, 23, 24);
|
|
--FOREACH t_alf_node_properties.node_id system.upgrade.t_alf_node_properties.batchsize
|
|
DELETE t_alf_node_properties
|
|
FROM t_alf_node_properties
|
|
JOIN alf_qname ON (t_alf_node_properties.qname_id = alf_qname.id)
|
|
JOIN alf_namespace ON (alf_qname.ns_id = alf_namespace.id)
|
|
WHERE
|
|
alf_namespace.uri = 'FILLER-http://www.alfresco.org/model/content/1.0' AND
|
|
alf_qname.local_name IN ('creator', 'created', 'modifier', 'modified') AND
|
|
t_alf_node_properties.node_id >= ${LOWERBOUND} AND t_alf_node_properties.node_id <= ${UPPERBOUND}
|
|
;
|
|
|
|
-- Copy all MLText values over
|
|
--FOREACH alf_node_properties.node_id system.upgrade.t_alf_node_properties.batchsize
|
|
INSERT INTO t_alf_node_properties
|
|
(
|
|
node_id, qname_id, locale_id, list_index,
|
|
actual_type_n, persisted_type_n,
|
|
boolean_value, long_value, float_value, double_value,
|
|
string_value,
|
|
serializable_value
|
|
)
|
|
SELECT
|
|
np.node_id, tqn.qname_id, loc.id, -1,
|
|
-1, 0,
|
|
FALSE, 0, 0, 0,
|
|
a2.string_value,
|
|
a2.serializable_value
|
|
FROM
|
|
alf_node_properties np
|
|
JOIN t_qnames tqn ON (np.qname = tqn.qname)
|
|
JOIN alf_attributes a1 ON (np.attribute_value = a1.id)
|
|
JOIN alf_map_attribute_entries ma ON (ma.map_id = a1.id)
|
|
JOIN alf_locale loc ON (ma.mkey = loc.locale_str)
|
|
JOIN alf_attributes a2 ON (ma.attribute_id = a2.id)
|
|
WHERE
|
|
np.node_id >= ${LOWERBOUND} AND np.node_id <= ${UPPERBOUND}
|
|
; -- (OPTIONAL)
|
|
--FOREACH t_alf_node_properties.node_id system.upgrade.t_alf_node_properties.batchsize
|
|
UPDATE t_alf_node_properties
|
|
SET actual_type_n = 6, persisted_type_n = 6, serializable_value = NULL
|
|
WHERE actual_type_n = -1 AND string_value IS NOT NULL
|
|
AND t_alf_node_properties.node_id >= ${LOWERBOUND} AND t_alf_node_properties.node_id <= ${UPPERBOUND}
|
|
;
|
|
--FOREACH t_alf_node_properties.node_id system.upgrade.t_alf_node_properties.batchsize
|
|
UPDATE t_alf_node_properties
|
|
SET actual_type_n = 9, persisted_type_n = 9
|
|
WHERE actual_type_n = -1 AND serializable_value IS NOT NULL
|
|
AND t_alf_node_properties.node_id >= ${LOWERBOUND} AND t_alf_node_properties.node_id <= ${UPPERBOUND}
|
|
;
|
|
--FOREACH t_alf_node_properties.node_id system.upgrade.t_alf_node_properties.batchsize
|
|
DELETE FROM t_alf_node_properties
|
|
WHERE actual_type_n = -1
|
|
AND t_alf_node_properties.node_id >= ${LOWERBOUND} AND t_alf_node_properties.node_id <= ${UPPERBOUND}
|
|
;
|
|
|
|
-- Delete the node properties and move the fixed values over
|
|
DROP TABLE alf_node_properties;
|
|
ALTER TABLE t_alf_node_properties RENAME TO alf_node_properties;
|
|
|
|
CREATE TABLE t_del_attributes
|
|
(
|
|
id BIGINT NOT NULL,
|
|
PRIMARY KEY (id)
|
|
);
|
|
|
|
--FOREACH alf_attributes.id system.upgrade.t_del_attributes.batchsize
|
|
INSERT INTO t_del_attributes
|
|
SELECT id FROM alf_attributes WHERE type = 'M'
|
|
AND alf_attributes.id >= ${LOWERBOUND} AND alf_attributes.id <= ${UPPERBOUND}
|
|
;
|
|
|
|
--FOREACH t_del_attributes.id system.upgrade.t_del_attributes.batchsize
|
|
DELETE t_del_attributes
|
|
FROM t_del_attributes
|
|
JOIN alf_map_attribute_entries ma ON (ma.attribute_id = t_del_attributes.id)
|
|
WHERE t_del_attributes.id >= ${LOWERBOUND} AND t_del_attributes.id <= ${UPPERBOUND}
|
|
;
|
|
|
|
--FOREACH t_del_attributes.id system.upgrade.t_del_attributes.batchsize
|
|
DELETE t_del_attributes
|
|
FROM t_del_attributes
|
|
JOIN alf_list_attribute_entries la ON (la.attribute_id = t_del_attributes.id)
|
|
WHERE t_del_attributes.id >= ${LOWERBOUND} AND t_del_attributes.id <= ${UPPERBOUND}
|
|
;
|
|
|
|
--FOREACH t_del_attributes.id system.upgrade.t_del_attributes.batchsize
|
|
DELETE t_del_attributes
|
|
FROM t_del_attributes
|
|
JOIN alf_global_attributes ga ON (ga.attribute = t_del_attributes.id)
|
|
WHERE t_del_attributes.id >= ${LOWERBOUND} AND t_del_attributes.id <= ${UPPERBOUND}
|
|
;
|
|
|
|
--FOREACH t_del_attributes.id system.upgrade.t_del_attributes.batchsize
|
|
INSERT INTO t_del_attributes
|
|
SELECT a.id FROM t_del_attributes t
|
|
JOIN alf_map_attribute_entries ma ON (ma.map_id = t.id)
|
|
JOIN alf_attributes a ON (ma.attribute_id = a.id)
|
|
WHERE t.id >= ${LOWERBOUND} AND t.id <= ${UPPERBOUND}
|
|
;
|
|
|
|
--FOREACH alf_map_attribute_entries.map_id system.upgrade.alf_map_attribute_entries.batchsize
|
|
DELETE alf_map_attribute_entries
|
|
FROM alf_map_attribute_entries
|
|
JOIN t_del_attributes t ON (alf_map_attribute_entries.map_id = t.id)
|
|
WHERE alf_map_attribute_entries.map_id >= ${LOWERBOUND} AND alf_map_attribute_entries.map_id <= ${UPPERBOUND}
|
|
;
|
|
|
|
--FOREACH alf_list_attribute_entries.list_id system.upgrade.alf_list_attribute_entries.batchsize
|
|
DELETE alf_list_attribute_entries
|
|
FROM alf_list_attribute_entries
|
|
JOIN t_del_attributes t ON (alf_list_attribute_entries.list_id = t.id)
|
|
WHERE alf_list_attribute_entries.list_id >= ${LOWERBOUND} AND alf_list_attribute_entries.list_id <= ${UPPERBOUND}
|
|
;
|
|
|
|
--FOREACH alf_attributes.id system.upgrade.alf_attributes.batchsize
|
|
DELETE alf_attributes
|
|
FROM alf_attributes
|
|
JOIN t_del_attributes t ON (alf_attributes.id = t.id)
|
|
WHERE alf_attributes.id >= ${LOWERBOUND} AND alf_attributes.id <= ${UPPERBOUND}
|
|
;
|
|
DROP TABLE t_del_attributes;
|
|
|
|
-- ---------------------------------------------------
|
|
-- Remove the FILLER- values from the namespace uri --
|
|
-- ---------------------------------------------------
|
|
UPDATE alf_namespace SET uri = '.empty' WHERE uri = 'FILLER-';
|
|
UPDATE alf_namespace SET uri = SUBSTR(uri, 8) WHERE uri LIKE 'FILLER-%';
|
|
|
|
-- ------------------
|
|
-- Final clean up --
|
|
-- ------------------
|
|
DROP TABLE t_qnames;
|
|
DROP TABLE t_prop_types;
|
|
DROP TABLE alf_node_status;
|
|
ALTER TABLE alf_store DROP INDEX FKBD4FF53D22DBA5BA, DROP FOREIGN KEY FKBD4FF53D22DBA5BA; -- (OPTIONAL)
|
|
ALTER TABLE alf_store DROP FOREIGN KEY alf_store_root; -- (OPTIONAL)
|
|
DROP TABLE alf_node;
|
|
ALTER TABLE t_alf_node RENAME TO alf_node;
|
|
DROP TABLE alf_store;
|
|
ALTER TABLE t_alf_store RENAME TO alf_store;
|
|
|
|
|
|
-- -------------------------------------
|
|
-- Modify index and constraint names --
|
|
-- -------------------------------------
|
|
ALTER TABLE alf_attributes DROP INDEX fk_attributes_n_acl, DROP FOREIGN KEY fk_attributes_n_acl; -- (optional)
|
|
ALTER TABLE alf_attributes DROP INDEX fk_attr_n_acl, DROP FOREIGN KEY fk_attr_n_acl; -- (optional)
|
|
ALTER TABLE alf_attributes
|
|
ADD INDEX fk_alf_attr_acl (acl_id)
|
|
;
|
|
|
|
ALTER TABLE alf_global_attributes DROP FOREIGN KEY FK64D0B9CF69B9F16A; -- (optional)
|
|
ALTER TABLE alf_global_attributes DROP INDEX FK64D0B9CF69B9F16A; -- (optional)
|
|
-- alf_global_attributes.attribute is declared unique. Indexes may automatically have been created.
|
|
ALTER TABLE alf_global_attributes
|
|
ADD INDEX fk_alf_gatt_att (attribute); -- (optional)
|
|
ALTER TABLE alf_global_attributes
|
|
ADD CONSTRAINT fk_alf_gatt_att FOREIGN KEY (attribute) REFERENCES alf_attributes (id)
|
|
;
|
|
|
|
ALTER TABLE alf_list_attribute_entries DROP INDEX FKC7D52FB02C5AB86C, DROP FOREIGN KEY FKC7D52FB02C5AB86C; -- (optional)
|
|
ALTER TABLE alf_list_attribute_entries DROP INDEX FKC7D52FB0ACD8822C, DROP FOREIGN KEY FKC7D52FB0ACD8822C; -- (optional)
|
|
ALTER TABLE alf_list_attribute_entries
|
|
ADD INDEX fk_alf_lent_att (attribute_id),
|
|
ADD CONSTRAINT fk_alf_lent_att FOREIGN KEY (attribute_id) REFERENCES alf_attributes (id),
|
|
ADD INDEX fk_alf_lent_latt (list_id),
|
|
ADD CONSTRAINT fk_alf_lent_latt FOREIGN KEY (list_id) REFERENCES alf_attributes (id)
|
|
;
|
|
|
|
ALTER TABLE alf_map_attribute_entries DROP INDEX FK335CAE26AEAC208C, DROP FOREIGN KEY FK335CAE26AEAC208C; -- (optional)
|
|
ALTER TABLE alf_map_attribute_entries DROP INDEX FK335CAE262C5AB86C, DROP FOREIGN KEY FK335CAE262C5AB86C; -- (optional)
|
|
ALTER TABLE alf_map_attribute_entries
|
|
ADD INDEX fk_alf_matt_matt (map_id),
|
|
ADD CONSTRAINT fk_alf_matt_matt FOREIGN KEY (map_id) REFERENCES alf_attributes (id),
|
|
ADD INDEX fk_alf_matt_att (attribute_id),
|
|
ADD CONSTRAINT fk_alf_matt_att FOREIGN KEY (attribute_id) REFERENCES alf_attributes (id)
|
|
;
|
|
|
|
ALTER TABLE alf_transaction DROP INDEX idx_commit_time_ms; -- (optional)
|
|
ALTER TABLE alf_transaction
|
|
ADD COLUMN commit_time_ms BIGINT NULL
|
|
; -- (optional)
|
|
ALTER TABLE alf_transaction
|
|
DROP INDEX FKB8761A3A9AE340B7, DROP FOREIGN KEY FKB8761A3A9AE340B7,
|
|
ADD INDEX fk_alf_txn_svr (server_id),
|
|
ADD CONSTRAINT fk_alf_txn_svr FOREIGN KEY (server_id) REFERENCES alf_server (id),
|
|
ADD INDEX idx_alf_txn_ctms (commit_time_ms)
|
|
;
|
|
|
|
--FOREACH alf_transaction.id system.upgrade.alf_transaction.batchsize
|
|
UPDATE alf_transaction SET commit_time_ms = id WHERE commit_time_ms IS NULL
|
|
AND alf_transaction.id >= ${LOWERBOUND} AND alf_transaction.id <= ${UPPERBOUND};
|
|
|
|
ALTER TABLE avm_child_entries DROP INDEX fk_avm_ce_child, DROP FOREIGN KEY fk_avm_ce_child; -- (optional)
|
|
ALTER TABLE avm_child_entries DROP INDEX fk_avm_ce_parent, DROP FOREIGN KEY fk_avm_ce_parent; -- (optional)
|
|
ALTER TABLE avm_child_entries
|
|
ADD INDEX fk_avm_ce_child (child_id),
|
|
ADD CONSTRAINT fk_avm_ce_child FOREIGN KEY (child_id) REFERENCES avm_nodes (id),
|
|
ADD INDEX fk_avm_ce_parent (parent_id),
|
|
ADD CONSTRAINT fk_avm_ce_parent FOREIGN KEY (parent_id) REFERENCES avm_nodes (id)
|
|
;
|
|
|
|
ALTER TABLE avm_history_links DROP INDEX fk_avm_hl_desc, DROP FOREIGN KEY fk_avm_hl_desc; -- (optional)
|
|
ALTER TABLE avm_history_links DROP INDEX fk_avm_hl_ancestor, DROP FOREIGN KEY fk_avm_hl_ancestor; -- (optional)
|
|
ALTER TABLE avm_history_links DROP INDEX idx_avm_hl_revpk; -- (optional)
|
|
ALTER TABLE avm_history_links
|
|
ADD INDEX fk_avm_hl_desc (descendent),
|
|
ADD CONSTRAINT fk_avm_hl_desc FOREIGN KEY (descendent) REFERENCES avm_nodes (id),
|
|
ADD INDEX fk_avm_hl_ancestor (ancestor),
|
|
ADD CONSTRAINT fk_avm_hl_ancestor FOREIGN KEY (ancestor) REFERENCES avm_nodes (id),
|
|
ADD INDEX idx_avm_hl_revpk (descendent, ancestor)
|
|
;
|
|
|
|
ALTER TABLE avm_merge_links DROP INDEX fk_avm_ml_to, DROP FOREIGN KEY fk_avm_ml_to; -- (optional)
|
|
ALTER TABLE avm_merge_links DROP INDEX fk_avm_ml_from, DROP FOREIGN KEY fk_avm_ml_from; -- (optional)
|
|
ALTER TABLE avm_merge_links
|
|
ADD INDEX fk_avm_ml_to (mto),
|
|
ADD CONSTRAINT fk_avm_ml_to FOREIGN KEY (mto) REFERENCES avm_nodes (id),
|
|
ADD INDEX fk_avm_ml_from (mfrom),
|
|
ADD CONSTRAINT fk_avm_ml_from FOREIGN KEY (mfrom) REFERENCES avm_nodes (id)
|
|
;
|
|
|
|
ALTER TABLE avm_nodes DROP INDEX fk_avm_n_acl, DROP FOREIGN KEY fk_avm_n_acl; -- (optional)
|
|
ALTER TABLE avm_nodes DROP INDEX fk_avm_n_store, DROP FOREIGN KEY fk_avm_n_store; -- (optional)
|
|
ALTER TABLE avm_nodes DROP INDEX idx_avm_n_pi; -- (optional)
|
|
ALTER TABLE avm_nodes
|
|
ADD INDEX fk_avm_n_acl (acl_id),
|
|
ADD CONSTRAINT fk_avm_n_acl FOREIGN KEY (acl_id) REFERENCES alf_access_control_list (id),
|
|
ADD INDEX fk_avm_n_store (store_new_id),
|
|
ADD CONSTRAINT fk_avm_n_store FOREIGN KEY (store_new_id) REFERENCES avm_stores (id),
|
|
ADD INDEX idx_avm_n_pi (primary_indirection)
|
|
;
|
|
|
|
ALTER TABLE avm_stores DROP INDEX fk_avm_s_root, DROP FOREIGN KEY fk_avm_s_root; -- (optional)
|
|
ALTER TABLE avm_stores
|
|
ADD INDEX fk_avm_s_acl (acl_id),
|
|
ADD CONSTRAINT fk_avm_s_acl FOREIGN KEY (acl_id) REFERENCES alf_access_control_list (id),
|
|
ADD INDEX fk_avm_s_root (current_root_id),
|
|
ADD CONSTRAINT fk_avm_s_root FOREIGN KEY (current_root_id) REFERENCES avm_nodes (id)
|
|
;
|
|
|
|
ALTER TABLE avm_version_layered_node_entry DROP INDEX FK182E672DEB9D70C, DROP FOREIGN KEY FK182E672DEB9D70C; -- (optional)
|
|
ALTER TABLE avm_version_layered_node_entry
|
|
ADD INDEX fk_avm_vlne_vr (version_root_id),
|
|
ADD CONSTRAINT fk_avm_vlne_vr FOREIGN KEY (version_root_id) REFERENCES avm_version_roots (id)
|
|
;
|
|
|
|
ALTER TABLE avm_version_roots DROP INDEX idx_avm_vr_version; -- (optional)
|
|
ALTER TABLE avm_version_roots DROP INDEX idx_avm_vr_revuq; -- (optional)
|
|
ALTER TABLE avm_version_roots DROP INDEX fk_avm_vr_root, DROP FOREIGN KEY fk_avm_vr_root; -- (optional)
|
|
ALTER TABLE avm_version_roots DROP INDEX fk_avm_vr_store, DROP FOREIGN KEY fk_avm_vr_store; -- (optional)
|
|
ALTER TABLE avm_version_roots
|
|
ADD INDEX idx_avm_vr_version (version_id),
|
|
ADD INDEX idx_avm_vr_revuq (avm_store_id, version_id),
|
|
ADD INDEX fk_avm_vr_root (root_id),
|
|
ADD CONSTRAINT fk_avm_vr_root FOREIGN KEY (root_id) REFERENCES avm_nodes (id),
|
|
ADD INDEX fk_avm_vr_store (avm_store_id),
|
|
ADD CONSTRAINT fk_avm_vr_store FOREIGN KEY (avm_store_id) REFERENCES avm_stores (id)
|
|
;
|
|
|
|
--
|
|
-- Record script finish
|
|
--
|
|
DELETE FROM alf_applied_patch WHERE id = 'patch.db-V2.2-Upgrade-From-2.1';
|
|
INSERT INTO alf_applied_patch
|
|
(id, description, fixes_from_schema, fixes_to_schema, applied_to_schema, target_schema, applied_on_date, applied_to_server, was_executed, succeeded, report)
|
|
VALUES
|
|
(
|
|
'patch.db-V2.2-Upgrade-From-2.1', 'Manually executed script upgrade V2.2: Upgrade from 2.1',
|
|
0, 85, -1, 91, null, 'UNKNOWN', ${TRUE}, ${TRUE}, 'Script completed'
|
|
);
|