!! Version 2.1.27 (2006-12-11) This version backports from 2.2.0-beta a bugfix for $TableRowIndexMax and also support for the [@{*$Variable}@] markup. !! Version 2.1.26 (2006-09-11) This version fixes a bug in feeds.php that would cause feed entries to be mixed up. !! Version 2.1.25 (2006-09-08) This release fixes a bug in authuser.php introduced by the 2.1.24 release. The skin template code has also been extended to allow [@@] and [@@] as aliases for [@@] and [@@]. !! Version 2.1.24 (2006-09-06) This release makes some improvements and fixes to the [[AuthUser]] capability. A bug in authuser.php that had trouble dealing with non-array values in $AuthUser has been fixed. It is now possible to specify group memberships from ''local/config.php'' (remember that such entries must come ''before'' including the ''authuser.php'' script): # alice and bob's passwords $AuthUser['alice'] = crypt('alicepassword'); $AuthUser['bob'] = crypt('bobpassword'); # members of the @writers and @admins groups $AuthUser['@writers'] = array('alice', 'bob'); $AuthUser['@admins'] = array('alice', 'dave'); # carol is a member of @editors and @writers $AuthUser['carol'] = array('@editors', '@writers'); AuthUser can now read from Apache-formatted .htgroup files. The location of the .htgroup file can be done either in ''local/config.php'' or [[Site.AuthUser]] # local/config.php: $AuthUser['htgroup'] = '/path/to/.htgroup'; # Site.AuthUser htgroup: /path/to/.htgroup !! Versions 2.1.21, 2.1.22, 2.1.23 (2006-09-05, 2006-09-06) This release closes a potential security vulnerability for sites that are running with 'register_globals' set to on. Details of the vulnerability will be forthcoming on the mailing list and site. Sites that are running with PHP 'register_globals' and 'allow_url_fopen' set to 'On' should upgrade to this release at the earliest opportunity. If upgrading isn't an option, contact Pm for a patch to older versions. There is now a tool available to analyze PmWiki sites for security and other configuration settings, see [[PmWiki:SiteAnalyzer]]. Version 2.1.23 also corrects a bug that prevented PmWiki from being able to read pagefiles created by versions of PmWiki before 0.5.6. !! Version 2.1.20 (2006-09-04) More minor bugfixes: * Corrected a bug with WikiWord references appearing in the [@(:attachlist:)@] markup. * Restore ability to remove/override PmWiki's default CSS settings. !! Version 2.1.19 (2006-08-30) This release provides a number of very minor bugfixes and enhancements: * Fixed a bug in the pageindex code that was causing it to not regenerate as quickly as it should. * Fixed image/object/embed handling in wikistyles to better support the [[Cookbook:Flash]] recipe. * Fixed a bug with wikistyles and input form tags. The next release(s) may have a number of substantial code enhancements and changes, so this release simply closes out a few items before introducing those changes. !! Version 2.1.18 (2006-08-28) This release closes a potential cross-site scripting vulnerability that could allow authors to inject Javascript code through the various table markups. The release also adds a new [@(:input image:)@] markup to generate image input tags in forms. Finally, this release corrects a problem with [@?action=print@] failing to properly set the [@{$Action}@] page variable. !! Version 2.1.17 (2006-08-26) This release fixes a long-standing bug with $EnableIMSCaching (PITS:00573), whereby login/logout operations wouldn't invalidate browser caches, causing some people to see versions of a page prior to the login/logout taking place. The new IMS caching code maintains a "imstime" cookie in the visitor's browser that keeps track of the time of last login, logout, author name change, or site modification. This cookie is then used to determine the proper response to browser requests containing If-Modified-Since headers. (Previously only the time of the last site modification was available.) Browsers which do not accept cookies will effectively act as though IMS caching is disabled. !! Version 2.1.16 (2006-08-26) This release makes some improvements to skin handling -- primarily this improves the capability of relocating skin files to other locations, and to provide the ability for recipes to insert items at the ''end'' of HTML output. This release introduces a [@@] directive into [[skin templates]], which allows recipes and local customizations to insert output near the end of a document using a $HTMLFooterFmt array from PHP. Also, the [@@] directive, which inserts the contents of $HTMLHeaderFmt into the output, has now been renamed to [@@]. PmWiki will continue to recognize [@@] to preserve compatibility with existing skins, but [@@] is preferred. A new $SkinLibDirs array has been introduced which allows the source locations and urls for skins to be specified from a customization file. By default $SkinDirUrls is set as array("./pub/skins/\$Skin" => "$PubDirUrl/skins/\$Skin", "$FarmD/pub/skins/\$Skin" => "$FarmPubDirUrl/skins/\$Skin") The keys (on the left) indicate the places to look for skins in the filesystem, while the values (on the right) indicate the urls corresponding to the locations on the left. Modifying the value of $SkinLibDirs allows skins to be located anywhere on the filesystem. As far as I can see, none of the changes introduced by this release should have any sort of negative impact on existing sites, so it should be safe to upgrade. (If I'm wrong, please let me know.) !! Version 2.1.15 (2006-08-25) This release includes a number of feature enhancements and code cleanups as reported or requested by administrators. First, AuthUser's LDAP authentication system now allows the use of a [@?filter@] parameter, consistent with urls used for mod_auth_ldap authorization in Apache. See the newly updated LDAP section of the [[AuthUser]] documentation for more details. A chicken-and-egg problem with the [@@_site_*@] authorization groups has been resolved. It's now possible to have a page's read authorization refer to things such as [@_site_edit@]. Also, the RetrieveAuthPage() function -- used for retrieving pages only if the visitor is authorized to do so -- now recognizes a special level parameter of 'ALWAYS', which means to always authorize access regardless of the browser or visitors current permissions. This may be useful for allowing certain operations to take place from within trusted scripts without having to grant full authorization to the browser. Hardcoded instances of the ''local/'' directory now use a customizable $LocalDir variable. This variable controls where PmWiki looks for ''local/config.php'' and per-group customization files. It may be useful for some [[Wiki Farm(s)]] contexts. Note that this does not change or affect the location of ''$FarmD/local/farmconfig.php''. Some minor internal changes have been made to ''scripts/wikistyles.php'' to better accommodate the wikipublisher recipe. It's probably better if we don't try to explain them. :-) !! Version 2.1.13, 2.1.14 (2006-08-15, 2006-08-16) This release fixes a bug in handling numeric passwords, and also allows ldaps:// authentication sources. !! Version 2.1.12 (2006-08-07) This version introduces the ability to nest divs and tables. The standard [@(:table:)@] and [@(:div:)@] markups are still available, except that a [@(:div:)@] may contain a [@(:table:)@] and vice-versa. As in previous versions of PmWiki, the [@(:div:)@] markup automatically closes any previous [@(:div:)@]. However, there are now [@(:div1:)@], [@(:div2:)@], etc. markups (and the corresponding [@(:div1end:)@], [@(:div2end:)@], ...) which can be used to uniquely distinguish divs for nesting purposes. To restore PmWiki's previous "non-nested" div behavior, set $Transition['nodivnest'] = 1; in a local customization file. Other changes in this release: * Add a [@(:noaction:)@] directive to suppress display of page actions. * Allow anchor tags to contain colons, hyphens, and dots. * Add "white-space" as an allowed wikistyle. * Other minor bug fixes and typographical corrections. !! Version 2.1.11 (2006-06-09) This is a minor update that prevents [@%define=%@] wikistyles from generating empty paragraphs in the HTML output. Prior to this release, markup lines containing only wikistyle definitions would often generate empty paragraphs (
), this release changes things so that a markup line beginning with [@%define=@] and containing only wikistyle definitions will not initiate a new paragraph. !! Version 2.1.10 (2006-06-03) Version 2.1.4 introduced an [@{$Action}@] page variable that would contain the current [@?action=@] value. Unfortunately, this page variable conflicted with a pre-existing [@$Action@] global variable that was being used by skins to display a human-friendly form of the current action. Since there's not really a clean way to resolve this, I've decided to keep [@{$Action}@] as a page variable with the current action value (as introduced in 2.1.4), and change the global for skins to be $ActionTitle. This will require updating skins to use $ActionTitle instead of $Action. I apologize for the conflict. This release adds a Site.LocalTemplates page for the [@fmt=#xyz@] option in pagelist and search results. The list of pages to be searched can be customized via the $FPLTemplatePageFmt variable. The [@fmt=#xyz@] option will now also search the current page for a matching template before searching Site.LocalTemplates and Site.PageListTemplates. The 'pmwiki' skin now places a around the "Recent Changes" link in the header to make it somewhat easier to style. !! Version 2.1.9 (2006-06-02) This release fixes a long-standing and difficult-to-find bug with the handling of [@[[~Author]]@] links. !! Version 2.1.8 (2006-06-01) This release simply changes the $NotifyListFmt variable to be $NotifyListPageFmt (more descriptive), and adds a $NotifyList array that can be used to specify notification entries from a configuration file. !! Version 2.1.7 (2006-05-31) This release introduces a variety of improvements and bugfixes. '''Vspace paragraphs are now divs:''' Version 2.1.7 changes the way that PmWiki handles vertical space in output (the infamous [@@] for vertical space sequences. In addition, PmWiki is able to collapse the vspace
...
tags. * If an [@[[#anchor]]@] is used more than once in a page, only the first generates an actual anchor (to preserve XHTML validity). * There are now [@(:if equal ...:)@] and [@(:if exists pagename:)@] [[conditional markup]]s. * Compound conditional markup expressions are now possible -- e.g. [@(:if [ group PmWiki && ! name PmWiki ] :)@] . * Added an $InputValues array that can supply default values for certain form controls (PITS:00566). * The default setting of $UploadUrlFmt is now based on $PubDirUrl instead of $ScriptUrl. * The $text global variable has been removed (use $_GET['text'], $_POST['text'], or $_REQUEST['text']). * A possible problem with url-encoding of attachments with non-ASCII characters has been addressed (PITS:00588). * Page actions in non-existent pages no longer display with non-existent link decorations. * A README.txt file has been added, and several documentation files are now available through the docs/ directory. * PmWiki is no longer available through CVS on sourceforge.net. It is now available via SVN on pmwiki.org, at svn://pmwiki.org/pmwiki/tags/latest . For more details, see PmWiki:Subversion. * The $NewlineXXX variable (deprecated in 2.0.0) has been removed. * There is experimental support for server-side caching of pages that take a long time to render; this is currently an unsupported feature and may be removed in future releases. !! Version 2.0.13 (2005-11-10) This is a release containing minor bugfixes and improvements in preparation for the 2.1.beta series. %red%Wiki administrators should note that after this release PmWiki will default to having WikiWords disabled.\\ To make sure WikiWords are enabled, use [@$LinkWikiWords = 1;@] in the ''local/config.php'' file. !! Version 2.0.12 (19-Oct-2005) This release cleans up problems with page validation for page links containing query fragments and ampersands, changes PmWiki to use a PHP "return" statement instead of "exit", and fixes a warning in scripts/transition.php. !! Version 2.0.11 (17-Oct-2005) This release fixes a couple of important bugs and adds some new features to PmWiki. Most importantly, this release fixes bug with ?action=attr affecting the page history. For sites using LDAP authentication with authuser.php, PmWiki now provides $AuthLDAPBindDN and $AuthLDAPBindPassword variables to specify the binding to be used for searching. It also works around a PHP oddity that causes users to appear authenticated when an empty password is provided. Authuser.php also now handles straight md5 password encryptions (commonly used by `MySQL databases). The core now includes the [@(:linebreaks:)@] markup (from Cookbook:LineBreaks), which causes text on separate lines in the markup to appear as separate lines in the output (i.e., no auto-joining of one line to the previous one). There have been some internal changes designed to provide better support for leading-whitespace rules (more details on this in a future release). The core now provides an [@(:if date:)@] markup to display text only if the current day is within a range of supplied dates. !! Version 2.0.10 (29-Sep-2005)\\ Version 2.0.9 (28-Sep-2005) This release fixes an oversight in xlpage-utf-8.php that failed to uppercase ASCII letters when mb_strtoupper isn't present. !! Version 2.0.8 (27-Sep-2005) This release simply adds the capability to use quotes to enter pass phrases (passwords containing spaces) using ?action=attr, and fixes a bug with displaying the name instead of the title in the default print skin. !! Version 2.0.7 (26-Sep-2005) This version changes the xlpage-utf-8.php case conversion slightly to use a more direct conversion table, and completed the table for more characters in the utf-8 set. This release also fixes the $VersionNum variable that was supposed to appear in 2.0.6. An accesskey shortcut (ak_textedit) is being added to the edit form text area. Lastly, this release adds a timelimit to the generation of .linkindex, to avoid long page times when generating the .linkindex. !! Version 2.0.6 (16-Sep-2005) In this release, we provide quite a few more updates for sites that want or need to use utf-8 encoding, fix a large number of utf-8 related bugs, introduce better handling of author cookies, and better support for keeping track of version releases. The biggest change is to the xlpage-utf-8.php recipe, which has been substantially rewritten from the previous version. This new version of xlpage-utf-8.php no longer depends on the [[http://www.php.net/mb_strtoupper | mb_strtoupper()]] function, which seems to be not available in many PHP installations. The new version of xlpage-utf-8.php uses mb_strtoupper() if it's available, but if not available then it manually performs case conversions from a Unicode table that is directly encoded in the script. At present this table only understands case conversions for Western European (Latin-1 or ISO-8859-1) and Cyrillic characters, we'll want to expand the table to support other language character sets as needed. Just contact me on the listserv if a particular character isn't yet supported. In addition to the above, author names and cookies in utf-8 environments now work again, and link suffixes containing non-ASCII characters work again also. The GUI button handling in IE has been greatly improved; text selection in IE now works as you would expect it to work when a gui button is pressed. Possibly still no hope for Mac Safari browsers, unfortunately... A $CookiePrefix variable has been introduced; a wiki administrator can set $CookiePrefix to prevent PmWiki's cookies from interfering with cookies set from other applications under the same domain name. Some XHTML validation issues surrounding the use of