-  TWiki Upgrade Guide
- Overview
- Upgrade Requirements
- Major Changes from TWiki 01-Sep-2001
- Major Changes from TWiki 01-Dec-2000
- TWiki Directory Structure and File Names
- Standard Upgrade Procedure from 01-Sep-2001 to 01-Dec-2001 Release
-  Standard Upgrade Procedure from 01-Dec-2000 to 01-Dec-2001 Release
- Pre-Upgrade Preparation
- Step 1: Backup & Unpack
- Step 2: Upgrade TWiki document files
- Step 3: Install new template files
- Step 4: Install new data and pub files
- Step 5: Install new CGI scripts
- Step 6: Install new Perl library files
- Step 7: Set configurations and test installation
- Step 8: Update topics
- Step 9: Customize template files
- Step 10: Switch over to new installation
- Step 11: Test the TWiki Plugins
- General Format Changes
 
- Known Issues
 
TWiki Upgrade Guide
Upgrade from TWiki 01-Dec-2000 or TWiki 01-Sep-2001 to TWiki 01-Dec-2001 (previous to new full release)Overview
This guide describes how to upgrade either from TWiki 01-Dec-2000 or TWiki 01-Sep-2001 to TWiki 01-Dec-2001.- The latest version of TWiki (01-Dec-2001) is a small incremental release over the 01-Sep-2001 version.
- The 01-Sep-2001 version involves several major new features and numerous enhancements to the last full version (01-Dec-2000). The file system set-up is almost identical, but much of the underlying data structure and processes is new. With all the changes, the upgrade procedure is straightforward, and your existing page data is imported directly.
Upgrade Requirements
- To upgrade from a 01-Dec-2000 or 01-Sep-2001 standard installation to the latest 01-Dec-2001 TWiki Production Release, follow the instructions below.
- NOTE: To upgrade from a pre-01-Dec-2000 TWiki, start with TWikiUpgradeTo01Dec2000.
- To upgrade from a Beta of the new release, or if you made custom modifications to the application, read through all new reference documentation, then use the procedure below as a guideline.
Major Changes from TWiki 01-Sep-2001
The latest 01-Dec-2001 release includes the following new features and enhancements compared to the 01-Sep-2001 release:-  FormattedSearch - New format=""parameter in%SEARCH{}%variable for database like reporting.
- Various bug fixes
Major Changes from TWiki 01-Dec-2000
The 01-Sep-2001 release includes the following new features and enhancements compared to the 01-Dec-2000 release:-  TWikiPlugins - Easily install program enhancements using external plug-in modules. Developers can create plug-ins in Perl, with the TWiki Plugin API.
-  InterwikiPlugin (preinstalled) - Link to external sites with text aliases, SiteAlias:Page; rules are defined in InterWikis. (Get more Plugins from the TWiki:Plugins web.)
 
-  InterwikiPlugin (preinstalled) - Link to external sites with text aliases, 
- TWikiTemplates - New, more flexible template system.
- TWikiSkins - Overwrite template headers and footers; page content is unaffected.
- TWikiMetaData - New data format
- TWiki.TWikiForms - Create multiple input forms per web; data is rendered in HTML tables.
- ManagingTopics - Individual topics can be renamed, moved and deleted through the browser. Deleted topics are stored in a common Trash web.
- Change passwords - Change and reset passwords using forms.
-  TOC (Table of Contents) - %TOC%variable generates a hierarchical table of contents from topic headings: <h1>...<h6>.
- Arbitrary Text for WikiWord Links - Text formatting rules to generate automatic links from any combination of words and spaces.
- Attachments Under Revision Control - Changes made to files attached to topics are now saved under revision control (RCS).
- SuperAdministrator Group - Lets you to make the members of one user group - by default, TWikiAdminGroup - into TWiki superusers, with the ability to overwrite locked topics from the browser interface. (This gets around the problem of topic lockouts, caused by typos in access privilege definitions.)
- HierarchicalNavigation uses new Meta Data variables to link hierarchically.
- Convert to XHTML - Pages are rendered for display in XHTML 1.0, as far as possible without breaking HTML 3.2 compliance.
TWiki Directory Structure and File Names
The TWiki directory structure remains the same, with one exception, the TWiki configuration file and Perl modules have been moved from thetwiki/bin directory into it's own twiki/lib directory tree. The following files have been renamed and moved:
| From TWiki 01-Dec-2000: | To TWiki 01-Dec-2001: | 
|---|---|
| twiki/bin/wikicfg.pm | twiki/lib/TWiki.cfg | 
| twiki/bin/wiki.pm | twiki/lib/TWiki.pm | 
| twiki/bin/wikiaccess.pm | twiki/lib/TWiki/Access.pm | 
| twiki/bin/wikiprefs.pm | twiki/lib/TWiki/Prefs.pm | 
| twiki/bin/wikisearch.pm | twiki/lib/TWiki/Search.pm | 
| twiki/bin/wikistore.pm | twiki/lib/TWiki/Store.pm | 
twiki/lib/TWiki/Plugins directory contains the new Plugin modules.
Standard Upgrade Procedure from 01-Sep-2001 to 01-Dec-2001 Release
This incremental update can be performed easily. The following steps describe the upgrade assuming that$TWIKIROOT is the root of your current 01-Sep-2001 release.
-  Back up and prepare:
-  Back up all existing TWiki directories $TWIKIROOT/bin,$TWIKIROOT/pub,$TWIKIROOT/data,$TWIKIROOT/templates.
- Create a temporary directory and unpack the ZIP file there.
 
