1
0
This repository has been archived on 2017-06-06. You can view files and clone it, but cannot push or open issues or pull requests.
informaticaD4P-2017/src/bootstrap.php

119 lines
3.7 KiB
PHP

<?php
/**
* Informatica Eindproject D4p
* 6in3, Stedelijk Gymnasium Nijmegen
* Docent: Hans de Wolf
*
* ==================
*
* Daniel Boutros,
* Christiaan Goossens,
* Jelmer Hinssen
*/
/**
* BOOTSTRAPPING SCRIPT
*/
// Get the Slim framework settings
$settings = require __DIR__ . '/settings.php';
// Create the Slim application object with the settings
/**
* ==============
* INSTRUCTIEBLOK
* ==============
*
* Slim Framework (https://www.slimframework.com/) is een basisframework om routing in PHP gemakkelijker te maken. Je kunt via functies van het Slim\App object verschillende routes aanmaken en daar PHP code aan koppelen. Slim zorgt er dan voor dat je daar automatisch uitkomt als je de opgegeven URL intypt in je browser.
*
* Slim maakt het ook makkelijker om benodigdheden voor je applicatie (dependencies) op een goede (standaardengebaseerde) manier te koppelen. Dit gebeurt bijvoorbeeld hieronder. Slim gebruikt hiervoor een container (http://php-di.org/doc/understanding-di.html)
*
*/
$app = new \Slim\App($settings);
/**
* Setup dependencies
*/
$container = $app->getContainer();
// Create the view renderer
/**
* ==============
* INSTRUCTIEBLOK
* ==============
*
* Hier wordt de 'view renderer' aan de dependency container (zie hierboven) toegevoegd. Dit zorgt dat je in je applicatie deze 'view renderer' kunt gebruiken via `$this->renderer`.
* De renderer wordt gebruikt om een PHP template (https://en.wikipedia.org/wiki/Web_template_system) aan je URL te koppelen.
*
* Dit kun je doen in je 'route' (URL) met de volgende code:
*
* ```
* return $this->renderer->render($response, 'index.phtml', $args);
* ```
*
* (index.phtml kan hier vervangen worden door een template adres uit de map templates)
*/
$container['renderer'] = function ($c) {
$settings = $c->get('settings')['renderer'];
return new Slim\Views\PhpRenderer($settings['template_path']);
};
// Add the database layer
/**
* ==============
* INSTRUCTIEBLOK
* ==============
*
* Je kunt de database gebruiken in je code via $this->db. Vermijd het direct gebruiken van het PDO object via $this->get('db.pdo').
* Je kunt hiervoor beter de ingebouwde functies van NotORM gebruiken.
*/
$container['db.pdo'] = function ($c) {
$settings = $c->get('settings')['db'];
$host = $settings['host'];
$name = $settings['name'];
$user = $settings['user'];
$pass = $settings['pass'];
$charset = $settings['charset'];
return new PDO("mysql:dbname=$name;host=$host;charset=$charset", $user, $pass);
};
$container['db'] = function ($c) {
$settings = $c->get('settings')['db'];
$pdo = $c->get('db.pdo');
return new NotORM($pdo);
};
// Inject the application main class
/**
* ==============
* INSTRUCTIEBLOK
* ==============
*
* Hieronder wordt de Main class van onze applicatie aangeroepen.
*
* In object georiënteerd PHP is een applicatie vaak gestructureerd in meerdere 'classes', die ook wel objecten worden genoemd. Een object kan worden gemaakt door het volgende:
*
*/
new Inforbank\Application\Login($app);
new Inforbank\Application\Main($app);
// Added API handler
new Inforbank\Application\API\Handler($app);
/**
* Bij het maken van dit object is in de class de __construct functie aangeroepen met de parameter $app. De functies die daar in staan zullen nu worden uitgevoerd.
*
* Je kunt de class herkennen uit talen als Java en C(++ of #), omdat ze daar ook worden gebruikt.
*
* Je kunt voor een beter begrip de volgende sites lezen:
* - https://www.sitepoint.com/php-53-namespaces-basics/ (over namespaces (wij gebruiken InfD4p\Application))
* - http://php.net/manual/en/language.oop5.basic.php (over de class)
*/
// Run app
$app->run();