| rev | line source | 
| jbe/bsw@0 | 1 <html> | 
| jbe/bsw@0 | 2   <head> | 
| jbe/bsw@0 | 3     <style> | 
| jbe/bsw@0 | 4       body { | 
| jbe/bsw@0 | 5         font-family: "Liberation Sans", sans-serif; | 
| jbe/bsw@0 | 6         font-size: 11pt; | 
| jbe/bsw@0 | 7         padding-bottom: 5ex; | 
| jbe/bsw@0 | 8       } | 
| jbe/bsw@0 | 9       .warning { | 
| jbe/bsw@0 | 10         color: #ff0000; | 
| jbe/bsw@0 | 11       } | 
| jbe/bsw@0 | 12       h1, h2 { | 
| jbe/bsw@0 | 13         font-family: "Liberation Serif", Georgia, serif; | 
| jbe/bsw@0 | 14       } | 
| jbe/bsw@0 | 15       h2 { | 
| jbe/bsw@0 | 16         margin-bottom: 0.3ex; | 
| jbe/bsw@0 | 17       } | 
| jbe/bsw@0 | 18       p { | 
| jbe/bsw@0 | 19         margin: 0px; | 
| jbe/bsw@0 | 20         line-height: 130%; | 
| jbe/bsw@0 | 21       } | 
| jbe/bsw@0 | 22       tt, pre { | 
| jbe/bsw@0 | 23         font-size: 10pt; | 
| jbe/bsw@0 | 24       } | 
| jbe/bsw@0 | 25       tt { | 
| jbe/bsw@0 | 26         font-weight: bold; | 
| jbe/bsw@0 | 27         white-space: nowrap; | 
| jbe/bsw@0 | 28       } | 
| jbe/bsw@0 | 29       .autodoc_entry { | 
| jbe/bsw@0 | 30         margin-top: 1ex; | 
| jbe/bsw@0 | 31         margin-bottom: 1ex; | 
| jbe/bsw@0 | 32        } | 
| jbe/bsw@0 | 33       .autodoc_comment_tail { | 
| jbe/bsw@0 | 34         font-style: italic; | 
| jbe/bsw@0 | 35       } | 
| jbe/bsw@0 | 36       .autodoc_entry .short_synopsis { | 
| jbe/bsw@0 | 37         cursor: pointer; | 
| jbe/bsw@0 | 38       } | 
| jbe/bsw@0 | 39       .autodoc_details { | 
| jbe/bsw@0 | 40         padding-left: 1em; | 
| jbe/bsw@0 | 41         padding-right: 1em; | 
| jbe/bsw@0 | 42         border: 1px solid #777; | 
| jbe/bsw@0 | 43       } | 
| jbe/bsw@0 | 44       .autodoc_synopsis { | 
| jbe/bsw@0 | 45         font-weight: bold; | 
| jbe/bsw@0 | 46       } | 
| jbe/bsw@0 | 47       .autodoc_synopsis .autodoc_comment_tail { | 
| jbe/bsw@0 | 48         font-weight: normal; | 
| jbe/bsw@0 | 49         color: #008000; | 
| jbe/bsw@0 | 50       } | 
| jbe/bsw@0 | 51       .autodoc_entry .autodoc_comment { | 
| jbe/bsw@0 | 52         color: #400080; | 
| jbe/bsw@0 | 53       } | 
| jbe/bsw@0 | 54       .autodoc_source { | 
| jbe/bsw@0 | 55         color: #505050; | 
| jbe/bsw@0 | 56       } | 
| jbe/bsw@0 | 57     </style> | 
| jbe@23 | 58     <title>WebMCP 1.1.1 Documentation</title> | 
| jbe/bsw@0 | 59   </head> | 
| jbe/bsw@0 | 60   <body> | 
| jbe@23 | 61     <h1>WebMCP 1.1.1 Documentation</h1> | 
| jbe/bsw@0 | 62     <p> | 
| jbe/bsw@0 | 63       WebMCP is a completely new web development framework, and has not been extensively tested yet. The API might change at any time, but in future releases there will be a list of all changes, which break downward compatibility. | 
| jbe/bsw@0 | 64     </p> | 
| jbe/bsw@0 | 65     <h2>Requirements</h2> | 
| jbe/bsw@0 | 66     <p> | 
| jbe/bsw@0 | 67       WebMCP has been developed on Linux and FreeBSD. Using it with Mac OS X is completely untested; Microsoft Windows is not supported. Beside the operating system, the only mandatory dependencies for WebMCP are the programming language <a href="http://www.lua.org/">Lua</a> version 5.1, <a href="http://www.postgresql.org/">PostgreSQL</a> version 8.2 or higher, a C compiler, and a Webserver like Lighttpd or Apache. | 
| jbe/bsw@0 | 68     </p> | 
| jbe/bsw@0 | 69     <h2>Installation</h2> | 
| jbe/bsw@0 | 70     <p> | 
| jbe/bsw@0 | 71       After downloading the tar.gz package, unpack it, enter the unpacked directory and type <tt>make</tt>. If you use Mac OS X or if you experience problems during compilation, you need to edit the <tt>Makefile.options</tt> file prior to compilation. The framework itself will be available in the <tt>framework/</tt> directory, while a demo application is available in the <tt>demo-app/</tt> directory. The <tt>framework.precompiled/</tt> and <tt>demo-app.precompiled/</tt> directories will contain a version with all Lua files being byte-code pre-compiled, which can be used instead. You may copy these directories (with <tt>cp -L</tt> to follow links) to any other place you like. Use the files <tt>doc/lighttpd.sample.conf</tt> or <tt>doc/apache.sample.conf</tt> to setup your webserver appropriatly. Don't forget to setup a database, and make the <tt>tmp/</tt> directory of the application writable for the web server process. Good luck and have fun! | 
| jbe/bsw@0 | 72     </p> | 
| jbe/bsw@0 | 73     <h2>Using the atom library</h2> | 
| jbe/bsw@0 | 74     <p> | 
| jbe/bsw@0 | 75       Lua itself has only very few built-in data types. The atom library gives support for extra data types. Currently the following extra data types are provided: | 
| jbe/bsw@0 | 76     </p> | 
| jbe/bsw@0 | 77     <ul> | 
| jbe/bsw@0 | 78       <li>atom.fraction</li> | 
| jbe/bsw@0 | 79       <li>atom.date</li> | 
| jbe/bsw@0 | 80       <li>atom.time</li> | 
| jbe/bsw@0 | 81       <li>atom.timestamp (date and time combined in one data type)</li> | 
| jbe/bsw@0 | 82     </ul> | 
| jbe/bsw@0 | 83     <p> | 
| jbe/bsw@0 | 84       In addition the following pseudo-types are existent, corresponding to Lua's base types: | 
| jbe/bsw@0 | 85     </p> | 
| jbe/bsw@0 | 86     <ul> | 
| jbe/bsw@0 | 87       <li>atom.boolean</li> | 
| jbe/bsw@0 | 88       <li>atom.string</li> | 
| jbe/bsw@0 | 89       <li>atom.integer</li> | 
| jbe/bsw@0 | 90       <li>atom.number</li> | 
| jbe/bsw@0 | 91     </ul> | 
| jbe/bsw@0 | 92     <p> | 
| jbe/bsw@0 | 93       Both atom.integer and atom.number refer to Lua's base type “number”. | 
| jbe/bsw@0 | 94     </p> | 
| jbe/bsw@0 | 95     <p> | 
| jbe/bsw@0 | 96       New values of atom data types are created by either calling <tt>atom.<i>type</i>:load(string_representation)</tt> or by calling <tt>atom.<i>type</i>{...}</tt>, e.g. <tt>atom.date{year=1970, month=1, day=1}</tt>. You can dump any atom value as a string by calling <tt>atom.dump(value)</tt> and later reload it with <tt>atom.<i>type</i>:load(string)</tt>. | 
| jbe/bsw@0 | 97     </p> | 
| jbe/bsw@0 | 98     <h2>Using the Object-Relational Mapper “mondelefant”</h2> | 
| jbe/bsw@0 | 99     <p> | 
| jbe/bsw@0 | 100       The library “mondelefant” shipping with WebMCP can be used to access PostgreSQL databases. It also serves as an Object-Relational Mapper (ORM). Opening a connection to a database is usually done in a config file in the following way: | 
| jbe/bsw@0 | 101     </p> | 
| jbe/bsw@0 | 102     <pre> | 
| jbe/bsw@0 | 103 db = assert( mondelefant.connect{ engine='postgresql', dbname='webmcp_demo' } ) | 
| jbe/bsw@0 | 104 at_exit(function() | 
| jbe/bsw@0 | 105   db:close() | 
| jbe/bsw@0 | 106 end) | 
| jbe/bsw@0 | 107 function mondelefant.class_prototype:get_db_conn() return db end | 
| jbe/bsw@0 | 108 | 
| jbe/bsw@0 | 109 function db:sql_tracer(command) | 
| jbe/bsw@0 | 110   return function(error_info) | 
| jbe/bsw@0 | 111     local error_info = error_info or {} | 
| jbe/bsw@0 | 112     trace.sql{ command = command, error_position = error_info.position } | 
| jbe/bsw@0 | 113   end | 
| jbe/bsw@0 | 114 end</pre> | 
| jbe/bsw@0 | 115     <p> | 
| jbe/bsw@0 | 116       Overwriting the <tt>sql_tracer</tt> method of the database handle is optional, but helpful for debugging. The parameters for <tt>mondelefant.connect</tt> are directly passed to PostgreSQL's client library libpq. See <a href="http://www.postgresql.org/docs/8.4/interactive/libpq-connect.html">PostgreSQL's documentation on PQconnect</a> for information about supported parameters. | 
| jbe/bsw@0 | 117     </p> | 
| jbe/bsw@0 | 118     <p> | 
| jbe/bsw@0 | 119       To define a model to be used within a WebMCP application, create a file named with the name of the model and <tt>.lua</tt> as extension in the <tt>model/</tt> directory of your application. The most basic definition of a model (named “movie” in this example) is: | 
| jbe/bsw@0 | 120     </p> | 
| jbe/bsw@0 | 121     <pre> | 
| jbe/bsw@0 | 122 Movie = mondelefant.new_class() | 
| jbe/bsw@0 | 123 Movie.table = 'movie'</pre> | 
| jbe/bsw@0 | 124     <p> | 
| jbe/bsw@0 | 125       Note: Model classes are always written CamelCase, while the name of the file in <tt>model/</tt> is written lower_case. | 
| jbe/bsw@0 | 126     </p> | 
| jbe/bsw@0 | 127     <p> | 
| jbe/bsw@0 | 128       To select objects from the database, the mondelefant library provides a selector framework: | 
| jbe/bsw@0 | 129     </p> | 
| jbe/bsw@0 | 130     <pre> | 
| jbe/bsw@0 | 131 local s = Movie:new_selector() | 
| jbe/bsw@0 | 132 s:add_where{ 'id = ?', param.get_id() } | 
| jbe/bsw@0 | 133 s:single_object_mode()  -- return single object instead of list | 
| jbe/bsw@0 | 134 local movie = s:exec()</pre> | 
| jbe/bsw@0 | 135     <p> | 
| jbe/bsw@0 | 136       A short form of the above query would be: | 
| jbe/bsw@0 | 137     </p> | 
| jbe/bsw@0 | 138     <pre> | 
| jbe/bsw@0 | 139 local movie = Movie:new_selector():add_where{ 'id = ?', param.get_id() }:single_object_mode():exec()</pre> | 
| jbe/bsw@0 | 140     <p> | 
| jbe/bsw@0 | 141       For more examples about how to use the model system, please take a look at the demo application. | 
| jbe/bsw@0 | 142     </p> | 
| jbe/bsw@0 | 143     <h2>The Model-View-Action (MVA) concept</h2> | 
| jbe/bsw@0 | 144     <p> | 
| jbe/bsw@0 | 145       As opposed to other web application frameworks, WebMCP does not use a Model-View-Controller (MVC) concept, but a Model-View-Action (MVA) concept. | 
| jbe/bsw@0 | 146     </p> | 
| jbe/bsw@0 | 147     <h3>Models</h3> | 
| jbe/bsw@0 | 148     <p> | 
| jbe/bsw@0 | 149       The models in MVA are like the models in MVC; they are used to access data stored in a relational database (PostgreSQL) in an object oriented way. They can also be used to provide methods for working with objects representing the database entries. | 
| jbe/bsw@0 | 150     </p> | 
| jbe/bsw@0 | 151     <h3>Views</h3> | 
| jbe/bsw@0 | 152     <p> | 
| jbe/bsw@0 | 153       The views in the MVA concept are different from the views in the MVC concept. As WebMCP has no controllers, the views are responsible for processing the GET/POST parameters from the webbrowser, fetching the data to be displayed, and creating the output by directly writing HTML to slots in a layout or by calling helper functions for the user interface. | 
| jbe/bsw@0 | 154     </p> | 
| jbe/bsw@0 | 155     <h3>Actions</h3> | 
| jbe/bsw@0 | 156     <p> | 
| jbe/bsw@0 | 157       Actions are similar to views, but supposed to change data in the database, hence only callable by HTTP POST requests. They are also responsible for processing the POST parameters from the webbrowser. They can modify the database, but instead of rendering a page to be displayed, they just return a status code. Depending on the status code there will be an internal forward or an HTTP 303 redirect to a view. When calling an action via a POST request, additional POST parameters, which are usually added by hidden form fields, determine the view to be displayed for each status code returned by the action. | 
| jbe/bsw@0 | 158     </p> | 
| jbe/bsw@0 | 159     <h2>Directory structure of a WebMCP application</h2> | 
| jbe/bsw@0 | 160     <ul> | 
| jbe/bsw@0 | 161       <li> | 
| jbe/bsw@0 | 162         Base Directory | 
| jbe/bsw@0 | 163         <ul> | 
| jbe/bsw@0 | 164           <li> | 
| jbe/bsw@0 | 165             <tt>app/</tt> | 
| jbe/bsw@0 | 166             <ul> | 
| jbe/bsw@0 | 167               <li> | 
| jbe/bsw@0 | 168                 <tt>main/</tt> | 
| jbe/bsw@0 | 169                 <ul> | 
| jbe/bsw@0 | 170                   <li> | 
| jbe/bsw@0 | 171                     <tt>_filter/</tt> | 
| jbe/bsw@0 | 172                     <ul> | 
| jbe/bsw@0 | 173                       <li> | 
| jbe/bsw@0 | 174                         <tt>10_first_filter.lua</tt> | 
| jbe/bsw@0 | 175                       <li> | 
| jbe/bsw@0 | 176                       </li> | 
| jbe/bsw@0 | 177                         <tt>30_third_filter.lua</tt> | 
| jbe/bsw@0 | 178                       </li> | 
| jbe/bsw@0 | 179                       <li>…</li> | 
| jbe/bsw@0 | 180                     </ul> | 
| jbe/bsw@0 | 181                   </li> | 
| jbe/bsw@0 | 182                   <li> | 
| jbe/bsw@0 | 183                     <tt>_filter_action/</tt> | 
| jbe/bsw@0 | 184                     <ul> | 
| jbe/bsw@0 | 185                       <li> | 
| jbe/bsw@0 | 186                         <tt>20_second_filter.lua</tt> | 
| jbe/bsw@0 | 187                       </li> | 
| jbe/bsw@0 | 188                       <li>…</li> | 
| jbe/bsw@0 | 189                     </ul> | 
| jbe/bsw@0 | 190                   </li> | 
| jbe/bsw@0 | 191                   <li> | 
| jbe/bsw@0 | 192                     <tt>_filter_view/</tt> | 
| jbe/bsw@0 | 193                     <ul> | 
| jbe/bsw@0 | 194                       <li>…</li> | 
| jbe/bsw@0 | 195                     </ul> | 
| jbe/bsw@0 | 196                   </li> | 
| jbe/bsw@0 | 197                   <li> | 
| jbe/bsw@0 | 198                     <tt>_layout/</tt> | 
| jbe/bsw@0 | 199                     <ul> | 
| jbe/bsw@0 | 200                       <li>…</li> | 
| jbe/bsw@0 | 201                     </ul> | 
| jbe/bsw@0 | 202                   </li> | 
| jbe/bsw@0 | 203                   <li> | 
| jbe/bsw@0 | 204                     <tt>index/</tt> | 
| jbe/bsw@0 | 205                     <ul> | 
| jbe/bsw@0 | 206                       <li> | 
| jbe/bsw@0 | 207                         <tt>_action/</tt> | 
| jbe/bsw@0 | 208                         <ul> | 
| jbe/bsw@0 | 209                           <li> | 
| jbe/bsw@0 | 210                             <i>action_name</i><tt>.lua</tt> | 
| jbe/bsw@0 | 211                           </li> | 
| jbe/bsw@0 | 212                           <li> | 
| jbe/bsw@0 | 213                             <i>another_action_name</i><tt>.lua</tt> | 
| jbe/bsw@0 | 214                           </li> | 
| jbe/bsw@0 | 215                           <li>…</li> | 
| jbe/bsw@0 | 216                         </ul> | 
| jbe/bsw@0 | 217                       </li> | 
| jbe/bsw@0 | 218                       <li> | 
| jbe/bsw@0 | 219                         <tt>index.lua</tt> | 
| jbe/bsw@0 | 220                       </li> | 
| jbe/bsw@0 | 221                       <li> | 
| jbe/bsw@0 | 222                         <i>other_view_name</i><tt>.lua</tt> | 
| jbe/bsw@0 | 223                       </li> | 
| jbe/bsw@0 | 224                       <li>…</li> | 
| jbe/bsw@0 | 225                     </ul> | 
| jbe/bsw@0 | 226                   </li> | 
| jbe/bsw@0 | 227                   <li> | 
| jbe/bsw@0 | 228                     <i>other_module_name</i><tt>/</tt> | 
| jbe/bsw@0 | 229                     <ul> | 
| jbe/bsw@0 | 230                       <li>…</li> | 
| jbe/bsw@0 | 231                     </ul> | 
| jbe/bsw@0 | 232                   </li> | 
| jbe/bsw@0 | 233                 </ul> | 
| jbe/bsw@0 | 234               </li> | 
| jbe/bsw@0 | 235               <li> | 
| jbe/bsw@0 | 236                 <i>other_application_name</i><tt>/</tt> | 
| jbe/bsw@0 | 237                 <ul> | 
| jbe/bsw@0 | 238                   <li>…</li> | 
| jbe/bsw@0 | 239                 </ul> | 
| jbe/bsw@0 | 240               </li> | 
| jbe/bsw@0 | 241             </ul> | 
| jbe/bsw@0 | 242           </li> | 
| jbe/bsw@0 | 243           <li> | 
| jbe/bsw@0 | 244             <tt>config/</tt> | 
| jbe/bsw@0 | 245             <ul> | 
| jbe/bsw@0 | 246               <li> | 
| jbe/bsw@0 | 247                 <tt>development.lua</tt> | 
| jbe/bsw@0 | 248               </li> | 
| jbe/bsw@0 | 249               <li> | 
| jbe/bsw@0 | 250                 <tt>production.lua</tt> | 
| jbe/bsw@0 | 251               <li> | 
| jbe/bsw@0 | 252               <li> | 
| jbe/bsw@0 | 253                 <i>other_config_name</i><tt>.lua</tt> | 
| jbe/bsw@0 | 254               </li> | 
| jbe/bsw@0 | 255               <li>…</li> | 
| jbe/bsw@0 | 256             </ul> | 
| jbe/bsw@0 | 257           </li> | 
| jbe/bsw@0 | 258           <li> | 
| jbe/bsw@0 | 259             <tt>db/</tt> | 
| jbe/bsw@0 | 260             <ul> | 
| jbe/bsw@0 | 261               <li> | 
| jbe/bsw@0 | 262                 <tt>schema.sql</tt> | 
| jbe/bsw@0 | 263               </li> | 
| jbe/bsw@0 | 264             </ul> | 
| jbe/bsw@0 | 265           </li> | 
| jbe/bsw@0 | 266           <li> | 
| jbe/bsw@0 | 267             <tt>locale/</tt> | 
| jbe/bsw@0 | 268             <ul> | 
| jbe/bsw@0 | 269               <li> | 
| jbe/bsw@0 | 270                 <tt>translations.de.lua</tt> | 
| jbe/bsw@0 | 271               </li> | 
| jbe/bsw@0 | 272               <li> | 
| jbe/bsw@0 | 273                 <tt>translations.en.lua</tt> | 
| jbe/bsw@0 | 274               </li> | 
| jbe/bsw@0 | 275               <li> | 
| jbe/bsw@0 | 276                 <tt>translations.</tt><i>languagecode</i><tt>.lua</tt> | 
| jbe/bsw@0 | 277               </li> | 
| jbe/bsw@0 | 278               <li>…</li> | 
| jbe/bsw@0 | 279             </ul> | 
| jbe/bsw@0 | 280           </li> | 
| jbe/bsw@0 | 281           <li> | 
| jbe/bsw@0 | 282             <tt>model/</tt> | 
| jbe/bsw@0 | 283             <ul> | 
| jbe/bsw@0 | 284               <li> | 
| jbe/bsw@0 | 285                 <i>model_name</i><tt>.lua</tt> | 
| jbe/bsw@0 | 286               </li> | 
| jbe/bsw@0 | 287               <li> | 
| jbe/bsw@0 | 288                 <i>another_model_name</i><tt>.lua</tt> | 
| jbe/bsw@0 | 289               </li> | 
| jbe/bsw@0 | 290               <li>…</li> | 
| jbe/bsw@0 | 291             </ul> | 
| jbe/bsw@0 | 292           </li> | 
| jbe/bsw@0 | 293           <li> | 
| jbe/bsw@0 | 294             <tt>static/</tt> | 
| jbe/bsw@0 | 295             <ul> | 
| jbe/bsw@0 | 296               <li>… (images, javascript, ...)</li> | 
| jbe/bsw@0 | 297             </ul> | 
| jbe/bsw@0 | 298           </li> | 
| jbe/bsw@0 | 299           <li> | 
| jbe/bsw@0 | 300             <tt>tmp/</tt> (writable by the web process) | 
| jbe/bsw@0 | 301           </li> | 
| jbe/bsw@0 | 302         </ul> | 
| jbe/bsw@0 | 303       </li> | 
| jbe/bsw@0 | 304     </ul> | 
| jbe/bsw@0 | 305     <h2>Automatically generated reference for the WebMCP environment</h2> | 
| jbe/bsw@0 | 306     <ul> |