-  Back up all existing TWiki directories 
-  Update files in TWiki root:
-  Overwrite all *.htmland*.txtfiles in$TWIKIROOTwith the new ones.
 
-  Overwrite all 
-  Update template files:
-  Overwrite all template files in $TWIKIROOT/templateswith the new ones.
 
-  Overwrite all template files in 
-  Update script files:
-  Overwrite all script files in $TWIKIROOT/binwith the new ones.
 
-  Overwrite all script files in 
-  Update library files:
-  Overwrite the TWiki.pmlibrary in$TWIKIROOT/libwith the new one.
-  Overwrite all *.pmlibrary files in$TWIKIROOT/lib/TWikiand$TWIKIROOT/lib/TWiki/Pluginswith the new ones.
 
-  Overwrite the 
-  Update data/TWiki files: (in case you want the updated docs)
- Using your browser, merge the new TWiki.TWikiRegistration topic (or TWiki.TWikiRegistrationPub in case you used that one) into your existing TWiki.TWikiRegistration topic.
-  In the temporary twiki/data/TWikidirectory where you unzipped the installation package:-  Remove the files you do not want to upgrade: TWikiPreferences.*,TWikiWebsTable.*,WebNotify.*,WebPreferences.*,WebStatistics.*and allWebTopic*files.
-  In case the cgi-scripts are not running as user nobody: The*,vRCS repository files delivered with the installation package are locked by user nobody and need to be changed the user of your cgi-scripts, i.e.www-data. A simple way to switch the locker of the RCS files is to use sed:
 for f in *,v; do sed 's/nobody\:/www-data\:/' $f > x; mv x $f; done
 
-  Remove the files you do not want to upgrade: 
-  Move all remaining *.txtand*.txt,vfiles from the temporarydata/TWikidirectory to your$TWIKIROOT/data/TWikidirectory.
 
-  Update pub/TWiki files:
-  Move the new pub/TWiki/TWikiDocGraphicsdirectory into your$TWIKIROOT/pub/TWikidirectory.
 
-  Move the new 
Standard Upgrade Procedure from 01-Dec-2000 to 01-Dec-2001 Release
The idea is to have the new and old installation work in parallel so that you can test the new installation before switching over. That way you can make the switch on your live TWiki installation within one minute without affecting the users.| Before Switch: | After Switch: | ||
|---|---|---|---|
| Current 01-Dec-2000: | New 01-Dec-2001: | Obsolete 01-Dec-2000: | New 01-Dec-2001: | 
| twiki/templates/ | twiki/templates2/ | twiki/templates1/ | twiki/templates/ | 
| twiki/bin/ | twiki/bin/2/ | (overwritten) | twiki/bin/ | 
| (N/A) | twiki/bin/lib/ | (N/A) | twiki/lib/ | 
| twiki/data/TWiki | twiki/data/TWiki2 | twiki/data/TWiki1 | twiki/data/TWiki | 
| (other directories do not change) | |||
Pre-Upgrade Preparation
Two major areas of TWiki functionality - TWikiTemplates and TWikiForms (input forms associated with a topic)- are entirely different in the new TWiki. If you've customized your templates or use Category Tables, read those sections before starting your upgrade. The following steps describe the upgrade on Unix. Windows setup is very similar. It's assumed that$TWIKIROOT is the root of your current 01-Dec-2000 release, ex: export TWIKIROOT=/some/dir/
Step 1: Backup & Unpack
-  Back up all existing TWiki directories twiki/bin,twiki/pub,twiki/data,twiki/templates.
-  Create a temporary directory and unpack the ZIP file there:
     
 mkdir -p ~/tmp/
 cp -p ~/downloads/TWiki20011201.zip ~/tmp/
 cd ~/tmp/
 unzip ~/tmp/TWiki20011201.zip
