| v0.51 (2002.02.14): Valentine release 
 
For the upgrade path from v0.50, consult the Upgrade page.Added 'hideifdefault' for jdetails.wsql, allowing to hide records if they match a default value
Extended the session support. It now works without logging in, and more functions are available for manipulating the session data.
Fixed the logging of errors from EVAL blocks in the webserver log files (finally!).
Added a mechanism for execution of blocks of perl after a record has been added by the jAdd.wsql system. It works through a session variable called 'editpostexecute' that can be set. See the Apache::WeSQL::Journalled man page for more information.
Calls to jloginform.wsql without specifying a redirdest parameter will redirect to index.wsql in the same directory, instead of going haywire.
The default return destination (i.e. when editdest is not defined through the web call or in the .cf file) after a call to jupdate.wsql is now the HTTP_REFERER
Fixed a security problem where theoretically someone who 1. read the source and 2. was crafty with cookies could access pages without logging on... The problem was introduced in v0.50
Added a 'loggedin' sub in Auth.pl which returns 1 when a user is logged in and 0 when not.
jlogout.wsql will now correctly redirect to what is passed in the parameter 'redirdest', instead of to jloginform?redirdest=<valueofredirdest>
Put all html from jloginform.wsql in the layout.cf file where it belongs.
Added support for 'textarea' form elements in jform.wsql
Removed inconsistency where $key in the details.cf file (only!) would be translated to $data{key}. Use $data{key} there from now on, like in the other .cf files.
Extended syntax for select() form element in form.cf slightly: you can now put several selects, one after the other.
The decode() call in .cf files will now correctly decode instead of re-encode whatever is passed as its parameter.
Removed some debug output in the PARAMCHECK processing code, and fixed the PARAMCHECK example in the Apache::WeSQL man page.
Fixed the perpetual redirection bug (happened for browsers/spiders with cookies disabled).
  
 | 
| v0.50 (2001.12.06): 'Sinterklaas' release! 
This is a complete rewrite of WeSQL, with the following enhancements:
 
Note that this version breaks backwards compatibility quite a bit, but that was necessary to get rid of not-so-clever old syntax. Porting your application from an older version to v0.50 is not impossible but might cost some time. You will find that this version actually simplifies the use of the library a lot.WeSQL is now a standard Apache Perl module, that can be installed with the usual 'perl Makefile.PL && make && make test && su && make install'.
Extensive logging in web server logs.
All code has been moved to Perl modules, which results in greater performance and portability.
The three level structure (WeSQL.pm, yourmodule.pm, action.cgi) has been reduced to 2 perl modules in the Apache namespace: WeSQL.pm and AppHandler.pm, and a number of other modules for the rest of the functionality. Virtually all intelligence is now contained in WeSQL.pm and its helper modules. AppHandler is the only module that needs to be duplicated to run multiple WeSQL sites on one server. See the Apache::WeSQL man page for more information.
These modules can now also easily be used from ordinary perl programs, bringing the power of all the (journalled) database subs to your scripts!
A set of subs, available from EVAL blocks, is now available to read/write/delete values from the current session. See the Apache::WeSQL::Journalled man page for more information.
Much more complete documentation.
All documentation (except for this changelog) is available as man pages.
An RPM is available for Redhat users.
The code is much cleaner!
 | 
| v0.28.02 (2001.04.29): New features
 
 
BugfixesExtended edit.wsql and details.wsql to support parameter and table field replacing in the append block, just like list.wsqlsqlcondition field in the forms file, for use in the modify_journalled sub in yourapplication.pmThe header and footer files are now also fully treated as wsql filesA layout file is now supported that allows further layout definition for the output of list.wsql, edit.wsql, and details.wsql. This allows much more freedom than supported before through the header and footer files.New way of dealing with superusers and ordinary users, and giving them the right permissions. Superusers now 'cloak' as someone to change their settings and add records on their behalf. 
 
