2010-10-16 05:33:26 +09:00
|
|
|
<?php
|
|
|
|
/*
|
|
|
|
* StatusNet - the distributed open-source microblogging tool
|
|
|
|
* Copyright (C) 2008-2010, StatusNet, Inc.
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2013-10-27 19:27:12 +09:00
|
|
|
if (!defined('GNUSOCIAL')) { exit(1); }
|
2010-10-16 05:33:26 +09:00
|
|
|
|
2013-10-31 00:28:59 +09:00
|
|
|
define('GNUSOCIAL_ENGINE', 'GNU social');
|
|
|
|
define('GNUSOCIAL_ENGINE_URL', 'https://www.gnu.org/software/social/');
|
|
|
|
|
2013-10-27 19:27:12 +09:00
|
|
|
define('GNUSOCIAL_BASE_VERSION', '1.1.1');
|
|
|
|
define('GNUSOCIAL_LIFECYCLE', 'alpha'); // 'dev', 'alpha[0-9]+', 'beta[0-9]+', 'rc[0-9]+', 'release'
|
2011-01-13 08:14:57 +09:00
|
|
|
|
2013-10-27 19:27:12 +09:00
|
|
|
define('GNUSOCIAL_VERSION', GNUSOCIAL_BASE_VERSION . '-' . GNUSOCIAL_LIFECYCLE);
|
2010-10-16 05:33:26 +09:00
|
|
|
|
2013-10-27 19:27:12 +09:00
|
|
|
define('GNUSOCIAL_CODENAME', 'Not decided yet');
|
2010-10-16 05:33:26 +09:00
|
|
|
|
|
|
|
define('AVATAR_PROFILE_SIZE', 96);
|
|
|
|
define('AVATAR_STREAM_SIZE', 48);
|
|
|
|
define('AVATAR_MINI_SIZE', 24);
|
|
|
|
|
|
|
|
define('NOTICES_PER_PAGE', 20);
|
|
|
|
define('PROFILES_PER_PAGE', 20);
|
2011-03-17 03:11:06 +09:00
|
|
|
define('MESSAGES_PER_PAGE', 20);
|
2012-05-14 17:06:37 +09:00
|
|
|
define('GROUPS_PER_PAGE', 20);
|
2010-10-16 05:33:26 +09:00
|
|
|
|
|
|
|
define('FOREIGN_NOTICE_SEND', 1);
|
|
|
|
define('FOREIGN_NOTICE_RECV', 2);
|
|
|
|
define('FOREIGN_NOTICE_SEND_REPLY', 4);
|
|
|
|
|
|
|
|
define('FOREIGN_FRIEND_SEND', 1);
|
|
|
|
define('FOREIGN_FRIEND_RECV', 2);
|
|
|
|
|
|
|
|
define('NOTICE_INBOX_SOURCE_SUB', 1);
|
|
|
|
define('NOTICE_INBOX_SOURCE_GROUP', 2);
|
|
|
|
define('NOTICE_INBOX_SOURCE_REPLY', 3);
|
|
|
|
define('NOTICE_INBOX_SOURCE_FORWARD', 4);
|
2011-03-07 03:03:39 +09:00
|
|
|
define('NOTICE_INBOX_SOURCE_PROFILE_TAG', 5);
|
2010-10-16 05:33:26 +09:00
|
|
|
define('NOTICE_INBOX_SOURCE_GATEWAY', -1);
|
|
|
|
|
2011-03-23 00:54:23 +09:00
|
|
|
// append our extlib dir as the last-resort place to find libs
|
2010-10-16 05:33:26 +09:00
|
|
|
|
|
|
|
set_include_path(get_include_path() . PATH_SEPARATOR . INSTALLDIR . '/extlib/');
|
|
|
|
|
|
|
|
// To protect against upstream libraries which haven't updated
|
|
|
|
// for PHP 5.3 where dl() function may not be present...
|
|
|
|
if (!function_exists('dl')) {
|
|
|
|
// function_exists() returns false for things in disable_functions,
|
|
|
|
// but they still exist and we'll die if we try to redefine them.
|
|
|
|
//
|
|
|
|
// Fortunately trying to call the disabled one will only trigger
|
|
|
|
// a warning, not a fatal, so it's safe to leave it for our case.
|
|
|
|
// Callers will be suppressing warnings anyway.
|
|
|
|
$disabled = array_filter(array_map('trim', explode(',', ini_get('disable_functions'))));
|
|
|
|
if (!in_array('dl', $disabled)) {
|
|
|
|
function dl($library) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-03-23 00:54:23 +09:00
|
|
|
// global configuration object
|
2010-10-16 05:33:26 +09:00
|
|
|
|
2013-10-05 03:49:07 +09:00
|
|
|
require_once 'PEAR.php';
|
|
|
|
require_once 'PEAR/Exception.php';
|
|
|
|
global $_PEAR;
|
|
|
|
$_PEAR = new PEAR;
|
|
|
|
$_PEAR->setErrorHandling(PEAR_ERROR_CALLBACK, 'PEAR_ErrorToPEAR_Exception');
|
|
|
|
|
|
|
|
require_once 'DB.php';
|
|
|
|
require_once 'DB/DataObject.php';
|
|
|
|
require_once 'DB/DataObject/Cast.php'; # for dates
|
|
|
|
global $_DB;
|
|
|
|
$_DB = new DB;
|
2010-10-16 05:33:26 +09:00
|
|
|
|
|
|
|
require_once(INSTALLDIR.'/lib/language.php');
|
|
|
|
|
|
|
|
// This gets included before the config file, so that admin code and plugins
|
|
|
|
// can use it
|
|
|
|
|
|
|
|
require_once(INSTALLDIR.'/lib/event.php');
|
|
|
|
require_once(INSTALLDIR.'/lib/plugin.php');
|
|
|
|
|
2013-11-19 04:43:00 +09:00
|
|
|
function addPlugin($name, array $attrs=array())
|
2010-10-16 05:33:26 +09:00
|
|
|
{
|
|
|
|
return StatusNet::addPlugin($name, $attrs);
|
|
|
|
}
|
|
|
|
|
|
|
|
function _have_config()
|
|
|
|
{
|
|
|
|
return StatusNet::haveConfig();
|
|
|
|
}
|
|
|
|
|
|
|
|
function __autoload($cls)
|
|
|
|
{
|
|
|
|
if (file_exists(INSTALLDIR.'/classes/' . $cls . '.php')) {
|
|
|
|
require_once(INSTALLDIR.'/classes/' . $cls . '.php');
|
|
|
|
} else if (file_exists(INSTALLDIR.'/lib/' . strtolower($cls) . '.php')) {
|
|
|
|
require_once(INSTALLDIR.'/lib/' . strtolower($cls) . '.php');
|
|
|
|
} else if (mb_substr($cls, -6) == 'Action' &&
|
|
|
|
file_exists(INSTALLDIR.'/actions/' . strtolower(mb_substr($cls, 0, -6)) . '.php')) {
|
|
|
|
require_once(INSTALLDIR.'/actions/' . strtolower(mb_substr($cls, 0, -6)) . '.php');
|
|
|
|
} else if ($cls == 'OAuthRequest') {
|
|
|
|
require_once('OAuth.php');
|
|
|
|
} else {
|
|
|
|
Event::handle('Autoload', array(&$cls));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// XXX: how many of these could be auto-loaded on use?
|
|
|
|
// XXX: note that these files should not use config options
|
|
|
|
// at compile time since DB config options are not yet loaded.
|
|
|
|
|
|
|
|
require_once 'Validate.php';
|
|
|
|
require_once 'markdown.php';
|
|
|
|
|
|
|
|
// XXX: other formats here
|
|
|
|
|
2010-12-08 03:50:05 +09:00
|
|
|
/**
|
|
|
|
* Avoid the NICKNAME_FMT constant; use the Nickname class instead.
|
|
|
|
*
|
|
|
|
* Nickname::DISPLAY_FMT is more suitable for inserting into regexes;
|
|
|
|
* note that it includes the [] and repeating bits, so should be wrapped
|
|
|
|
* directly in a capture paren usually.
|
|
|
|
*
|
|
|
|
* For validation, use Nickname::normalize(), Nickname::isValid() etc.
|
|
|
|
*
|
|
|
|
* @deprecated
|
|
|
|
*/
|
2010-10-16 05:33:26 +09:00
|
|
|
define('NICKNAME_FMT', VALIDATE_NUM.VALIDATE_ALPHA_LOWER);
|
|
|
|
|
|
|
|
require_once INSTALLDIR.'/lib/util.php';
|
|
|
|
require_once INSTALLDIR.'/lib/action.php';
|
|
|
|
require_once INSTALLDIR.'/lib/mail.php';
|
|
|
|
|
|
|
|
require_once INSTALLDIR.'/lib/clientexception.php';
|
|
|
|
require_once INSTALLDIR.'/lib/serverexception.php';
|
|
|
|
|
|
|
|
|
|
|
|
//set PEAR error handling to use regular PHP exceptions
|
|
|
|
function PEAR_ErrorToPEAR_Exception($err)
|
|
|
|
{
|
|
|
|
//DB_DataObject throws error when an empty set would be returned
|
|
|
|
//That behavior is weird, and not how the rest of StatusNet works.
|
|
|
|
//So just ignore those errors.
|
|
|
|
if ($err->getCode() == DB_DATAOBJECT_ERROR_NODATA) {
|
|
|
|
return;
|
|
|
|
}
|
2011-09-30 23:46:51 +09:00
|
|
|
|
|
|
|
$msg = $err->getMessage();
|
|
|
|
$userInfo = $err->getUserInfo();
|
|
|
|
|
|
|
|
// Log this; push the message up as an exception
|
|
|
|
|
|
|
|
common_log(LOG_ERR, "PEAR Error: $msg ($userInfo)");
|
|
|
|
|
2011-11-26 23:54:41 +09:00
|
|
|
// HACK: queue handlers get kicked by the long-query killer, and
|
|
|
|
// keep the same broken connection. We die here to get a new
|
|
|
|
// process started.
|
|
|
|
|
2011-11-27 00:20:32 +09:00
|
|
|
if (php_sapi_name() == 'cli' && preg_match('/nativecode=2006/', $userInfo)) {
|
2011-11-26 23:54:41 +09:00
|
|
|
common_log(LOG_ERR, "Lost DB connection; dying.");
|
|
|
|
exit(100);
|
|
|
|
}
|
|
|
|
|
2010-10-16 05:33:26 +09:00
|
|
|
if ($err->getCode()) {
|
|
|
|
throw new PEAR_Exception($err->getMessage(), $err->getCode());
|
|
|
|
}
|
|
|
|
throw new PEAR_Exception($err->getMessage());
|
|
|
|
}
|