Step 2: Upgrade TWiki document files
-  Move the document files to your TWiki root ( twiki):
 mv ~/tmp/TWiki*.html $TWIKIROOT
 mv ~/tmp/index.html $TWIKIROOT
 mv ~/tmp/readme.txt $TWIKIROOT
 mv ~/tmp/license.txt $TWIKIROOT
Step 3: Install new template files
-  Move & rename the template directory to a temporary twiki/templates2directory, ex:
 mv ~/tmp/templates $TWIKIROOT/templates2
-  Pay attention to the file and directory permissions (security issue). Set file permissions, ex:
     
 chmod 644 *.cgi
Step 4: Install new data and pub files
-  Move the TWiki web to a temporary TWiki2 twiki/data/TWiki2directory. Do the same to files attached to this web, ex:
 mv ~/tmp/data/TWiki $TWIKIROOT/data/TWiki2
 mv ~/tmp/pub/TWiki $TWIKIROOT/pub/TWiki2
-  Move & rename the Know web to a temporary twiki/data/Know2directory, ex:
 mv ~/tmp/data/Know $TWIKIROOT/data/Know2
 mv ~/tmp/pub/Know $TWIKIROOT/pub/Know2
-  Move the _default and Trash web, ex:
     
 mv ~/tmp/data/_default $TWIKIROOT/data
 mv ~/tmp/data/Trash $TWIKIROOT/data
-  Move the MIME types file, ex:
     
 mv ~/tmp/data/mime.types $TWIKIROOT/data
