2012-03-23 16:58:05 +00:00
|
|
|
Web App Structure {#appstructure}
|
|
|
|
=================
|
|
|
|
|
2012-04-02 16:09:22 +01:00
|
|
|
The framework assumes that a number of files and directories are present in
|
2012-03-23 16:58:05 +00:00
|
|
|
order to work correctly. Note that you can easily change these if you handle
|
|
|
|
the initialisation of the various modules in the framework yourself, but if
|
|
|
|
you use the Application module to handle all the setup for you, you must
|
|
|
|
follow the structure given in this documentation.
|
|
|
|
|
2012-04-02 16:09:22 +01:00
|
|
|
Generally, .htaccess files are used to keep users out of many directories,
|
|
|
|
but if you are concerned about any of the files being present in the web tree,
|
|
|
|
you can move them out into non-web-accessible locations as long as you
|
|
|
|
specify appropriate paths in the configuration and when creating an
|
|
|
|
Application object.
|
|
|
|
|
2012-03-23 16:58:05 +00:00
|
|
|
Structure overview
|
|
|
|
------------------
|
|
|
|
|
|
|
|
This diagram shows a typical web application's directory hierarchy. Notes
|
|
|
|
follow the diagram
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/54a9d/54a9dd840d298b3c61e2d088ef1f8a6e751ddd76" alt="directory structure"
|
|
|
|
|
|
|
|
<dl><dt>blocks</dt>
|
2012-03-26 17:51:41 +01:00
|
|
|
<dd>Contains subclasses of Block that implement the actual functionality of
|
2012-03-23 16:58:05 +00:00
|
|
|
your web application. Further subdirectories may be present, if more complex
|
|
|
|
class hierarchies are needed. See the @ref blocks "Blocks" information for more details.</dd>
|
|
|
|
</dl>
|
|
|
|
|
|
|
|
<dl><dt>config</dt>
|
2012-03-26 17:51:41 +01:00
|
|
|
<dd>Contains the global site.cfg file, protected by .htaccess. You can easily
|
2012-03-23 16:58:05 +00:00
|
|
|
place the configuration file outside the web tree if you want, by using the
|
|
|
|
`config` argument to Application::new(). See the @ref config "Configuration" information for
|
|
|
|
more about the config file, and how configuration information is stored and
|
|
|
|
passed to your Block implementations.</dd>
|
|
|
|
</dl>
|
|
|
|
|
|
|
|
<dl><dt>index.cgi</dt>
|
|
|
|
<dd>The front-end script for the application (or, potentially, one of them).
|
|
|
|
If you are using the Application class to handle all the framework setup for
|
|
|
|
you, this will usually contain very little code indeed - potentially only
|
|
|
|
the 6 lines shown in the Application documentation!</dd>
|
|
|
|
</dl>
|
|
|
|
|
|
|
|
<dl><dt>lang</dt>
|
2012-03-26 17:51:41 +01:00
|
|
|
<dd>Contains subdirectories containing language files. Each subdirectory should be
|
|
|
|
a language name, and can contain any number of files that define the language
|
|
|
|
variables for the template engine. If langauge file handling is disabled in the
|
|
|
|
template engine, this directory can be omitted.</dd>
|
|
|
|
</dl>
|
|
|
|
|
|
|
|
<dl><dt>modules</dt>
|
|
|
|
<dd>If you have any application-specific non-Block modules, you may wish to
|
|
|
|
add them to a separate directory tree for clarity (remember to add `use lib qw(modules)`
|
|
|
|
to the index.cgi file if you do this). The modules directory can contain any
|
|
|
|
modules you need, and by calling Modules::add_load_path() you can even use the
|
|
|
|
dynamic module loading facility to load modules from this directory too.</dd>
|
|
|
|
</dl>
|
|
|
|
|
|
|
|
<dl><dt>templates</dt>
|
|
|
|
<dd>The templates directory contains the templates for the application, each
|
|
|
|
set of templates is arranged in its own theme directory - you will generally
|
|
|
|
need to provide at least the 'default' template directory.</dd>
|
2012-03-23 16:58:05 +00:00
|
|
|
</dl>
|
2012-04-16 23:15:00 +01:00
|
|
|
|
|
|
|
A copy of this structure may be found in the `supportfiles/webapp` directory.
|