5 define('EOL', "<br />\r\n");
7 define('REGISTER_CLOSED', 0);
8 define('REGISTER_APPROVE', 1);
9 define('REGISTER_OPEN', 2);
11 define ( 'DIRECTION_ANY', 0);
12 define ( 'DIRECTION_IN', 1);
13 define ( 'DIRECTION_OUT', 2);
14 define ( 'DIRECTION_BOTH', 3);
16 define ( 'NOTIFY_INTRO', 0x0001 );
17 define ( 'NOTIFY_CONFIRM', 0x0002 );
18 define ( 'NOTIFY_WALL', 0x0004 );
19 define ( 'NOTIFY_COMMENT', 0x0008 );
20 define ( 'NOTIFY_MAIL', 0x0010 );
22 define ( 'NAMESPACE_DFRN' , 'http://purl.org/macgirvin/dfrn/1.0' );
25 if(! class_exists('App')) {
28 public $module_loaded = false;
37 public $error = false;
51 function __construct() {
53 $this->config = array();
54 $this->page = array();
55 $this->pager= array();
57 $this->scheme = ((isset($_SERVER['HTTPS'])
58 && ($_SERVER['HTTPS'])) ? 'https' : 'http' );
59 $this->hostname = str_replace('www.','',
60 $_SERVER['SERVER_NAME']);
61 set_include_path("include/$this->hostname"
62 . PATH_SEPARATOR . 'include'
63 . PATH_SEPARATOR . '.' );
65 if(substr($_SERVER['QUERY_STRING'],0,2) == "q=")
66 $_SERVER['QUERY_STRING'] = substr($_SERVER['QUERY_STRING'],2);
67 $this->cmd = trim($_GET['q'],'/');
70 $this->argv = explode('/',$this->cmd);
71 $this->argc = count($this->argv);
72 if((array_key_exists('0',$this->argv)) && strlen($this->argv[0])) {
73 $this->module = $this->argv[0];
76 $this->module = 'home';
79 if($this->cmd == '.well-known/host-meta')
80 require_once('include/hostxrd.php');
82 $this->pager['page'] = ((x($_GET,'page')) ? $_GET['page'] : 1);
83 $this->pager['itemspage'] = 50;
84 $this->pager['start'] = ($this->pager['page'] * $this->pager['itemspage']) - $this->pager['itemspage'];
85 $this->pager['total'] = 0;
88 function get_baseurl($ssl = false) {
89 if(strlen($this->baseurl))
90 return $this->baseurl;
92 $this->baseurl = (($ssl) ? 'https' : $this->scheme) . "://" . $this->hostname
93 . ((isset($this->path) && strlen($this->path))
94 ? '/' . $this->path : '' );
95 return $this->baseurl;
98 function set_baseurl($url) {
99 $this->baseurl = $url;
102 function get_hostname() {
103 return $this->hostname;
106 function set_hostname($h) {
107 $this->hostname = $h;
110 function set_path($p) {
111 $this->path = ltrim(trim($p),'/');
114 function get_path() {
118 function set_pager_total($n) {
119 $this->pager['total'] = intval($n);
122 function set_pager_itemspage($n) {
123 $this->pager['itemspage'] = intval($n);
124 $this->pager['start'] = ($this->pager['page'] * $this->pager['itemspage']) - $this->pager['itemspage'];
128 function init_pagehead() {
129 if(file_exists("view/head.tpl"))
130 $s = file_get_contents("view/head.tpl");
131 $this->page['htmlhead'] = replace_macros($s,array('$baseurl' => $this->get_baseurl()));
137 if(! function_exists('x')) {
138 function x($s,$k = NULL) {
140 if((is_array($s)) && (array_key_exists($k,$s))) {
158 if(! function_exists('system_unavailable')) {
159 function system_unavailable() {
160 include('system_unavailable.php');
164 if(! function_exists('replace_macros')) {
165 function replace_macros($s,$r) {
170 if(is_array($r) && count($r)) {
171 foreach ($r as $k => $v ) {
176 return str_replace($search,$replace,$s);
180 if(! function_exists('load_translation_table')) {
181 function load_translation_table($lang) {
186 if(! function_exists('t')) {
191 return $a->strings[$s];
195 if(! function_exists('fetch_url')) {
196 function fetch_url($url,$binary = false) {
197 $ch = curl_init($url);
198 if(! $ch) return false;
200 curl_setopt($ch, CURLOPT_HEADER, 0);
201 curl_setopt($ch, CURLOPT_FOLLOWLOCATION,true);
202 curl_setopt($ch, CURLOPT_MAXREDIRS,8);
203 curl_setopt($ch, CURLOPT_RETURNTRANSFER,true);
205 curl_setopt($ch, CURLOPT_BINARYTRANSFER,1);
213 if(! function_exists('post_url')) {
214 function post_url($url,$params) {
215 $ch = curl_init($url);
216 if(! $ch) return false;
218 curl_setopt($ch, CURLOPT_HEADER, 0);
219 curl_setopt($ch, CURLOPT_FOLLOWLOCATION,true);
220 curl_setopt($ch, CURLOPT_MAXREDIRS,8);
221 curl_setopt($ch, CURLOPT_RETURNTRANSFER,true);
222 curl_setopt($ch, CURLOPT_POST,1);
223 curl_setopt($ch, CURLOPT_POSTFIELDS,$params);
231 if(! function_exists('random_string')) {
232 function random_string() {
233 return(hash('sha256',uniqid(rand(),true)));
236 if(! function_exists('notags')) {
237 function notags($string) {
238 // protect against :<> with high-bit set
239 return(str_replace(array("<",">","\xBA","\xBC","\xBE"), array('[',']','','',''), $string));
242 if(! function_exists('escape_tags')) {
243 function escape_tags($string) {
245 return(htmlspecialchars($string));
248 if(! function_exists('login')) {
249 function login($register = false) {
251 $register_html = (($register) ? file_get_contents("view/register-link.tpl") : "");
254 if(x($_SESSION,'authenticated')) {
255 $o = file_get_contents("view/logout.tpl");
258 $o = file_get_contents("view/login.tpl");
260 $o = replace_macros($o,array('$register_html' => $register_html ));
266 if(! function_exists('autoname')) {
267 function autoname($len) {
269 $vowels = array('a','a','ai','au','e','e','e','ee','ea','i','ie','o','ou','u');
270 if(mt_rand(0,5) == 4)
288 's','sc','sh','sm','sp','st',
296 $midcons = array('ck','ct','gn','ld','lf','lm','lt','mb','mm', 'mn','mp',
297 'nd','ng','nk','nt','rn','rp','rt');
299 $noend = array('bl', 'br', 'cl','cr','dr','fl','fr','gl','gr',
300 'kh', 'kl','kr','mn','pl','pr','rh','tr','qu','wh');
302 $start = mt_rand(0,2);
310 for ($x = 0; $x < $len; $x ++) {
311 $r = mt_rand(0,count($table) - 1);
314 if($table == $vowels)
315 $table = array_merge($cons,$midcons);
321 $word = substr($word,0,$len);
323 foreach($noend as $noe) {
324 if((strlen($word) > 2) && (substr($word,-2) == $noe)) {
325 $word = substr($word,0,-1);
329 if(substr($word,-1) == 'q')
330 $word = substr($word,0,-1);
334 if(! function_exists('killme')) {
336 session_write_close();
340 if(! function_exists('goaway')) {
341 function goaway($s) {
342 header("Location: $s");
347 if(! function_exists('xml_status')) {
348 function xml_status($st) {
349 header( "Content-type: text/xml" );
350 echo '<?xml version="1.0" encoding="UTF-8"?>'."\r\n";
351 echo "<result><status>$st</status></result>\r\n";
355 if(! function_exists('local_user')) {
356 function local_user() {
357 if((x($_SESSION,'authenticated')) && (x($_SESSION,'uid')))
358 return $_SESSION['uid'];
362 if(! function_exists('remote_user')) {
363 function remote_user() {
364 if((x($_SESSION,'authenticated')) && (x($_SESSION,'visitor_id')))
365 return $_SESSION['visitor_id'];
369 function footer(&$a) {
371 $s = fetch_url("http://fortunemod.com/cookie.php?equal=1");
372 $a->page['content'] .= "<div class=\"fortune\" >$s</div>";
375 if(! function_exists('notice')) {
376 function notice($s) {
378 $_SESSION['sysmsg'] .= $s;
382 if(! function_exists('get_max_import_size')) {
383 function get_max_import_size() {
385 return ((x($a->config,'max_import_size')) ? $a->config['max_import_size'] : 0 );
388 if(! function_exists('xmlify')) {
389 function xmlify($str) {
392 for($x = 0; $x < strlen($str); $x ++) {
423 $buffer = trim($buffer);
427 if(! function_exists('unxmlify')) {
428 function unxmlify($s) {
429 $ret = str_replace('&','&', $s);
430 $ret = str_replace(array('<','>','"','''),array('<','>','"',"'"),$ret);
434 if(! function_exists('hex2bin')) {
435 function hex2bin($s) {
436 return(pack("H*",$s));
440 if(! function_exists('paginate')) {
441 function paginate(&$a) {
443 $stripped = ereg_replace("(&page=[0-9]*)","",$_SERVER['QUERY_STRING']);
444 $stripped = str_replace('q=','',$stripped);
445 $stripped = trim($stripped,'/');
446 $url = $a->get_baseurl() . '/' . $stripped;
449 if($a->pager['total'] > $a->pager['itemspage']) {
450 $o .= '<div class="pager">';
451 if($a->pager['page'] != 1)
452 $o .= '<span class="pager_prev">'."<a href=\"$url".'&page='.($a->pager['page'] - 1).'">' . t('prev') . '</a></span> ';
454 $o .= "<span class=\"pager_first\"><a href=\"$url"."&page=1\">" . t('first') . "</a></span> ";
456 $numpages = $a->pager['total'] / $a->pager['itemspage'];
459 $numstop = $numpages;
462 $numstart = (($pagenum > 7) ? ($pagenum - 7) : 1);
463 $numstop = (($pagenum > ($numpages - 7)) ? $numpages : ($numstart + 14));
466 for($i = $numstart; $i <= $numstop; $i++){
467 if($i == $a->pager['page'])
468 $o .= '<span class="pager_current">'.(($i < 10) ? ' '.$i : $i);
470 $o .= "<span class=\"pager_n\"><a href=\"$url"."&page=$i\">".(($i < 10) ? ' '.$i : $i)."</a>";
474 if(($a->pager['total'] % $a->pager['itemspage']) != 0) {
475 if($i == $a->pager['page'])
476 $o .= '<span class="pager_current">'.(($i < 10) ? ' '.$i : $i);
478 $o .= "<span class=\"pager_n\"><a href=\"$url"."&page=$i\">".(($i < 10) ? ' '.$i : $i)."</a>";
482 $lastpage = (($numpages > intval($numpages)) ? intval($numpages)+1 : $numpages);
483 $o .= "<span class=\"pager_last\"><a href=\"$url"."&page=$lastpage\">" . t('last') . "</a></span> ";
485 if(($a->pager['total'] - ($a->pager['itemspage'] * $a->pager['page'])) > 0)
486 $o .= '<span class="pager_next">'."<a href=\"$url"."&page=".($a->pager['page'] + 1).'">' . t('next') . '</a></span>';
487 $o .= '</div>'."\r\n";
492 if(! function_exists('expand_acl')) {
493 function expand_acl($s) {
496 $a = explode('<',$s);
497 for($x = 0; $x < count($a); $x ++) {
498 $a[$x] = intval(str_replace(array('<','>'),array('',''),$a[$x]));
505 if(! function_exists('sanitise_acl')) {
506 function sanitise_acl(&$item) {
507 $item = '<' . intval(notags(trim($item))) . '>';