Strict but sane Error reporting system
[mirrors/Kyberia-bloodline.git] / wwwroot / nodes.php
CommitLineData
51ff3226 1<?php
cae06914 2//requiring main config file with path/database etc. constants
3require_once('config/config.inc');
4
5//Ask for auth if enabled...
6//if(isset($realm) && isset($users)) require_once(INCLUDE_DIR.'http_auth.php');
7
51ff3226 8//starting timer for benchmarking purposes
9$timer_start=Time()+SubStr(MicroTime(),0,8);
51ff3226 10//setting PHPSESSID cookie and starting user session
11session_start();
12
5c9aff9f 13@ini_set('magic_quotes_gpc' , 'off');
cae06914 14if(get_magic_quotes_gpc()) {
15 die("Error: magic_quotes_gpc needs to be disabled! F00K!\n");
16}
5c9aff9f 17
4dd26acd 18//Smarty from DB
00be2b5c
H
19$smarty_resource = 'kyberia';
20//$smarty_resource = ''; //same as 'file' (fallback)
21/* I have moved old templates to DB using following lame script:
cae06914 22 * for i in *.tpl; do j=$(echo "$i" | cut -d . -f 1);
23 echo UPDATE nodes SET node_content = "'$(php -r
24 "echo mysql_escape_string(file_get_contents('$i'));")'" WHERE
25 node_id = "'$j'" COLLATE utf8_bin LIMIT '1;';
26 done | mysql --user=kyberia --password=PASSSSSSS kyberia
27 * In future we should have some mechanism for distributing templates
28 * because they are very important part of kyberia source...
00be2b5c 29 */
822594dc 30
51ff3226 31//connecting to database and creating universal $db object
1675d71f 32//require_once(INCLUDE_DIR.'senate.inc'); // in config already
cb5cd120
H
33require_once(INCLUDE_DIR.'log.inc');
34require_once(INCLUDE_DIR.'ubik.inc');
35require_once(INCLUDE_DIR.'nodes.inc');
36require_once(INCLUDE_DIR.'error_messages.inc');
37require_once(INCLUDE_DIR.'database.inc');
38require_once(INCLUDE_DIR.'transports.inc');
51ff3226 39
e23557a6 40$db = new CLASS_DATABASE();
51ff3226 41
bc85490b
H
42switch(true) {
43 case preg_match('/id\/([0-9]+)(?:\/([0-9]+)\/?)?/',$_SERVER['PATH_INFO'],$match):
44 // print_r($match);
45 $_GET['node_id']=$match[1];
46 if (!empty($match[2])) {
47 $_GET['template_id']=$match[2];
48 }
49 //Base36 fascism redirect
50 if(!count($_POST) && !(isset($_GET['template_id']) && $_GET['template_id'] == 'download')) { //Fix ugly download hack...
51 header('Location: /k/'.base_convert($_GET['node_id'], 10, 36).
52 (isset($_GET['template_id'])?'/'.base_convert($_GET['template_id'], 10, 36):'')
53 );
54 die("Die!!! All Fascists Are Bastards...\n");
55 }
56 break;
57 case preg_match('/k\/([a-z0-9]{1,7})(?:\/([a-z0-9]{1,7}))?/',$_SERVER['PATH_INFO'],$match):
58 $_GET['node_id']=base_convert($match[1], 36, 10);
59 if (!empty($match[2])) {
60 $_GET['template_id']=base_convert($match[2],36,10);
61 }
62 break;
63 case preg_match('/name\/(.*?)\/?$/',$_SERVER['PATH_INFO'],$match):
64 $_GET['node_id'] = nodes::getNodeIdByName($match[1]);
65 break;
de8e1dde
H
66 case preg_match('/search\/(.*?)\/?$/',$_SERVER['PATH_INFO'],$match):
67 //$query = nodes::getNodeIdByName($match[1]);
68 //XXX TODO: Predat searchi az bude fungovat
69 break;
bc85490b
H
70 case preg_match('/\/(.+)\/?$/',$_SERVER['PATH_INFO'],$match):
71 $_GET['node_id'] = nodes::getNodeIdByName($match[1]);
72 break;
73 default:
de8e1dde 74 $_GET['node_id']=1; //WELCOME_NODE
bc85490b 75 break;
08f5f7a7
DH
76}
77
51ff3226 78if (!empty($_GET['template_id'])) {
79 $template_id=$_GET['template_id'];
5b9c0808 80} else {
81 $template_id=false;
51ff3226 82}
51ff3226 83
8f03b4ac 84error_reporting(E_ALL | E_STRICT);
5f73d0e7 85//$_SESSION['debugging']=0;
08f5f7a7
DH
86//unset($_SESSION['debugging']);
87//Well... we should make some event
88//or JavaScript page to turning this on/off...
89//exit;
8f03b4ac 90if(isset($_SESSION['debugging']) && $_SESSION['debugging']) {
08f5f7a7
DH
91 echo 'GET VARIABLES::<br/>';
92 print_r($_GET);
93 echo 'POST VARIABLES::<br/>';
94 print_r($_POST);
95 echo '<b>SESSION VARIABLES::</b><br/>';
96 print_r($_SESSION);
8f03b4ac
H
97} else {
98 set_error_handler('logger::error_handler');
08f5f7a7
DH
99}
100
f046f788
H
101require_once(INCLUDE_DIR.'logout_idle.inc'); //Logout when idle
102
de8e1dde 103//initializing node
08f5f7a7
DH
104$node = nodes::getNodeById($_GET['node_id'],(isset($_SESSION['user_id']))?$_SESSION['user_id']:'');
105
065440d5 106//XXX Paths are wrong (!)
51ff3226 107//loading smarty template engine and setting main parameters
108require(SMARTY_DIR.'Smarty.class.php');
109$smarty = new Smarty;
6a967e24 110require(INCLUDE_DIR.'smarty/resource.kyberia.php');
00be2b5c 111$smarty->default_resource_type=$smarty_resource;
51ff3226 112
065440d5 113//$smarty->php_handling = SMARTY_PHP_REMOVE; //XXX
39244cfc 114$smarty->template_dir = TEMPLATE_DIR;
51ff3226 115//echo TEMPLATE_DIR.TEMPLATE_SET;
116//echo $smarty->template_dir;
a81e2af2 117$smarty->compile_dir = SYSTEM_DATA.'templates_c/';
175043f4 118$smarty->config_dir = SMARTY_DIR.'configs/'; //XXX neexistuje
51ff3226 119$smarty->cache_dir = SMARTY_DIR.'cache/';
120$smarty->plugins_dir = SMARTY_PLUGIN_DIR ;
121if ($_SESSION['debugging']) $smarty->debugging=true;
122
9850bdc4 123// initializing variables
124// preg_replace prevents LFI
65c78def 125if (empty($_POST['event'])) $event='display';
9850bdc4 126else $event= preg_replace( "![^a-zA-Z0-9_]+!", "", $_POST['event']);
51ff3226 127
128
129if ($_SESSION['debugging']) {
130 echo "<pre><b>NODE::";
131 print_r($node);
132 echo "</pre>";
133}
134
12425f11 135if ((isset($_SESSION['user_id']) && ($node['node_creator']==$_SESSION['user_id']))) {
006bd683 136 $node['node_permission']='owner';
137}
51ff3226 138
006bd683 139if (isset($_SESSION['cube_vector']) && ($_SESSION['cube_vector'])) {
51ff3226 140 if (strpos($node['node_vector'],$_SESSION['cube_vector'])===false) {
141 echo "node::".$node['node_vector'];
142 echo "cube_Vector::".$_SESSION['cube_vector'];
143 echo "you are out of allowed cwbe. access forbidden";
144 die();
145 }
146}
147
570ab4b6 148@include_once(INCLUDE_DIR.'mail_rss.inc'); //haluz...
51ff3226 149
150//checking permissions
7a5cc9b5
DH
151include_once(BACKEND_DIR.'/'.DB_TYPE.'/permissions.inc');
152$permissions=permissions::checkPerms($node);
153if ($_SESSION['debugging']) {
154 print_r($permissions);
51ff3226 155}
7a5cc9b5 156
51ff3226 157
08f5f7a7
DH
158
159// DO NOT MESS WITH THIS !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
160//creating neural network
161$db->update("update nodes set node_views=node_views+1 where node_id='".$node['node_id']."'");
162if (isset($referer_id) && is_numeric($referer_id)) {
163 $q="update neurons set synapse=synapse+1 where dst='".$node['node_id']."' and src='$referer_id'";
164 $result=$db->update($q);
165 if (!$result) {
166 $q="insert into neurons set synapse_creator='".$_SESSION['user_id']."',dst='".$node['node_id']."',src='$referer_id',synapse=1";
167 $db->query($q);
168 }
169} else {
170 logger::log('enter',$node['node_id'],'failed');
171}
172
173
174
570ab4b6 175//entering the node (executing the eventz)
51ff3226 176if (($permissions['r']) || ($event != 'register')) {
5b9c0808 177 //performing node_events (based on update/insert/delete db queries)
178 if ($event) {
179 require(INCLUDE_DIR.'eventz.inc');
180 }
51ff3226 181}
182
51ff3226 183?>
This page took 0.50898 seconds and 4 git commands to generate.