HTML/Ballot/Trusting version 0.2 ================================= A simple module for inseucre web ballots. This is a very beta version that will mature over the next week or so. Please let me know how it breaks. Features: * no test is made of who is voting, so users may vote any number of times, or may even vote (and surely will) thousands of times using a "LWP" hack. * a HTML page of voting options and one of the results of votes so far is generated from a single HTML template, and it is in these pages that ballot status is maintained, so no additional file access is required. * HTML output into the template is minimal, but all unique entities are given a "class" attribute for easy CSS re-definitions. * simple bar charts of results are generated using HTML. * users may submit a comment with thier vote, though no connection between the value of the vote and the user is recorded * users' IP addresses may be recorded, and displayed, and a chart of the IP addresses from which communication has been received the most may be displayed. In future these features may be added: * A more secure version is being considered, which uses simple e-mail authentication of users, sending ony one voting password to any e-mail address: this may appear as "HTML::Ballot::MoreCynical". * This may be extended to include a ballot `time out'. * Options to have graphs based on single-pixels, or using the "GD" interface will arrive some time in the future. USE 1. Construct an HTML template that can be used to generate the question and answer pages. Where you wish the questions and answers to appear, insert the following element: <TEMPLATEITEM name='QUESTIONS'></TEMPLATEITEM> The template should at least define the CSS representation for "votehighscorebar" and "votebar" as having a coloured background, or you will not be able to view the results' bar graph. See the CSS SPECIFICATION entry elsewhere in this document for more details on other CSS classes employed. Other functions may be included as below. Note that "TEMPLATEITEM"s may require some minimal content of at least a space character, I'm not sure, I'd better check. * If you wish to allow a user to submit a comment with their vote, include the following element: <TEMPLATEITEM name='COMMENT'> This is what voter's have said: </TEMPLATEITEM> Unlike the "QUESTIONS TEMPLATEITEM", any text you include in this block will be reatained at the top of a list of users' comments. * If you wish to have the result page display a list of the names entered by voters, also include: <TEMPLATEITEM name='VOTERLIST'> Here is the voterlist... </TEMPLATEITEM> This acts in the manner of the "COMMENT TEMPLATEITEM", above. * If you wish to have the result page display a list of the most frequently-posting IP addresses, include: <TEMPLATEITEM name='IPCHART'> <H2>Top IP Addresses To Post To This Ballot</H2> </TEMPLATEITEM> To this, the module will add a "SPAN" of HTML that lists the top posters. Anything before that span (in this example, the "H2" element) will remain. 2. Initiate the ballot by constructnig an HTML::Ballot::Trusting object and calling "create" method upon it in a manner simillar to that described in the SYNOPSIS entry elsewhere in this document. In response, you should receive a list of the locations of files used and dynamically created by the process. INSTALLATION To install this module, do the usual: perl Makefile.PL make - nmake on Win32 make test - etc make install Then please read the POD. DEPENDENCIES As well as the pragmas 'strict' and 'warnings', this module requires CGI.pm, HTML::EasyTemplate version 0.985 or higher, HTML::Entities. AUTHOR Lee Goddard - lgoddard@cpan.org COPYRIGHT AND LICENCE This module and all associated code is Copyright (C) Lee Goddard 2001. All rights reserved. This is free software and may be used under the same terms as Perl itself.