v0.28.01 (2001.02.20):(cosmetic) updates of the documentationFixed issue with fields containing single quotes in sub jUpdate in yourapplication.pmFixed bug in jDelete sub, where the cookies{id} value would be empty, effectively rendering this function useless...
Changed the EVAL block in list.wsql from PRE to POSTINSERT because we include it from details.wsql in the addressbook, and inserting PRE code after the PRE block has been executed results in all sorts of nasty behaviour...
Fixed the Edit-link in details.wsql, that was broken if the name of the view was different from the table nameFixed some serious bugs in edit.wsql that would give people access to records not owned by them... (missing $uidcond all over the place)Finally discovered the PostgreSQL equivalent of 'SHOW COLUMNS FROM', and fixed sub build_columnarray in yourapplication.pm once and for all (psql -E is very, very useful!)details.wsql now passes all extra paramaters passed to it when deleting a recordMade replace and relation work together properly in list.wsqlNow ignore form fields defined in the 'forms' file that refer to unexisting table columns, in edit.wsqljUpdate sub now works with PostgreSQLAdded correct word boundary check in list.wsql for the replace paramaterFile not found errors are now also logged in the apache error log New features
 
 
BugfixesAdded the suid field in the journalling code, which allows 'superusers'Extended the documentation (slightly) 
 
v0.28 (2001.02.02):Added further security checking on the COOKIES and PARAMETERS hashesUpdated the modify_journalling sub in yourapplication.pm: the pkey variable was entered in an sqlUpdate statement where it shouldn't be...
The jUpdate sub always dropped the last table elementMade sql-queries in LIST statements case-insensitive. Can't believe that one survived so long!!Fixed the return type of build_columnarray in yourapplication.pm when using PostgreSQL New features
 
 
BugfixesThe values from checkboxes with multiple values will now all be available in the $queryparams hash, as one pipe-separated value. Ideal for direct use in a RegExp...
There is a brand new sample-application, a completely working addressbook, built with one html page and some describing files, using the new edit.wsql, list.wsql and details.wsql files described belowedit.wsql, list.wsql and details.wsql are three WeSQL files that are smart enough to deal with most common database operations: add/modify, and listing/viewing of selections of records. These three files closely cooperate with some subs in the <application>.pm file, and expect a 'journalled' database. They don't ever actually remove records from the database, they just disable them by setting the status to zero. See the documentation for more information.
 
 
v0.28b15 (2000.10.18):The CUTFILE tag will now only be matched when found just after a \n (newline), and followed immediately by one. This facilitates generating the tag from blocks of Perl.Fixed a tricky bug in PARAMCHECK. Parameters with value '0' were changed to '' for the PARAMCHECK.Important security fix, disallow passing of WeSQL commands through parameters! UPGRADE to v0.28 or above NOW!! (Thanks to Kristof Verniers for discovering this one!)Logging in Apache logs of fatal errors in EVAL blocksnewapp.pl: fixed some errors in the generation of the recommended http configuration file New features
 
 
BugfixesAdded the INCLUDE tag, which allows inclusion of one WeSQL file in another one. Of course, you want to pass a different set of parameters to this included WeSQL file. Well, you can - just use a prefix :-) 
 