-  Move the TWiki logo files, ex:
     
 mv ~/tmp/pub/*.gif $TWIKIROOT/pub
-  Pay attention to the file permissions of the TWiki2andKnow2directories and its files. The files must be writable by the cgi-scripts (usually usernobody).
-  In case the cgi-scripts are not running as user nobody: The*,vRCS repository files delivered with the installation package are locked by user nobody and need to be changed the user of your cgi-scripts, i.e.www-data. A simple way to switch the locker of the RCS files is to use sed:
 for f in *,v; do sed 's/nobody\:/www-data\:/' $f > x; mv x $f; done
Step 5: Install new CGI scripts
-  Move & rename the CGI script directory to a temporary twiki/bin/2directory, ex:
 mv ~/tmp/bin $TWIKIROOT/bin/2
-  If necessary, change the script names to include the required extension, ex: .cgi
-  Copy any additional scripts you might have from the 01-Dec-2000 release, ex:
     
 cp -p $TWIKIROOT/bin/somescript $TWIKIROOT/bin/2
-  In case you use basic authentication, rename .htaccess.txtto.htaccessand customize it, ex:
 cd $TWIKIROOT/bin/2
 mv .htaccess.txt .htaccess
 diff ../.htaccess .
 and merge the content
-  Pay attention to the file and directory permissions (security issue). Set permissions, ex:
     
 chmod 755 *.cgi
Step 6: Install new Perl library files
-  Move the lib directory to a temporary twiki/bin/libdirectory, ex:
 mv ~/tmp/lib $TWIKIROOT/bin
-  Pay attention to the file and directory permissions (security issue). Set permissions, ex:
     
 chmod 644 *.pm
Step 7: Set configurations and test installation
-  Merge the content of the old twiki/bin/wikicfg.pminto the newtwiki/lib/TWiki.cfgconfiguration file. Use thediffcommand to find out the differences, ex:
 cd $TWIKIROOT/bin/lib
 diff ../wikicfg.pm TWiki.cfg
-  Make sure to set the correct temporary location of templates and scripts, ex:
     
 $scriptUrlPath = "/twiki/bin/2";
 $templateDir = "/home/httpd/twiki/templates2";
-  Do not merge the functions extendHandleCommonTags,extendGetRenderedVersionOutsidePRE,extendGetRenderedVersionInsidePREfrom the oldtwiki/bin/wikicfg.pm. This is now handled by the Default plugintwiki/lib/TWiki/Plugins/Default.pm
-  Test your new TWiki installation to see if you can view topics. Point your browser to the old installation and fix the URL to see the new installation, ex:
-  Old URL: http://localhost/cgi-bin/view
-  New URL: http://localhost/cgi-bin/2/view
 
-  Old URL: 
Step 8: Update topics
You can do the following changes using your old TWiki 01-Dec-2000 or new TWiki 01-Dec-2001 installation. Pointing your browser to the old installation for edit-copy-edit-paste operations is recommended, so that users don't get surprised by meta data content showing up in topics.-  Remember that you now have two TWiki webs:
-  The original TWikiweb.
-  The new TWiki2web, which gets renamed toTWikiwhen you switch over the installation.
 
-  The original 
-  In case you customized TWiki.TWikiRegistration, merge your changes back intoTWiki2.TWikiRegistration.
-  Copy TWiki.TWikiWebsTabletoTWiki2.TWikiWebsTable.-  Do the same for any other topics you might have created in the TWikiweb.
 
-  Do the same for any other topics you might have created in the 
-  In TWiki2.TWikiPreferences, merge the oldTWiki.TWikiPreferencessettings and customize it.- Add your webs to WIKIWEBLIST
- Set the WIKIWEBMASTER
- Set the SMTPMAILHOST
 
-  In WebPreferencesof all webs, add or change the following web preferences: (seeTWiki.WebPreferences)-  Add a NOSEARCHALL in case you want to exclude the web from a web="all"search:
 * Set NOSEARCHALL = on
-  In WEBTOPICLIST, remove the %WEB% . {}decoration from the list (it is now in the templates), ex:
 * Set WEBTOPICLIST = <a href="Home">Home</a>
 | <a href="WebChanges">Changes</a>
 | <a href="WebIndex">Index</a>
 | <a href="WebSearch">Search</a>
 | Go <input type="text" name="topic" size="16" />
-  Add a these new preferences:
        
 * Set DENYWEBVIEW =
 * Set ALLOWWEBVIEW =
 * Set DENYWEBRENAME =
 * Set ALLOWWEBRENAME =
-  Set the FINALPREFERENCES:
        
 * Set FINALPREFERENCES = WEBTOPICLIST, DENYWEBVIEW, ALLOWWEBVIEW, DENYWEBCHANGE, ALLOWWEBCHANGE, DENYWEBRENAME, ALLOWWEBRENAME
 
-  Add a NOSEARCHALL in case you want to exclude the web from a 
-  Optional: In WebSearchof all webs, replace content with this one line:
 %INCLUDE{"%TWIKIWEB%.WebSearch"}%
-  Optional: In WebChangesof all webs, replace content with this one line:
 %INCLUDE{"%TWIKIWEB%.WebChanges"}%
Step 9: Customize template files
NOTE: Skip this step if you did not customize your template files.-  Remember that you have now two template directories:
-  The original twiki/templates.
-  The new twiki/templates2, which gets renamed totwiki/templateswhen you switch over the installation.
 
-  The original 
-  Customized templates and skins need to be upgraded to the new TWikiTemplates. This isn't difficult, but you have be familiar with the new template set-up before starting the conversion. The safest way is to use the new templates as a base and to merge your changes back. Changes in new templates:
-  Templates are now rendered by TWiki. You can use all TextFormattingRules, but you have to escape unwanted ones. Also, remove empty lines unless you want a =<p />tag added.
- Added TWikiMetaData rendering.
 
-  Templates are now rendered by TWiki. You can use all TextFormattingRules, but you have to escape unwanted ones. Also, remove empty lines unless you want a 
-  Form Templates replace the TWikiCategoryTables:
-  Create a replacement WebFormtopic based ontwikicatitems.tmplin each web that uses a Category Table. See details in TWikiForms and compare with the settings in theKnow2.WebPreferencestopic.
 NOTE: Do not remove thetwikicatitems.tmplfile, it is still used for topics that are of the old format.
-  Searches need to be adjusted to deal with format change. It is possible to define a regular expression search that can deal at the same time with topics in the old format and new format.
-  Example: List all topics in the Know web that have a TopicClassification? of PublicFAQ?: 
 %SEARCH{ "[T]opicClassification.*?(td..td|value\=).*?[P]ublicFAQ" casesensitive="on" regex="on" nosearch="on" web="Know"}%
 (The[T]and[P]is done so that search does not find the topic where this search string is located in!)
-  Example: Create a link that lists all topics in the Know web with a TopicClassification? of PublicFAQ?: 
 [[%SCRIPTURL%/search%SCRIPTSUFFIX%/Know/?scope=text
 &search=%5BT%5DopicClassification.*%3F%28td..td%7C
 value%5C%3D%29.*%3F%5BP%5DublicFAQ®ex=on][All Public FAQ]]
 All Public FAQ
 
-  Example: List all topics in the Know web that have a TopicClassification? of PublicFAQ?: 
 
-  Create a replacement 
-  For each web that has a custom notedited.tmpltemplate, create an equivalent WebTopicEditTemplate to conform with the new TemplateTopics. The new format replaces thenotedited.tmpl,notext.tmplandnotwiki.tmpltemplates.
Step 10: Switch over to new installation
In this step, you move the working 01-Dec-2001 installation to the old 01-Dec-2000 installation, so that users don't have to change the URL.-  Test your new 01-Dec-2001 installation under twiki/bin/2/viewto make sure everything works as expected.- NOTE: Don't worry about the Plugins, they'll work after the switch.
 
-  Edit $TWIKIROOT/bin/2/TWiki.cfgand remove the/2from$scriptUrlPathand$templateDir, ex:
 $scriptUrlPath = "/twiki/bin";
 $templateDir = "/home/httpd/twiki/templates";
-  Rename the TWiki2web toTWiki, including attachments, ex:
 cd $TWIKIROOT/data
 mv TWiki TWiki1
 mv TWiki2 TWiki
 cd $TWIKIROOT/pub
 mv TWiki TWiki1
 mv TWiki2 TWiki
-  Rename the templates2directory totemplates, ex:
 cd $TWIKIROOT
 mv templates templates1
 mv templates2 templates
-  Move the libdirectory one level up from$TWIKIROOT/bin/libto$TWIKIROOT/lib, ex:
 cd $TWIKIROOT
 mv bin/lib .
-  Copy content of bin/2tobin, ex:
 cd $TWIKIROOT/bin
 cp -p bin/2/* .
 cp -p bin/2/.htaccess .
- Point your browser to the original URL and make sure the relocated 01-Dec-2001 installation works as expected: check browsing, searching and user registration.
-  Clean up and remove obsolete directories:
-  Remove directory $TWIKIROOT/bin/2
-  Remove directory $TWIKIROOT/templates1
-  Remove directory $TWIKIROOT/data/TWiki1
-  Remove directory $TWIKIROOT/pub/TWiki1
-  Remove temporary directory, ex: ~/tmp
 
-  Remove directory 
Step 11: Test the TWiki Plugins
-  Test the new TWikiPlugins by checking the Plugins settings in TWikiPreferences.
-  The EmptyPlugin,DefaultPlugin, andInterwikiPluginshould be preinstalled. To check the InterwikiPlugin, go to its page.
 
-  The 
-  If you have customized the functions extendHandleCommonTags,extendGetRenderedVersionOutsidePREandextendGetRenderedVersionInsidePREintwiki/bin/wikicfg.pm:-  Merge those changes back into twiki/lib/TWiki/Plugins/Default.pm
 
-  Merge those changes back into 
General Format Changes
-  The format of the %GMTIME{"..."}%and%SERVERTIME{"..."}%variables is now"$hour:$min"instead of"hour:min". More in TWikiVariables.
-  ExtendingTableSyntax: Enhanced table syntax might have unwanted side effect: | *bold* |cells,| center aligned |and| right aligned |cells, span multiple columns using| empty cells |||. More in TextFormattingRules.
-  Use Net::SMTPmodule instead ofsendmailif installed.
-  Use <verbatim> ... </verbatim>tags instead of<pre> ... </pre>tags where appropriate. More in TextFormattingRules.
-  New variable %STARTINCLUDE%and%STOPINCLUDE%variables to control what gets included of a topic. More in TWikiVariables.
-  FileAttachment info is now stored as TWiki Meta Data.
- Upgrading of imported pagess is done automatically after first edit, on save. "In memory" upgrade is done on topic view.
-  Attachments are now under revision control: $attachAsciiPathinTWiki.cfgdefines which file types are stored in ASCII, otherwise, binary format is used. This means that the RCS version used should support binary files.
 
-  Handling for topic-specific templates like edit.new.tmplhas been removed and replaced by template topics in the new TWikiTemplates.
-  A new file warning.txtfile can appear in thedatadirectory. It may contain diagnostic info identifying problems that need fixing. This file could get fairly large if you have a lot of problems your site - you can delete it at any time.
Known Issues
- Check TWiki:Codev/KnownIssuesOfTWiki01Dec2001 for known issues of TWiki 01 Dec 2001 (production release)
- Check TWiki:Codev/KnownIssuesOfTWiki01Sep2001 for known issues of TWiki 01 Sep 2001 (production release)
-- MikeMannix - 12 Sep 2001
-- PeterThoeny - 03 Dec 2001
 
   
   
   
   
  