]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - lib/framework.php
3a62bb5d68633e1d057a6980b1d78e188bf9ec37
[quix0rs-gnu-social.git] / lib / framework.php
1 <?php
2 /*
3  * StatusNet - the distributed open-source microblogging tool
4  * Copyright (C) 2008-2010, 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('GNUSOCIAL')) { exit(1); }
21
22 define('GNUSOCIAL_ENGINE', 'GNU social');
23 define('GNUSOCIAL_ENGINE_URL', 'https://www.gnu.org/software/social/');
24
25 define('GNUSOCIAL_BASE_VERSION', '1.2.0');
26 define('GNUSOCIAL_LIFECYCLE', 'beta4'); // 'dev', 'alpha[0-9]+', 'beta[0-9]+', 'rc[0-9]+', 'release'
27
28 define('GNUSOCIAL_VERSION', GNUSOCIAL_BASE_VERSION . '-' . GNUSOCIAL_LIFECYCLE);
29
30 define('GNUSOCIAL_CODENAME', 'Not decided yet');
31
32 define('AVATAR_PROFILE_SIZE', 96);
33 define('AVATAR_STREAM_SIZE', 48);
34 define('AVATAR_MINI_SIZE', 24);
35
36 define('NOTICES_PER_PAGE', 20);
37 define('PROFILES_PER_PAGE', 20);
38 define('MESSAGES_PER_PAGE', 20);
39 define('GROUPS_PER_PAGE', 20);
40 define('APPS_PER_PAGE', 20);
41 define('PEOPLETAGS_PER_PAGE', 20);
42
43 define('GROUPS_PER_MINILIST', 8);
44 define('PROFILES_PER_MINILIST', 8);
45
46 define('FOREIGN_NOTICE_SEND', 1);
47 define('FOREIGN_NOTICE_RECV', 2);
48 define('FOREIGN_NOTICE_SEND_REPLY', 4);
49
50 define('FOREIGN_FRIEND_SEND', 1);
51 define('FOREIGN_FRIEND_RECV', 2);
52
53 define('NOTICE_INBOX_SOURCE_SUB', 1);
54 define('NOTICE_INBOX_SOURCE_GROUP', 2);
55 define('NOTICE_INBOX_SOURCE_REPLY', 3);
56 define('NOTICE_INBOX_SOURCE_FORWARD', 4);
57 define('NOTICE_INBOX_SOURCE_PROFILE_TAG', 5);
58 define('NOTICE_INBOX_SOURCE_GATEWAY', -1);
59
60 define('URL_REGEX_VALID_PATH_CHARS',        '\pN\pL\,\!\(\)\.\:\-\_\+\/\=\&\;\%\~\*\$\+\'\@');
61 define('URL_REGEX_VALID_QSTRING_CHARS',     URL_REGEX_VALID_PATH_CHARS);
62 define('URL_REGEX_VALID_FRAGMENT_CHARS',    URL_REGEX_VALID_PATH_CHARS . '\?\#');
63
64 // append our extlib dir as the last-resort place to find libs
65
66 set_include_path(get_include_path() . PATH_SEPARATOR . INSTALLDIR . '/extlib/');
67
68 // To protect against upstream libraries which haven't updated
69 // for PHP 5.3 where dl() function may not be present...
70 if (!function_exists('dl')) {
71     // function_exists() returns false for things in disable_functions,
72     // but they still exist and we'll die if we try to redefine them.
73     //
74     // Fortunately trying to call the disabled one will only trigger
75     // a warning, not a fatal, so it's safe to leave it for our case.
76     // Callers will be suppressing warnings anyway.
77     $disabled = array_filter(array_map('trim', explode(',', ini_get('disable_functions'))));
78     if (!in_array('dl', $disabled)) {
79         function dl($library) {
80             return false;
81         }
82     }
83 }
84
85 // global configuration object
86
87 require_once 'PEAR.php';
88 require_once 'PEAR/Exception.php';
89 global $_PEAR;
90 $_PEAR = new PEAR;
91 $_PEAR->setErrorHandling(PEAR_ERROR_CALLBACK, 'PEAR_ErrorToPEAR_Exception');
92
93 require_once 'DB.php';
94 require_once 'DB/DataObject.php';
95 require_once 'DB/DataObject/Cast.php'; # for dates
96 global $_DB;
97 $_DB = new DB;
98
99 require_once(INSTALLDIR.'/lib/language.php');
100
101 // This gets included before the config file, so that admin code and plugins
102 // can use it
103
104 require_once(INSTALLDIR.'/lib/event.php');
105 require_once(INSTALLDIR.'/lib/plugin.php');
106
107 function addPlugin($name, array $attrs=array())
108 {
109     return GNUsocial::addPlugin($name, $attrs);
110 }
111
112 function _have_config()
113 {
114     return GNUsocial::haveConfig();
115 }
116
117 function GNUsocial_class_autoload($cls)
118 {
119     if (file_exists(INSTALLDIR.'/classes/' . $cls . '.php')) {
120         require_once(INSTALLDIR.'/classes/' . $cls . '.php');
121     } else if (file_exists(INSTALLDIR.'/lib/' . strtolower($cls) . '.php')) {
122         require_once(INSTALLDIR.'/lib/' . strtolower($cls) . '.php');
123     } else if (mb_substr($cls, -6) == 'Action' &&
124                file_exists(INSTALLDIR.'/actions/' . strtolower(mb_substr($cls, 0, -6)) . '.php')) {
125         require_once(INSTALLDIR.'/actions/' . strtolower(mb_substr($cls, 0, -6)) . '.php');
126     } else if ($cls === 'OAuthRequest' || $cls === 'OAuthException') {
127         require_once('OAuth.php');
128     } else {
129         Event::handle('Autoload', array(&$cls));
130     }
131 }
132
133 // Autoload function queue, starting with our own discovery method
134 spl_autoload_register('GNUsocial_class_autoload');
135
136 /**
137  * Extlibs with namespaces (or directly in extlib/)
138  * This covers libraries such as: Validate and \Michelf\Markdown
139  *
140  * The namespaced based structure is called "PSR-0 autoloading standard":
141  *    \<Vendor Name>\(<Namespace>\)*<Class Name>
142  * and is available here: http://www.php-fig.org/psr/psr-0/
143 */
144 spl_autoload_register(function($class){
145     $class_base = preg_replace('{\\\\|_(?!.*\\\\)}', DIRECTORY_SEPARATOR, ltrim($class, '\\'));
146     $file = INSTALLDIR."/extlib/{$class_base}.php";
147     if (file_exists($file)) {
148         require_once $file;
149         return;
150     }
151
152     # Try if the system has this external library
153     $file = "/usr/share/php/{$class_base}.php";
154     if (file_exists($file)) {
155         require_once $file;
156         return;
157     }
158 });
159
160 require_once INSTALLDIR.'/lib/util.php';
161 require_once INSTALLDIR.'/lib/action.php';
162 require_once INSTALLDIR.'/lib/mail.php';
163
164 //set PEAR error handling to use regular PHP exceptions
165 function PEAR_ErrorToPEAR_Exception(PEAR_Error $err)
166 {
167     //DB_DataObject throws error when an empty set would be returned
168     //That behavior is weird, and not how the rest of StatusNet works.
169     //So just ignore those errors.
170     if ($err->getCode() == DB_DATAOBJECT_ERROR_NODATA) {
171         return;
172     }
173
174     $msg      = $err->getMessage();
175     $userInfo = $err->getUserInfo();
176
177     // Log this; push the message up as an exception
178
179     common_log(LOG_ERR, "PEAR Error: $msg ($userInfo)");
180
181     // HACK: queue handlers get kicked by the long-query killer, and 
182     // keep the same broken connection. We die here to get a new
183     // process started.
184
185     if (php_sapi_name() == 'cli' && preg_match('/nativecode=2006/', $userInfo)) {
186         common_log(LOG_ERR, "Lost DB connection; dying.");
187         exit(100);
188     }
189
190     if ($err->getCode()) {
191         throw new PEAR_Exception($err->getMessage(), $err->getCode());
192     }
193     throw new PEAR_Exception($err->getMessage());
194 }