v0.27 (2000.08.09):Errors from the EVAL statements will now be properly logged in the Apache logs.Reviewed sqlInsert2 sub, temporarily fixed a serious problem with comma's that could cause MySQL to choke. This solution is temporary, the sqlInsert2 sub needs serious reviewing.Fixed possible 'fetch() without execute()' bugs in the logs, result of doing non-select queries in LIST statements,
or rather, of trying to retrieve results from these queries.Using a LIST for anything else than a select might seem silly at first, but doing an update query that way can surely be handy :-)Fixed a few problems with the sqlDisconnect sub in yourapplication.pmFixed nasty bug in PARAMCHECK tag (regexp matching was not doing the right thing)The build_columnlist sub, used by the generic add, delete and modify subs, did not work properly on empty tables. 
Rewrote it to work with empty tables under both MySQL and PostgreSQL.Clarified the situation with the alternative values for parameters and other substituted fields. 
The syntax is now as follows: PR_TEST|[ALTERNATIVE VALUE]. 'ALTERNATIVE VALUE' can now contain any characters (including whitespace), 
if you want to use a right bracket (]), escape it with a backslash. New features
 
 
BugfixesThe PARAMCHECK tag has been added. PARAMCHECK allows checking parameters against certain conditions.
The CUTFILE tag has been added. When the CUTFILE tag is encountered, the rest of the html file will not be shown.
 
 
v0.26 (2000.06.10):Some small fixes in newapp.plFixed substitution. There was a stupid bug - if something like "PR_XXX" was not matched, the html would be mangled up.Fixed issues with escaping single and double quotes in the %queryparams hash. WeSQL now escape both single and double quotes, 
and not only on the first line of the parameter in the %queryparam hash, like it was before. The things some real-life testing
can bring up... New features
 
 
BugfixesSupport for PostgreSQL has been added, and newapp.pl has been updated to reflect the changes. It will now
ask you whether you have a PostgreSQL or MySQL database.
AutoCommit is by default off for PostgreSQL, which means that you can decide to commit or rollback yourself 
if you use the $dbh database handler directly (which, of course, has been possible from the very first version of WeSQL). 
MySQL does not support transactions, so when you use MySQL this is irrelevant.
The parsing of files is now modularised. You can decide which actions should be done on a file, and in what order. 
In addition, you can insert a function of your own at any point in the chain - the only requirement is that you return the processed text, 
and that you define your function in your package.pm file, so that it can be referenced to from the WeSQL.pm module. 
See the documentation for more information. 
As a side effect, the 'MAGIC' string introduced in an earlier version has been dropped.
Improved error handling: no more 'internal server error' messages when the underlying dababase server is not available.
 
 
NULL values in the database will now return the string 'NULL' after substitution in the LIST statement. 
Any 'A_XXX'-like statement in a LIST block, where XXX is not a defined column name, will remain unchanged. 
Older versions of WeSQL would eat the 'A_' bit, and leave only the 'XXX' bit.
Now newapp.pl will ask if you want to recreate the database that you want to access with your new application. 
In previous versions it just dropped and recreated that database. (Ouch!)
The suggested addition to the httpd.conf file does not contain a DocumentRoot anymore. It was not necessary, 
and dropping it means that when something goes wrong, there will be _no_ access to your source html files.
sampleapp's searchsomething.html had links to the wrong page (modify instead of modifyform) :-(
Fixed several stupid bugs in newapp.pl that would mess things up unless you chose root/test as the credentials
for your database access. :-((((
 | 
| v0.25 (2000.05.25): New features
 
 
BugfixesA new tool, 'newapp.pl', has been added, to fully automate starting a new application with WeSQL. This greatly facilitates the WeSQL installation procedure.
Support for cookies has been added. Cookies are now accessible in action.cgi and the *EVAL blocks through the hash %cookies, and in the html files through COOKIE_(uppercase cookie name). 
They can be set via HTML, with a statement like this in the header:
 <META http-equiv=\"Set-Cookie\" content=\"the=cure;expires=Friday, 31-Dec-01 23:59:59 GMT; path=/\">.
Added the sub genericQuery to WeSQL.pm, with which any statement that can be understood by the underlying database can be executed. Results are returned via an object. genericQuery can be used like sqlSelectMany.
The generic add, modify and del subs that used to reside in action.cgi have been moved to sampleapp.pm.
In addition, they have become more generic - they will now ignore any form field with a name that is not
a column name in the table. Keep in mind that the form fields with name 'table' and 'redirdest' still have
a special meaning!
 
 
Single quotes are now also a separator for PR_XXX and COOKIE_XXX placeholders. 
Hence, something like "Hello, this is 'PR_ME|Ward' speaking" would be correctly translated to either "Hello, this is 'Ward' speaking" if the parameter 'me' was not set - in older versions, the last single quote would mysteriously disappear.
 
v0.24 (2000.05.23):New features
 
 
v0.23 (2000.05.20):Implemented support for MAGIC string to allow switching off the PREEVAL, PR_, EVAL, LIST and POSTEVAL
parsing for each html file seperately. This can improve performance greatly in case of huge html-files, and
can be quite useful for debugging purposes.
 New features
 
 
v0.22 (2000.05.19):
Added PREEVAL, EVAL, and POSTEVAL tags that allow insertion of perl 
into the html files. Start building those queries dynamically!
 Bugfixes
 
 
v0.21 (2000.05.12):
Allow the use of < and > in queries
 Bugfixes
 
 
Column names are now case-insensitive when using sub sqlSelectMany2
 |