]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - lib/common.php
Merge branch 'master' into 0.9.x
[quix0rs-gnu-social.git] / lib / common.php
1 <?php
2 /*
3  * StatusNet - the distributed open-source microblogging tool
4  * Copyright (C) 2008, 2009, StatusNet, Inc.
5  *
6  * This program is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU Affero General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU Affero General Public License for more details.
15  *
16  * You should have received a copy of the GNU Affero General Public License
17  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
18  */
19
20 if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); }
21
22 //exit with 200 response, if this is checking fancy from the installer
23 if (isset($_REQUEST['p']) && $_REQUEST['p'] == 'check-fancy') {  exit; }
24
25 define('STATUSNET_BASE_VERSION', '0.9.7');
26 define('STATUSNET_LIFECYCLE', 'fix1'); // 'dev', 'alpha[0-9]+', 'beta[0-9]+', 'rc[0-9]+', '' for release
27 define('STATUSNET_VERSION', STATUSNET_BASE_VERSION . STATUSNET_LIFECYCLE);
28
29 define('LACONICA_VERSION', STATUSNET_VERSION); // compatibility
30
31 define('STATUSNET_CODENAME', 'World Leader Pretend');
32
33 define('AVATAR_PROFILE_SIZE', 96);
34 define('AVATAR_STREAM_SIZE', 48);
35 define('AVATAR_MINI_SIZE', 24);
36
37 define('NOTICES_PER_PAGE', 20);
38 define('PROFILES_PER_PAGE', 20);
39 define('MESSAGES_PER_PAGE', 20);
40
41 define('FOREIGN_NOTICE_SEND', 1);
42 define('FOREIGN_NOTICE_RECV', 2);
43 define('FOREIGN_NOTICE_SEND_REPLY', 4);
44
45 define('FOREIGN_FRIEND_SEND', 1);
46 define('FOREIGN_FRIEND_RECV', 2);
47
48 define('NOTICE_INBOX_SOURCE_SUB', 1);
49 define('NOTICE_INBOX_SOURCE_GROUP', 2);
50 define('NOTICE_INBOX_SOURCE_REPLY', 3);
51 define('NOTICE_INBOX_SOURCE_FORWARD', 4);
52 define('NOTICE_INBOX_SOURCE_GATEWAY', -1);
53
54 # append our extlib dir as the last-resort place to find libs
55
56 set_include_path(get_include_path() . PATH_SEPARATOR . INSTALLDIR . '/extlib/');
57
58 // To protect against upstream libraries which haven't updated
59 // for PHP 5.3 where dl() function may not be present...
60 if (!function_exists('dl')) {
61     // function_exists() returns false for things in disable_functions,
62     // but they still exist and we'll die if we try to redefine them.
63     //
64     // Fortunately trying to call the disabled one will only trigger
65     // a warning, not a fatal, so it's safe to leave it for our case.
66     // Callers will be suppressing warnings anyway.
67     try {
68         // Reading the ini setting is hard as we don't know PHP's parsing,
69         // but we can check if it is disabled through reflection.
70         $dl = new ReflectionFunction('dl');
71         // $disabled = $dl->isDisabled(); // don't need to check this now
72     } catch (ReflectionException $e) {
73         // Ok, it *really* doesn't exist!
74         function dl($library) {
75             return false;
76         }
77     }
78 }
79
80 # global configuration object
81
82 require_once('PEAR.php');
83 require_once('DB/DataObject.php');
84 require_once('DB/DataObject/Cast.php'); # for dates
85
86 require_once(INSTALLDIR.'/lib/language.php');
87
88 // This gets included before the config file, so that admin code and plugins
89 // can use it
90
91 require_once(INSTALLDIR.'/lib/event.php');
92 require_once(INSTALLDIR.'/lib/plugin.php');
93
94 function addPlugin($name, $attrs = null)
95 {
96     return StatusNet::addPlugin($name, $attrs);
97 }
98
99 function _have_config()
100 {
101     return StatusNet::haveConfig();
102 }
103
104 /**
105  * Wrapper for class autoloaders.
106  * This used to be the special function name __autoload(), but that causes bugs with PHPUnit 3.5+
107  */
108 function autoload_sn($cls)
109 {
110     if (file_exists(INSTALLDIR.'/classes/' . $cls . '.php')) {
111         require_once(INSTALLDIR.'/classes/' . $cls . '.php');
112     } else if (file_exists(INSTALLDIR.'/lib/' . strtolower($cls) . '.php')) {
113         require_once(INSTALLDIR.'/lib/' . strtolower($cls) . '.php');
114     } else if (mb_substr($cls, -6) == 'Action' &&
115                file_exists(INSTALLDIR.'/actions/' . strtolower(mb_substr($cls, 0, -6)) . '.php')) {
116         require_once(INSTALLDIR.'/actions/' . strtolower(mb_substr($cls, 0, -6)) . '.php');
117     } else if ($cls == 'OAuthRequest') {
118         require_once('OAuth.php');
119     } else {
120         Event::handle('Autoload', array(&$cls));
121     }
122 }
123
124 spl_autoload_register('autoload_sn');
125
126 // XXX: how many of these could be auto-loaded on use?
127 // XXX: note that these files should not use config options
128 // at compile time since DB config options are not yet loaded.
129
130 require_once 'Validate.php';
131 require_once 'markdown.php';
132
133 // XXX: other formats here
134
135 /**
136  * Avoid the NICKNAME_FMT constant; use the Nickname class instead.
137  *
138  * Nickname::DISPLAY_FMT is more suitable for inserting into regexes;
139  * note that it includes the [] and repeating bits, so should be wrapped
140  * directly in a capture paren usually.
141  *
142  * For validation, use Nickname::normalize(), Nickname::isValid() etc.
143  *
144  * @deprecated
145  */
146 define('NICKNAME_FMT', VALIDATE_NUM.VALIDATE_ALPHA_LOWER);
147
148 require_once INSTALLDIR.'/lib/util.php';
149 require_once INSTALLDIR.'/lib/action.php';
150 require_once INSTALLDIR.'/lib/mail.php';
151 require_once INSTALLDIR.'/lib/subs.php';
152
153 require_once INSTALLDIR.'/lib/clientexception.php';
154 require_once INSTALLDIR.'/lib/serverexception.php';
155
156 try {
157     StatusNet::init(@$server, @$path, @$conffile);
158 } catch (NoConfigException $e) {
159     // XXX: Throw a conniption if database not installed
160     // XXX: Find a way to use htmlwriter for this instead of handcoded markup
161     // TRANS: Error message displayed when no configuration file was found for a StatusNet installation.
162     echo '<p>'. _('No configuration file found.') .'</p>';
163     // TRANS: Error message displayed when no configuration file was found for a StatusNet installation.
164     // TRANS: Is followed by a list of directories (separated by HTML breaks).
165     echo '<p>'. _('I looked for configuration files in the following places:') .'<br /> ';
166     echo implode($e->configFiles, '<br />');
167     // TRANS: Error message displayed when no configuration file was found for a StatusNet installation.
168     echo '<p>'. _('You may wish to run the installer to fix this.') .'</p>';
169     // @todo FIXME Link should be in a para?
170     // TRANS: Error message displayed when no configuration file was found for a StatusNet installation.
171     // TRANS: The text is link text that leads to the installer page.
172     echo '<a href="install.php">'. _('Go to the installer.') .'</a>';
173     exit;
174 }