diff --git a/backend.php b/backend.php
index 077788dc7..7bbec8c5a 100644
--- a/backend.php
+++ b/backend.php
@@ -18,7 +18,6 @@
require_once "functions.php";
if ($op != "share") require_once "sessions.php";
- require_once "modules/backend-rpc.php";
require_once "sanity_check.php";
require_once "config.php";
require_once "db.php";
@@ -126,7 +125,7 @@
5 => __("Power User"),
10 => __("Administrator"));
-
+
$error = sanity_check($link);
@@ -137,7 +136,7 @@
switch($op) { // Select action according to $op value.
case "rpc":
- // Handle remote procedure calls.
+ require_once "modules/backend-rpc.php";
handle_rpc_request($link);
break; // rpc
@@ -394,7 +393,6 @@
$reply['runtime-info'] = make_runtime_info($link);
print json_encode($reply);
-
break; // viewfeed
case "pref-feeds":
diff --git a/functions.php b/functions.php
index 29489b40f..974d02a5e 100644
--- a/functions.php
+++ b/functions.php
@@ -90,14 +90,8 @@
}
require_once 'db-prefs.php';
- require_once 'errors.php';
require_once 'version.php';
- require_once 'lib/phpmailer/class.phpmailer.php';
- require_once 'lib/sphinxapi.php';
- require_once 'lib/tmhoauth/tmhOAuth.php';
-
- //define('MAGPIE_USER_AGENT_EXT', ' (Tiny Tiny RSS/' . VERSION . ')');
define('MAGPIE_OUTPUT_ENCODING', 'UTF-8');
define('SELF_USER_AGENT', 'Tiny Tiny RSS/' . VERSION . ' (http://tt-rss.org/)');
@@ -105,28 +99,9 @@
ini_set('user_agent', SELF_USER_AGENT);
- require_once "lib/simplepie/simplepie.inc";
- require_once "lib/magpierss/rss_fetch.inc";
- require_once 'lib/magpierss/rss_utils.inc';
- require_once 'lib/htmlpurifier/library/HTMLPurifier.auto.php';
require_once 'lib/pubsubhubbub/publisher.php';
- require_once 'lib/pubsubhubbub/subscriber.php';
- $config = HTMLPurifier_Config::createDefault();
-
- $allowed = "p,a[href],i,em,b,strong,code,pre,blockquote,br,img[src|alt|title],ul,ol,li,h1,h2,h3,h4,s,object[classid|type|id|name|width|height|codebase],param[name|value],table,tr,td";
-
- $config->set('HTML.SafeObject', true);
- @$config->set('HTML', 'Allowed', $allowed);
- $config->set('Output.FlashCompat', true);
- $config->set('Attr.EnableID', true);
- if (!defined('MOBILE_VERSION')) {
- @$config->set('Cache', 'SerializerPath', CACHE_DIR . "/htmlpurifier");
- } else {
- @$config->set('Cache', 'SerializerPath', "../" . CACHE_DIR . "/htmlpurifier");
- }
-
- $purifier = new HTMLPurifier($config);
+ $purifier = false;
$tz_offset = -1;
$utc_tz = new DateTimeZone('UTC');
@@ -437,6 +412,10 @@
function update_rss_feed_real($link, $feed, $ignore_daemon = false, $no_cache = false,
$override_url = false) {
+ require_once "lib/simplepie/simplepie.inc";
+ require_once "lib/magpierss/rss_fetch.inc";
+ require_once 'lib/magpierss/rss_utils.inc';
+
global $memcache;
$debug_enabled = defined('DAEMON_EXTENDED_DEBUG') || $_REQUEST['xdebug'];
@@ -764,6 +743,8 @@
if ($feed_hub_url && function_exists('curl_init') &&
!ini_get("open_basedir")) {
+ require_once 'lib/pubsubhubbub/subscriber.php';
+
$callback_url = get_self_url_prefix() .
"/public.php?op=pubsub&id=$feed";
@@ -874,6 +855,8 @@
if (!$entry_content) $entry_content = $item["content"]["encoded"];
if (!$entry_content) $entry_content = $item["content"];
+ if (is_array($entry_content)) $entry_content = $entry_content[0];
+
// Magpie bugs are getting ridiculous
if (trim($entry_content) == "Array") $entry_content = false;
@@ -2290,8 +2273,7 @@
}
function sanity_check($link) {
-
- global $ERRORS;
+ require_once 'errors.php';
$error_code = 0;
$schema_version = get_schema_version($link, true);
@@ -3775,9 +3757,28 @@
$res = trim($str); if (!$res) return '';
-// if (get_pref($link, "STRIP_UNSAFE_TAGS", $owner) || $force_strip_tags) {
+ // create global Purifier object if needed
+ if (!$purifier) {
+ require_once 'lib/htmlpurifier/library/HTMLPurifier.auto.php';
+
+ $config = HTMLPurifier_Config::createDefault();
+
+ $allowed = "p,a[href],i,em,b,strong,code,pre,blockquote,br,img[src|alt|title],ul,ol,li,h1,h2,h3,h4,s,object[classid|type|id|name|width|height|codebase],param[name|value],table,tr,td";
+
+ $config->set('HTML.SafeObject', true);
+ @$config->set('HTML', 'Allowed', $allowed);
+ $config->set('Output.FlashCompat', true);
+ $config->set('Attr.EnableID', true);
+ if (!defined('MOBILE_VERSION')) {
+ @$config->set('Cache', 'SerializerPath', CACHE_DIR . "/htmlpurifier");
+ } else {
+ @$config->set('Cache', 'SerializerPath', "../" . CACHE_DIR . "/htmlpurifier");
+ }
+
+ $purifier = new HTMLPurifier($config);
+ }
+
$res = $purifier->purify($res);
-// }
if (get_pref($link, "STRIP_IMAGES", $owner)) {
$res = preg_replace('/]+>/is', '', $res);
@@ -3844,6 +3845,8 @@
*/
function send_headlines_digests($link, $limit = 100) {
+ require_once 'lib/phpmailer/class.phpmailer.php';
+
if (!DIGEST_ENABLE) return false;
$user_limit = DIGEST_EMAIL_LIMIT;
@@ -7086,6 +7089,8 @@
}
function sphinx_search($query, $offset = 0, $limit = 30) {
+ require_once 'lib/sphinxapi.php';
+
$sphinxClient = new SphinxClient();
$sphinxClient->SetServer('localhost', 9312);
@@ -7203,6 +7208,9 @@
function fetch_twitter_rss($link, $url, $owner_uid) {
+
+ require_once 'lib/tmhoauth/tmhOAuth.php';
+
$result = db_query($link, "SELECT twitter_oauth FROM ttrss_users
WHERE id = $owner_uid");
diff --git a/modules/backend-rpc.php b/modules/backend-rpc.php
index d74c68464..34adc8f91 100644
--- a/modules/backend-rpc.php
+++ b/modules/backend-rpc.php
@@ -667,6 +667,8 @@
if ($subop == "sendEmail") {
$secretkey = $_REQUEST['secretkey'];
+ require_once 'lib/phpmailer/class.phpmailer.php';
+
$reply = array();
if (DIGEST_ENABLE && $_SESSION['email_secretkey'] &&
diff --git a/modules/pref-users.php b/modules/pref-users.php
index 984b2c55b..7be4eb437 100644
--- a/modules/pref-users.php
+++ b/modules/pref-users.php
@@ -285,6 +285,8 @@
$status_msg = format_notice(T_sprintf("Changed password of user %s
to %s", $login, $tmp_user_pwd));
+ require_once 'lib/phpmailer/class.phpmailer.php';
+
if ($email) {
$status_msg += format_notice(T_sprintf("Notifying %s.", $email));
diff --git a/register.php b/register.php
index 19fce7113..cc453c0f2 100644
--- a/register.php
+++ b/register.php
@@ -4,6 +4,8 @@
// 1) templates/register_notice.txt - displayed above the registration form
// 2) register_expire_do.php - contains user expiration queries when necessary
+ require_once 'lib/phpmailer/class.phpmailer.php';
+
$action = $_REQUEST["action"];
require_once "functions.php";