NAME
CGI::Portable::AppStatic - Define whole response screens within a config file.
DEPENDENCIES
Perl Version
5.004
Standard Modules
I<none>
Nonstandard Modules
CGI::Portable 0.45
SYNOPSIS
This documentation will come in a subsequent version.
DESCRIPTION
This Perl 5 object class is a simple encapsulated application, or "component", that runs in the CGI::Portable environment. It allows you to define a complete static "program response screen" within the standard "preferences" config file without having to write your own "application" to do it. Or, to be specific, this module allows you to set any CGI::Portable::Response properties by providing a like-named "preference" with each new value, rather than having to explicitely call each appropriate accessor method. This module is designed to be easily subclassed by your own application components, so they can do the same things while you only need to program the interesting dynamic functionality. An example scenario has users of your subclassed application using AppStatic methods to apply a common header or footer or stylesheet to every screen.
SYNTAX
This class does not export any functions or methods, so you need to call them using object notation. This means using Class->function() for functions and $object->method() for methods. If you are inheriting this class for your own modules, then that often means something like $self->method().
This class does not have any of its own stored properties, so there is no risk of property namespace collisions with subclasses. Instead, you must provide the CGI::Portable object to each method explicitely as its first argument.
THE ONLY PUBLIC METHOD
main( GLOBALS )
You invoke this method to run the application component that is encapsulated by this class. The required argument GLOBALS is an CGI::Portable object that you have previously configured to hold the instance settings and user input for this class. When this method returns then the encapsulated application will have finished and you can get its user output from the CGI::Portable object.
This method is simple and intended to be overriden by subclasses. All it does by itself is invoke the private methods listed under PRIVATE METHODS FOR USE BY SUBCLASSES, which do the actual work.
PREFERENCES HANDLED BY THIS MODULE
These preferences have names that are the same as the CGI::Portable::Response properties that their values are being used to set, except that each has a prefix indicating how the value is set. The prefixes used include any of the following, where they make sense for each property: "low", "high", "add", "append", "prepend". Preferences are used only if they have a defined value.
The first two prefixes are valid with all scalar and list properties; "low" priority values are applied as early as possible, and will be lost if the subclassed application decides to set the same properties; "high" priority values are assigned after the "main program" does its work, and will overwrite any same properties that the "main program" sets.
The latter three prefixes only make sense with non-scalar or "list" properties where each property can store multiple values; they are all applied as late as possible, and try to preserve existing property values while adding their own. The "append" and "prepend" prefixes are only used where the order of the property elements is important, such as in the "page body". The "add" prefix is only used where the order is not preserved, such as with the "page meta" tags.
This module assumes that the CGI::Portable object passed to it did not have any of its output properties set prior to main() being called, so even the "low" priority preferences will overwrite any pre-existing same properties. To avoid unpleasantries it is a good idea for calling modules to apply all of their own output after called modules have finished, or to employ make_new_context() and related functionality.
These preferences are for generic HTTP responses:
low_http_status_code - string
low_http_window_target - string
low_http_content_type - string
low_http_redirect_url - string
low_http_cookies - array of encoded cookie strings
low_http_headers - hash of header names and values
low_http_body - string
low_http_body_is_binary - boolean
high_http_status_code - string
high_http_window_target - string
high_http_content_type - string
high_http_redirect_url - string
high_http_cookies - array of encoded cookie strings
high_http_headers - hash of header names and values
high_http_body - string
high_http_body_is_binary - boolean
add_http_cookies - array of encoded cookie strings
add_http_headers - hash of header names and values
These preferences are specifically for HTML pages:
low_page_title - string
low_page_author - string
low_page_meta - hash of meta-tag names and values
low_page_style_sources - array of strings (urls)
low_page_style_code - array of strings (raw code)
low_page_head - array
low_page_frameset_attributes - hash
low_page_frameset - array of hashes (each hash is attributes for new FRAME tag)
low_page_body_attributes - hash
low_page_body - array
high_page_title - string
high_page_author - string
high_page_meta - hash of meta-tag names and values
high_page_style_sources - array of strings (urls)
high_page_style_code - array of strings (raw code)
high_page_head - array
high_page_frameset_attributes - hash
high_page_frameset - array of hashes (each hash is attributes for new FRAME tag)
high_page_body_attributes - hash
high_page_body - array
add_page_meta - hash of meta-tag names and values
add_page_style_sources - array of strings (urls)
add_page_style_code - array of strings (raw code)
add_page_frameset_attributes - hash
add_page_body_attributes - hash
prepend_page_head - array
prepend_page_frameset - array of hashes (each hash is attributes for new FRAME tag)
prepend_page_body - array
append_page_head - array
append_page_frameset - array of hashes (each hash is attributes for new FRAME tag)
append_page_body - array
These preferences are miscellaneous:
page_replace - hash of tokens to search for and what to replace them with
- this preference is passed to search_and_replace_page_body() after
all of the other properties have been set.
- this preference is deprecated and exists for backwards compatability
with CGI-WPM-Base since no elegant substitute exists yet.
PRIVATE METHODS FOR USE BY SUBCLASSES
set_static_low_replace( GLOBALS )
This method will apply all of the "low" priority preferences, which replace any respective properties.
set_static_high_replace( GLOBALS )
This method will apply all of the "high" priority preferences, which replace any respective properties.
set_static_attach_unordered( GLOBALS )
This method will apply all of the "add" preferences, which try to add values to any respective properties without deleting previous values. Previous values are only deleted where the properties are hashes and new hash keys are the same as existing ones; different keys do not conflict.
set_static_attach_ordered( GLOBALS )
This method will apply all of the "append" and "prepend" preferences, which will always add to their respective properties without deleting previous values.
set_static_miscellaneous( GLOBALS )
This method will apply all of the miscellaneous preferences, which are currently deprecated but exist because no elegant replacements exist yet. These properties are applied after all others mentioned above. Specifically, this method implements the "page_replace" preference only.
AUTHOR
Copyright (c) 1999-2001, Darren R. Duncan. All rights reserved. This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself. However, I do request that this copyright information remain attached to the file. If you modify this module and redistribute a changed version then please attach a note listing the modifications.
I am always interested in knowing how my work helps others, so if you put this module to use in any of your own code then please send me the URL. Also, if you make modifications to the module because it doesn't work the way you need, please send me a copy so that I can roll desirable changes into the main release.
Address comments, suggestions, and bug reports to perl@DarrenDuncan.net.
SEE ALSO
perl(1), CGI::Portable, CGI::Portable::Response, CGI::Portable::Files.