differences in the entry: the text of the wiki page
[p]h-source is the PHP software used to create h-node.org. The h-source source code is hosted at [a]http://savannah.nongnu.org/projects/h-source/|Savannah[/a].[/p]
[p]At the moment, there is no stable releases but you can download clone the SVN version (updated daily). In order to download the SVN version you have to install [a]http://subversion.apache.org/|subversion[/a]. Then type the following command in a terminal:[/p] git repository:[/p]
[code]svn co svn://svn.savannah.nongnu.org/h-source/trunk/h-source[/code] [code]git clone https://git.savannah.gnu.org/h-source.git[/code]
[p]You can [p]h-node.org pulls from the h-node branch weekly. There is also access a [a]https://staging.h-node.org|staging instance[/a] that tracks the subversion repository using HTTP (slower)[/p]
[code]svn co http://svn.savannah.nongnu.org/svn/h-source/trunk/h-source[/code] development branch.[/p]
[h1]How h-source works[/h1]
[p]h-source has been developed using the [a]http://www.easygiant.org|EasyGiant[/a] PHP framework. The EasyGiant PHP framework forces the developer to adopt the MVC (model-view-controller) paradigm. According to this paradigm each web page served is managed by a Controller, a Model and one or more View files. [/p]
[p]For example, the URL of this page is the following:[/p]
[code]
http://www.h-node.org/wiki/page/en/h-source[/code]
[p]We can split the above URL in four parts[/p]
[enum]
[*] [b]http://www.h-node.org[/b] -> the domain name[/*]
[*] [b]wiki[/b] -> the controller, that is a PHP class [/*]
[*] [b]page[/b] -> the public method of the controller used to serve this page [/*]
[*] [b]en/h-source[/b] -> the query string, a list (separated by /) of arguments passed to the [b]page[/b] public method of the [b]wiki[/b] controller[/*]
[/enum]
[p]Inside the source code of h-source you can download, you will find the following file: [/p]
[code]Application/Controllers/WikiController.php[/code]
[p]It is the PHP class associated with the wiki controller mentioned above. That file has a public method named [b]page[/b], which require two arguments (passed in the query string: en/h-source) In this way, it is easy to find the PHP file that is serving the page you have requested. This page is served by the [b]WikiController.php[/b] PHP class by means of the [b]page[/b] public method[/p]
[p]For each [b]Controller[/b] (in this case wiki -> WikiController.php) there is also a [b]Model[/b] and one or more [b]view[/b] files.[/p]
[p]The model manages database queries, inserting new data to the database, updating old data and retrieving some data. Each model is a PHP class. All model classes are saved inside the [b]Application/Models[/b] folder. Each model manages a single database table. In this case, the [b]WikiModel.php[/b] file, the model PHP class, is used to manage the [i]wiki MySQL table[/i].[/p]
[p]The view files are simple PHP files that contain the HTML code that forms the web page, mixed with some simple PHP instructions. All the logic is written inside the controller (WikiController.php) and the model (WikiModel.php).[/p]
[p]All the view files used by a controller are saved inside the folder Application/Views or Application/Views/<controller>, where <controller> is the controller name. The view files placed inside Application/Views can be used by all controllers while the view files saved inside Application/Views/<controller> can be used only by the controller named <controller>.[/p]
[p]So, in the case of the wiki (WikiController.php) controller, all view files are placed inside a folder:[/p]
[code]Application/Views/Wiki[/code]
[p]The view file that serves the content of this page is [b]Application/Views/Wiki/page.php[/b][/p]