Newer
Older
smart-home-server / server / SHServ / EventsHandlers.php
<?php

namespace SHServ;

class EventsHandlers{
	public function handlers(){
		events() -> handler('kernel:Bootstrap.ready_app', function(Array $params) {
			app() -> routes -> routes_init();
			if(!app() -> console_flag) {
				app() -> router -> start_routing();
			}
		});

		events() -> handler('kernel:CallControl.no_calls', function(Array $params) {
			if(!app() -> console_flag) {
				echo "404 not found";
			}
		});

		if(FCONF["devmode"]) {
			events() -> handler("module:Template.start_making", function(Array $params) {
				app() -> devtools -> add_template_to_map(
					$params["template_instance"],
					$params["template_name"]
				);
			});

			events() -> handler("module:Template.ready_template", function(Array $params) {
				app() -> devtools -> render_template_done(
					$params["template_name"]
				);
			});

			events() -> handler("kernel:CallControl.leading_call", function(Array $params) {
				app() -> devtools -> loging_action_call(
					$params["action"],
					$params["type"],
					$params["params"]
				);
			});

			events() -> handler("kernel:CallControl.completed_call", function(Array $params) {
				app() -> devtools -> loging_action_time();
			});

			events() -> handler("kernel:Bootstrap.app_finished", function(Array $params){
				if(isset($_GET["devp"])) {
					app() -> devtools -> show();
				}
			});

			events() -> handler("module:ThinBuilder.ready_sql", function(Array $params){
				app() -> devtools -> loging_sql_query($params["sql"]);
			});

			events() -> handler("module:ThinBuilder.query", function(Array $params){
				app() -> devtools -> loging_sql_query_result();
			});
		}
	}
}