Move Cache to src
This commit is contained in:
Hypolite Petovan 2017-11-09 12:28:52 -05:00 committed by GitHub
commit 1474751f23
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
21 changed files with 1011 additions and 773 deletions

242
boot.php
View file

@ -18,10 +18,11 @@
* easily as email does today. * easily as email does today.
*/ */
require_once(__DIR__ . DIRECTORY_SEPARATOR . 'vendor' . DIRECTORY_SEPARATOR . 'autoload.php'); require_once __DIR__ . DIRECTORY_SEPARATOR . 'vendor' . DIRECTORY_SEPARATOR . 'autoload.php';
use Friendica\App; use Friendica\App;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\PConfig; use Friendica\Core\PConfig;
use Friendica\Core\Worker; use Friendica\Core\Worker;
@ -34,7 +35,6 @@ require_once 'include/text.php';
require_once 'include/datetime.php'; require_once 'include/datetime.php';
require_once 'include/pgettext.php'; require_once 'include/pgettext.php';
require_once 'include/nav.php'; require_once 'include/nav.php';
require_once 'include/cache.php';
require_once 'include/features.php'; require_once 'include/features.php';
require_once 'include/identity.php'; require_once 'include/identity.php';
require_once 'update.php'; require_once 'update.php';
@ -65,7 +65,6 @@ define ( 'ATOM_TIME', 'Y-m-d\TH:i:s\Z' );
* $a->config['system']['jpeg_quality'] = n; * $a->config['system']['jpeg_quality'] = n;
* in .htconfig.php, where n is netween 1 and 100, and with very poor results * in .htconfig.php, where n is netween 1 and 100, and with very poor results
* below about 50 * below about 50
*
*/ */
define('JPEG_QUALITY', 100); define('JPEG_QUALITY', 100);
@ -75,7 +74,6 @@ define ( 'JPEG_QUALITY', 100 );
define('PNG_QUALITY', 8); define('PNG_QUALITY', 8);
/** /**
*
* An alternate way of limiting picture upload sizes. Specify the maximum pixel * An alternate way of limiting picture upload sizes. Specify the maximum pixel
* length that pictures are allowed to be (for non-square pictures, it will apply * length that pictures are allowed to be (for non-square pictures, it will apply
* to the longest side). Pictures longer than this length will be resized to be * to the longest side). Pictures longer than this length will be resized to be
@ -88,7 +86,6 @@ define ( 'PNG_QUALITY', 8 );
* *
* If you don't want to set a maximum length, set to -1. The default value is * If you don't want to set a maximum length, set to -1. The default value is
* defined by 'MAX_IMAGE_LENGTH' below. * defined by 'MAX_IMAGE_LENGTH' below.
*
*/ */
define('MAX_IMAGE_LENGTH', -1); define('MAX_IMAGE_LENGTH', -1);
@ -146,7 +143,9 @@ define ( 'CACHE_MINUTE', 7 );
define('REGISTER_CLOSED', 0); define('REGISTER_CLOSED', 0);
define('REGISTER_APPROVE', 1); define('REGISTER_APPROVE', 1);
define('REGISTER_OPEN', 2); define('REGISTER_OPEN', 2);
/** @}*/ /**
* @}
*/
/** /**
* @name Contact_is * @name Contact_is
@ -157,7 +156,9 @@ define ( 'REGISTER_OPEN', 2 );
define('CONTACT_IS_FOLLOWER', 1); define('CONTACT_IS_FOLLOWER', 1);
define('CONTACT_IS_SHARING', 2); define('CONTACT_IS_SHARING', 2);
define('CONTACT_IS_FRIEND', 3); define('CONTACT_IS_FRIEND', 3);
/** @}*/ /**
* @}
*/
/** /**
* @name Update * @name Update
@ -167,7 +168,9 @@ define ( 'CONTACT_IS_FRIEND', 3);
*/ */
define('UPDATE_SUCCESS', 0); define('UPDATE_SUCCESS', 0);
define('UPDATE_FAILED', 1); define('UPDATE_FAILED', 1);
/** @}*/ /**
* @}
*/
/** /**
* @name page/profile types * @name page/profile types
@ -186,7 +189,9 @@ define ( 'PAGE_COMMUNITY', 2 );
define('PAGE_FREELOVE', 3); define('PAGE_FREELOVE', 3);
define('PAGE_BLOG', 4); define('PAGE_BLOG', 4);
define('PAGE_PRVGROUP', 5); define('PAGE_PRVGROUP', 5);
/** @}*/ /**
* @}
*/
/** /**
* @name account types * @name account types
@ -208,7 +213,9 @@ define ( 'ACCOUNT_TYPE_PERSON', 0 );
define('ACCOUNT_TYPE_ORGANISATION', 1); define('ACCOUNT_TYPE_ORGANISATION', 1);
define('ACCOUNT_TYPE_NEWS', 2); define('ACCOUNT_TYPE_NEWS', 2);
define('ACCOUNT_TYPE_COMMUNITY', 3); define('ACCOUNT_TYPE_COMMUNITY', 3);
/** @}*/ /**
* @}
*/
/** /**
* @name CP * @name CP
@ -219,7 +226,9 @@ define ( 'ACCOUNT_TYPE_COMMUNITY', 3 );
define('CP_NO_COMMUNITY_PAGE', -1); define('CP_NO_COMMUNITY_PAGE', -1);
define('CP_USERS_ON_SERVER', 0); define('CP_USERS_ON_SERVER', 0);
define('CP_GLOBAL_COMMUNITY', 1); define('CP_GLOBAL_COMMUNITY', 1);
/** @}*/ /**
* @}
*/
/** /**
* @name Protocols * @name Protocols
@ -234,7 +243,9 @@ define('PROTOCOL_OSTATUS_SALMON', 3);
define('PROTOCOL_OSTATUS_FEED', 4); // Deprecated define('PROTOCOL_OSTATUS_FEED', 4); // Deprecated
define('PROTOCOL_GS_CONVERSATION', 5); // Deprecated define('PROTOCOL_GS_CONVERSATION', 5); // Deprecated
define('PROTOCOL_SPLITTED_CONV', 6); define('PROTOCOL_SPLITTED_CONV', 6);
/** @}*/ /**
* @}
*/
/** /**
* @name Network * @name Network
@ -263,7 +274,9 @@ define ( 'NETWORK_NEWS', 'nntp'); // Network News Transfer Protoc
define('NETWORK_ICALENDAR', 'ical'); // iCalendar define('NETWORK_ICALENDAR', 'ical'); // iCalendar
define('NETWORK_PNUT', 'pnut'); // pnut.io define('NETWORK_PNUT', 'pnut'); // pnut.io
define('NETWORK_PHANTOM', 'unkn'); // Place holder define('NETWORK_PHANTOM', 'unkn'); // Place holder
/** @}*/ /**
* @}
*/
/** /**
* These numbers are used in stored permissions * These numbers are used in stored permissions
@ -474,13 +487,12 @@ if (!defined('CURLE_OPERATION_TIMEDOUT')) {
define('CURLE_OPERATION_TIMEDOUT', CURLE_OPERATION_TIMEOUTED); define('CURLE_OPERATION_TIMEDOUT', CURLE_OPERATION_TIMEOUTED);
} }
/** /**
*
* Reverse the effect of magic_quotes_gpc if it is enabled. * Reverse the effect of magic_quotes_gpc if it is enabled.
* Please disable magic_quotes_gpc so we don't have to do this. * Please disable magic_quotes_gpc so we don't have to do this.
* See http://php.net/manual/en/security.magicquotes.disabling.php * See http://php.net/manual/en/security.magicquotes.disabling.php
*
*/ */
function startup() { function startup()
{
error_reporting(E_ERROR | E_WARNING | E_PARSE); error_reporting(E_ERROR | E_WARNING | E_PARSE);
set_time_limit(0); set_time_limit(0);
@ -510,7 +522,8 @@ function startup() {
* *
* Useful in functions which require it but don't get it passed to them * Useful in functions which require it but don't get it passed to them
*/ */
function get_app() { function get_app()
{
global $a; global $a;
if (empty($a)) { if (empty($a)) {
@ -534,8 +547,9 @@ function get_app() {
* *
* @return bool|int * @return bool|int
*/ */
function x($s, $k = NULL) { function x($s, $k = null)
if ($k != NULL) { {
if ($k != null) {
if ((is_array($s)) && (array_key_exists($k, $s))) { if ((is_array($s)) && (array_key_exists($k, $s))) {
if ($s[$k]) { if ($s[$k]) {
return (int) 1; return (int) 1;
@ -557,8 +571,9 @@ function x($s, $k = NULL) {
/** /**
* @brief Called from db initialisation if db is dead. * @brief Called from db initialisation if db is dead.
*/ */
function system_unavailable() { function system_unavailable()
include('system_unavailable.php'); {
include 'system_unavailable.php';
system_down(); system_down();
killme(); killme();
} }
@ -571,18 +586,20 @@ function system_unavailable() {
* @return string * @return string
* @TODO Function is deprecated and only used in some addons * @TODO Function is deprecated and only used in some addons
*/ */
function z_root() { function z_root()
{
return System::baseUrl(); return System::baseUrl();
} }
/** /**
* @brief Return absolut URL for given $path. * @brief Return absolut URL for given $path.
* *
* @param string $path * @param string $path given path
* *
* @return string * @return string
*/ */
function absurl($path) { function absurl($path)
{
if (strpos($path, '/') === 0) { if (strpos($path, '/') === 0) {
return z_path() . $path; return z_path() . $path;
} }
@ -594,17 +611,18 @@ function absurl($path) {
* *
* @return boolean * @return boolean
*/ */
function is_ajax() { function is_ajax()
{
return (!empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest'); return (!empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest');
} }
/** /**
* @brief Function to check if request was an AJAX (xmlhttprequest) request. * @brief Function to check if request was an AJAX (xmlhttprequest) request.
* *
* @param $via_worker boolean Is the check run via the poller? * @param boolean $via_worker boolean Is the check run via the poller?
*/ */
function check_db($via_worker) { function check_db($via_worker)
{
$build = Config::get('system', 'build'); $build = Config::get('system', 'build');
if (!x($build)) { if (!x($build)) {
Config::set('system', 'build', DB_UPDATE_VERSION); Config::set('system', 'build', DB_UPDATE_VERSION);
@ -621,9 +639,11 @@ function check_db($via_worker) {
/** /**
* Sets the base url for use in cmdline programs which don't have * Sets the base url for use in cmdline programs which don't have
* $_SERVER variables * $_SERVER variables
*
* @param object $a App
*/ */
function check_url(App $a) { function check_url(App $a)
{
$url = Config::get('system', 'url'); $url = Config::get('system', 'url');
// if the url isn't set or the stored url is radically different // if the url isn't set or the stored url is radically different
@ -644,8 +664,10 @@ function check_url(App $a) {
/** /**
* @brief Automatic database updates * @brief Automatic database updates
* @param object $a App
*/ */
function update_db(App $a) { function update_db(App $a)
{
$build = Config::get('system', 'build'); $build = Config::get('system', 'build');
if (!x($build)) { if (!x($build)) {
$build = Config::set('system', 'build', DB_UPDATE_VERSION); $build = Config::set('system', 'build', DB_UPDATE_VERSION);
@ -712,9 +734,9 @@ function update_db(App $a) {
return; return;
} }
function run_update_function($x) { function run_update_function($x)
{
if (function_exists('update_' . $x)) { if (function_exists('update_' . $x)) {
// There could be a lot of processes running or about to run. // There could be a lot of processes running or about to run.
// We want exactly one process to run the update command. // We want exactly one process to run the update command.
// So store the fact that we're taking responsibility // So store the fact that we're taking responsibility
@ -764,11 +786,10 @@ function run_update_function($x) {
* Then go through the config list and if we have a plugin that isn't installed, * Then go through the config list and if we have a plugin that isn't installed,
* call the install procedure and add it to the database. * call the install procedure and add it to the database.
* *
* @param App $a * @param object $a App
*
*/ */
function check_plugins(App $a) { function check_plugins(App $a)
{
$r = q("SELECT * FROM `addon` WHERE `installed` = 1"); $r = q("SELECT * FROM `addon` WHERE `installed` = 1");
if (DBM::is_result($r)) { if (DBM::is_result($r)) {
$installed = $r; $installed = $r;
@ -810,7 +831,8 @@ function check_plugins(App $a) {
return; return;
} }
function get_guid($size = 16, $prefix = "") { function get_guid($size = 16, $prefix = "")
{
if ($prefix == "") { if ($prefix == "") {
$a = get_app(); $a = get_app();
$prefix = hash("crc32", $a->get_hostname()); $prefix = hash("crc32", $a->get_hostname());
@ -832,18 +854,17 @@ function get_guid($size = 16, $prefix = "") {
/** /**
* @brief Wrapper for adding a login box. * @brief Wrapper for adding a login box.
* *
* @param bool $register * @param bool $register If $register == true provide a registration link.
* If $register == true provide a registration link.
* This will most always depend on the value of $a->config['register_policy']. * This will most always depend on the value of $a->config['register_policy'].
* @param bool $hiddens * @param bool $hiddens optional
* *
* @return string * @return string Returns the complete html for inserting into the page
* Returns the complete html for inserting into the page
* *
* @hooks 'login_hook' * @hooks 'login_hook'
* string $o * string $o
*/ */
function login($register = false, $hiddens = false) { function login($register = false, $hiddens = false)
{
$a = get_app(); $a = get_app();
$o = ""; $o = "";
$reg = false; $reg = false;
@ -861,17 +882,21 @@ function login($register = false, $hiddens = false) {
if (local_user()) { if (local_user()) {
$tpl = get_markup_template("logout.tpl"); $tpl = get_markup_template("logout.tpl");
} else { } else {
$a->page['htmlhead'] .= replace_macros(get_markup_template("login_head.tpl"), array( $a->page['htmlhead'] .= replace_macros(
get_markup_template("login_head.tpl"),
array(
'$baseurl' => $a->get_baseurl(true) '$baseurl' => $a->get_baseurl(true)
)); )
);
$tpl = get_markup_template("login.tpl"); $tpl = get_markup_template("login.tpl");
$_SESSION['return_url'] = $a->query_string; $_SESSION['return_url'] = $a->query_string;
$a->module = 'login'; $a->module = 'login';
} }
$o .= replace_macros($tpl, array( $o .= replace_macros(
$tpl,
array(
'$dest_url' => $dest_url, '$dest_url' => $dest_url,
'$logout' => t('Logout'), '$logout' => t('Logout'),
'$login' => t('Login'), '$login' => t('Login'),
@ -895,7 +920,8 @@ function login($register = false, $hiddens = false) {
'$privacytitle' => t('Website Privacy Policy'), '$privacytitle' => t('Website Privacy Policy'),
'$privacylink' => t('privacy policy'), '$privacylink' => t('privacy policy'),
)); )
);
call_hooks('login_hook', $o); call_hooks('login_hook', $o);
@ -905,7 +931,8 @@ function login($register = false, $hiddens = false) {
/** /**
* @brief Used to end the current process, after saving session state. * @brief Used to end the current process, after saving session state.
*/ */
function killme() { function killme()
{
global $session_exists; global $session_exists;
if (!get_app()->is_backend()) { if (!get_app()->is_backend()) {
@ -922,7 +949,8 @@ function killme() {
/** /**
* @brief Redirect to another URL and terminate this process. * @brief Redirect to another URL and terminate this process.
*/ */
function goaway($s) { function goaway($s)
{
if (!strstr(normalise_link($s), "http://")) { if (!strstr(normalise_link($s), "http://")) {
$s = System::baseUrl() . "/" . $s; $s = System::baseUrl() . "/" . $s;
} }
@ -936,7 +964,8 @@ function goaway($s) {
* *
* @return int|bool user id or false * @return int|bool user id or false
*/ */
function local_user() { function local_user()
{
if (x($_SESSION, 'authenticated') && x($_SESSION, 'uid')) { if (x($_SESSION, 'authenticated') && x($_SESSION, 'uid')) {
return intval($_SESSION['uid']); return intval($_SESSION['uid']);
} }
@ -948,7 +977,8 @@ function local_user() {
* *
* @return int|bool public contact id or false * @return int|bool public contact id or false
*/ */
function public_contact() { function public_contact()
{
static $public_contact_id = false; static $public_contact_id = false;
if (!$public_contact_id && x($_SESSION, 'authenticated')) { if (!$public_contact_id && x($_SESSION, 'authenticated')) {
@ -971,7 +1001,8 @@ function public_contact() {
* *
* @return int|bool visitor_id or false * @return int|bool visitor_id or false
*/ */
function remote_user() { function remote_user()
{
// You cannot be both local and remote // You cannot be both local and remote
if (local_user()) { if (local_user()) {
return false; return false;
@ -989,7 +1020,8 @@ function remote_user() {
* *
* @param string $s - Text of notice * @param string $s - Text of notice
*/ */
function notice($s) { function notice($s)
{
$a = get_app(); $a = get_app();
if (!x($_SESSION, 'sysmsg')) { if (!x($_SESSION, 'sysmsg')) {
$_SESSION['sysmsg'] = array(); $_SESSION['sysmsg'] = array();
@ -1006,7 +1038,8 @@ function notice($s) {
* *
* @param string $s - Text of notice * @param string $s - Text of notice
*/ */
function info($s) { function info($s)
{
$a = get_app(); $a = get_app();
if (local_user() && PConfig::get(local_user(), 'system', 'ignore_info')) { if (local_user() && PConfig::get(local_user(), 'system', 'ignore_info')) {
@ -1026,7 +1059,8 @@ function info($s) {
* *
* @return int * @return int
*/ */
function get_max_import_size() { function get_max_import_size()
{
$a = get_app(); $a = get_app();
return ((x($a->config, 'max_import_size')) ? $a->config['max_import_size'] : 0 ); return ((x($a->config, 'max_import_size')) ? $a->config['max_import_size'] : 0 );
} }
@ -1038,12 +1072,14 @@ function get_max_import_size() {
* *
* @return boolean "false" if proc_run couldn't be executed * @return boolean "false" if proc_run couldn't be executed
*/ */
function proc_run() { function proc_run()
{
$proc_args = func_get_args(); $proc_args = func_get_args();
call_user_func_array('Friendica\Core\Worker::add', $proc_args); call_user_func_array('Friendica\Core\Worker::add', $proc_args);
} }
function current_theme() { function current_theme()
{
$app_base_themes = array('duepuntozero', 'dispy', 'quattro'); $app_base_themes = array('duepuntozero', 'dispy', 'quattro');
$a = get_app(); $a = get_app();
@ -1053,7 +1089,8 @@ function current_theme() {
// Find the theme that belongs to the user whose stuff we are looking at // Find the theme that belongs to the user whose stuff we are looking at
if ($a->profile_uid && ($a->profile_uid != local_user())) { if ($a->profile_uid && ($a->profile_uid != local_user())) {
$r = q("select theme from user where uid = %d limit 1", $r = q(
"select theme from user where uid = %d limit 1",
intval($a->profile_uid) intval($a->profile_uid)
); );
if (DBM::is_result($r)) { if (DBM::is_result($r)) {
@ -1107,15 +1144,17 @@ function current_theme() {
} }
} }
if ($theme_name && if ($theme_name
(file_exists('view/theme/' . $theme_name . '/style.css') || && (file_exists('view/theme/' . $theme_name . '/style.css')
file_exists('view/theme/' . $theme_name . '/style.php'))) { || file_exists('view/theme/' . $theme_name . '/style.php'))
) {
return($theme_name); return($theme_name);
} }
foreach ($app_base_themes as $t) { foreach ($app_base_themes as $t) {
if (file_exists('view/theme/' . $t . '/style.css') || if (file_exists('view/theme/' . $t . '/style.css')
file_exists('view/theme/' . $t . '/style.php')) { || file_exists('view/theme/' . $t . '/style.php')
) {
return($t); return($t);
} }
} }
@ -1135,7 +1174,8 @@ function current_theme() {
* *
* @return string * @return string
*/ */
function current_theme_url() { function current_theme_url()
{
$a = get_app(); $a = get_app();
$t = current_theme(); $t = current_theme();
@ -1148,10 +1188,9 @@ function current_theme_url() {
return('view/theme/' . $t . '/style.css'); return('view/theme/' . $t . '/style.css');
} }
function feed_birthday($uid, $tz) { function feed_birthday($uid, $tz)
{
/** /**
*
* Determine the next birthday, but only if the birthday is published * Determine the next birthday, but only if the birthday is published
* in the default profile. We _could_ also look for a private profile that the * in the default profile. We _could_ also look for a private profile that the
* recipient can see, but somebody could get mad at us if they start getting * recipient can see, but somebody could get mad at us if they start getting
@ -1166,7 +1205,6 @@ function feed_birthday($uid, $tz) {
* viewer's timezone also, but first we are going to convert it from the birthday * viewer's timezone also, but first we are going to convert it from the birthday
* person's timezone to GMT - so the viewer may find the birthday starting at * person's timezone to GMT - so the viewer may find the birthday starting at
* 6:00PM the day before, but that will correspond to midnight to the birthday person. * 6:00PM the day before, but that will correspond to midnight to the birthday person.
*
*/ */
$birthday = ''; $birthday = '';
@ -1174,7 +1212,8 @@ function feed_birthday($uid, $tz) {
$tz = 'UTC'; $tz = 'UTC';
} }
$p = q("SELECT `dob` FROM `profile` WHERE `is-default` = 1 AND `uid` = %d LIMIT 1", $p = q(
"SELECT `dob` FROM `profile` WHERE `is-default` = 1 AND `uid` = %d LIMIT 1",
intval($uid) intval($uid)
); );
@ -1200,7 +1239,8 @@ function feed_birthday($uid, $tz) {
* *
* @return bool true if user is an admin * @return bool true if user is an admin
*/ */
function is_site_admin() { function is_site_admin()
{
$a = get_app(); $a = get_app();
$adminlist = explode(",", str_replace(" ", "", $a->config['admin_email'])); $adminlist = explode(",", str_replace(" ", "", $a->config['admin_email']));
@ -1220,7 +1260,8 @@ function is_site_admin() {
* *
* @return string * @return string
*/ */
function build_querystring($params, $name = null) { function build_querystring($params, $name = null)
{
$ret = ""; $ret = "";
foreach ($params as $key => $val) { foreach ($params as $key => $val) {
if (is_array($val)) { if (is_array($val)) {
@ -1244,7 +1285,8 @@ function build_querystring($params, $name = null) {
return $ret; return $ret;
} }
function explode_querystring($query) { function explode_querystring($query)
{
$arg_st = strpos($query, '?'); $arg_st = strpos($query, '?');
if ($arg_st !== false) { if ($arg_st !== false) {
$base = substr($query, 0, $arg_st); $base = substr($query, 0, $arg_st);
@ -1280,7 +1322,8 @@ function explode_querystring($query) {
* *
* Taken from http://webcheatsheet.com/php/get_current_page_url.php * Taken from http://webcheatsheet.com/php/get_current_page_url.php
*/ */
function curPageURL() { function curPageURL()
{
$pageURL = 'http'; $pageURL = 'http';
if ($_SERVER["HTTPS"] == "on") { if ($_SERVER["HTTPS"] == "on") {
$pageURL .= "s"; $pageURL .= "s";
@ -1296,7 +1339,8 @@ function curPageURL() {
return $pageURL; return $pageURL;
} }
function random_digits($digits) { function random_digits($digits)
{
$rn = ''; $rn = '';
for ($i = 0; $i < $digits; $i++) { for ($i = 0; $i < $digits; $i++) {
/// @TODO rand() is different to mt_rand() and maybe lesser "random" /// @TODO rand() is different to mt_rand() and maybe lesser "random"
@ -1305,7 +1349,8 @@ function random_digits($digits) {
return $rn; return $rn;
} }
function get_server() { function get_server()
{
$server = Config::get("system", "directory"); $server = Config::get("system", "directory");
if ($server == "") { if ($server == "") {
@ -1315,7 +1360,8 @@ function get_server() {
return($server); return($server);
} }
function get_temppath() { function get_temppath()
{
$a = get_app(); $a = get_app();
$temppath = Config::get("system", "temppath"); $temppath = Config::get("system", "temppath");
@ -1355,7 +1401,8 @@ function get_temppath() {
return ''; return '';
} }
function get_cachefile($file, $writemode = true) { function get_cachefile($file, $writemode = true)
{
$cache = get_itemcachepath(); $cache = get_itemcachepath();
if ((!$cache) || (!is_dir($cache))) { if ((!$cache) || (!is_dir($cache))) {
@ -1377,7 +1424,8 @@ function get_cachefile($file, $writemode = true) {
return $cachepath; return $cachepath;
} }
function clear_cache($basepath = "", $path = "") { function clear_cache($basepath = "", $path = "")
{
if ($path == "") { if ($path == "") {
$basepath = get_itemcachepath(); $basepath = get_itemcachepath();
$path = $basepath; $path = $basepath;
@ -1412,7 +1460,8 @@ function clear_cache($basepath = "", $path = "") {
} }
} }
function get_itemcachepath() { function get_itemcachepath()
{
// Checking, if the cache is deactivated // Checking, if the cache is deactivated
$cachetime = (int) Config::get('system', 'itemcache_duration'); $cachetime = (int) Config::get('system', 'itemcache_duration');
if ($cachetime < 0) { if ($cachetime < 0) {
@ -1445,7 +1494,8 @@ function get_itemcachepath() {
* *
* @return string Spool path * @return string Spool path
*/ */
function get_spoolpath() { function get_spoolpath()
{
$spoolpath = Config::get('system', 'spoolpath'); $spoolpath = Config::get('system', 'spoolpath');
if (($spoolpath != "") && App::directory_usable($spoolpath)) { if (($spoolpath != "") && App::directory_usable($spoolpath)) {
// We have a spool path and it is usable // We have a spool path and it is usable
@ -1478,7 +1528,8 @@ function get_spoolpath() {
} }
/// @deprecated /// @deprecated
function set_template_engine(App $a, $engine = 'internal') { function set_template_engine(App $a, $engine = 'internal')
{
/// @note This function is no longer necessary, but keep it as a wrapper to the class method /// @note This function is no longer necessary, but keep it as a wrapper to the class method
/// to avoid breaking themes again unnecessarily /// to avoid breaking themes again unnecessarily
/// @TODO maybe output a warning here so the theme developer can see it? PHP won't show such warnings like Java does. /// @TODO maybe output a warning here so the theme developer can see it? PHP won't show such warnings like Java does.
@ -1487,13 +1538,15 @@ function set_template_engine(App $a, $engine = 'internal') {
} }
if (!function_exists('exif_imagetype')) { if (!function_exists('exif_imagetype')) {
function exif_imagetype($file) { function exif_imagetype($file)
{
$size = getimagesize($file); $size = getimagesize($file);
return $size[2]; return $size[2];
} }
} }
function validate_include(&$file) { function validate_include(&$file)
{
$orig_file = $file; $orig_file = $file;
$file = realpath($file); $file = realpath($file);
@ -1524,7 +1577,8 @@ function validate_include(&$file) {
return ($valid); return ($valid);
} }
function current_load() { function current_load()
{
if (!function_exists('sys_getloadavg')) { if (!function_exists('sys_getloadavg')) {
return false; return false;
} }
@ -1543,7 +1597,8 @@ function current_load() {
* *
* @return int * @return int
*/ */
function argc() { function argc()
{
return get_app()->argc; return get_app()->argc;
} }
@ -1553,7 +1608,8 @@ function argc() {
* @param int $x argv key * @param int $x argv key
* @return string Value of the argv key * @return string Value of the argv key
*/ */
function argv($x) { function argv($x)
{
if (array_key_exists($x, get_app()->argv)) { if (array_key_exists($x, get_app()->argv)) {
return get_app()->argv[$x]; return get_app()->argv[$x];
} }
@ -1574,11 +1630,11 @@ function argv($x) {
* 'pageno' => $pageno The number of the actual page * 'pageno' => $pageno The number of the actual page
* 'reload_uri' => $reload_uri The URI of the content we have to load * 'reload_uri' => $reload_uri The URI of the content we have to load
*/ */
function infinite_scroll_data($module) { function infinite_scroll_data($module)
{
if (PConfig::get(local_user(), 'system', 'infinite_scroll') if (PConfig::get(local_user(), 'system', 'infinite_scroll')
&& ($module == "network") && ($_GET["mode"] != "minimal")) { && ($module == "network") && ($_GET["mode"] != "minimal")
) {
// get the page number // get the page number
if (is_string($_GET["page"])) { if (is_string($_GET["page"])) {
$pageno = $_GET["page"]; $pageno = $_GET["page"];
@ -1589,7 +1645,7 @@ function infinite_scroll_data($module) {
$reload_uri = ""; $reload_uri = "";
// try to get the uri from which we load the content // try to get the uri from which we load the content
foreach ($_GET AS $param => $value) { foreach ($_GET as $param => $value) {
if (($param != "page") && ($param != "q")) { if (($param != "page") && ($param != "q")) {
$reload_uri .= "&" . $param . "=" . urlencode($value); $reload_uri .= "&" . $param . "=" . urlencode($value);
} }

View file

@ -5,6 +5,7 @@
*/ */
use Friendica\App; use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\Database\DBM; use Friendica\Database\DBM;

View file

@ -1,6 +1,7 @@
<?php <?php
use Friendica\App; use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\Core\Config; use Friendica\Core\Config;

View file

@ -1,6 +1,7 @@
<?php <?php
use Friendica\App; use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Database\DBM; use Friendica\Database\DBM;
use Friendica\Network\Probe; use Friendica\Network\Probe;

View file

@ -1,5 +1,5 @@
<?php <?php
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\Worker; use Friendica\Core\Worker;
use Friendica\Database\DBM; use Friendica\Database\DBM;

View file

@ -1,5 +1,5 @@
<?php <?php
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Database\DBM; use Friendica\Database\DBM;
use Friendica\Network\Probe; use Friendica\Network\Probe;

View file

@ -4,6 +4,7 @@
*/ */
use Friendica\App; use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\PConfig; use Friendica\Core\PConfig;
use Friendica\Core\System; use Friendica\Core\System;
@ -13,7 +14,6 @@ use Friendica\Database\DBM;
require_once 'include/ForumManager.php'; require_once 'include/ForumManager.php';
require_once 'include/bbcode.php'; require_once 'include/bbcode.php';
require_once 'mod/proxy.php'; require_once 'mod/proxy.php';
require_once 'include/cache.php';
/** /**
* *
@ -34,14 +34,15 @@ require_once 'include/cache.php';
* the theme is chosen before the _init() function of a theme is run, which will usually * the theme is chosen before the _init() function of a theme is run, which will usually
* load a lot of theme-specific content * load a lot of theme-specific content
* *
* @param App $a * @param object $a App
* @param string $nickname * @param string $nickname string
* @param int $profile * @param int $profile int
* @param array $profiledata * @param array $profiledata array
*/ */
function profile_load(App $a, $nickname, $profile = 0, $profiledata = array()) { function profile_load(App $a, $nickname, $profile = 0, $profiledata = array())
{
$user = q("SELECT `uid` FROM `user` WHERE `nickname` = '%s' LIMIT 1", $user = q(
"SELECT `uid` FROM `user` WHERE `nickname` = '%s' LIMIT 1",
dbesc($nickname) dbesc($nickname)
); );
@ -64,7 +65,8 @@ function profile_load(App $a, $nickname, $profile = 0, $profiledata = array()) {
// fetch user tags if this isn't the default profile // fetch user tags if this isn't the default profile
if (!$pdata['is-default']) { if (!$pdata['is-default']) {
$x = q("SELECT `pub_keywords` FROM `profile` WHERE `uid` = %d AND `is-default` = 1 LIMIT 1", $x = q(
"SELECT `pub_keywords` FROM `profile` WHERE `uid` = %d AND `is-default` = 1 LIMIT 1",
intval($pdata['profile_uid']) intval($pdata['profile_uid'])
); );
if ($x && count($x)) if ($x && count($x))
@ -79,8 +81,9 @@ function profile_load(App $a, $nickname, $profile = 0, $profiledata = array()) {
$a->page['title'] = $a->profile['name'] . " @ " . $a->config['sitename']; $a->page['title'] = $a->profile['name'] . " @ " . $a->config['sitename'];
if (!$profiledata && !PConfig::get(local_user(),'system','always_my_theme')) if (!$profiledata && !PConfig::get(local_user(), 'system', 'always_my_theme')) {
$_SESSION['theme'] = $a->profile['theme']; $_SESSION['theme'] = $a->profile['theme'];
}
$_SESSION['mobile-theme'] = $a->profile['mobile-theme']; $_SESSION['mobile-theme'] = $a->profile['mobile-theme'];
@ -95,14 +98,18 @@ function profile_load(App $a, $nickname, $profile = 0, $profiledata = array()) {
require_once $theme_info_file; require_once $theme_info_file;
} }
if (! (x($a->page,'aside'))) if (! (x($a->page, 'aside'))) {
$a->page['aside'] = ''; $a->page['aside'] = '';
}
if (local_user() && local_user() == $a->profile['uid'] && $profiledata) { if (local_user() && local_user() == $a->profile['uid'] && $profiledata) {
$a->page['aside'] .= replace_macros(get_markup_template('profile_edlink.tpl'),array( $a->page['aside'] .= replace_macros(
get_markup_template('profile_edlink.tpl'),
array(
'$editprofile' => t('Edit profile'), '$editprofile' => t('Edit profile'),
'$profid' => $a->profile['id'] '$profid' => $a->profile['id']
)); )
);
} }
$block = (((Config::get('system', 'block_public')) && (! local_user()) && (! remote_user())) ? true : false); $block = (((Config::get('system', 'block_public')) && (! local_user()) && (! remote_user())) ? true : false);
@ -112,10 +119,11 @@ function profile_load(App $a, $nickname, $profile = 0, $profiledata = array()) {
* By now, the contact block isn't shown, when a different profile is given * By now, the contact block isn't shown, when a different profile is given
* But: When this profile was on the same server, then we could display the contacts * But: When this profile was on the same server, then we could display the contacts
*/ */
if ($profiledata) if ($profiledata) {
$a->page['aside'] .= profile_sidebar($profiledata, true); $a->page['aside'] .= profile_sidebar($profiledata, true);
else } else {
$a->page['aside'] .= profile_sidebar($a->profile, $block); $a->page['aside'] .= profile_sidebar($a->profile, $block);
}
/*if (! $block) /*if (! $block)
$a->page['aside'] .= contact_block();*/ $a->page['aside'] .= contact_block();*/
@ -132,14 +140,14 @@ function profile_load(App $a, $nickname, $profile = 0, $profiledata = array()) {
* Passing a non-zero profile ID can also allow a preview of a selected profile * Passing a non-zero profile ID can also allow a preview of a selected profile
* by the owner * by the owner
* *
* @param string $nickname * @param string $nickname nick
* @param int $uid * @param int $uid uid
* @param int $profile * @param int $profile ID of the profile
* ID of the profile
* @returns array * @returns array
* Includes all available profile data * Includes all available profile data
*/ */
function get_profiledata_by_nick($nickname, $uid = 0, $profile = 0) { function get_profiledata_by_nick($nickname, $uid = 0, $profile = 0)
{
if (remote_user() && count($_SESSION['remote'])) { if (remote_user() && count($_SESSION['remote'])) {
foreach ($_SESSION['remote'] as $visitor) { foreach ($_SESSION['remote'] as $visitor) {
if ($visitor['uid'] == $uid) { if ($visitor['uid'] == $uid) {
@ -156,7 +164,8 @@ function get_profiledata_by_nick($nickname, $uid = 0, $profile = 0) {
if ($profile) { if ($profile) {
$profile_int = intval($profile); $profile_int = intval($profile);
$r = dba::fetch_first("SELECT `contact`.`id` AS `contact_id`, `contact`.`photo` AS `contact_photo`, $r = dba::fetch_first(
"SELECT `contact`.`id` AS `contact_id`, `contact`.`photo` AS `contact_photo`,
`contact`.`thumb` AS `contact_thumb`, `contact`.`micro` AS `contact_micro`, `contact`.`thumb` AS `contact_thumb`, `contact`.`micro` AS `contact_micro`,
`profile`.`uid` AS `profile_uid`, `profile`.*, `profile`.`uid` AS `profile_uid`, `profile`.*,
`contact`.`avatar-date` AS picdate, `contact`.`addr`, `user`.* `contact`.`avatar-date` AS picdate, `contact`.`addr`, `user`.*
@ -169,7 +178,8 @@ function get_profiledata_by_nick($nickname, $uid = 0, $profile = 0) {
); );
} }
if (!DBM::is_result($r)) { if (!DBM::is_result($r)) {
$r = dba::fetch_first("SELECT `contact`.`id` AS `contact_id`, `contact`.`photo` as `contact_photo`, $r = dba::fetch_first(
"SELECT `contact`.`id` AS `contact_id`, `contact`.`photo` as `contact_photo`,
`contact`.`thumb` AS `contact_thumb`, `contact`.`micro` AS `contact_micro`, `contact`.`thumb` AS `contact_thumb`, `contact`.`micro` AS `contact_micro`,
`profile`.`uid` AS `profile_uid`, `profile`.*, `profile`.`uid` AS `profile_uid`, `profile`.*,
`contact`.`avatar-date` AS picdate, `contact`.`addr`, `user`.* `contact`.`avatar-date` AS picdate, `contact`.`addr`, `user`.*
@ -203,7 +213,8 @@ function get_profiledata_by_nick($nickname, $uid = 0, $profile = 0) {
* @hooks 'profile_sidebar' * @hooks 'profile_sidebar'
* array $arr * array $arr
*/ */
function profile_sidebar($profile, $block = 0) { function profile_sidebar($profile, $block = 0)
{
$a = get_app(); $a = get_app();
$o = ''; $o = '';
@ -230,7 +241,7 @@ function profile_sidebar($profile, $block = 0) {
// don't show connect link to yourself // don't show connect link to yourself
$connect = (($profile['uid'] != local_user()) ? t('Connect') : False); $connect = (($profile['uid'] != local_user()) ? t('Connect') : false);
// don't show connect link to authenticated visitors either // don't show connect link to authenticated visitors either
if (remote_user() && count($_SESSION['remote'])) { if (remote_user() && count($_SESSION['remote'])) {
@ -258,7 +269,7 @@ function profile_sidebar($profile, $block = 0) {
if ($connect && ($profile['network'] != NETWORK_DFRN) && !isset($profile['remoteconnect'])) if ($connect && ($profile['network'] != NETWORK_DFRN) && !isset($profile['remoteconnect']))
$connect = false; $connect = false;
$remoteconnect = NULL; $remoteconnect = null;
if (isset($profile['remoteconnect'])) if (isset($profile['remoteconnect']))
$remoteconnect = $profile['remoteconnect']; $remoteconnect = $profile['remoteconnect'];
@ -272,15 +283,19 @@ function profile_sidebar($profile, $block = 0) {
$wallmessage_link = "wallmessage/".$profile["nickname"]; $wallmessage_link = "wallmessage/".$profile["nickname"];
if (remote_user()) { if (remote_user()) {
$r = q("SELECT `url` FROM `contact` WHERE `uid` = %d AND `id` = '%s' AND `rel` = %d", $r = q(
"SELECT `url` FROM `contact` WHERE `uid` = %d AND `id` = '%s' AND `rel` = %d",
intval($profile['uid']), intval($profile['uid']),
intval(remote_user()), intval(remote_user()),
intval(CONTACT_IS_FRIEND)); intval(CONTACT_IS_FRIEND)
);
} else { } else {
$r = q("SELECT `url` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s' AND `rel` = %d", $r = q(
"SELECT `url` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s' AND `rel` = %d",
intval($profile['uid']), intval($profile['uid']),
dbesc(normalise_link(get_my_url())), dbesc(normalise_link(get_my_url())),
intval(CONTACT_IS_FRIEND)); intval(CONTACT_IS_FRIEND)
);
} }
if ($r) { if ($r) {
$remote_url = $r[0]["url"]; $remote_url = $r[0]["url"];
@ -295,8 +310,10 @@ function profile_sidebar($profile, $block = 0) {
// show edit profile to yourself // show edit profile to yourself
if (!$is_contact && $profile['uid'] == local_user() && feature_enabled(local_user(), 'multi_profiles')) { if (!$is_contact && $profile['uid'] == local_user() && feature_enabled(local_user(), 'multi_profiles')) {
$profile['edit'] = array(System::baseUrl(). '/profiles', t('Profiles'),"", t('Manage/edit profiles')); $profile['edit'] = array(System::baseUrl(). '/profiles', t('Profiles'),"", t('Manage/edit profiles'));
$r = q("SELECT * FROM `profile` WHERE `uid` = %d", $r = q(
local_user()); "SELECT * FROM `profile` WHERE `uid` = %d",
local_user()
);
$profile['menu'] = array( $profile['menu'] = array(
'chg_photo' => t('Change profile photo'), 'chg_photo' => t('Change profile photo'),
@ -305,7 +322,6 @@ function profile_sidebar($profile, $block = 0) {
); );
if (DBM::is_result($r)) { if (DBM::is_result($r)) {
foreach ($r as $rr) { foreach ($r as $rr) {
$profile['menu']['entries'][] = array( $profile['menu']['entries'][] = array(
'photo' => $rr['thumb'], 'photo' => $rr['thumb'],
@ -315,11 +331,8 @@ function profile_sidebar($profile, $block = 0) {
'isdefault' => $rr['is-default'], 'isdefault' => $rr['is-default'],
'visibile_to_everybody' => t('visible to everybody'), 'visibile_to_everybody' => t('visible to everybody'),
'edit_visibility' => t('Edit visibility'), 'edit_visibility' => t('Edit visibility'),
); );
} }
} }
} }
if (!$is_contact && $profile['uid'] == local_user() && !feature_enabled(local_user(), 'multi_profiles')) { if (!$is_contact && $profile['uid'] == local_user() && !feature_enabled(local_user(), 'multi_profiles')) {
@ -339,29 +352,31 @@ function profile_sidebar($profile, $block = 0) {
|| (x($profile, 'locality') == 1) || (x($profile, 'locality') == 1)
|| (x($profile, 'region') == 1) || (x($profile, 'region') == 1)
|| (x($profile, 'postal-code') == 1) || (x($profile, 'postal-code') == 1)
|| (x($profile,'country-name') == 1)) || (x($profile, 'country-name') == 1)
) {
$location = t('Location:'); $location = t('Location:');
}
$gender = ((x($profile,'gender') == 1) ? t('Gender:') : False); $gender = ((x($profile, 'gender') == 1) ? t('Gender:') : false);
$marital = ((x($profile,'marital') == 1) ? t('Status:') : False); $marital = ((x($profile, 'marital') == 1) ? t('Status:') : false);
$homepage = ((x($profile,'homepage') == 1) ? t('Homepage:') : False); $homepage = ((x($profile, 'homepage') == 1) ? t('Homepage:') : false);
$about = ((x($profile,'about') == 1) ? t('About:') : False); $about = ((x($profile, 'about') == 1) ? t('About:') : false);
$xmpp = ((x($profile,'xmpp') == 1) ? t('XMPP:') : False); $xmpp = ((x($profile, 'xmpp') == 1) ? t('XMPP:') : false);
if (($profile['hidewall'] || $block) && (! local_user()) && (! remote_user())) { if (($profile['hidewall'] || $block) && (! local_user()) && (! remote_user())) {
$location = $pdesc = $gender = $marital = $homepage = $about = False; $location = $pdesc = $gender = $marital = $homepage = $about = false;
} }
$firstname = ((strpos($profile['name'], ' ')) $firstname = ((strpos($profile['name'], ' '))
? trim(substr($profile['name'], 0, strpos($profile['name'], ' '))) : $profile['name']); ? trim(substr($profile['name'], 0, strpos($profile['name'], ' '))) : $profile['name']);
$lastname = (($firstname === $profile['name']) ? '' : trim(substr($profile['name'], strlen($firstname)))); $lastname = (($firstname === $profile['name']) ? '' : trim(substr($profile['name'], strlen($firstname))));
if ($profile['guid'] != "") if ($profile['guid'] != "") {
$diaspora = array( $diaspora = array(
'guid' => $profile['guid'], 'guid' => $profile['guid'],
'podloc' => System::baseUrl(), 'podloc' => System::baseUrl(),
@ -374,19 +389,24 @@ function profile_sidebar($profile, $block = 0) {
'photo100' => $profile['contact_thumb'], 'photo100' => $profile['contact_thumb'],
'photo50' => $profile['contact_micro'], 'photo50' => $profile['contact_micro'],
); );
else } else {
$diaspora = false; $diaspora = false;
}
if (!$block) { if (!$block) {
$contact_block = contact_block(); $contact_block = contact_block();
if (is_array($a->profile) && !$a->profile['hide-friends']) { if (is_array($a->profile) && !$a->profile['hide-friends']) {
$r = q("SELECT `gcontact`.`updated` FROM `contact` INNER JOIN `gcontact` WHERE `gcontact`.`nurl` = `contact`.`nurl` AND `self` AND `uid` = %d LIMIT 1", $r = q(
intval($a->profile['uid'])); "SELECT `gcontact`.`updated` FROM `contact` INNER JOIN `gcontact` WHERE `gcontact`.`nurl` = `contact`.`nurl` AND `self` AND `uid` = %d LIMIT 1",
if (DBM::is_result($r)) intval($a->profile['uid'])
);
if (DBM::is_result($r)) {
$updated = date("c", strtotime($r[0]['updated'])); $updated = date("c", strtotime($r[0]['updated']));
}
$r = q("SELECT COUNT(*) AS `total` FROM `contact` $r = q(
"SELECT COUNT(*) AS `total` FROM `contact`
WHERE `uid` = %d WHERE `uid` = %d
AND NOT `self` AND NOT `blocked` AND NOT `pending` AND NOT `self` AND NOT `blocked` AND NOT `pending`
AND NOT `hidden` AND NOT `archive` AND NOT `hidden` AND NOT `archive`
@ -396,10 +416,11 @@ function profile_sidebar($profile, $block = 0) {
dbesc(NETWORK_DIASPORA), dbesc(NETWORK_DIASPORA),
dbesc(NETWORK_OSTATUS) dbesc(NETWORK_OSTATUS)
); );
if (DBM::is_result($r)) if (DBM::is_result($r)) {
$contacts = intval($r[0]['total']); $contacts = intval($r[0]['total']);
} }
} }
}
$p = array(); $p = array();
foreach ($profile as $k => $v) { foreach ($profile as $k => $v) {
@ -407,22 +428,28 @@ function profile_sidebar($profile, $block = 0) {
$p[$k] = $v; $p[$k] = $v;
} }
if (isset($p["about"])) if (isset($p["about"])) {
$p["about"] = bbcode($p["about"]); $p["about"] = bbcode($p["about"]);
}
if (isset($p["address"])) if (isset($p["address"])) {
$p["address"] = bbcode($p["address"]); $p["address"] = bbcode($p["address"]);
else } else {
$p["address"] = bbcode($p["location"]); $p["address"] = bbcode($p["location"]);
}
if (isset($p["photo"])) { if (isset($p["photo"])) {
$p["photo"] = proxy_url($p["photo"], false, PROXY_SIZE_SMALL); $p["photo"] = proxy_url($p["photo"], false, PROXY_SIZE_SMALL);
} }
if ($a->theme['template_engine'] === 'internal')
if ($a->theme['template_engine'] === 'internal') {
$location = template_escape($location); $location = template_escape($location);
}
$tpl = get_markup_template('profile_vcard.tpl'); $tpl = get_markup_template('profile_vcard.tpl');
$o .= replace_macros($tpl, array( $o .= replace_macros(
$tpl,
array(
'$profile' => $p, '$profile' => $p,
'$xmpp' => $xmpp, '$xmpp' => $xmpp,
'$connect' => $connect, '$connect' => $connect,
@ -442,7 +469,8 @@ function profile_sidebar($profile, $block = 0) {
'$updated' => $updated, '$updated' => $updated,
'$diaspora' => $diaspora, '$diaspora' => $diaspora,
'$contact_block' => $contact_block, '$contact_block' => $contact_block,
)); )
);
$arr = array('profile' => &$profile, 'entry' => &$o); $arr = array('profile' => &$profile, 'entry' => &$o);
@ -452,19 +480,21 @@ function profile_sidebar($profile, $block = 0) {
} }
function get_birthdays() { function get_birthdays()
{
$a = get_app(); $a = get_app();
$o = ''; $o = '';
if (! local_user() || $a->is_mobile || $a->is_tablet) if (! local_user() || $a->is_mobile || $a->is_tablet) {
return $o; return $o;
}
// $mobile_detect = new Mobile_Detect(); /**
// $is_mobile = $mobile_detect->isMobile() || $mobile_detect->isTablet(); * $mobile_detect = new Mobile_Detect();
* $is_mobile = $mobile_detect->isMobile() || $mobile_detect->isTablet();
// if ($is_mobile) * if ($is_mobile)
// return $o; * return $o;
*/
$bd_format = t('g A l F d'); // 8 AM Friday January 18 $bd_format = t('g A l F d'); // 8 AM Friday January 18
$bd_short = t('F d'); $bd_short = t('F d');
@ -472,7 +502,8 @@ function get_birthdays() {
$cachekey = "get_birthdays:".local_user(); $cachekey = "get_birthdays:".local_user();
$r = Cache::get($cachekey); $r = Cache::get($cachekey);
if (is_null($r)) { if (is_null($r)) {
$s = dba::p("SELECT `event`.*, `event`.`id` AS `eid`, `contact`.* FROM `event` $s = dba::p(
"SELECT `event`.*, `event`.`id` AS `eid`, `contact`.* FROM `event`
INNER JOIN `contact` ON `contact`.`id` = `event`.`cid` INNER JOIN `contact` ON `contact`.`id` = `event`.`cid`
WHERE `event`.`uid` = ? AND `type` = 'birthday' AND `start` < ? AND `finish` > ? WHERE `event`.`uid` = ? AND `type` = 'birthday' AND `start` < ? AND `finish` > ?
ORDER BY `start` ASC ", ORDER BY `start` ASC ",
@ -492,21 +523,25 @@ function get_birthdays() {
$istoday = false; $istoday = false;
foreach ($r as $rr) { foreach ($r as $rr) {
if (strlen($rr['name'])) if (strlen($rr['name'])) {
$total ++; $total ++;
if ((strtotime($rr['start'] . ' +00:00') < $now) && (strtotime($rr['finish'] . ' +00:00') > $now)) }
if ((strtotime($rr['start'] . ' +00:00') < $now) && (strtotime($rr['finish'] . ' +00:00') > $now)) {
$istoday = true; $istoday = true;
} }
}
$classtoday = $istoday ? ' birthday-today ' : ''; $classtoday = $istoday ? ' birthday-today ' : '';
if ($total) { if ($total) {
foreach ($r as &$rr) { foreach ($r as &$rr) {
if (! strlen($rr['name'])) if (! strlen($rr['name'])) {
continue; continue;
}
// avoid duplicates // avoid duplicates
if (in_array($rr['cid'],$cids)) if (in_array($rr['cid'], $cids)) {
continue; continue;
}
$cids[] = $rr['cid']; $cids[] = $rr['cid'];
$today = (((strtotime($rr['start'] . ' +00:00') < $now) && (strtotime($rr['finish'] . ' +00:00') > $now)) ? true : false); $today = (((strtotime($rr['start'] . ' +00:00') < $now) && (strtotime($rr['finish'] . ' +00:00') > $now)) ? true : false);
@ -520,14 +555,15 @@ function get_birthdays() {
$rr['link'] = $url; $rr['link'] = $url;
$rr['title'] = $rr['name']; $rr['title'] = $rr['name'];
$rr['date'] = day_translate(datetime_convert('UTC', $a->timezone, $rr['start'], $rr['adjust'] ? $bd_format : $bd_short)) . (($today) ? ' ' . t('[today]') : ''); $rr['date'] = day_translate(datetime_convert('UTC', $a->timezone, $rr['start'], $rr['adjust'] ? $bd_format : $bd_short)) . (($today) ? ' ' . t('[today]') : '');
$rr['startime'] = Null; $rr['startime'] = null;
$rr['today'] = $today; $rr['today'] = $today;
} }
} }
} }
$tpl = get_markup_template("birthdays_reminder.tpl"); $tpl = get_markup_template("birthdays_reminder.tpl");
return replace_macros($tpl, array( return replace_macros(
$tpl,
array(
'$baseurl' => System::baseUrl(), '$baseurl' => System::baseUrl(),
'$classtoday' => $classtoday, '$classtoday' => $classtoday,
'$count' => $total, '$count' => $total,
@ -536,13 +572,13 @@ function get_birthdays() {
'$events' => $r, '$events' => $r,
'$lbr' => '{', // raw brackets mess up if/endif macro processing '$lbr' => '{', // raw brackets mess up if/endif macro processing
'$rbr' => '}' '$rbr' => '}'
)
)); );
} }
function get_events() { function get_events()
{
require_once 'include/bbcode.php'; require_once 'include/bbcode.php';
$a = get_app(); $a = get_app();
@ -551,16 +587,18 @@ function get_events() {
return $o; return $o;
} }
// $mobile_detect = new Mobile_Detect(); /**
// $is_mobile = $mobile_detect->isMobile() || $mobile_detect->isTablet(); * $mobile_detect = new Mobile_Detect();
* $is_mobile = $mobile_detect->isMobile() || $mobile_detect->isTablet();
// if ($is_mobile) * if ($is_mobile)
// return $o; * return $o;
*/
$bd_format = t('g A l F d'); // 8 AM Friday January 18 $bd_format = t('g A l F d'); // 8 AM Friday January 18
$bd_short = t('F d'); $bd_short = t('F d');
$s = dba::p("SELECT `event`.* FROM `event` $s = dba::p(
"SELECT `event`.* FROM `event`
WHERE `event`.`uid` = ? AND `type` != 'birthday' AND `start` < ? AND `start` >= ? WHERE `event`.`uid` = ? AND `type` != 'birthday' AND `start` < ? AND `start` >= ?
ORDER BY `start` ASC ", ORDER BY `start` ASC ",
local_user(), local_user(),
@ -615,27 +653,32 @@ function get_events() {
$classtoday = (($istoday) ? 'event-today' : ''); $classtoday = (($istoday) ? 'event-today' : '');
} }
$tpl = get_markup_template("events_reminder.tpl"); $tpl = get_markup_template("events_reminder.tpl");
return replace_macros($tpl, array( return replace_macros(
$tpl,
array(
'$baseurl' => System::baseUrl(), '$baseurl' => System::baseUrl(),
'$classtoday' => $classtoday, '$classtoday' => $classtoday,
'$count' => count($r), '$count' => count($r),
'$event_reminders' => t('Event Reminders'), '$event_reminders' => t('Event Reminders'),
'$event_title' => t('Events this week:'), '$event_title' => t('Events this week:'),
'$events' => $r, '$events' => $r,
)); )
);
} }
function advanced_profile(App $a) { function advanced_profile(App $a)
{
$o = ''; $o = '';
$uid = $a->profile['uid']; $uid = $a->profile['uid'];
$o .= replace_macros(get_markup_template('section_title.tpl'),array( $o .= replace_macros(
get_markup_template('section_title.tpl'),
array(
'$title' => t('Profile') '$title' => t('Profile')
)); )
);
if ($a->profile['name']) { if ($a->profile['name']) {
$tpl = get_markup_template('profile_advanced.tpl'); $tpl = get_markup_template('profile_advanced.tpl');
$profile = array(); $profile = array();
@ -656,7 +699,6 @@ function advanced_profile(App $a) {
: day_translate(datetime_convert('UTC', 'UTC', '2001-' . substr($a->profile['dob'], 5) . ' 00:00 +00:00', $short_bd_format))); : day_translate(datetime_convert('UTC', 'UTC', '2001-' . substr($a->profile['dob'], 5) . ' 00:00 +00:00', $short_bd_format)));
$profile['birthday'] = array( t('Birthday:'), $val); $profile['birthday'] = array( t('Birthday:'), $val);
} }
if (!empty($a->profile['dob']) if (!empty($a->profile['dob'])
&& $a->profile['dob'] > '0001-01-01' && $a->profile['dob'] > '0001-01-01'
@ -759,18 +801,22 @@ function advanced_profile(App $a) {
$profile['edit'] = array(System::baseUrl(). '/profiles/'.$a->profile['id'], t('Edit profile'),"", t('Edit profile')); $profile['edit'] = array(System::baseUrl(). '/profiles/'.$a->profile['id'], t('Edit profile'),"", t('Edit profile'));
} }
return replace_macros($tpl, array( return replace_macros(
$tpl,
array(
'$title' => t('Profile'), '$title' => t('Profile'),
'$basic' => t('Basic'), '$basic' => t('Basic'),
'$advanced' => t('Advanced'), '$advanced' => t('Advanced'),
'$profile' => $profile '$profile' => $profile
)); )
);
} }
return ''; return '';
} }
function profile_tabs($a, $is_owner=False, $nickname=Null) { function profile_tabs($a, $is_owner = false, $nickname = null)
{
//echo "<pre>"; var_dump($a->user); killme(); //echo "<pre>"; var_dump($a->user); killme();
if (is_null($nickname)) { if (is_null($nickname)) {
@ -871,17 +917,18 @@ function profile_tabs($a, $is_owner=False, $nickname=Null) {
return replace_macros($tpl, array('$tabs' => $arr['tabs'])); return replace_macros($tpl, array('$tabs' => $arr['tabs']));
} }
function get_my_url() { function get_my_url()
{
if (x($_SESSION, 'my_url')) { if (x($_SESSION, 'my_url')) {
return $_SESSION['my_url']; return $_SESSION['my_url'];
} }
return false; return false;
} }
function zrl_init(App $a) { function zrl_init(App $a)
{
$tmp_str = get_my_url(); $tmp_str = get_my_url();
if (validate_url($tmp_str)) { if (validate_url($tmp_str)) {
// Is it a DDoS attempt? // Is it a DDoS attempt?
// The check fetches the cached value from gprobe to reduce the load for this system // The check fetches the cached value from gprobe to reduce the load for this system
$urlparts = parse_url($tmp_str); $urlparts = parse_url($tmp_str);
@ -898,7 +945,8 @@ function zrl_init(App $a) {
} }
} }
function zrl($s, $force = false) { function zrl($s, $force = false)
{
if (! strlen($s)) { if (! strlen($s)) {
return $s; return $s;
} }
@ -930,7 +978,8 @@ function zrl($s, $force = false) {
* @note Returns local_user instead of user ID if "always_my_theme" * @note Returns local_user instead of user ID if "always_my_theme"
* is set to true * is set to true
*/ */
function get_theme_uid() { function get_theme_uid()
{
$uid = ((!empty($_REQUEST['puid'])) ? intval($_REQUEST['puid']) : 0); $uid = ((!empty($_REQUEST['puid'])) ? intval($_REQUEST['puid']) : 0);
if ((local_user()) && ((PConfig::get(local_user(), 'system', 'always_my_theme')) || (! $uid))) { if ((local_user()) && ((PConfig::get(local_user(), 'system', 'always_my_theme')) || (! $uid))) {
return local_user(); return local_user();

View file

@ -5,6 +5,7 @@
*/ */
use Friendica\App; use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\ParseUrl; use Friendica\ParseUrl;
use Friendica\Core\Config; use Friendica\Core\Config;

View file

@ -4,6 +4,7 @@
*/ */
use Friendica\App; use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Database\DBM; use Friendica\Database\DBM;
@ -23,14 +24,12 @@ require_once 'include/follow.php';
require_once 'include/api.php'; require_once 'include/api.php';
require_once 'mod/proxy.php'; require_once 'mod/proxy.php';
require_once 'include/xml.php'; require_once 'include/xml.php';
require_once 'include/cache.php';
/** /**
* @brief This class contain functions for the OStatus protocol * @brief This class contain functions for the OStatus protocol
*
*/ */
class ostatus { class ostatus
{
private static $itemlist; private static $itemlist;
private static $conv_list = array(); private static $conv_list = array();
@ -45,8 +44,8 @@ class ostatus {
* *
* @return array Array of author related entries for the item * @return array Array of author related entries for the item
*/ */
private static function fetchauthor($xpath, $context, $importer, &$contact, $onlyfetch) { private static function fetchauthor($xpath, $context, $importer, &$contact, $onlyfetch)
{
$author = array(); $author = array();
$author["author-link"] = $xpath->evaluate('atom:author/atom:uri/text()', $context)->item(0)->nodeValue; $author["author-link"] = $xpath->evaluate('atom:author/atom:uri/text()', $context)->item(0)->nodeValue;
$author["author-name"] = $xpath->evaluate('atom:author/atom:name/text()', $context)->item(0)->nodeValue; $author["author-name"] = $xpath->evaluate('atom:author/atom:name/text()', $context)->item(0)->nodeValue;
@ -56,7 +55,7 @@ class ostatus {
$alternate = $xpath->query("atom:author/atom:link[@rel='alternate']", $context)->item(0)->attributes; $alternate = $xpath->query("atom:author/atom:link[@rel='alternate']", $context)->item(0)->attributes;
if (is_object($alternate)) { if (is_object($alternate)) {
foreach ($alternate AS $attributes) { foreach ($alternate as $attributes) {
if (($attributes->name == "href") && ($attributes->textContent != "")) { if (($attributes->name == "href") && ($attributes->textContent != "")) {
$author["author-link"] = $attributes->textContent; $author["author-link"] = $attributes->textContent;
} }
@ -117,10 +116,10 @@ class ostatus {
$avatarlist = array(); $avatarlist = array();
$avatars = $xpath->query("atom:author/atom:link[@rel='avatar']", $context); $avatars = $xpath->query("atom:author/atom:link[@rel='avatar']", $context);
foreach ($avatars AS $avatar) { foreach ($avatars as $avatar) {
$href = ""; $href = "";
$width = 0; $width = 0;
foreach ($avatar->attributes AS $attributes) { foreach ($avatar->attributes as $attributes) {
if ($attributes->name == "href") { if ($attributes->name == "href") {
$href = $attributes->textContent; $href = $attributes->textContent;
} }
@ -148,7 +147,6 @@ class ostatus {
// Only update the contacts if it is an OStatus contact // Only update the contacts if it is an OStatus contact
if ($r && ($r['id'] > 0) && !$onlyfetch && ($contact["network"] == NETWORK_OSTATUS)) { if ($r && ($r['id'] > 0) && !$onlyfetch && ($contact["network"] == NETWORK_OSTATUS)) {
// This contact is vital, so we awake it from the dead // This contact is vital, so we awake it from the dead
unmark_for_death($contact); unmark_for_death($contact);
@ -238,8 +236,8 @@ class ostatus {
* *
* @return array Array of author related entries for the item * @return array Array of author related entries for the item
*/ */
public static function salmon_author($xml, $importer) { public static function salmon_author($xml, $importer)
{
if ($xml == "") if ($xml == "")
return; return;
@ -258,7 +256,7 @@ class ostatus {
$entries = $xpath->query('/atom:entry'); $entries = $xpath->query('/atom:entry');
foreach ($entries AS $entry) { foreach ($entries as $entry) {
// fetch the author // fetch the author
$author = self::fetchauthor($xpath, $entry, $importer, $contact, true); $author = self::fetchauthor($xpath, $entry, $importer, $contact, true);
return $author; return $author;
@ -272,10 +270,11 @@ class ostatus {
* *
* @return array attributes * @return array attributes
*/ */
private static function read_attributes($element) { private static function read_attributes($element)
{
$attribute = array(); $attribute = array();
foreach ($element->attributes AS $attributes) { foreach ($element->attributes as $attributes) {
$attribute[$attributes->name] = $attributes->textContent; $attribute[$attributes->name] = $attributes->textContent;
} }
@ -287,10 +286,11 @@ class ostatus {
* *
* @param string $xml The XML * @param string $xml The XML
* @param array $importer user record of the importing user * @param array $importer user record of the importing user
* @param array $contact * @param array $contact contact
* @param string $hub Called by reference, returns the fetched hub data * @param string $hub Called by reference, returns the fetched hub data
*/ */
public static function import($xml, $importer, &$contact, &$hub) { public static function import($xml, $importer, &$contact, &$hub)
{
self::process($xml, $importer, $contact, $hub); self::process($xml, $importer, $contact, $hub);
} }
@ -306,7 +306,8 @@ class ostatus {
* *
* @return boolean Could the XML be processed? * @return boolean Could the XML be processed?
*/ */
private static function process($xml, $importer, &$contact, &$hub, $stored = false, $initialize = true) { private static function process($xml, $importer, &$contact, &$hub, $stored = false, $initialize = true)
{
if ($initialize) { if ($initialize) {
self::$itemlist = array(); self::$itemlist = array();
self::$conv_list = array(); self::$conv_list = array();
@ -333,7 +334,7 @@ class ostatus {
$hub = ""; $hub = "";
$hub_attributes = $xpath->query("/atom:feed/atom:link[@rel='hub']")->item(0)->attributes; $hub_attributes = $xpath->query("/atom:feed/atom:link[@rel='hub']")->item(0)->attributes;
if (is_object($hub_attributes)) { if (is_object($hub_attributes)) {
foreach ($hub_attributes AS $hub_attribute) { foreach ($hub_attributes as $hub_attribute) {
if ($hub_attribute->name == "href") { if ($hub_attribute->name == "href") {
$hub = $hub_attribute->textContent; $hub = $hub_attribute->textContent;
logger("Found hub ".$hub, LOGGER_DEBUG); logger("Found hub ".$hub, LOGGER_DEBUG);
@ -380,11 +381,11 @@ class ostatus {
// Reverse the order of the entries // Reverse the order of the entries
$entrylist = array(); $entrylist = array();
foreach ($entries AS $entry) { foreach ($entries as $entry) {
$entrylist[] = $entry; $entrylist[] = $entry;
} }
foreach (array_reverse($entrylist) AS $entry) { foreach (array_reverse($entrylist) as $entry) {
// fetch the author // fetch the author
$authorelement = $xpath->query('/atom:entry/atom:author', $entry); $authorelement = $xpath->query('/atom:entry/atom:author', $entry);
@ -479,7 +480,7 @@ class ostatus {
// Never post a thread when the only interaction by our contact was a like // Never post a thread when the only interaction by our contact was a like
$valid = false; $valid = false;
$verbs = array(ACTIVITY_POST, ACTIVITY_SHARE); $verbs = array(ACTIVITY_POST, ACTIVITY_SHARE);
foreach (self::$itemlist AS $item) { foreach (self::$itemlist as $item) {
if (!empty($item['contact-id']) && in_array($item['verb'], $verbs)) { if (!empty($item['contact-id']) && in_array($item['verb'], $verbs)) {
$valid = true; $valid = true;
} }
@ -500,7 +501,7 @@ class ostatus {
$default_contact = $item['contact-id']; $default_contact = $item['contact-id'];
} }
} }
foreach (self::$itemlist AS $item) { foreach (self::$itemlist as $item) {
$found = dba::exists('item', array('uid' => $importer["uid"], 'uri' => $item["uri"])); $found = dba::exists('item', array('uid' => $importer["uid"], 'uri' => $item["uri"]));
if ($found) { if ($found) {
logger("Item with uri ".$item["uri"]." for user ".$importer["uid"]." already exists.", LOGGER_DEBUG); logger("Item with uri ".$item["uri"]." for user ".$importer["uid"]." already exists.", LOGGER_DEBUG);
@ -526,8 +527,8 @@ class ostatus {
return true; return true;
} }
private static function deleteNotice($item) { private static function deleteNotice($item)
{
$condition = array('uid' => $item['uid'], 'author-link' => $item['author-link'], 'uri' => $item['uri']); $condition = array('uid' => $item['uid'], 'author-link' => $item['author-link'], 'uri' => $item['uri']);
$deleted = dba::select('item', array('id', 'parent-uri'), $condition, array('limit' => 1)); $deleted = dba::select('item', array('id', 'parent-uri'), $condition, array('limit' => 1));
if (!DBM::is_result($deleted)) { if (!DBM::is_result($deleted)) {
@ -536,9 +537,12 @@ class ostatus {
} }
// Currently we don't have a central deletion function that we could use in this case. The function "item_drop" doesn't work for that case // Currently we don't have a central deletion function that we could use in this case. The function "item_drop" doesn't work for that case
dba::update('item', array('deleted' => true, 'title' => '', 'body' => '', dba::update(
'item',
array('deleted' => true, 'title' => '', 'body' => '',
'edited' => datetime_convert(), 'changed' => datetime_convert()), 'edited' => datetime_convert(), 'changed' => datetime_convert()),
array('id' => $deleted["id"])); array('id' => $deleted["id"])
);
delete_thread($deleted["id"], $deleted["parent-uri"]); delete_thread($deleted["id"], $deleted["parent-uri"]);
@ -553,7 +557,8 @@ class ostatus {
* @param array $item The item array * @param array $item The item array
* @param array $importer user record of the importing user * @param array $importer user record of the importing user
*/ */
private static function processPost($xpath, $entry, &$item, $importer) { private static function processPost($xpath, $entry, &$item, $importer)
{
$item["body"] = html2bbcode($xpath->query('atom:content/text()', $entry)->item(0)->nodeValue); $item["body"] = html2bbcode($xpath->query('atom:content/text()', $entry)->item(0)->nodeValue);
$item["object-type"] = $xpath->query('activity:object-type/text()', $entry)->item(0)->nodeValue; $item["object-type"] = $xpath->query('activity:object-type/text()', $entry)->item(0)->nodeValue;
if (($item["object-type"] == ACTIVITY_OBJ_BOOKMARK) || ($item["object-type"] == ACTIVITY_OBJ_EVENT)) { if (($item["object-type"] == ACTIVITY_OBJ_BOOKMARK) || ($item["object-type"] == ACTIVITY_OBJ_EVENT)) {
@ -570,7 +575,7 @@ class ostatus {
$conv = $xpath->query('ostatus:conversation', $entry); $conv = $xpath->query('ostatus:conversation', $entry);
if (is_object($conv->item(0))) { if (is_object($conv->item(0))) {
foreach ($conv->item(0)->attributes AS $attributes) { foreach ($conv->item(0)->attributes as $attributes) {
if ($attributes->name == "ref") { if ($attributes->name == "ref") {
$item['conversation-uri'] = $attributes->textContent; $item['conversation-uri'] = $attributes->textContent;
} }
@ -584,7 +589,7 @@ class ostatus {
$inreplyto = $xpath->query('thr:in-reply-to', $entry); $inreplyto = $xpath->query('thr:in-reply-to', $entry);
if (is_object($inreplyto->item(0))) { if (is_object($inreplyto->item(0))) {
foreach ($inreplyto->item(0)->attributes AS $attributes) { foreach ($inreplyto->item(0)->attributes as $attributes) {
if ($attributes->name == "ref") { if ($attributes->name == "ref") {
$item["parent-uri"] = $attributes->textContent; $item["parent-uri"] = $attributes->textContent;
} }
@ -601,8 +606,8 @@ class ostatus {
$categories = $xpath->query('atom:category', $entry); $categories = $xpath->query('atom:category', $entry);
if ($categories) { if ($categories) {
foreach ($categories AS $category) { foreach ($categories as $category) {
foreach ($category->attributes AS $attributes) { foreach ($category->attributes as $attributes) {
if ($attributes->name == "term") { if ($attributes->name == "term") {
$term = $attributes->textContent; $term = $attributes->textContent;
if (strlen($item["tag"])) { if (strlen($item["tag"])) {
@ -628,7 +633,7 @@ class ostatus {
$notice_info = $xpath->query('statusnet:notice_info', $entry); $notice_info = $xpath->query('statusnet:notice_info', $entry);
if ($notice_info && ($notice_info->length > 0)) { if ($notice_info && ($notice_info->length > 0)) {
foreach ($notice_info->item(0)->attributes AS $attributes) { foreach ($notice_info->item(0)->attributes as $attributes) {
if ($attributes->name == "source") { if ($attributes->name == "source") {
$item["app"] = strip_tags($attributes->textContent); $item["app"] = strip_tags($attributes->textContent);
} }
@ -693,8 +698,8 @@ class ostatus {
* @param string $conversation The link to the conversation * @param string $conversation The link to the conversation
* @param string $conversation_uri The conversation in "uri" format * @param string $conversation_uri The conversation in "uri" format
*/ */
private static function fetchConversation($conversation, $conversation_uri) { private static function fetchConversation($conversation, $conversation_uri)
{
// Ensure that we only store a conversation once in a process // Ensure that we only store a conversation once in a process
if (isset(self::$conv_list[$conversation])) { if (isset(self::$conv_list[$conversation])) {
return; return;
@ -723,7 +728,7 @@ class ostatus {
$links = $xpath->query('//link'); $links = $xpath->query('//link');
if ($links) { if ($links) {
foreach ($links AS $link) { foreach ($links as $link) {
$attribute = ostatus::read_attributes($link); $attribute = ostatus::read_attributes($link);
if (($attribute['rel'] == 'alternate') && ($attribute['type'] == 'application/atom+xml')) { if (($attribute['rel'] == 'alternate') && ($attribute['type'] == 'application/atom+xml')) {
$file = $attribute['href']; $file = $attribute['href'];
@ -750,8 +755,11 @@ class ostatus {
* @brief Store a feed in several conversation entries * @brief Store a feed in several conversation entries
* *
* @param string $xml The feed * @param string $xml The feed
* @param string $conversation conversation
* @param string $conversation_uri conversation uri
*/ */
private static function storeConversation($xml, $conversation = '', $conversation_uri = '') { private static function storeConversation($xml, $conversation = '', $conversation_uri = '')
{
$doc = new DOMDocument(); $doc = new DOMDocument();
@$doc->loadXML($xml); @$doc->loadXML($xml);
@ -763,7 +771,7 @@ class ostatus {
$entries = $xpath->query('/atom:feed/atom:entry'); $entries = $xpath->query('/atom:feed/atom:entry');
// Now store the entries // Now store the entries
foreach ($entries AS $entry) { foreach ($entries as $entry) {
$doc2 = new DOMDocument(); $doc2 = new DOMDocument();
$doc2->preserveWhiteSpace = false; $doc2->preserveWhiteSpace = false;
$doc2->formatOutput = true; $doc2->formatOutput = true;
@ -776,7 +784,7 @@ class ostatus {
$inreplyto = $xpath->query('thr:in-reply-to', $entry); $inreplyto = $xpath->query('thr:in-reply-to', $entry);
if (is_object($inreplyto->item(0))) { if (is_object($inreplyto->item(0))) {
foreach ($inreplyto->item(0)->attributes AS $attributes) { foreach ($inreplyto->item(0)->attributes as $attributes) {
if ($attributes->name == "ref") { if ($attributes->name == "ref") {
$conv_data['reply-to-uri'] = $attributes->textContent; $conv_data['reply-to-uri'] = $attributes->textContent;
} }
@ -788,7 +796,7 @@ class ostatus {
$conv = $xpath->query('ostatus:conversation', $entry); $conv = $xpath->query('ostatus:conversation', $entry);
if (is_object($conv->item(0))) { if (is_object($conv->item(0))) {
foreach ($conv->item(0)->attributes AS $attributes) { foreach ($conv->item(0)->attributes as $attributes) {
if ($attributes->name == "ref") { if ($attributes->name == "ref") {
$conv_data['conversation-uri'] = $attributes->textContent; $conv_data['conversation-uri'] = $attributes->textContent;
} }
@ -833,7 +841,8 @@ class ostatus {
* *
* @param string $self The link to the self item * @param string $self The link to the self item
*/ */
private static function fetchSelf($self, &$item) { private static function fetchSelf($self, &$item)
{
$condition = array('`item-uri` = ? AND `protocol` IN (?, ?)', $self, PROTOCOL_DFRN, PROTOCOL_OSTATUS_SALMON); $condition = array('`item-uri` = ? AND `protocol` IN (?, ?)', $self, PROTOCOL_DFRN, PROTOCOL_OSTATUS_SALMON);
if (dba::exists('conversation', $condition)) { if (dba::exists('conversation', $condition)) {
logger('Conversation '.$item['uri'].' is already stored.', LOGGER_DEBUG); logger('Conversation '.$item['uri'].' is already stored.', LOGGER_DEBUG);
@ -866,7 +875,8 @@ class ostatus {
* @param string $related_uri The related item in "uri" format * @param string $related_uri The related item in "uri" format
* @param array $importer user record of the importing user * @param array $importer user record of the importing user
*/ */
private static function fetchRelated($related, $related_uri, $importer) { private static function fetchRelated($related, $related_uri, $importer)
{
$condition = array('`item-uri` = ? AND `protocol` IN (?, ?)', $related_uri, PROTOCOL_DFRN, PROTOCOL_OSTATUS_SALMON); $condition = array('`item-uri` = ? AND `protocol` IN (?, ?)', $related_uri, PROTOCOL_DFRN, PROTOCOL_OSTATUS_SALMON);
$conversation = dba::select('conversation', array('source', 'protocol'), $condition, array('limit' => 1)); $conversation = dba::select('conversation', array('source', 'protocol'), $condition, array('limit' => 1));
if (DBM::is_result($conversation)) { if (DBM::is_result($conversation)) {
@ -907,7 +917,7 @@ class ostatus {
$links = $xpath->query('//link'); $links = $xpath->query('//link');
if ($links) { if ($links) {
foreach ($links AS $link) { foreach ($links as $link) {
$attribute = self::read_attributes($link); $attribute = self::read_attributes($link);
if (($attribute['rel'] == 'alternate') && ($attribute['type'] == 'application/atom+xml')) { if (($attribute['rel'] == 'alternate') && ($attribute['type'] == 'application/atom+xml')) {
$atom_file = $attribute['href']; $atom_file = $attribute['href'];
@ -974,7 +984,8 @@ class ostatus {
* *
* @return array with data from links * @return array with data from links
*/ */
private static function processRepeatedItem($xpath, $entry, &$item, $importer) { private static function processRepeatedItem($xpath, $entry, &$item, $importer)
{
$activityobjects = $xpath->query('activity:object', $entry)->item(0); $activityobjects = $xpath->query('activity:object', $entry)->item(0);
if (!is_object($activityobjects)) { if (!is_object($activityobjects)) {
@ -1013,7 +1024,7 @@ class ostatus {
$inreplyto = $xpath->query('thr:in-reply-to', $activityobjects); $inreplyto = $xpath->query('thr:in-reply-to', $activityobjects);
if (is_object($inreplyto->item(0))) { if (is_object($inreplyto->item(0))) {
foreach ($inreplyto->item(0)->attributes AS $attributes) { foreach ($inreplyto->item(0)->attributes as $attributes) {
if ($attributes->name == "ref") { if ($attributes->name == "ref") {
$item["parent-uri"] = $attributes->textContent; $item["parent-uri"] = $attributes->textContent;
} }
@ -1031,18 +1042,20 @@ class ostatus {
* *
* @return array with data from the links * @return array with data from the links
*/ */
private static function processLinks($links, &$item) { private static function processLinks($links, &$item)
{
$link_data = array('add_body' => '', 'self' => ''); $link_data = array('add_body' => '', 'self' => '');
foreach ($links AS $link) { foreach ($links as $link) {
$attribute = self::read_attributes($link); $attribute = self::read_attributes($link);
if (($attribute['rel'] != "") && ($attribute['href'] != "")) { if (($attribute['rel'] != "") && ($attribute['href'] != "")) {
switch ($attribute['rel']) { switch ($attribute['rel']) {
case "alternate": case "alternate":
$item["plink"] = $attribute['href']; $item["plink"] = $attribute['href'];
if (($item["object-type"] == ACTIVITY_OBJ_QUESTION) || if (($item["object-type"] == ACTIVITY_OBJ_QUESTION)
($item["object-type"] == ACTIVITY_OBJ_EVENT)) { || ($item["object-type"] == ACTIVITY_OBJ_EVENT)
) {
$item["body"] .= add_page_info($attribute['href']); $item["body"] .= add_page_info($attribute['href']);
} }
break; break;
@ -1096,7 +1109,8 @@ class ostatus {
* *
* @return string URL in the format http(s)://.... * @return string URL in the format http(s)://....
*/ */
public static function convert_href($href) { public static function convert_href($href)
{
$elements = explode(":", $href); $elements = explode(":", $href);
if ((count($elements) <= 2) || ($elements[0] != "tag")) if ((count($elements) <= 2) || ($elements[0] != "tag"))
@ -1126,7 +1140,8 @@ class ostatus {
* *
* @return string The guid if the post is a reshare * @return string The guid if the post is a reshare
*/ */
private static function get_reshared_guid($item) { private static function get_reshared_guid($item)
{
$body = trim($item["body"]); $body = trim($item["body"]);
// Skip if it isn't a pure repeated messages // Skip if it isn't a pure repeated messages
@ -1162,14 +1177,16 @@ class ostatus {
* *
* @return string The cleaned body * @return string The cleaned body
*/ */
private static function format_picture_post($body) { private static function format_picture_post($body)
{
$siteinfo = get_attached_data($body); $siteinfo = get_attached_data($body);
if (($siteinfo["type"] == "photo")) { if (($siteinfo["type"] == "photo")) {
if (isset($siteinfo["preview"])) if (isset($siteinfo["preview"])) {
$preview = $siteinfo["preview"]; $preview = $siteinfo["preview"];
else } else {
$preview = $siteinfo["image"]; $preview = $siteinfo["image"];
}
// Is it a remote picture? Then make a smaller preview here // Is it a remote picture? Then make a smaller preview here
$preview = proxy_url($preview, false, PROXY_SIZE_SMALL); $preview = proxy_url($preview, false, PROXY_SIZE_SMALL);
@ -1178,10 +1195,11 @@ class ostatus {
$preview = str_replace(array("-0.jpg", "-0.png"), array("-2.jpg", "-2.png"), $preview); $preview = str_replace(array("-0.jpg", "-0.png"), array("-2.jpg", "-2.png"), $preview);
$preview = str_replace(array("-1.jpg", "-1.png"), array("-2.jpg", "-2.png"), $preview); $preview = str_replace(array("-1.jpg", "-1.png"), array("-2.jpg", "-2.png"), $preview);
if (isset($siteinfo["url"])) if (isset($siteinfo["url"])) {
$url = $siteinfo["url"]; $url = $siteinfo["url"];
else } else {
$url = $siteinfo["image"]; $url = $siteinfo["image"];
}
$body = trim($siteinfo["text"])." [url]".$url."[/url]\n[img]".$preview."[/img]"; $body = trim($siteinfo["text"])." [url]".$url."[/url]\n[img]".$preview."[/img]";
} }
@ -1197,8 +1215,8 @@ class ostatus {
* *
* @return object header root element * @return object header root element
*/ */
private static function add_header($doc, $owner) { private static function add_header($doc, $owner)
{
$a = get_app(); $a = get_app();
$root = $doc->createElementNS(NAMESPACE_ATOM1, 'feed'); $root = $doc->createElementNS(NAMESPACE_ATOM1, 'feed');
@ -1256,8 +1274,10 @@ class ostatus {
* *
* @param object $doc XML document * @param object $doc XML document
* @param object $root XML root element where the hub links are added * @param object $root XML root element where the hub links are added
* @param object $nick nick
*/ */
public static function hublinks($doc, $root, $nick) { public static function hublinks($doc, $root, $nick)
{
$h = System::baseUrl() . '/pubsubhubbub/'.$nick; $h = System::baseUrl() . '/pubsubhubbub/'.$nick;
xml::add_element($doc, $root, "link", "", array("href" => $h, "rel" => "hub")); xml::add_element($doc, $root, "link", "", array("href" => $h, "rel" => "hub"));
} }
@ -1269,7 +1289,8 @@ class ostatus {
* @param object $root XML root element where the hub links are added * @param object $root XML root element where the hub links are added
* @param array $item Data of the item that is to be posted * @param array $item Data of the item that is to be posted
*/ */
private static function get_attachment($doc, $root, $item) { private static function get_attachment($doc, $root, $item)
{
$o = ""; $o = "";
$siteinfo = get_attached_data($item["body"]); $siteinfo = get_attached_data($item["body"]);
@ -1334,8 +1355,8 @@ class ostatus {
* *
* @return object author element * @return object author element
*/ */
private static function add_author($doc, $owner) { private static function add_author($doc, $owner)
{
$r = q("SELECT `homepage`, `publish` FROM `profile` WHERE `uid` = %d AND `is-default` LIMIT 1", intval($owner["uid"])); $r = q("SELECT `homepage`, `publish` FROM `profile` WHERE `uid` = %d AND `is-default` LIMIT 1", intval($owner["uid"]));
if (DBM::is_result($r)) { if (DBM::is_result($r)) {
$profile = $r[0]; $profile = $r[0];
@ -1402,7 +1423,6 @@ class ostatus {
* @TODO Picture attachments should look like this: * @TODO Picture attachments should look like this:
* <a href="https://status.pirati.ca/attachment/572819" title="https://status.pirati.ca/file/heluecht-20151202T222602-rd3u49p.gif" * <a href="https://status.pirati.ca/attachment/572819" title="https://status.pirati.ca/file/heluecht-20151202T222602-rd3u49p.gif"
* class="attachment thumbnail" id="attachment-572819" rel="nofollow external">https://status.pirati.ca/attachment/572819</a> * class="attachment thumbnail" id="attachment-572819" rel="nofollow external">https://status.pirati.ca/attachment/572819</a>
*
*/ */
/** /**
@ -1412,7 +1432,8 @@ class ostatus {
* *
* @return string activity * @return string activity
*/ */
private static function construct_verb($item) { private static function construct_verb($item)
{
if ($item['verb']) if ($item['verb'])
return $item['verb']; return $item['verb'];
return ACTIVITY_POST; return ACTIVITY_POST;
@ -1425,7 +1446,8 @@ class ostatus {
* *
* @return string Object type * @return string Object type
*/ */
private static function construct_objecttype($item) { private static function construct_objecttype($item)
{
if (in_array($item['object-type'], array(ACTIVITY_OBJ_NOTE, ACTIVITY_OBJ_COMMENT))) if (in_array($item['object-type'], array(ACTIVITY_OBJ_NOTE, ACTIVITY_OBJ_COMMENT)))
return $item['object-type']; return $item['object-type'];
return ACTIVITY_OBJ_NOTE; return ACTIVITY_OBJ_NOTE;
@ -1437,11 +1459,12 @@ class ostatus {
* @param object $doc XML document * @param object $doc XML document
* @param array $item Data of the item that is to be posted * @param array $item Data of the item that is to be posted
* @param array $owner Contact data of the poster * @param array $owner Contact data of the poster
* @param bool $toplevel * @param bool $toplevel optional default false
* *
* @return object Entry element * @return object Entry element
*/ */
private static function entry($doc, $item, $owner, $toplevel = false) { private static function entry($doc, $item, $owner, $toplevel = false)
{
$repeated_guid = self::get_reshared_guid($item); $repeated_guid = self::get_reshared_guid($item);
if ($repeated_guid != "") if ($repeated_guid != "")
$xml = self::reshare_entry($doc, $item, $owner, $repeated_guid, $toplevel); $xml = self::reshare_entry($doc, $item, $owner, $repeated_guid, $toplevel);
@ -1466,16 +1489,13 @@ class ostatus {
* *
* @return object Source element * @return object Source element
*/ */
private static function source_entry($doc, $contact) { private static function source_entry($doc, $contact)
{
$source = $doc->createElement("source"); $source = $doc->createElement("source");
xml::add_element($doc, $source, "id", $contact["poll"]); xml::add_element($doc, $source, "id", $contact["poll"]);
xml::add_element($doc, $source, "title", $contact["name"]); xml::add_element($doc, $source, "title", $contact["name"]);
xml::add_element($doc, $source, "link", "", array("rel" => "alternate", xml::add_element($doc, $source, "link", "", array("rel" => "alternate", "type" => "text/html", "href" => $contact["alias"]));
"type" => "text/html", xml::add_element($doc, $source, "link", "", array("rel" => "self", "type" => "application/atom+xml", "href" => $contact["poll"]));
"href" => $contact["alias"]));
xml::add_element($doc, $source, "link", "", array("rel" => "self",
"type" => "application/atom+xml",
"href" => $contact["poll"]));
xml::add_element($doc, $source, "icon", $contact["photo"]); xml::add_element($doc, $source, "icon", $contact["photo"]);
xml::add_element($doc, $source, "updated", datetime_convert("UTC", "UTC", $contact["success_update"]."+00:00", ATOM_TIME)); xml::add_element($doc, $source, "updated", datetime_convert("UTC", "UTC", $contact["success_update"]."+00:00", ATOM_TIME));
@ -1492,16 +1512,21 @@ class ostatus {
*/ */
private static function contact_entry($url, $owner) { private static function contact_entry($url, $owner) {
$r = q("SELECT * FROM `contact` WHERE `nurl` = '%s' AND `uid` IN (0, %d) ORDER BY `uid` DESC LIMIT 1", $r = q(
dbesc(normalise_link($url)), intval($owner["uid"])); "SELECT * FROM `contact` WHERE `nurl` = '%s' AND `uid` IN (0, %d) ORDER BY `uid` DESC LIMIT 1",
dbesc(normalise_link($url)),
intval($owner["uid"])
);
if (DBM::is_result($r)) { if (DBM::is_result($r)) {
$contact = $r[0]; $contact = $r[0];
$contact["uid"] = -1; $contact["uid"] = -1;
} }
if (!DBM::is_result($r)) { if (!DBM::is_result($r)) {
$r = q("SELECT * FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1", $r = q(
dbesc(normalise_link($url))); "SELECT * FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
dbesc(normalise_link($url))
);
if (DBM::is_result($r)) { if (DBM::is_result($r)) {
$contact = $r[0]; $contact = $r[0];
$contact["uid"] = -1; $contact["uid"] = -1;
@ -1509,19 +1534,22 @@ class ostatus {
} }
} }
if (!DBM::is_result($r)) if (!DBM::is_result($r)) {
$contact = owner; $contact = owner;
}
if (!isset($contact["poll"])) { if (!isset($contact["poll"])) {
$data = Probe::uri($url); $data = Probe::uri($url);
$contact["poll"] = $data["poll"]; $contact["poll"] = $data["poll"];
if (!$contact["alias"]) if (!$contact["alias"]) {
$contact["alias"] = $data["alias"]; $contact["alias"] = $data["alias"];
} }
}
if (!isset($contact["alias"])) if (!isset($contact["alias"])) {
$contact["alias"] = $contact["url"]; $contact["alias"] = $contact["url"];
}
return $contact; return $contact;
} }
@ -1537,17 +1565,22 @@ class ostatus {
* *
* @return object Entry element * @return object Entry element
*/ */
private static function reshare_entry($doc, $item, $owner, $repeated_guid, $toplevel) { private static function reshare_entry($doc, $item, $owner, $repeated_guid, $toplevel)
{
if (($item["id"] != $item["parent"]) && (normalise_link($item["author-link"]) != normalise_link($owner["url"]))) { if (($item["id"] != $item["parent"]) && (normalise_link($item["author-link"]) != normalise_link($owner["url"]))) {
logger("OStatus entry is from author ".$owner["url"]." - not from ".$item["author-link"].". Quitting.", LOGGER_DEBUG); logger("OStatus entry is from author ".$owner["url"]." - not from ".$item["author-link"].". Quitting.", LOGGER_DEBUG);
} }
$title = self::entry_header($doc, $entry, $owner, $toplevel); $title = self::entry_header($doc, $entry, $owner, $toplevel);
$r = q("SELECT * FROM `item` WHERE `uid` = %d AND `guid` = '%s' AND NOT `private` AND `network` IN ('%s', '%s', '%s') LIMIT 1", $r = q(
intval($owner["uid"]), dbesc($repeated_guid), "SELECT * FROM `item` WHERE `uid` = %d AND `guid` = '%s' AND NOT `private` AND `network` IN ('%s', '%s', '%s') LIMIT 1",
dbesc(NETWORK_DFRN), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_OSTATUS)); intval($owner["uid"]),
dbesc($repeated_guid),
dbesc(NETWORK_DFRN),
dbesc(NETWORK_DIASPORA),
dbesc(NETWORK_OSTATUS)
);
if (DBM::is_result($r)) { if (DBM::is_result($r)) {
$repeated_item = $r[0]; $repeated_item = $r[0];
} else { } else {
@ -1603,8 +1636,8 @@ class ostatus {
* *
* @return object Entry element with "like" * @return object Entry element with "like"
*/ */
private static function like_entry($doc, $item, $owner, $toplevel) { private static function like_entry($doc, $item, $owner, $toplevel)
{
if (($item["id"] != $item["parent"]) && (normalise_link($item["author-link"]) != normalise_link($owner["url"]))) { if (($item["id"] != $item["parent"]) && (normalise_link($item["author-link"]) != normalise_link($owner["url"]))) {
logger("OStatus entry is from author ".$owner["url"]." - not from ".$item["author-link"].". Quitting.", LOGGER_DEBUG); logger("OStatus entry is from author ".$owner["url"]." - not from ".$item["author-link"].". Quitting.", LOGGER_DEBUG);
} }
@ -1616,8 +1649,11 @@ class ostatus {
$as_object = $doc->createElement("activity:object"); $as_object = $doc->createElement("activity:object");
$parent = q("SELECT * FROM `item` WHERE `uri` = '%s' AND `uid` = %d", $parent = q(
dbesc($item["thr-parent"]), intval($item["uid"])); "SELECT * FROM `item` WHERE `uri` = '%s' AND `uid` = %d",
dbesc($item["thr-parent"]),
intval($item["uid"])
);
$parent_item = (($item['thr-parent']) ? $item['thr-parent'] : $item['parent-uri']); $parent_item = (($item['thr-parent']) ? $item['thr-parent'] : $item['parent-uri']);
xml::add_element($doc, $as_object, "activity:object-type", self::construct_objecttype($parent[0])); xml::add_element($doc, $as_object, "activity:object-type", self::construct_objecttype($parent[0]));
@ -1640,8 +1676,8 @@ class ostatus {
* *
* @return object author element * @return object author element
*/ */
private static function add_person_object($doc, $owner, $contact) { private static function add_person_object($doc, $owner, $contact)
{
$object = $doc->createElement("activity:object"); $object = $doc->createElement("activity:object");
xml::add_element($doc, $object, "activity:object-type", ACTIVITY_OBJ_PERSON); xml::add_element($doc, $object, "activity:object-type", ACTIVITY_OBJ_PERSON);
@ -1700,8 +1736,11 @@ class ostatus {
$item['follow'] = $contact['alias']; $item['follow'] = $contact['alias'];
} }
$r = q("SELECT `id` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s'", $r = q(
intval($owner['uid']), dbesc(normalise_link($contact["url"]))); "SELECT `id` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s'",
intval($owner['uid']),
dbesc(normalise_link($contact["url"]))
);
if (DBM::is_result($r)) { if (DBM::is_result($r)) {
$connect_id = $r[0]['id']; $connect_id = $r[0]['id'];
@ -1719,8 +1758,8 @@ class ostatus {
$action = "unfollow"; $action = "unfollow";
} }
$item["uri"] = $item['parent-uri'] = $item['thr-parent'] = $item["uri"] = $item['parent-uri'] = $item['thr-parent']
'tag:'.get_app()->get_hostname(). = 'tag:'.get_app()->get_hostname().
','.date('Y-m-d').':'.$action.':'.$owner['uid']. ','.date('Y-m-d').':'.$action.':'.$owner['uid'].
':person:'.$connect_id.':'.$item['created']; ':person:'.$connect_id.':'.$item['created'];
@ -1748,8 +1787,8 @@ class ostatus {
* *
* @return object Entry element * @return object Entry element
*/ */
private static function note_entry($doc, $item, $owner, $toplevel) { private static function note_entry($doc, $item, $owner, $toplevel)
{
if (($item["id"] != $item["parent"]) && (normalise_link($item["author-link"]) != normalise_link($owner["url"]))) { if (($item["id"] != $item["parent"]) && (normalise_link($item["author-link"]) != normalise_link($owner["url"]))) {
logger("OStatus entry is from author ".$owner["url"]." - not from ".$item["author-link"].". Quitting.", LOGGER_DEBUG); logger("OStatus entry is from author ".$owner["url"]." - not from ".$item["author-link"].". Quitting.", LOGGER_DEBUG);
} }
@ -1775,7 +1814,8 @@ class ostatus {
* *
* @return string The title for the element * @return string The title for the element
*/ */
private static function entry_header($doc, &$entry, $owner, $toplevel) { private static function entry_header($doc, &$entry, $owner, $toplevel)
{
/// @todo Check if this title stuff is really needed (I guess not) /// @todo Check if this title stuff is really needed (I guess not)
if (!$toplevel) { if (!$toplevel) {
$entry = $doc->createElement("entry"); $entry = $doc->createElement("entry");
@ -1811,10 +1851,11 @@ class ostatus {
* @param string $verb The activity verb * @param string $verb The activity verb
* @param bool $complete Add the "status_net" element? * @param bool $complete Add the "status_net" element?
*/ */
private static function entry_content($doc, $entry, $item, $owner, $title, $verb = "", $complete = true) { private static function entry_content($doc, $entry, $item, $owner, $title, $verb = "", $complete = true)
{
if ($verb == "") if ($verb == "") {
$verb = self::construct_verb($item); $verb = self::construct_verb($item);
}
xml::add_element($doc, $entry, "id", $item["uri"]); xml::add_element($doc, $entry, "id", $item["uri"]);
xml::add_element($doc, $entry, "title", $title); xml::add_element($doc, $entry, "title", $title);
@ -1829,10 +1870,12 @@ class ostatus {
xml::add_element($doc, $entry, "content", $body, array("type" => "html")); xml::add_element($doc, $entry, "content", $body, array("type" => "html"));
xml::add_element($doc, $entry, "link", "", array("rel" => "alternate", "type" => "text/html", xml::add_element($doc, $entry, "link", "", array("rel" => "alternate", "type" => "text/html",
"href" => System::baseUrl()."/display/".$item["guid"])); "href" => System::baseUrl()."/display/".$item["guid"])
);
if ($complete && ($item["id"] > 0)) if ($complete && ($item["id"] > 0)) {
xml::add_element($doc, $entry, "status_net", "", array("notice_id" => $item["id"])); xml::add_element($doc, $entry, "status_net", "", array("notice_id" => $item["id"]));
}
xml::add_element($doc, $entry, "activity:verb", $verb); xml::add_element($doc, $entry, "activity:verb", $verb);
@ -1847,19 +1890,21 @@ class ostatus {
* @param object $entry The entry element where the elements are added * @param object $entry The entry element where the elements are added
* @param array $item Data of the item that is to be posted * @param array $item Data of the item that is to be posted
* @param array $owner Contact data of the poster * @param array $owner Contact data of the poster
* @param $complete * @param bool $complete default true
*/ */
private static function entry_footer($doc, $entry, $item, $owner, $complete = true) { private static function entry_footer($doc, $entry, $item, $owner, $complete = true)
{
$mentioned = array(); $mentioned = array();
if (($item['parent'] != $item['id']) || ($item['parent-uri'] !== $item['uri']) || (($item['thr-parent'] !== '') && ($item['thr-parent'] !== $item['uri']))) { if (($item['parent'] != $item['id']) || ($item['parent-uri'] !== $item['uri']) || (($item['thr-parent'] !== '') && ($item['thr-parent'] !== $item['uri']))) {
$parent = q("SELECT `guid`, `author-link`, `owner-link` FROM `item` WHERE `id` = %d", intval($item["parent"])); $parent = q("SELECT `guid`, `author-link`, `owner-link` FROM `item` WHERE `id` = %d", intval($item["parent"]));
$parent_item = (($item['thr-parent']) ? $item['thr-parent'] : $item['parent-uri']); $parent_item = (($item['thr-parent']) ? $item['thr-parent'] : $item['parent-uri']);
$thrparent = q("SELECT `guid`, `author-link`, `owner-link`, `plink` FROM `item` WHERE `uid` = %d AND `uri` = '%s'", $thrparent = q(
"SELECT `guid`, `author-link`, `owner-link`, `plink` FROM `item` WHERE `uid` = %d AND `uri` = '%s'",
intval($owner["uid"]), intval($owner["uid"]),
dbesc($parent_item)); dbesc($parent_item)
);
if ($thrparent) { if ($thrparent) {
$mentioned[$thrparent[0]["author-link"]] = $thrparent[0]["author-link"]; $mentioned[$thrparent[0]["author-link"]] = $thrparent[0]["author-link"];
$mentioned[$thrparent[0]["owner-link"]] = $thrparent[0]["owner-link"]; $mentioned[$thrparent[0]["owner-link"]] = $thrparent[0]["owner-link"];
@ -1909,31 +1954,43 @@ class ostatus {
$tags = item_getfeedtags($item); $tags = item_getfeedtags($item);
if (count($tags)) if (count($tags)) {
foreach ($tags as $t) foreach ($tags as $t) {
if ($t[0] == "@") if ($t[0] == "@") {
$mentioned[$t[1]] = $t[1]; $mentioned[$t[1]] = $t[1];
}
}
}
// Make sure that mentions are accepted (GNU Social has problems with mixing HTTP and HTTPS) // Make sure that mentions are accepted (GNU Social has problems with mixing HTTP and HTTPS)
$newmentions = array(); $newmentions = array();
foreach ($mentioned AS $mention) { foreach ($mentioned as $mention) {
$newmentions[str_replace("http://", "https://", $mention)] = str_replace("http://", "https://", $mention); $newmentions[str_replace("http://", "https://", $mention)] = str_replace("http://", "https://", $mention);
$newmentions[str_replace("https://", "http://", $mention)] = str_replace("https://", "http://", $mention); $newmentions[str_replace("https://", "http://", $mention)] = str_replace("https://", "http://", $mention);
} }
$mentioned = $newmentions; $mentioned = $newmentions;
foreach ($mentioned AS $mention) { foreach ($mentioned as $mention) {
$r = q("SELECT `forum`, `prv` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s'", $r = q(
"SELECT `forum`, `prv` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s'",
intval($owner["uid"]), intval($owner["uid"]),
dbesc(normalise_link($mention))); dbesc(normalise_link($mention))
if ($r[0]["forum"] || $r[0]["prv"]) );
xml::add_element($doc, $entry, "link", "", array("rel" => "mentioned", if ($r[0]["forum"] || $r[0]["prv"]) {
xml::add_element($doc, $entry, "link", "",
array(
"rel" => "mentioned",
"ostatus:object-type" => ACTIVITY_OBJ_GROUP, "ostatus:object-type" => ACTIVITY_OBJ_GROUP,
"href" => $mention)); "href" => $mention)
else );
xml::add_element($doc, $entry, "link", "", array("rel" => "mentioned", } else {
xml::add_element($doc, $entry, "link", "",
array(
"rel" => "mentioned",
"ostatus:object-type" => ACTIVITY_OBJ_PERSON, "ostatus:object-type" => ACTIVITY_OBJ_PERSON,
"href" => $mention)); "href" => $mention)
);
}
} }
if (!$item["private"]) { if (!$item["private"]) {
@ -1945,10 +2002,13 @@ class ostatus {
xml::add_element($doc, $entry, "mastodon:scope", "public"); xml::add_element($doc, $entry, "mastodon:scope", "public");
} }
if (count($tags)) if (count($tags)) {
foreach ($tags as $t) foreach ($tags as $t) {
if ($t[0] != "@") if ($t[0] != "@") {
xml::add_element($doc, $entry, "category", "", array("term" => $t[2])); xml::add_element($doc, $entry, "category", "", array("term" => $t[2]));
}
}
}
self::get_attachment($doc, $entry, $item); self::get_attachment($doc, $entry, $item);
@ -1959,11 +2019,13 @@ class ostatus {
$attributes = array("local_id" => $item["id"], "source" => $app); $attributes = array("local_id" => $item["id"], "source" => $app);
if (isset($parent["id"])) if (isset($parent["id"])) {
$attributes["repeat_of"] = $parent["id"]; $attributes["repeat_of"] = $parent["id"];
}
if ($item["coord"] != "") if ($item["coord"] != "") {
xml::add_element($doc, $entry, "georss:point", $item["coord"]); xml::add_element($doc, $entry, "georss:point", $item["coord"]);
}
xml::add_element($doc, $entry, "statusnet:notice_info", "", $attributes); xml::add_element($doc, $entry, "statusnet:notice_info", "", $attributes);
} }
@ -1972,14 +2034,15 @@ class ostatus {
/** /**
* @brief Creates the XML feed for a given nickname * @brief Creates the XML feed for a given nickname
* *
* @param App $a The application class * @param object $a The application class
* @param string $owner_nick Nickname of the feed owner * @param string $owner_nick Nickname of the feed owner
* @param string $last_update Date of the last update * @param string $last_update Date of the last update
* @param integer $max_items Number of maximum items to fetch * @param integer $max_items Number of maximum items to fetch
* *
* @return string XML feed * @return string XML feed
*/ */
public static function feed(App $a, $owner_nick, &$last_update, $max_items = 300) { public static function feed(App $a, $owner_nick, &$last_update, $max_items = 300)
{
$stamp = microtime(true); $stamp = microtime(true);
$cachekey = "ostatus:feed:".$owner_nick.":".$last_update; $cachekey = "ostatus:feed:".$owner_nick.":".$last_update;
@ -1993,10 +2056,12 @@ class ostatus {
return $result['feed']; return $result['feed'];
} }
$r = q("SELECT `contact`.*, `user`.`nickname`, `user`.`timezone`, `user`.`page-flags` $r = q(
"SELECT `contact`.*, `user`.`nickname`, `user`.`timezone`, `user`.`page-flags`
FROM `contact` INNER JOIN `user` ON `user`.`uid` = `contact`.`uid` FROM `contact` INNER JOIN `user` ON `user`.`uid` = `contact`.`uid`
WHERE `contact`.`self` AND `user`.`nickname` = '%s' LIMIT 1", WHERE `contact`.`self` AND `user`.`nickname` = '%s' LIMIT 1",
dbesc($owner_nick)); dbesc($owner_nick)
);
if (!DBM::is_result($r)) { if (!DBM::is_result($r)) {
return; return;
} }
@ -2010,7 +2075,8 @@ class ostatus {
$check_date = datetime_convert('UTC', 'UTC', $last_update, 'Y-m-d H:i:s'); $check_date = datetime_convert('UTC', 'UTC', $last_update, 'Y-m-d H:i:s');
$authorid = get_contact($owner["url"], 0); $authorid = get_contact($owner["url"], 0);
$items = q("SELECT `item`.*, `item`.`id` AS `item_id` FROM `item` USE INDEX (`uid_contactid_created`) $items = q(
"SELECT `item`.*, `item`.`id` AS `item_id` FROM `item` USE INDEX (`uid_contactid_created`)
STRAIGHT_JOIN `thread` ON `thread`.`iid` = `item`.`parent` STRAIGHT_JOIN `thread` ON `thread`.`iid` = `item`.`parent`
WHERE `item`.`uid` = %d AND `item`.`contact-id` = %d AND WHERE `item`.`uid` = %d AND `item`.`contact-id` = %d AND
`item`.`author-id` = %d AND `item`.`created` > '%s' AND `item`.`author-id` = %d AND `item`.`created` > '%s' AND
@ -2019,14 +2085,15 @@ class ostatus {
ORDER BY `item`.`created` DESC LIMIT %d", ORDER BY `item`.`created` DESC LIMIT %d",
intval($owner["uid"]), intval($owner["id"]), intval($owner["uid"]), intval($owner["id"]),
intval($authorid), dbesc($check_date), intval($authorid), dbesc($check_date),
dbesc(NETWORK_OSTATUS), dbesc(NETWORK_DFRN), intval($max_items)); dbesc(NETWORK_OSTATUS), dbesc(NETWORK_DFRN), intval($max_items)
);
$doc = new DOMDocument('1.0', 'utf-8'); $doc = new DOMDocument('1.0', 'utf-8');
$doc->formatOutput = true; $doc->formatOutput = true;
$root = self::add_header($doc, $owner); $root = self::add_header($doc, $owner);
foreach ($items AS $item) { foreach ($items as $item) {
if (Config::get('system', 'ostatus_debug')) { if (Config::get('system', 'ostatus_debug')) {
$item['body'] .= '🍼'; $item['body'] .= '🍼';
} }
@ -2056,8 +2123,8 @@ class ostatus {
* *
* @return string XML for the salmon * @return string XML for the salmon
*/ */
public static function salmon($item,$owner) { public static function salmon($item, $owner)
{
$doc = new DOMDocument('1.0', 'utf-8'); $doc = new DOMDocument('1.0', 'utf-8');
$doc->formatOutput = true; $doc->formatOutput = true;

View file

@ -3,7 +3,7 @@
* @file include/photos.php * @file include/photos.php
* @brief Functions related to photo handling. * @brief Functions related to photo handling.
*/ */
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\PConfig; use Friendica\Core\PConfig;

View file

@ -1,5 +1,8 @@
<?php <?php
/**
* @file include/queue.php
*/
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\Worker; use Friendica\Core\Worker;
use Friendica\Database\DBM; use Friendica\Database\DBM;
@ -11,9 +14,9 @@ require_once 'include/datetime.php';
require_once 'include/items.php'; require_once 'include/items.php';
require_once 'include/bbcode.php'; require_once 'include/bbcode.php';
require_once 'include/socgraph.php'; require_once 'include/socgraph.php';
require_once 'include/cache.php';
function queue_run(&$argv, &$argc) { function queue_run(&$argv, &$argc)
{
global $a; global $a;
if ($argc > 1) { if ($argc > 1) {
@ -26,15 +29,16 @@ function queue_run(&$argv, &$argc) {
$cachekey_server = 'queue_run:server:'; $cachekey_server = 'queue_run:server:';
if (!$queue_id) { if (!$queue_id) {
logger('queue: start'); logger('queue: start');
// Handling the pubsubhubbub requests // Handling the pubsubhubbub requests
Worker::add(array('priority' => PRIORITY_HIGH, 'dont_fork' => true), 'pubsubpublish'); Worker::add(array('priority' => PRIORITY_HIGH, 'dont_fork' => true), 'pubsubpublish');
$r = q("SELECT `queue`.*, `contact`.`name`, `contact`.`uid` FROM `queue` $r = q(
"SELECT `queue`.*, `contact`.`name`, `contact`.`uid` FROM `queue`
INNER JOIN `contact` ON `queue`.`cid` = `contact`.`id` INNER JOIN `contact` ON `queue`.`cid` = `contact`.`id`
WHERE `queue`.`created` < UTC_TIMESTAMP() - INTERVAL 3 DAY"); WHERE `queue`.`created` < UTC_TIMESTAMP() - INTERVAL 3 DAY"
);
if (DBM::is_result($r)) { if (DBM::is_result($r)) {
foreach ($r as $rr) { foreach ($r as $rr) {
@ -66,8 +70,10 @@ function queue_run(&$argv, &$argc) {
require_once 'include/salmon.php'; require_once 'include/salmon.php';
$r = q("SELECT * FROM `queue` WHERE `id` = %d LIMIT 1", $r = q(
intval($queue_id)); "SELECT * FROM `queue` WHERE `id` = %d LIMIT 1",
intval($queue_id)
);
if (!DBM::is_result($r)) { if (!DBM::is_result($r)) {
return; return;
@ -75,7 +81,8 @@ function queue_run(&$argv, &$argc) {
$q_item = $r[0]; $q_item = $r[0];
$c = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1", $c = q(
"SELECT * FROM `contact` WHERE `id` = %d LIMIT 1",
intval($q_item['cid']) intval($q_item['cid'])
); );
@ -111,7 +118,8 @@ function queue_run(&$argv, &$argc) {
} }
} }
$u = q("SELECT `user`.*, `user`.`pubkey` AS `upubkey`, `user`.`prvkey` AS `uprvkey` $u = q(
"SELECT `user`.*, `user`.`pubkey` AS `upubkey`, `user`.`prvkey` AS `uprvkey`
FROM `user` WHERE `uid` = %d LIMIT 1", FROM `user` WHERE `uid` = %d LIMIT 1",
intval($c[0]['uid']) intval($c[0]['uid'])
); );
@ -176,7 +184,6 @@ function queue_run(&$argv, &$argc) {
update_queue_time($q_item['id']); update_queue_time($q_item['id']);
} }
break; break;
} }
logger('Deliver status '.(int)$deliver_status.' for item '.$q_item['id'].' to '.$contact['name'].' <'.$contact['url'].'>'); logger('Deliver status '.(int)$deliver_status.' for item '.$q_item['id'].' to '.$contact['name'].' <'.$contact['url'].'>');

View file

@ -1,27 +1,28 @@
<?php <?php
// Session management functions. These provide database storage of PHP /**
// session info. * Session management functions. These provide database storage of PHP session info.
*/
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Database\DBM; use Friendica\Database\DBM;
require_once('include/cache.php');
$session_exists = 0; $session_exists = 0;
$session_expire = 180000; $session_expire = 180000;
function ref_session_open($s, $n) { function ref_session_open($s, $n)
{
return true; return true;
} }
function ref_session_read($id) { function ref_session_read($id)
{
global $session_exists; global $session_exists;
if (!x($id)) { if (!x($id)) {
return ''; return '';
} }
$memcache = cache::memcache(); $memcache = Cache::memcache();
if (is_object($memcache)) { if (is_object($memcache)) {
$data = $memcache->get(get_app()->get_hostname().":session:".$id); $data = $memcache->get(get_app()->get_hostname().":session:".$id);
if (!is_bool($data)) { if (!is_bool($data)) {
@ -56,7 +57,8 @@ function ref_session_read($id) {
* @param string $data Serialized session data * @param string $data Serialized session data
* @return boolean Returns false if parameters are missing, true otherwise * @return boolean Returns false if parameters are missing, true otherwise
*/ */
function ref_session_write($id, $data) { function ref_session_write($id, $data)
{
global $session_exists, $session_expire; global $session_exists, $session_expire;
if (!$id || !$data) { if (!$id || !$data) {
@ -66,7 +68,7 @@ function ref_session_write($id, $data) {
$expire = time() + $session_expire; $expire = time() + $session_expire;
$default_expire = time() + 300; $default_expire = time() + 300;
$memcache = cache::memcache(); $memcache = Cache::memcache();
$a = get_app(); $a = get_app();
if (is_object($memcache) && is_object($a)) { if (is_object($memcache) && is_object($a)) {
$memcache->set($a->get_hostname().":session:".$id, $data, MEMCACHE_COMPRESSED, $expire); $memcache->set($a->get_hostname().":session:".$id, $data, MEMCACHE_COMPRESSED, $expire);
@ -85,12 +87,14 @@ function ref_session_write($id, $data) {
return true; return true;
} }
function ref_session_close() { function ref_session_close()
{
return true; return true;
} }
function ref_session_destroy($id) { function ref_session_destroy($id)
$memcache = cache::memcache(); {
$memcache = Cache::memcache();
if (is_object($memcache)) { if (is_object($memcache)) {
$memcache->delete(get_app()->get_hostname().":session:".$id); $memcache->delete(get_app()->get_hostname().":session:".$id);
@ -101,7 +105,8 @@ function ref_session_destroy($id) {
return true; return true;
} }
function ref_session_gc($expire) { function ref_session_gc($expire)
{
dba::delete('session', array("`expire` < ?", time())); dba::delete('session', array("`expire` < ?", time()));
return true; return true;
} }
@ -117,7 +122,9 @@ if (Config::get('system', 'ssl_policy') == SSL_POLICY_FULL) {
} }
if (!Config::get('system', 'disable_database_session')) { if (!Config::get('system', 'disable_database_session')) {
session_set_save_handler('ref_session_open', 'ref_session_close', session_set_save_handler(
'ref_session_open', 'ref_session_close',
'ref_session_read', 'ref_session_write', 'ref_session_read', 'ref_session_write',
'ref_session_destroy', 'ref_session_gc'); 'ref_session_destroy', 'ref_session_gc'
);
} }

View file

@ -9,6 +9,7 @@
use Friendica\App; use Friendica\App;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\Worker; use Friendica\Core\Worker;
use Friendica\Database\DBM; use Friendica\Database\DBM;

View file

@ -1,18 +1,20 @@
<?php <?php
/**
* @file include/ping.php
*/
use Friendica\App; use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\Core\PConfig; use Friendica\Core\PConfig;
use Friendica\Database\DBM; use Friendica\Database\DBM;
require_once('include/datetime.php'); require_once 'include/datetime.php';
require_once('include/bbcode.php'); require_once 'include/bbcode.php';
require_once('include/ForumManager.php'); require_once 'include/ForumManager.php';
require_once('include/group.php'); require_once 'include/group.php';
require_once('mod/proxy.php'); require_once 'mod/proxy.php';
require_once('include/xml.php'); require_once 'include/xml.php';
require_once('include/cache.php'); require_once 'include/enotify.php';
require_once('include/enotify.php');
/** /**
* @brief Outputs the counts and the lists of various notifications * @brief Outputs the counts and the lists of various notifications
@ -99,7 +101,6 @@ function ping_init(App $a)
if (local_user()) { if (local_user()) {
// Different login session than the page that is calling us. // Different login session than the page that is calling us.
if (intval($_GET['uid']) && intval($_GET['uid']) != local_user()) { if (intval($_GET['uid']) && intval($_GET['uid']) != local_user()) {
$data = array('result' => array('invalid' => 1)); $data = array('result' => array('invalid' => 1));
if ($format == 'json') { if ($format == 'json') {
@ -120,7 +121,8 @@ function ping_init(App $a)
$notifs = ping_get_notifications(local_user()); $notifs = ping_get_notifications(local_user());
$items_unseen = q("SELECT `item`.`id`, `item`.`parent`, `item`.`verb`, `item`.`wall`, `item`.`author-name`, $items_unseen = q(
"SELECT `item`.`id`, `item`.`parent`, `item`.`verb`, `item`.`wall`, `item`.`author-name`,
`item`.`contact-id`, `item`.`author-link`, `item`.`author-avatar`, `item`.`created`, `item`.`object`, `item`.`contact-id`, `item`.`author-link`, `item`.`author-avatar`, `item`.`created`, `item`.`object`,
`pitem`.`author-name` AS `pname`, `pitem`.`author-link` AS `plink` `pitem`.`author-name` AS `pname`, `pitem`.`author-link` AS `plink`
FROM `item` INNER JOIN `item` AS `pitem` ON `pitem`.`id` = `item`.`parent` FROM `item` INNER JOIN `item` AS `pitem` ON `pitem`.`id` = `item`.`parent`
@ -128,7 +130,8 @@ function ping_init(App $a)
`item`.`deleted` = 0 AND `item`.`uid` = %d AND `pitem`.`parent` != 0 `item`.`deleted` = 0 AND `item`.`uid` = %d AND `pitem`.`parent` != 0
AND `item`.`contact-id` != %d AND `item`.`contact-id` != %d
ORDER BY `item`.`created` DESC", ORDER BY `item`.`created` DESC",
intval(local_user()), intval(local_user()) intval(local_user()),
intval(local_user())
); );
if (DBM::is_result($items_unseen)) { if (DBM::is_result($items_unseen)) {
@ -169,13 +172,15 @@ function ping_init(App $a)
} }
} }
$intros1 = q("SELECT `intro`.`id`, `intro`.`datetime`, $intros1 = q(
"SELECT `intro`.`id`, `intro`.`datetime`,
`fcontact`.`name`, `fcontact`.`url`, `fcontact`.`photo` `fcontact`.`name`, `fcontact`.`url`, `fcontact`.`photo`
FROM `intro` LEFT JOIN `fcontact` ON `intro`.`fid` = `fcontact`.`id` FROM `intro` LEFT JOIN `fcontact` ON `intro`.`fid` = `fcontact`.`id`
WHERE `intro`.`uid` = %d AND `intro`.`blocked` = 0 AND `intro`.`ignore` = 0 AND `intro`.`fid` != 0", WHERE `intro`.`uid` = %d AND `intro`.`blocked` = 0 AND `intro`.`ignore` = 0 AND `intro`.`fid` != 0",
intval(local_user()) intval(local_user())
); );
$intros2 = q("SELECT `intro`.`id`, `intro`.`datetime`, $intros2 = q(
"SELECT `intro`.`id`, `intro`.`datetime`,
`contact`.`name`, `contact`.`url`, `contact`.`photo` `contact`.`name`, `contact`.`url`, `contact`.`photo`
FROM `intro` LEFT JOIN `contact` ON `intro`.`contact-id` = `contact`.`id` FROM `intro` LEFT JOIN `contact` ON `intro`.`contact-id` = `contact`.`id`
WHERE `intro`.`uid` = %d AND `intro`.`blocked` = 0 AND `intro`.`ignore` = 0 AND `intro`.`contact-id` != 0", WHERE `intro`.`uid` = %d AND `intro`.`blocked` = 0 AND `intro`.`ignore` = 0 AND `intro`.`contact-id` != 0",
@ -186,7 +191,8 @@ function ping_init(App $a)
$intros = $intros1 + $intros2; $intros = $intros1 + $intros2;
$myurl = System::baseUrl() . '/profile/' . $a->user['nickname'] ; $myurl = System::baseUrl() . '/profile/' . $a->user['nickname'] ;
$mails = q("SELECT `id`, `from-name`, `from-url`, `from-photo`, `created` FROM `mail` $mails = q(
"SELECT `id`, `from-name`, `from-url`, `from-photo`, `created` FROM `mail`
WHERE `uid` = %d AND `seen` = 0 AND `from-url` != '%s' ", WHERE `uid` = %d AND `seen` = 0 AND `from-url` != '%s' ",
intval(local_user()), intval(local_user()),
dbesc($myurl) dbesc($myurl)
@ -194,9 +200,11 @@ function ping_init(App $a)
$mail_count = count($mails); $mail_count = count($mails);
if ($a->config['register_policy'] == REGISTER_APPROVE && is_site_admin()) { if ($a->config['register_policy'] == REGISTER_APPROVE && is_site_admin()) {
$regs = q("SELECT `contact`.`name`, `contact`.`url`, `contact`.`micro`, `register`.`created`, COUNT(*) AS `total` $regs = q(
"SELECT `contact`.`name`, `contact`.`url`, `contact`.`micro`, `register`.`created`, COUNT(*) AS `total`
FROM `contact` RIGHT JOIN `register` ON `register`.`uid` = `contact`.`uid` FROM `contact` RIGHT JOIN `register` ON `register`.`uid` = `contact`.`uid`
WHERE `contact`.`self` = 1"); WHERE `contact`.`self` = 1"
);
if (DBM::is_result($regs)) { if (DBM::is_result($regs)) {
$register_count = $regs[0]['total']; $register_count = $regs[0]['total'];
@ -206,7 +214,8 @@ function ping_init(App $a)
$cachekey = "ping_init:".local_user(); $cachekey = "ping_init:".local_user();
$ev = Cache::get($cachekey); $ev = Cache::get($cachekey);
if (is_null($ev)) { if (is_null($ev)) {
$ev = q("SELECT type, start, adjust FROM `event` $ev = q(
"SELECT type, start, adjust FROM `event`
WHERE `event`.`uid` = %d AND `start` < '%s' AND `finish` > '%s' and `ignore` = 0 WHERE `event`.`uid` = %d AND `start` < '%s' AND `finish` > '%s' and `ignore` = 0
ORDER BY `start` ASC ", ORDER BY `start` ASC ",
intval(local_user()), intval(local_user()),
@ -228,20 +237,20 @@ function ping_init(App $a)
if ($x['type'] === 'birthday') { if ($x['type'] === 'birthday') {
$birthdays ++; $birthdays ++;
$bd = true; $bd = true;
} } else {
else {
$events ++; $events ++;
} }
if (datetime_convert('UTC', ((intval($x['adjust'])) ? $a->timezone : 'UTC'), $x['start'], 'Y-m-d') === $str_now) { if (datetime_convert('UTC', ((intval($x['adjust'])) ? $a->timezone : 'UTC'), $x['start'], 'Y-m-d') === $str_now) {
$all_events_today ++; $all_events_today ++;
if ($bd) if ($bd) {
$birthdays_today ++; $birthdays_today ++;
else } else {
$events_today ++; $events_today ++;
} }
} }
} }
} }
}
$data['intro'] = $intro_count; $data['intro'] = $intro_count;
$data['mail'] = $mail_count; $data['mail'] = $mail_count;
@ -426,7 +435,8 @@ function ping_get_notifications($uid)
$a = get_app(); $a = get_app();
do { do {
$r = q("SELECT `notify`.*, `item`.`visible`, `item`.`spam`, `item`.`deleted` $r = q(
"SELECT `notify`.*, `item`.`visible`, `item`.`spam`, `item`.`deleted`
FROM `notify` LEFT JOIN `item` ON `item`.`id` = `notify`.`iid` FROM `notify` LEFT JOIN `item` ON `item`.`id` = `notify`.`iid`
WHERE `notify`.`uid` = %d AND `notify`.`msg` != '' WHERE `notify`.`uid` = %d AND `notify`.`msg` != ''
AND NOT (`notify`.`type` IN (%d, %d)) AND NOT (`notify`.`type` IN (%d, %d))
@ -448,7 +458,7 @@ function ping_get_notifications($uid)
$offset += 50; $offset += 50;
} }
foreach ($r AS $notification) { foreach ($r as $notification) {
if (is_null($notification["visible"])) { if (is_null($notification["visible"])) {
$notification["visible"] = true; $notification["visible"] = true;
} }
@ -468,7 +478,8 @@ function ping_get_notifications($uid)
$notification["name"] = strip_tags(bbcode($notification["name"])); $notification["name"] = strip_tags(bbcode($notification["name"]));
$notification["message"] = format_notification_message($notification["name"], strip_tags(bbcode($notification["msg"]))); $notification["message"] = format_notification_message($notification["name"], strip_tags(bbcode($notification["msg"])));
q("UPDATE `notify` SET `name_cache` = '%s', `msg_cache` = '%s' WHERE `id` = %d", q(
"UPDATE `notify` SET `name_cache` = '%s', `msg_cache` = '%s' WHERE `id` = %d",
dbesc($notification["name"]), dbesc($notification["name"]),
dbesc($notification["message"]), dbesc($notification["message"]),
intval($notification["id"]) intval($notification["id"])
@ -477,8 +488,9 @@ function ping_get_notifications($uid)
$notification["href"] = System::baseUrl() . "/notify/view/" . $notification["id"]; $notification["href"] = System::baseUrl() . "/notify/view/" . $notification["id"];
if ($notification["visible"] && !$notification["spam"] && if ($notification["visible"] && !$notification["spam"]
!$notification["deleted"] && !is_array($result[$notification["parent"]])) { && !$notification["deleted"] && !is_array($result[$notification["parent"]])
) {
// Should we condense the notifications or show them all? // Should we condense the notifications or show them all?
if (PConfig::get(local_user(), 'system', 'detailed_notif')) { if (PConfig::get(local_user(), 'system', 'detailed_notif')) {
$result[$notification["id"]] = $notification; $result[$notification["id"]] = $notification;
@ -497,7 +509,7 @@ function ping_get_notifications($uid)
* @deprecated * @deprecated
* *
* @param array $data The initial ping data array * @param array $data The initial ping data array
* @param int $sysnotify_count Number of unseen system notifications * @param int $sysnotify Number of unseen system notifications
* @param array $notifs Complete list of notification * @param array $notifs Complete list of notification
* @param array $sysmsgs List of system notice messages * @param array $sysmsgs List of system notice messages
* @param array $sysmsgs_info List of system info messages * @param array $sysmsgs_info List of system info messages

View file

@ -4,6 +4,7 @@
// https://web.archive.org/web/20160405005550/http://portablecontacts.net/draft-spec.html // https://web.archive.org/web/20160405005550/http://portablecontacts.net/draft-spec.html
use Friendica\App; use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Database\DBM; use Friendica\Database\DBM;

View file

@ -1,6 +1,7 @@
<?php <?php
use Friendica\App; use Friendica\App;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Database\DBM; use Friendica\Database\DBM;

View file

@ -3,11 +3,11 @@
namespace Friendica; namespace Friendica;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\PConfig; use Friendica\Core\PConfig;
use Friendica\Database\DBM; use Friendica\Database\DBM;
use Cache;
use dba; use dba;
use Detection\MobileDetect; use Detection\MobileDetect;

View file

@ -1,21 +1,25 @@
<?php <?php
/** /**
* @file include/cache.php * @file src/Core/Cache.php
*
* @brief Class for storing data for a short time
*/ */
namespace Friendica\Core;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\PConfig; use Friendica\Core\PConfig;
use Friendica\Database\DBM; use Friendica\Database\DBM;
class Cache { /**
* @brief Class for storing data for a short time
*/
class Cache
{
/** /**
* @brief Check for memcache and open a connection if configured * @brief Check for memcache and open a connection if configured
* *
* @return object|boolean The memcache object - or "false" if not successful * @return object|boolean The memcache object - or "false" if not successful
*/ */
public static function memcache() { public static function memcache()
{
if (!function_exists('memcache_connect')) { if (!function_exists('memcache_connect')) {
return false; return false;
} }
@ -43,30 +47,31 @@ class Cache {
* *
* @return integer The cache duration in seconds * @return integer The cache duration in seconds
*/ */
private static function duration($level) { private static function duration($level)
{
switch ($level) { switch ($level) {
case CACHE_MONTH; case CACHE_MONTH:
$seconds = 2592000; $seconds = 2592000;
break; break;
case CACHE_WEEK; case CACHE_WEEK:
$seconds = 604800; $seconds = 604800;
break; break;
case CACHE_DAY; case CACHE_DAY:
$seconds = 86400; $seconds = 86400;
break; break;
case CACHE_HOUR; case CACHE_HOUR:
$seconds = 3600; $seconds = 3600;
break; break;
case CACHE_HALF_HOUR; case CACHE_HALF_HOUR:
$seconds = 1800; $seconds = 1800;
break; break;
case CACHE_QUARTER_HOUR; case CACHE_QUARTER_HOUR:
$seconds = 900; $seconds = 900;
break; break;
case CACHE_FIVE_MINUTES; case CACHE_FIVE_MINUTES:
$seconds = 300; $seconds = 300;
break; break;
case CACHE_MINUTE; case CACHE_MINUTE:
$seconds = 60; $seconds = 60;
break; break;
} }
@ -80,8 +85,8 @@ class Cache {
* *
* @return mixed Cached $value or "null" if not found * @return mixed Cached $value or "null" if not found
*/ */
public static function get($key) { public static function get($key)
{
$memcache = self::memcache(); $memcache = self::memcache();
if (is_object($memcache)) { if (is_object($memcache)) {
// We fetch with the hostname as key to avoid problems with other applications // We fetch with the hostname as key to avoid problems with other applications
@ -101,7 +106,8 @@ class Cache {
// Frequently clear cache // Frequently clear cache
self::clear($duration); self::clear($duration);
$r = q("SELECT `v` FROM `cache` WHERE `k`='%s' LIMIT 1", $r = q(
"SELECT `v` FROM `cache` WHERE `k`='%s' LIMIT 1",
dbesc($key) dbesc($key)
); );
@ -126,11 +132,11 @@ class Cache {
* The input $value can have multiple formats. * The input $value can have multiple formats.
* *
* @param string $key The key to the cached data * @param string $key The key to the cached data
* @param mixed $valie The value that is about to be stored * @param mixed $value The value that is about to be stored
* @param integer $duration The cache lifespan * @param integer $duration The cache lifespan
*/ */
public static function set($key, $value, $duration = CACHE_MONTH) { public static function set($key, $value, $duration = CACHE_MONTH)
{
// Do we have an installed memcache? Use it instead. // Do we have an installed memcache? Use it instead.
$memcache = self::memcache(); $memcache = self::memcache();
if (is_object($memcache)) { if (is_object($memcache)) {
@ -140,70 +146,96 @@ class Cache {
} }
/// @todo store the cache data in the same way like the config data /// @todo store the cache data in the same way like the config data
q("REPLACE INTO `cache` (`k`,`v`,`expire_mode`,`updated`) VALUES ('%s','%s',%d,'%s')", q(
"REPLACE INTO `cache` (`k`,`v`,`expire_mode`,`updated`) VALUES ('%s','%s',%d,'%s')",
dbesc($key), dbesc($key),
dbesc(serialize($value)), dbesc(serialize($value)),
intval($duration), intval($duration),
dbesc(datetime_convert())); dbesc(datetime_convert())
);
} }
/** /**
* @brief Remove outdated data from the cache * @brief Remove outdated data from the cache
* *
* @param integer $maxlevel The maximum cache level that is to be cleared * @param integer $max_level The maximum cache level that is to be cleared
*/ */
public static function clear($max_level = CACHE_MONTH) { public static function clear($max_level = CACHE_MONTH)
{
// Clear long lasting cache entries only once a day // Clear long lasting cache entries only once a day
if (Config::get("system", "cache_cleared_day") < time() - self::duration(CACHE_DAY)) { if (Config::get("system", "cache_cleared_day") < time() - self::duration(CACHE_DAY)) {
if ($max_level == CACHE_MONTH) { if ($max_level == CACHE_MONTH) {
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d", q(
dbesc(datetime_convert('UTC','UTC',"now - 30 days")), intval(CACHE_MONTH)); "DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
dbesc(datetime_convert('UTC', 'UTC', "now - 30 days")),
intval(CACHE_MONTH)
);
} }
if ($max_level <= CACHE_WEEK) { if ($max_level <= CACHE_WEEK) {
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d", q(
dbesc(datetime_convert('UTC','UTC',"now - 7 days")), intval(CACHE_WEEK)); "DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
dbesc(datetime_convert('UTC', 'UTC', "now - 7 days")),
intval(CACHE_WEEK)
);
} }
if ($max_level <= CACHE_DAY) { if ($max_level <= CACHE_DAY) {
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d", q(
dbesc(datetime_convert('UTC','UTC',"now - 1 days")), intval(CACHE_DAY)); "DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
dbesc(datetime_convert('UTC', 'UTC', "now - 1 days")),
intval(CACHE_DAY)
);
} }
Config::set("system", "cache_cleared_day", time()); Config::set("system", "cache_cleared_day", time());
} }
if (($max_level <= CACHE_HOUR) && (Config::get("system", "cache_cleared_hour")) < time() - self::duration(CACHE_HOUR)) { if (($max_level <= CACHE_HOUR) && (Config::get("system", "cache_cleared_hour")) < time() - self::duration(CACHE_HOUR)) {
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d", q(
dbesc(datetime_convert('UTC','UTC',"now - 1 hours")), intval(CACHE_HOUR)); "DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
dbesc(datetime_convert('UTC', 'UTC', "now - 1 hours")),
intval(CACHE_HOUR)
);
Config::set("system", "cache_cleared_hour", time()); Config::set("system", "cache_cleared_hour", time());
} }
if (($max_level <= CACHE_HALF_HOUR) && (Config::get("system", "cache_cleared_half_hour")) < time() - self::duration(CACHE_HALF_HOUR)) { if (($max_level <= CACHE_HALF_HOUR) && (Config::get("system", "cache_cleared_half_hour")) < time() - self::duration(CACHE_HALF_HOUR)) {
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d", q(
dbesc(datetime_convert('UTC','UTC',"now - 30 minutes")), intval(CACHE_HALF_HOUR)); "DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
dbesc(datetime_convert('UTC', 'UTC', "now - 30 minutes")),
intval(CACHE_HALF_HOUR)
);
Config::set("system", "cache_cleared_half_hour", time()); Config::set("system", "cache_cleared_half_hour", time());
} }
if (($max_level <= CACHE_QUARTER_HOUR) && (Config::get("system", "cache_cleared_quarter_hour")) < time() - self::duration(CACHE_QUARTER_HOUR)) { if (($max_level <= CACHE_QUARTER_HOUR) && (Config::get("system", "cache_cleared_quarter_hour")) < time() - self::duration(CACHE_QUARTER_HOUR)) {
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d", q(
dbesc(datetime_convert('UTC','UTC',"now - 15 minutes")), intval(CACHE_QUARTER_HOUR)); "DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
dbesc(datetime_convert('UTC', 'UTC', "now - 15 minutes")),
intval(CACHE_QUARTER_HOUR)
);
Config::set("system", "cache_cleared_quarter_hour", time()); Config::set("system", "cache_cleared_quarter_hour", time());
} }
if (($max_level <= CACHE_FIVE_MINUTES) && (Config::get("system", "cache_cleared_five_minute")) < time() - self::duration(CACHE_FIVE_MINUTES)) { if (($max_level <= CACHE_FIVE_MINUTES) && (Config::get("system", "cache_cleared_five_minute")) < time() - self::duration(CACHE_FIVE_MINUTES)) {
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d", q(
dbesc(datetime_convert('UTC','UTC',"now - 5 minutes")), intval(CACHE_FIVE_MINUTES)); "DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
dbesc(datetime_convert('UTC', 'UTC', "now - 5 minutes")),
intval(CACHE_FIVE_MINUTES)
);
Config::set("system", "cache_cleared_five_minute", time()); Config::set("system", "cache_cleared_five_minute", time());
} }
if (($max_level <= CACHE_MINUTE) && (Config::get("system", "cache_cleared_minute")) < time() - self::duration(CACHE_MINUTE)) { if (($max_level <= CACHE_MINUTE) && (Config::get("system", "cache_cleared_minute")) < time() - self::duration(CACHE_MINUTE)) {
q("DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d", q(
dbesc(datetime_convert('UTC','UTC',"now - 1 minutes")), intval(CACHE_MINUTE)); "DELETE FROM `cache` WHERE `updated` < '%s' AND `expire_mode` = %d",
dbesc(datetime_convert('UTC', 'UTC', "now - 1 minutes")),
intval(CACHE_MINUTE)
);
Config::set("system", "cache_cleared_minute", time()); Config::set("system", "cache_cleared_minute", time());
} }

View file

@ -10,11 +10,11 @@ namespace Friendica\Network;
use Friendica\App; use Friendica\App;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Database\DBM; use Friendica\Database\DBM;
use dba; use dba;
use Cache;
use xml; use xml;
use DomXPath; use DomXPath;

View file

@ -11,13 +11,13 @@ namespace Friendica\Protocol;
use Friendica\App; use Friendica\App;
use Friendica\Core\System; use Friendica\Core\System;
use Friendica\Core\Cache;
use Friendica\Core\Config; use Friendica\Core\Config;
use Friendica\Core\PConfig; use Friendica\Core\PConfig;
use Friendica\Core\Worker; use Friendica\Core\Worker;
use Friendica\Database\DBM; use Friendica\Database\DBM;
use Friendica\Network\Probe; use Friendica\Network\Probe;
use Cache;
use dba; use dba;
use SimpleXMLElement; use SimpleXMLElement;
use xml; use xml;

View file

@ -7,6 +7,7 @@
<exclude name="PEAR.NamingConventions.ValidVariableName.PrivateNoUnderscore"/> <exclude name="PEAR.NamingConventions.ValidVariableName.PrivateNoUnderscore"/>
<exclude name="PEAR.NamingConventions.ValidFunctionName.PrivateNoUnderscore"/> <exclude name="PEAR.NamingConventions.ValidFunctionName.PrivateNoUnderscore"/>
<exclude name="PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps"/> <exclude name="PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps"/>
<exclude name="PEAR.WhiteSpace.ScopeIndent.IncorrectExact"/>
<exclude name="PSR1.Methods.CamelCapsMethodName.NotCamelCaps"/> <exclude name="PSR1.Methods.CamelCapsMethodName.NotCamelCaps"/>
</rule> </rule>
<description>PSR2 with tabs instead of spaces.</description> <description>PSR2 with tabs instead of spaces.</description>