parent
6189f6c8e7
commit
4ca68c7af0
151 changed files with 987 additions and 8742 deletions
7
boot.php
7
boot.php
|
|
@ -25,6 +25,7 @@ use Friendica\Core\System;
|
||||||
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\Util\Lock;
|
use Friendica\Util\Lock;
|
||||||
|
|
||||||
require_once 'include/network.php';
|
require_once 'include/network.php';
|
||||||
|
|
@ -769,7 +770,7 @@ function run_update_function($x) {
|
||||||
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;
|
||||||
} else {
|
} else {
|
||||||
$installed = array();
|
$installed = array();
|
||||||
|
|
@ -1055,7 +1056,7 @@ function current_theme() {
|
||||||
$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)) {
|
||||||
$page_theme = $r[0]['theme'];
|
$page_theme = $r[0]['theme'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -1177,7 +1178,7 @@ function feed_birthday($uid, $tz) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($p)) {
|
if (DBM::is_result($p)) {
|
||||||
$tmp_dob = substr($p[0]['dob'], 5);
|
$tmp_dob = substr($p[0]['dob'], 5);
|
||||||
if (intval($tmp_dob)) {
|
if (intval($tmp_dob)) {
|
||||||
$y = datetime_convert($tz, $tz, 'now', 'Y');
|
$y = datetime_convert($tz, $tz, 'now', 'Y');
|
||||||
|
|
|
||||||
|
|
@ -73,7 +73,7 @@ If there are only a handful of references to a single non-namespaced class, just
|
||||||
````php
|
````php
|
||||||
namespace Friendica\Core;
|
namespace Friendica\Core;
|
||||||
...
|
...
|
||||||
if (\dbm::is_result($r)) {
|
if (\DBM::is_result($r)) {
|
||||||
...
|
...
|
||||||
}
|
}
|
||||||
````
|
````
|
||||||
|
|
@ -82,7 +82,7 @@ namespace Friendica\Core;
|
||||||
|
|
||||||
use \dbm;
|
use \dbm;
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
...
|
...
|
||||||
}
|
}
|
||||||
````
|
````
|
||||||
|
|
|
||||||
|
|
@ -104,7 +104,7 @@ class Dfrn {
|
||||||
|
|
||||||
mail_post($a){
|
mail_post($a){
|
||||||
...
|
...
|
||||||
Friendica\dfrn::mail($item, $owner);
|
Friendica\DFRN::mail($item, $owner);
|
||||||
...
|
...
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
@ -125,12 +125,12 @@ switch($contact['network']) {
|
||||||
case NETWORK_DFRN:
|
case NETWORK_DFRN:
|
||||||
if ($mail) {
|
if ($mail) {
|
||||||
$item['body'] = ...
|
$item['body'] = ...
|
||||||
$atom = Dfrn::mail($item, $owner);
|
$atom = DFRN::mail($item, $owner);
|
||||||
} elseif ($fsuggest) {
|
} elseif ($fsuggest) {
|
||||||
$atom = Dfrn::fsuggest($item, $owner);
|
$atom = DFRN::fsuggest($item, $owner);
|
||||||
q("DELETE FROM `fsuggest` WHERE `id` = %d LIMIT 1", intval($item['id']));
|
q("DELETE FROM `fsuggest` WHERE `id` = %d LIMIT 1", intval($item['id']));
|
||||||
} elseif ($relocate)
|
} elseif ($relocate)
|
||||||
$atom = Dfrn::relocate($owner, $uid);
|
$atom = DFRN::relocate($owner, $uid);
|
||||||
[...]
|
[...]
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,9 +4,10 @@ use Friendica\App;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
use Friendica\Protocol\Dfrn;
|
use Friendica\Protocol\DFRN;
|
||||||
|
|
||||||
// Included here for completeness, but this is a very dangerous operation.
|
// Included here for completeness, but this is a very dangerous operation.
|
||||||
// It is the caller's responsibility to confirm the requestor's intent and
|
// It is the caller's responsibility to confirm the requestor's intent and
|
||||||
|
|
@ -49,7 +50,7 @@ function contact_remove($id) {
|
||||||
$r = q("SELECT `uid` FROM `contact` WHERE `id` = %d AND NOT `self` LIMIT 1",
|
$r = q("SELECT `uid` FROM `contact` WHERE `id` = %d AND NOT `self` LIMIT 1",
|
||||||
intval($id)
|
intval($id)
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r) || !intval($r[0]['uid'])) {
|
if (!DBM::is_result($r) || !intval($r[0]['uid'])) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -94,7 +95,7 @@ function terminate_friendship($user,$self,$contact) {
|
||||||
} elseif ($contact['network'] === NETWORK_DIASPORA) {
|
} elseif ($contact['network'] === NETWORK_DIASPORA) {
|
||||||
Diaspora::send_unshare($user,$contact);
|
Diaspora::send_unshare($user,$contact);
|
||||||
} elseif ($contact['network'] === NETWORK_DFRN) {
|
} elseif ($contact['network'] === NETWORK_DFRN) {
|
||||||
Dfrn::deliver($user,$contact,'placeholder', 1);
|
DFRN::deliver($user,$contact,'placeholder', 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
@ -163,7 +164,7 @@ function unmark_for_death($contact) {
|
||||||
);
|
);
|
||||||
|
|
||||||
// We don't need to update, we never marked this contact as dead
|
// We don't need to update, we never marked this contact as dead
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -213,7 +214,7 @@ function get_contact_details_by_url($url, $uid = -1, $default = array()) {
|
||||||
$r = dba::inArray($s);
|
$r = dba::inArray($s);
|
||||||
|
|
||||||
// Fetch contact data from the contact table for the given user, checking with the alias
|
// Fetch contact data from the contact table for the given user, checking with the alias
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$s = dba::p("SELECT `id`, `id` AS `cid`, 0 AS `gid`, 0 AS `zid`, `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, `xmpp`,
|
$s = dba::p("SELECT `id`, `id` AS `cid`, 0 AS `gid`, 0 AS `zid`, `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, `xmpp`,
|
||||||
`keywords`, `gender`, `photo`, `thumb`, `micro`, `forum`, `prv`, (`forum` | `prv`) AS `community`, `contact-type`, `bd` AS `birthday`, `self`
|
`keywords`, `gender`, `photo`, `thumb`, `micro`, `forum`, `prv`, (`forum` | `prv`) AS `community`, `contact-type`, `bd` AS `birthday`, `self`
|
||||||
FROM `contact` WHERE `alias` IN (?, ?, ?) AND `uid` = ?",
|
FROM `contact` WHERE `alias` IN (?, ?, ?) AND `uid` = ?",
|
||||||
|
|
@ -222,7 +223,7 @@ function get_contact_details_by_url($url, $uid = -1, $default = array()) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch the data from the contact table with "uid=0" (which is filled automatically)
|
// Fetch the data from the contact table with "uid=0" (which is filled automatically)
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$s = dba::p("SELECT `id`, 0 AS `cid`, `id` AS `zid`, 0 AS `gid`, `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, `xmpp`,
|
$s = dba::p("SELECT `id`, 0 AS `cid`, `id` AS `zid`, 0 AS `gid`, `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, `xmpp`,
|
||||||
`keywords`, `gender`, `photo`, `thumb`, `micro`, `forum`, `prv`, (`forum` | `prv`) AS `community`, `contact-type`, `bd` AS `birthday`, 0 AS `self`
|
`keywords`, `gender`, `photo`, `thumb`, `micro`, `forum`, `prv`, (`forum` | `prv`) AS `community`, `contact-type`, `bd` AS `birthday`, 0 AS `self`
|
||||||
FROM `contact` WHERE `nurl` = ? AND `uid` = 0",
|
FROM `contact` WHERE `nurl` = ? AND `uid` = 0",
|
||||||
|
|
@ -231,7 +232,7 @@ function get_contact_details_by_url($url, $uid = -1, $default = array()) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch the data from the contact table with "uid=0" (which is filled automatically) - checked with the alias
|
// Fetch the data from the contact table with "uid=0" (which is filled automatically) - checked with the alias
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$s = dba::p("SELECT `id`, 0 AS `cid`, `id` AS `zid`, 0 AS `gid`, `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, `xmpp`,
|
$s = dba::p("SELECT `id`, 0 AS `cid`, `id` AS `zid`, 0 AS `gid`, `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, `xmpp`,
|
||||||
`keywords`, `gender`, `photo`, `thumb`, `micro`, `forum`, `prv`, (`forum` | `prv`) AS `community`, `contact-type`, `bd` AS `birthday`, 0 AS `self`
|
`keywords`, `gender`, `photo`, `thumb`, `micro`, `forum`, `prv`, (`forum` | `prv`) AS `community`, `contact-type`, `bd` AS `birthday`, 0 AS `self`
|
||||||
FROM `contact` WHERE `alias` IN (?, ?, ?) AND `uid` = 0",
|
FROM `contact` WHERE `alias` IN (?, ?, ?) AND `uid` = 0",
|
||||||
|
|
@ -240,7 +241,7 @@ function get_contact_details_by_url($url, $uid = -1, $default = array()) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch the data from the gcontact table
|
// Fetch the data from the gcontact table
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$s = dba::p("SELECT 0 AS `id`, 0 AS `cid`, `id` AS `gid`, 0 AS `zid`, 0 AS `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, '' AS `xmpp`,
|
$s = dba::p("SELECT 0 AS `id`, 0 AS `cid`, `id` AS `gid`, 0 AS `zid`, 0 AS `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, '' AS `xmpp`,
|
||||||
`keywords`, `gender`, `photo`, `photo` AS `thumb`, `photo` AS `micro`, `community` AS `forum`, 0 AS `prv`, `community`, `contact-type`, `birthday`, 0 AS `self`
|
`keywords`, `gender`, `photo`, `photo` AS `thumb`, `photo` AS `micro`, `community` AS `forum`, 0 AS `prv`, `community`, `contact-type`, `birthday`, 0 AS `self`
|
||||||
FROM `gcontact` WHERE `nurl` = ?",
|
FROM `gcontact` WHERE `nurl` = ?",
|
||||||
|
|
@ -248,7 +249,7 @@ function get_contact_details_by_url($url, $uid = -1, $default = array()) {
|
||||||
$r = dba::inArray($s);
|
$r = dba::inArray($s);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
// If there is more than one entry we filter out the connector networks
|
// If there is more than one entry we filter out the connector networks
|
||||||
if (count($r) > 1) {
|
if (count($r) > 1) {
|
||||||
foreach ($r AS $id => $result) {
|
foreach ($r AS $id => $result) {
|
||||||
|
|
@ -351,20 +352,20 @@ function get_contact_details_by_addr($addr, $uid = -1) {
|
||||||
dbesc($addr), intval($uid));
|
dbesc($addr), intval($uid));
|
||||||
|
|
||||||
// Fetch the data from the contact table with "uid=0" (which is filled automatically)
|
// Fetch the data from the contact table with "uid=0" (which is filled automatically)
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
$r = q("SELECT `id`, 0 AS `cid`, `id` AS `zid`, 0 AS `gid`, `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, `xmpp`,
|
$r = q("SELECT `id`, 0 AS `cid`, `id` AS `zid`, 0 AS `gid`, `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, `xmpp`,
|
||||||
`keywords`, `gender`, `photo`, `thumb`, `micro`, `forum`, `prv`, (`forum` | `prv`) AS `community`, `contact-type`, `bd` AS `birthday`, 0 AS `self`
|
`keywords`, `gender`, `photo`, `thumb`, `micro`, `forum`, `prv`, (`forum` | `prv`) AS `community`, `contact-type`, `bd` AS `birthday`, 0 AS `self`
|
||||||
FROM `contact` WHERE `addr` = '%s' AND `uid` = 0",
|
FROM `contact` WHERE `addr` = '%s' AND `uid` = 0",
|
||||||
dbesc($addr));
|
dbesc($addr));
|
||||||
|
|
||||||
// Fetch the data from the gcontact table
|
// Fetch the data from the gcontact table
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
$r = q("SELECT 0 AS `id`, 0 AS `cid`, `id` AS `gid`, 0 AS `zid`, 0 AS `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, '' AS `xmpp`,
|
$r = q("SELECT 0 AS `id`, 0 AS `cid`, `id` AS `gid`, 0 AS `zid`, 0 AS `uid`, `url`, `nurl`, `alias`, `network`, `name`, `nick`, `addr`, `location`, `about`, '' AS `xmpp`,
|
||||||
`keywords`, `gender`, `photo`, `photo` AS `thumb`, `photo` AS `micro`, `community` AS `forum`, 0 AS `prv`, `community`, `contact-type`, `birthday`, 0 AS `self`
|
`keywords`, `gender`, `photo`, `photo` AS `thumb`, `photo` AS `micro`, `community` AS `forum`, 0 AS `prv`, `community`, `contact-type`, `birthday`, 0 AS `self`
|
||||||
FROM `gcontact` WHERE `addr` = '%s'",
|
FROM `gcontact` WHERE `addr` = '%s'",
|
||||||
dbesc($addr));
|
dbesc($addr));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$data = Probe::uri($addr);
|
$data = Probe::uri($addr);
|
||||||
|
|
||||||
$profile = get_contact_details_by_url($data['url'], $uid);
|
$profile = get_contact_details_by_url($data['url'], $uid);
|
||||||
|
|
@ -486,7 +487,7 @@ function random_profile() {
|
||||||
ORDER BY rand() LIMIT 1",
|
ORDER BY rand() LIMIT 1",
|
||||||
dbesc(NETWORK_DFRN));
|
dbesc(NETWORK_DFRN));
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return dirname($r[0]['url']);
|
return dirname($r[0]['url']);
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
@ -553,12 +554,12 @@ function get_contact($url, $uid = 0, $no_update = false) {
|
||||||
$contact = dba::select('contact', array('id', 'avatar-date'), array('nurl' => normalise_link($url), 'uid' => $uid), array('limit' => 1));
|
$contact = dba::select('contact', array('id', 'avatar-date'), array('nurl' => normalise_link($url), 'uid' => $uid), array('limit' => 1));
|
||||||
|
|
||||||
// Then the addr (nick@server.tld)
|
// Then the addr (nick@server.tld)
|
||||||
if (!dbm::is_result($contact)) {
|
if (!DBM::is_result($contact)) {
|
||||||
$contact = dba::select('contact', array('id', 'avatar-date'), array('addr' => $url, 'uid' => $uid), array('limit' => 1));
|
$contact = dba::select('contact', array('id', 'avatar-date'), array('addr' => $url, 'uid' => $uid), array('limit' => 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Then the alias (which could be anything)
|
// Then the alias (which could be anything)
|
||||||
if (!dbm::is_result($contact)) {
|
if (!DBM::is_result($contact)) {
|
||||||
// The link could be provided as http although we stored it as https
|
// The link could be provided as http although we stored it as https
|
||||||
$ssl_url = str_replace('http://', 'https://', $url);
|
$ssl_url = str_replace('http://', 'https://', $url);
|
||||||
$r = dba::p("SELECT `id`, `avatar-date` FROM `contact` WHERE `alias` IN (?, ?, ?) AND `uid` = ? LIMIT 1",
|
$r = dba::p("SELECT `id`, `avatar-date` FROM `contact` WHERE `alias` IN (?, ?, ?) AND `uid` = ? LIMIT 1",
|
||||||
|
|
@ -567,7 +568,7 @@ function get_contact($url, $uid = 0, $no_update = false) {
|
||||||
dba::close($r);
|
dba::close($r);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($contact)) {
|
if (DBM::is_result($contact)) {
|
||||||
$contact_id = $contact["id"];
|
$contact_id = $contact["id"];
|
||||||
|
|
||||||
// Update the contact every 7 days
|
// Update the contact every 7 days
|
||||||
|
|
@ -597,7 +598,7 @@ function get_contact($url, $uid = 0, $no_update = false) {
|
||||||
// Get data from the gcontact table
|
// Get data from the gcontact table
|
||||||
$gcontacts = dba::select('gcontact', array('name', 'nick', 'url', 'photo', 'addr', 'alias', 'network'),
|
$gcontacts = dba::select('gcontact', array('name', 'nick', 'url', 'photo', 'addr', 'alias', 'network'),
|
||||||
array('nurl' => normalise_link($url)), array('limit' => 1));
|
array('nurl' => normalise_link($url)), array('limit' => 1));
|
||||||
if (!dbm::is_result($gcontacts)) {
|
if (!DBM::is_result($gcontacts)) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -626,7 +627,7 @@ function get_contact($url, $uid = 0, $no_update = false) {
|
||||||
$contacts = q("SELECT `id` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d ORDER BY `id` LIMIT 2",
|
$contacts = q("SELECT `id` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d ORDER BY `id` LIMIT 2",
|
||||||
dbesc(normalise_link($data["url"])),
|
dbesc(normalise_link($data["url"])),
|
||||||
intval($uid));
|
intval($uid));
|
||||||
if (!dbm::is_result($contacts)) {
|
if (!DBM::is_result($contacts)) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -635,7 +636,7 @@ function get_contact($url, $uid = 0, $no_update = false) {
|
||||||
// Update the newly created contact from data in the gcontact table
|
// Update the newly created contact from data in the gcontact table
|
||||||
$gcontact = dba::select('gcontact', array('location', 'about', 'keywords', 'gender'),
|
$gcontact = dba::select('gcontact', array('location', 'about', 'keywords', 'gender'),
|
||||||
array('nurl' => normalise_link($data["url"])), array('limit' => 1));
|
array('nurl' => normalise_link($data["url"])), array('limit' => 1));
|
||||||
if (dbm::is_result($gcontact)) {
|
if (DBM::is_result($gcontact)) {
|
||||||
// Only use the information when the probing hadn't fetched these values
|
// Only use the information when the probing hadn't fetched these values
|
||||||
if ($data['keywords'] != '') {
|
if ($data['keywords'] != '') {
|
||||||
unset($gcontact['keywords']);
|
unset($gcontact['keywords']);
|
||||||
|
|
@ -663,7 +664,7 @@ function get_contact($url, $uid = 0, $no_update = false) {
|
||||||
array('id' => $contact_id), array('limit' => 1));
|
array('id' => $contact_id), array('limit' => 1));
|
||||||
|
|
||||||
// This condition should always be true
|
// This condition should always be true
|
||||||
if (!dbm::is_result($contact)) {
|
if (!DBM::is_result($contact)) {
|
||||||
return $contact_id;
|
return $contact_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -711,7 +712,7 @@ function blockedContact($cid) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$blocked = dba::select('contact', array('blocked'), array('id' => $cid), array('limit' => 1));
|
$blocked = dba::select('contact', array('blocked'), array('id' => $cid), array('limit' => 1));
|
||||||
if (!dbm::is_result($blocked)) {
|
if (!DBM::is_result($blocked)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return (bool)$blocked['blocked'];
|
return (bool)$blocked['blocked'];
|
||||||
|
|
@ -730,7 +731,7 @@ function hiddenContact($cid) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$hidden = dba::select('contact', array('hidden'), array('id' => $cid), array('limit' => 1));
|
$hidden = dba::select('contact', array('hidden'), array('id' => $cid), array('limit' => 1));
|
||||||
if (!dbm::is_result($hidden)) {
|
if (!DBM::is_result($hidden)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return (bool)$hidden['hidden'];
|
return (bool)$hidden['hidden'];
|
||||||
|
|
@ -793,7 +794,7 @@ function posts_from_contact_url(App $a, $contact_url) {
|
||||||
WHERE `contact`.`nurl` = '%s' AND `contact`.`uid` = 0",
|
WHERE `contact`.`nurl` = '%s' AND `contact`.`uid` = 0",
|
||||||
dbesc(normalise_link($contact_url)));
|
dbesc(normalise_link($contact_url)));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @file include/ForumManager.php
|
* @file include/ForumManager.php
|
||||||
|
|
@ -93,7 +94,7 @@ class ForumManager {
|
||||||
$total = count($contacts);
|
$total = count($contacts);
|
||||||
$visible_forums = 10;
|
$visible_forums = 10;
|
||||||
|
|
||||||
if (dbm::is_result($contacts)) {
|
if (DBM::is_result($contacts)) {
|
||||||
|
|
||||||
$id = 0;
|
$id = 0;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,866 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* @file include/NotificationsManager.php
|
|
||||||
* @brief Methods for read and write notifications from/to database
|
|
||||||
* or for formatting notifications
|
|
||||||
*/
|
|
||||||
|
|
||||||
use Friendica\Core\Pconfig;
|
|
||||||
use Friendica\Core\System;
|
|
||||||
|
|
||||||
require_once 'include/html2plain.php';
|
|
||||||
require_once 'include/datetime.php';
|
|
||||||
require_once 'include/bbcode.php';
|
|
||||||
require_once 'include/Contact.php';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Methods for read and write notifications from/to database
|
|
||||||
* or for formatting notifications
|
|
||||||
*/
|
|
||||||
class NotificationsManager {
|
|
||||||
private $a;
|
|
||||||
|
|
||||||
public function __construct() {
|
|
||||||
$this->a = get_app();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief set some extra note properties
|
|
||||||
*
|
|
||||||
* @param array $notes array of note arrays from db
|
|
||||||
* @return array Copy of input array with added properties
|
|
||||||
*
|
|
||||||
* Set some extra properties to note array from db:
|
|
||||||
* - timestamp as int in default TZ
|
|
||||||
* - date_rel : relative date string
|
|
||||||
* - msg_html: message as html string
|
|
||||||
* - msg_plain: message as plain text string
|
|
||||||
*/
|
|
||||||
private function _set_extra($notes) {
|
|
||||||
$rets = array();
|
|
||||||
foreach($notes as $n) {
|
|
||||||
$local_time = datetime_convert('UTC',date_default_timezone_get(),$n['date']);
|
|
||||||
$n['timestamp'] = strtotime($local_time);
|
|
||||||
$n['date_rel'] = relative_date($n['date']);
|
|
||||||
$n['msg_html'] = bbcode($n['msg'], false, false, false, false);
|
|
||||||
$n['msg_plain'] = explode("\n",trim(html2plain($n['msg_html'], 0)))[0];
|
|
||||||
|
|
||||||
$rets[] = $n;
|
|
||||||
}
|
|
||||||
return $rets;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Get all notifications for local_user()
|
|
||||||
*
|
|
||||||
* @param array $filter optional Array "column name"=>value: filter query by columns values
|
|
||||||
* @param string $order optional Space separated list of column to sort by. prepend name with "+" to sort ASC, "-" to sort DESC. Default to "-date"
|
|
||||||
* @param string $limit optional Query limits
|
|
||||||
*
|
|
||||||
* @return array of results or false on errors
|
|
||||||
*/
|
|
||||||
public function getAll($filter = array(), $order="-date", $limit="") {
|
|
||||||
$filter_str = array();
|
|
||||||
$filter_sql = "";
|
|
||||||
foreach($filter as $column => $value) {
|
|
||||||
$filter_str[] = sprintf("`%s` = '%s'", $column, dbesc($value));
|
|
||||||
}
|
|
||||||
if (count($filter_str)>0) {
|
|
||||||
$filter_sql = "AND ".implode(" AND ", $filter_str);
|
|
||||||
}
|
|
||||||
|
|
||||||
$aOrder = explode(" ", $order);
|
|
||||||
$asOrder = array();
|
|
||||||
foreach($aOrder as $o) {
|
|
||||||
$dir = "asc";
|
|
||||||
if ($o[0]==="-") {
|
|
||||||
$dir = "desc";
|
|
||||||
$o = substr($o,1);
|
|
||||||
}
|
|
||||||
if ($o[0]==="+") {
|
|
||||||
$dir = "asc";
|
|
||||||
$o = substr($o,1);
|
|
||||||
}
|
|
||||||
$asOrder[] = "$o $dir";
|
|
||||||
}
|
|
||||||
$order_sql = implode(", ", $asOrder);
|
|
||||||
|
|
||||||
if($limit!="")
|
|
||||||
$limit = " LIMIT ".$limit;
|
|
||||||
|
|
||||||
$r = q("SELECT * FROM `notify` WHERE `uid` = %d $filter_sql ORDER BY $order_sql $limit",
|
|
||||||
intval(local_user())
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
return $this->_set_extra($r);
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Get one note for local_user() by $id value
|
|
||||||
*
|
|
||||||
* @param int $id
|
|
||||||
* @return array note values or null if not found
|
|
||||||
*/
|
|
||||||
public function getByID($id) {
|
|
||||||
$r = q("SELECT * FROM `notify` WHERE `id` = %d AND `uid` = %d LIMIT 1",
|
|
||||||
intval($id),
|
|
||||||
intval(local_user())
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return $this->_set_extra($r)[0];
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief set seen state of $note of local_user()
|
|
||||||
*
|
|
||||||
* @param array $note
|
|
||||||
* @param bool $seen optional true or false, default true
|
|
||||||
* @return bool true on success, false on errors
|
|
||||||
*/
|
|
||||||
public function setSeen($note, $seen = true) {
|
|
||||||
return q("UPDATE `notify` SET `seen` = %d WHERE ( `link` = '%s' OR ( `parent` != 0 AND `parent` = %d AND `otype` = '%s' )) AND `uid` = %d",
|
|
||||||
intval($seen),
|
|
||||||
dbesc($note['link']),
|
|
||||||
intval($note['parent']),
|
|
||||||
dbesc($note['otype']),
|
|
||||||
intval(local_user())
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief set seen state of all notifications of local_user()
|
|
||||||
*
|
|
||||||
* @param bool $seen optional true or false. default true
|
|
||||||
* @return bool true on success, false on error
|
|
||||||
*/
|
|
||||||
public function setAllSeen($seen = true) {
|
|
||||||
return q("UPDATE `notify` SET `seen` = %d WHERE `uid` = %d",
|
|
||||||
intval($seen),
|
|
||||||
intval(local_user())
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief List of pages for the Notifications TabBar
|
|
||||||
*
|
|
||||||
* @return array with with notifications TabBar data
|
|
||||||
*/
|
|
||||||
public function getTabs() {
|
|
||||||
$tabs = array(
|
|
||||||
array(
|
|
||||||
'label' => t('System'),
|
|
||||||
'url'=>'notifications/system',
|
|
||||||
'sel'=> (($this->a->argv[1] == 'system') ? 'active' : ''),
|
|
||||||
'id' => 'system-tab',
|
|
||||||
'accesskey' => 'y',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Network'),
|
|
||||||
'url'=>'notifications/network',
|
|
||||||
'sel'=> (($this->a->argv[1] == 'network') ? 'active' : ''),
|
|
||||||
'id' => 'network-tab',
|
|
||||||
'accesskey' => 'w',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Personal'),
|
|
||||||
'url'=>'notifications/personal',
|
|
||||||
'sel'=> (($this->a->argv[1] == 'personal') ? 'active' : ''),
|
|
||||||
'id' => 'personal-tab',
|
|
||||||
'accesskey' => 'r',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Home'),
|
|
||||||
'url' => 'notifications/home',
|
|
||||||
'sel'=> (($this->a->argv[1] == 'home') ? 'active' : ''),
|
|
||||||
'id' => 'home-tab',
|
|
||||||
'accesskey' => 'h',
|
|
||||||
),
|
|
||||||
array(
|
|
||||||
'label' => t('Introductions'),
|
|
||||||
'url' => 'notifications/intros',
|
|
||||||
'sel'=> (($this->a->argv[1] == 'intros') ? 'active' : ''),
|
|
||||||
'id' => 'intro-tab',
|
|
||||||
'accesskey' => 'i',
|
|
||||||
),
|
|
||||||
);
|
|
||||||
|
|
||||||
return $tabs;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Format the notification query in an usable array
|
|
||||||
*
|
|
||||||
* @param array $notifs The array from the db query
|
|
||||||
* @param string $ident The notifications identifier (e.g. network)
|
|
||||||
* @return array
|
|
||||||
* string 'label' => The type of the notification
|
|
||||||
* string 'link' => URL to the source
|
|
||||||
* string 'image' => The avatar image
|
|
||||||
* string 'url' => The profile url of the contact
|
|
||||||
* string 'text' => The notification text
|
|
||||||
* string 'when' => The date of the notification
|
|
||||||
* string 'ago' => T relative date of the notification
|
|
||||||
* bool 'seen' => Is the notification marked as "seen"
|
|
||||||
*/
|
|
||||||
private function formatNotifs($notifs, $ident = "") {
|
|
||||||
|
|
||||||
$notif = array();
|
|
||||||
$arr = array();
|
|
||||||
|
|
||||||
if (dbm::is_result($notifs)) {
|
|
||||||
|
|
||||||
foreach ($notifs as $it) {
|
|
||||||
// Because we use different db tables for the notification query
|
|
||||||
// we have sometimes $it['unseen'] and sometimes $it['seen].
|
|
||||||
// So we will have to transform $it['unseen']
|
|
||||||
if (array_key_exists('unseen', $it)) {
|
|
||||||
$it['seen'] = ($it['unseen'] > 0 ? false : true);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Depending on the identifier of the notification we need to use different defaults
|
|
||||||
switch ($ident) {
|
|
||||||
case 'system':
|
|
||||||
$default_item_label = 'notify';
|
|
||||||
$default_item_link = System::baseUrl(true).'/notify/view/'. $it['id'];
|
|
||||||
$default_item_image = proxy_url($it['photo'], false, PROXY_SIZE_MICRO);
|
|
||||||
$default_item_url = $it['url'];
|
|
||||||
$default_item_text = strip_tags(bbcode($it['msg']));
|
|
||||||
$default_item_when = datetime_convert('UTC', date_default_timezone_get(), $it['date'], 'r');
|
|
||||||
$default_item_ago = relative_date($it['date']);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'home':
|
|
||||||
$default_item_label = 'comment';
|
|
||||||
$default_item_link = System::baseUrl(true).'/display/'.$it['pguid'];
|
|
||||||
$default_item_image = proxy_url($it['author-avatar'], false, PROXY_SIZE_MICRO);
|
|
||||||
$default_item_url = $it['author-link'];
|
|
||||||
$default_item_text = sprintf(t("%s commented on %s's post"), $it['author-name'], $it['pname']);
|
|
||||||
$default_item_when = datetime_convert('UTC', date_default_timezone_get(), $it['created'], 'r');
|
|
||||||
$default_item_ago = relative_date($it['created']);
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
$default_item_label = (($it['id'] == $it['parent']) ? 'post' : 'comment');
|
|
||||||
$default_item_link = System::baseUrl(true).'/display/'.$it['pguid'];
|
|
||||||
$default_item_image = proxy_url($it['author-avatar'], false, PROXY_SIZE_MICRO);
|
|
||||||
$default_item_url = $it['author-link'];
|
|
||||||
$default_item_text = (($it['id'] == $it['parent'])
|
|
||||||
? sprintf(t("%s created a new post"), $it['author-name'])
|
|
||||||
: sprintf(t("%s commented on %s's post"), $it['author-name'], $it['pname']));
|
|
||||||
$default_item_when = datetime_convert('UTC', date_default_timezone_get(), $it['created'], 'r');
|
|
||||||
$default_item_ago = relative_date($it['created']);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Transform the different types of notification in an usable array
|
|
||||||
switch ($it['verb']){
|
|
||||||
case ACTIVITY_LIKE:
|
|
||||||
$notif = array(
|
|
||||||
'label' => 'like',
|
|
||||||
'link' => System::baseUrl(true).'/display/'.$it['pguid'],
|
|
||||||
'image' => proxy_url($it['author-avatar'], false, PROXY_SIZE_MICRO),
|
|
||||||
'url' => $it['author-link'],
|
|
||||||
'text' => sprintf(t("%s liked %s's post"), $it['author-name'], $it['pname']),
|
|
||||||
'when' => $default_item_when,
|
|
||||||
'ago' => $default_item_ago,
|
|
||||||
'seen' => $it['seen']
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ACTIVITY_DISLIKE:
|
|
||||||
$notif = array(
|
|
||||||
'label' => 'dislike',
|
|
||||||
'link' => System::baseUrl(true).'/display/'.$it['pguid'],
|
|
||||||
'image' => proxy_url($it['author-avatar'], false, PROXY_SIZE_MICRO),
|
|
||||||
'url' => $it['author-link'],
|
|
||||||
'text' => sprintf(t("%s disliked %s's post"), $it['author-name'], $it['pname']),
|
|
||||||
'when' => $default_item_when,
|
|
||||||
'ago' => $default_item_ago,
|
|
||||||
'seen' => $it['seen']
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ACTIVITY_ATTEND:
|
|
||||||
$notif = array(
|
|
||||||
'label' => 'attend',
|
|
||||||
'link' => System::baseUrl(true).'/display/'.$it['pguid'],
|
|
||||||
'image' => proxy_url($it['author-avatar'], false, PROXY_SIZE_MICRO),
|
|
||||||
'url' => $it['author-link'],
|
|
||||||
'text' => sprintf(t("%s is attending %s's event"), $it['author-name'], $it['pname']),
|
|
||||||
'when' => $default_item_when,
|
|
||||||
'ago' => $default_item_ago,
|
|
||||||
'seen' => $it['seen']
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ACTIVITY_ATTENDNO:
|
|
||||||
$notif = array(
|
|
||||||
'label' => 'attendno',
|
|
||||||
'link' => System::baseUrl(true).'/display/'.$it['pguid'],
|
|
||||||
'image' => proxy_url($it['author-avatar'], false, PROXY_SIZE_MICRO),
|
|
||||||
'url' => $it['author-link'],
|
|
||||||
'text' => sprintf( t("%s is not attending %s's event"), $it['author-name'], $it['pname']),
|
|
||||||
'when' => $default_item_when,
|
|
||||||
'ago' => $default_item_ago,
|
|
||||||
'seen' => $it['seen']
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ACTIVITY_ATTENDMAYBE:
|
|
||||||
$notif = array(
|
|
||||||
'label' => 'attendmaybe',
|
|
||||||
'link' => System::baseUrl(true).'/display/'.$it['pguid'],
|
|
||||||
'image' => proxy_url($it['author-avatar'], false, PROXY_SIZE_MICRO),
|
|
||||||
'url' => $it['author-link'],
|
|
||||||
'text' => sprintf(t("%s may attend %s's event"), $it['author-name'], $it['pname']),
|
|
||||||
'when' => $default_item_when,
|
|
||||||
'ago' => $default_item_ago,
|
|
||||||
'seen' => $it['seen']
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ACTIVITY_FRIEND:
|
|
||||||
$xmlhead="<"."?xml version='1.0' encoding='UTF-8' ?".">";
|
|
||||||
$obj = parse_xml_string($xmlhead.$it['object']);
|
|
||||||
$it['fname'] = $obj->title;
|
|
||||||
|
|
||||||
$notif = array(
|
|
||||||
'label' => 'friend',
|
|
||||||
'link' => System::baseUrl(true).'/display/'.$it['pguid'],
|
|
||||||
'image' => proxy_url($it['author-avatar'], false, PROXY_SIZE_MICRO),
|
|
||||||
'url' => $it['author-link'],
|
|
||||||
'text' => sprintf(t("%s is now friends with %s"), $it['author-name'], $it['fname']),
|
|
||||||
'when' => $default_item_when,
|
|
||||||
'ago' => $default_item_ago,
|
|
||||||
'seen' => $it['seen']
|
|
||||||
);
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
$notif = array(
|
|
||||||
'label' => $default_item_label,
|
|
||||||
'link' => $default_item_link,
|
|
||||||
'image' => $default_item_image,
|
|
||||||
'url' => $default_item_url,
|
|
||||||
'text' => $default_item_text,
|
|
||||||
'when' => $default_item_when,
|
|
||||||
'ago' => $default_item_ago,
|
|
||||||
'seen' => $it['seen']
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$arr[] = $notif;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $arr;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Total number of network notifications
|
|
||||||
* @param int|string $seen
|
|
||||||
* If 0 only include notifications into the query
|
|
||||||
* which aren't marked as "seen"
|
|
||||||
* @return int Number of network notifications
|
|
||||||
*/
|
|
||||||
private function networkTotal($seen = 0) {
|
|
||||||
$sql_seen = "";
|
|
||||||
|
|
||||||
if($seen === 0)
|
|
||||||
$sql_seen = " AND `item`.`unseen` = 1 ";
|
|
||||||
|
|
||||||
$r = q("SELECT COUNT(*) AS `total`
|
|
||||||
FROM `item` INNER JOIN `item` AS `pitem` ON `pitem`.`id`=`item`.`parent`
|
|
||||||
WHERE `item`.`visible` = 1 AND `pitem`.`parent` != 0 AND
|
|
||||||
`item`.`deleted` = 0 AND `item`.`uid` = %d AND `item`.`wall` = 0
|
|
||||||
$sql_seen",
|
|
||||||
intval(local_user())
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
return $r[0]['total'];
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Get network notifications
|
|
||||||
*
|
|
||||||
* @param int|string $seen
|
|
||||||
* If 0 only include notifications into the query
|
|
||||||
* which aren't marked as "seen"
|
|
||||||
* @param int $start Start the query at this point
|
|
||||||
* @param int $limit Maximum number of query results
|
|
||||||
*
|
|
||||||
* @return array with
|
|
||||||
* string 'ident' => Notification identifier
|
|
||||||
* int 'total' => Total number of available network notifications
|
|
||||||
* array 'notifications' => Network notifications
|
|
||||||
*/
|
|
||||||
public function networkNotifs($seen = 0, $start = 0, $limit = 80) {
|
|
||||||
$ident = 'network';
|
|
||||||
$total = $this->networkTotal($seen);
|
|
||||||
$notifs = array();
|
|
||||||
$sql_seen = "";
|
|
||||||
|
|
||||||
if($seen === 0)
|
|
||||||
$sql_seen = " AND `item`.`unseen` = 1 ";
|
|
||||||
|
|
||||||
|
|
||||||
$r = q("SELECT `item`.`id`,`item`.`parent`, `item`.`verb`, `item`.`author-name`, `item`.`unseen`,
|
|
||||||
`item`.`author-link`, `item`.`author-avatar`, `item`.`created`, `item`.`object` AS `object`,
|
|
||||||
`pitem`.`author-name` AS `pname`, `pitem`.`author-link` AS `plink`, `pitem`.`guid` AS `pguid`
|
|
||||||
FROM `item` INNER JOIN `item` AS `pitem` ON `pitem`.`id`=`item`.`parent`
|
|
||||||
WHERE `item`.`visible` = 1 AND `pitem`.`parent` != 0 AND
|
|
||||||
`item`.`deleted` = 0 AND `item`.`uid` = %d AND `item`.`wall` = 0
|
|
||||||
$sql_seen
|
|
||||||
ORDER BY `item`.`created` DESC LIMIT %d, %d ",
|
|
||||||
intval(local_user()),
|
|
||||||
intval($start),
|
|
||||||
intval($limit)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
$notifs = $this->formatNotifs($r, $ident);
|
|
||||||
|
|
||||||
$arr = array (
|
|
||||||
'notifications' => $notifs,
|
|
||||||
'ident' => $ident,
|
|
||||||
'total' => $total,
|
|
||||||
);
|
|
||||||
|
|
||||||
return $arr;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Total number of system notifications
|
|
||||||
* @param int|string $seen
|
|
||||||
* If 0 only include notifications into the query
|
|
||||||
* which aren't marked as "seen"
|
|
||||||
* @return int Number of system notifications
|
|
||||||
*/
|
|
||||||
private function systemTotal($seen = 0) {
|
|
||||||
$sql_seen = "";
|
|
||||||
|
|
||||||
if($seen === 0)
|
|
||||||
$sql_seen = " AND `seen` = 0 ";
|
|
||||||
|
|
||||||
$r = q("SELECT COUNT(*) AS `total` FROM `notify` WHERE `uid` = %d $sql_seen",
|
|
||||||
intval(local_user())
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
return $r[0]['total'];
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Get system notifications
|
|
||||||
*
|
|
||||||
* @param int|string $seen
|
|
||||||
* If 0 only include notifications into the query
|
|
||||||
* which aren't marked as "seen"
|
|
||||||
* @param int $start Start the query at this point
|
|
||||||
* @param int $limit Maximum number of query results
|
|
||||||
*
|
|
||||||
* @return array with
|
|
||||||
* string 'ident' => Notification identifier
|
|
||||||
* int 'total' => Total number of available system notifications
|
|
||||||
* array 'notifications' => System notifications
|
|
||||||
*/
|
|
||||||
public function systemNotifs($seen = 0, $start = 0, $limit = 80) {
|
|
||||||
$ident = 'system';
|
|
||||||
$total = $this->systemTotal($seen);
|
|
||||||
$notifs = array();
|
|
||||||
$sql_seen = "";
|
|
||||||
|
|
||||||
if($seen === 0)
|
|
||||||
$sql_seen = " AND `seen` = 0 ";
|
|
||||||
|
|
||||||
$r = q("SELECT `id`, `url`, `photo`, `msg`, `date`, `seen` FROM `notify`
|
|
||||||
WHERE `uid` = %d $sql_seen ORDER BY `date` DESC LIMIT %d, %d ",
|
|
||||||
intval(local_user()),
|
|
||||||
intval($start),
|
|
||||||
intval($limit)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
$notifs = $this->formatNotifs($r, $ident);
|
|
||||||
|
|
||||||
$arr = array (
|
|
||||||
'notifications' => $notifs,
|
|
||||||
'ident' => $ident,
|
|
||||||
'total' => $total,
|
|
||||||
);
|
|
||||||
|
|
||||||
return $arr;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Addional SQL query string for the personal notifications
|
|
||||||
*
|
|
||||||
* @return string The additional sql query
|
|
||||||
*/
|
|
||||||
private function _personal_sql_extra() {
|
|
||||||
$myurl = System::baseUrl(true) . '/profile/'. $this->a->user['nickname'];
|
|
||||||
$myurl = substr($myurl,strpos($myurl,'://')+3);
|
|
||||||
$myurl = str_replace(array('www.','.'),array('','\\.'),$myurl);
|
|
||||||
$diasp_url = str_replace('/profile/','/u/',$myurl);
|
|
||||||
$sql_extra = sprintf(" AND ( `item`.`author-link` regexp '%s' OR `item`.`tag` regexp '%s' OR `item`.`tag` regexp '%s' ) ",
|
|
||||||
dbesc($myurl . '$'),
|
|
||||||
dbesc($myurl . '\\]'),
|
|
||||||
dbesc($diasp_url . '\\]')
|
|
||||||
);
|
|
||||||
|
|
||||||
return $sql_extra;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Total number of personal notifications
|
|
||||||
* @param int|string $seen
|
|
||||||
* If 0 only include notifications into the query
|
|
||||||
* which aren't marked as "seen"
|
|
||||||
* @return int Number of personal notifications
|
|
||||||
*/
|
|
||||||
private function personalTotal($seen = 0) {
|
|
||||||
$sql_seen = "";
|
|
||||||
$sql_extra = $this->_personal_sql_extra();
|
|
||||||
|
|
||||||
if($seen === 0)
|
|
||||||
$sql_seen = " AND `item`.`unseen` = 1 ";
|
|
||||||
|
|
||||||
$r = q("SELECT COUNT(*) AS `total`
|
|
||||||
FROM `item` INNER JOIN `item` AS `pitem` ON `pitem`.`id`=`item`.`parent`
|
|
||||||
WHERE `item`.`visible` = 1
|
|
||||||
$sql_extra
|
|
||||||
$sql_seen
|
|
||||||
AND `item`.`deleted` = 0 AND `item`.`uid` = %d AND `item`.`wall` = 0 " ,
|
|
||||||
intval(local_user())
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
return $r[0]['total'];
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Get personal notifications
|
|
||||||
*
|
|
||||||
* @param int|string $seen
|
|
||||||
* If 0 only include notifications into the query
|
|
||||||
* which aren't marked as "seen"
|
|
||||||
* @param int $start Start the query at this point
|
|
||||||
* @param int $limit Maximum number of query results
|
|
||||||
*
|
|
||||||
* @return array with
|
|
||||||
* string 'ident' => Notification identifier
|
|
||||||
* int 'total' => Total number of available personal notifications
|
|
||||||
* array 'notifications' => Personal notifications
|
|
||||||
*/
|
|
||||||
public function personalNotifs($seen = 0, $start = 0, $limit = 80) {
|
|
||||||
$ident = 'personal';
|
|
||||||
$total = $this->personalTotal($seen);
|
|
||||||
$sql_extra = $this->_personal_sql_extra();
|
|
||||||
$notifs = array();
|
|
||||||
$sql_seen = "";
|
|
||||||
|
|
||||||
if($seen === 0)
|
|
||||||
$sql_seen = " AND `item`.`unseen` = 1 ";
|
|
||||||
|
|
||||||
$r = q("SELECT `item`.`id`,`item`.`parent`, `item`.`verb`, `item`.`author-name`, `item`.`unseen`,
|
|
||||||
`item`.`author-link`, `item`.`author-avatar`, `item`.`created`, `item`.`object` AS `object`,
|
|
||||||
`pitem`.`author-name` AS `pname`, `pitem`.`author-link` AS `plink`, `pitem`.`guid` AS `pguid`
|
|
||||||
FROM `item` INNER JOIN `item` AS `pitem` ON `pitem`.`id`=`item`.`parent`
|
|
||||||
WHERE `item`.`visible` = 1
|
|
||||||
$sql_extra
|
|
||||||
$sql_seen
|
|
||||||
AND `item`.`deleted` = 0 AND `item`.`uid` = %d AND `item`.`wall` = 0
|
|
||||||
ORDER BY `item`.`created` DESC LIMIT %d, %d " ,
|
|
||||||
intval(local_user()),
|
|
||||||
intval($start),
|
|
||||||
intval($limit)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
$notifs = $this->formatNotifs($r, $ident);
|
|
||||||
|
|
||||||
$arr = array (
|
|
||||||
'notifications' => $notifs,
|
|
||||||
'ident' => $ident,
|
|
||||||
'total' => $total,
|
|
||||||
);
|
|
||||||
|
|
||||||
return $arr;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Total number of home notifications
|
|
||||||
* @param int|string $seen
|
|
||||||
* If 0 only include notifications into the query
|
|
||||||
* which aren't marked as "seen"
|
|
||||||
* @return int Number of home notifications
|
|
||||||
*/
|
|
||||||
private function homeTotal($seen = 0) {
|
|
||||||
$sql_seen = "";
|
|
||||||
|
|
||||||
if($seen === 0)
|
|
||||||
$sql_seen = " AND `item`.`unseen` = 1 ";
|
|
||||||
|
|
||||||
$r = q("SELECT COUNT(*) AS `total` FROM `item`
|
|
||||||
WHERE `item`.`visible` = 1 AND
|
|
||||||
`item`.`deleted` = 0 AND `item`.`uid` = %d AND `item`.`wall` = 1
|
|
||||||
$sql_seen",
|
|
||||||
intval(local_user())
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
return $r[0]['total'];
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Get home notifications
|
|
||||||
*
|
|
||||||
* @param int|string $seen
|
|
||||||
* If 0 only include notifications into the query
|
|
||||||
* which aren't marked as "seen"
|
|
||||||
* @param int $start Start the query at this point
|
|
||||||
* @param int $limit Maximum number of query results
|
|
||||||
*
|
|
||||||
* @return array with
|
|
||||||
* string 'ident' => Notification identifier
|
|
||||||
* int 'total' => Total number of available home notifications
|
|
||||||
* array 'notifications' => Home notifications
|
|
||||||
*/
|
|
||||||
public function homeNotifs($seen = 0, $start = 0, $limit = 80) {
|
|
||||||
$ident = 'home';
|
|
||||||
$total = $this->homeTotal($seen);
|
|
||||||
$notifs = array();
|
|
||||||
$sql_seen = "";
|
|
||||||
|
|
||||||
if($seen === 0)
|
|
||||||
$sql_seen = " AND `item`.`unseen` = 1 ";
|
|
||||||
|
|
||||||
$r = q("SELECT `item`.`id`,`item`.`parent`, `item`.`verb`, `item`.`author-name`, `item`.`unseen`,
|
|
||||||
`item`.`author-link`, `item`.`author-avatar`, `item`.`created`, `item`.`object` AS `object`,
|
|
||||||
`pitem`.`author-name` AS `pname`, `pitem`.`author-link` AS `plink`, `pitem`.`guid` AS `pguid`
|
|
||||||
FROM `item` INNER JOIN `item` AS `pitem` ON `pitem`.`id`=`item`.`parent`
|
|
||||||
WHERE `item`.`visible` = 1 AND
|
|
||||||
`item`.`deleted` = 0 AND `item`.`uid` = %d AND `item`.`wall` = 1
|
|
||||||
$sql_seen
|
|
||||||
ORDER BY `item`.`created` DESC LIMIT %d, %d ",
|
|
||||||
intval(local_user()),
|
|
||||||
intval($start),
|
|
||||||
intval($limit)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
$notifs = $this->formatNotifs($r, $ident);
|
|
||||||
|
|
||||||
$arr = array (
|
|
||||||
'notifications' => $notifs,
|
|
||||||
'ident' => $ident,
|
|
||||||
'total' => $total,
|
|
||||||
);
|
|
||||||
|
|
||||||
return $arr;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Total number of introductions
|
|
||||||
* @param bool $all
|
|
||||||
* If false only include introductions into the query
|
|
||||||
* which aren't marked as ignored
|
|
||||||
* @return int Number of introductions
|
|
||||||
*/
|
|
||||||
private function introTotal($all = false) {
|
|
||||||
$sql_extra = "";
|
|
||||||
|
|
||||||
if(!$all)
|
|
||||||
$sql_extra = " AND `ignore` = 0 ";
|
|
||||||
|
|
||||||
$r = q("SELECT COUNT(*) AS `total` FROM `intro`
|
|
||||||
WHERE `intro`.`uid` = %d $sql_extra AND `intro`.`blocked` = 0 ",
|
|
||||||
intval($_SESSION['uid'])
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
return $r[0]['total'];
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Get introductions
|
|
||||||
*
|
|
||||||
* @param bool $all
|
|
||||||
* If false only include introductions into the query
|
|
||||||
* which aren't marked as ignored
|
|
||||||
* @param int $start Start the query at this point
|
|
||||||
* @param int $limit Maximum number of query results
|
|
||||||
*
|
|
||||||
* @return array with
|
|
||||||
* string 'ident' => Notification identifier
|
|
||||||
* int 'total' => Total number of available introductions
|
|
||||||
* array 'notifications' => Introductions
|
|
||||||
*/
|
|
||||||
public function introNotifs($all = false, $start = 0, $limit = 80) {
|
|
||||||
$ident = 'introductions';
|
|
||||||
$total = $this->introTotal($seen);
|
|
||||||
$notifs = array();
|
|
||||||
$sql_extra = "";
|
|
||||||
|
|
||||||
if(!$all)
|
|
||||||
$sql_extra = " AND `ignore` = 0 ";
|
|
||||||
|
|
||||||
/// @todo Fetch contact details by "get_contact_details_by_url" instead of queries to contact, fcontact and gcontact
|
|
||||||
$r = q("SELECT `intro`.`id` AS `intro_id`, `intro`.*, `contact`.*,
|
|
||||||
`fcontact`.`name` AS `fname`, `fcontact`.`url` AS `furl`,
|
|
||||||
`fcontact`.`photo` AS `fphoto`, `fcontact`.`request` AS `frequest`,
|
|
||||||
`gcontact`.`location` AS `glocation`, `gcontact`.`about` AS `gabout`,
|
|
||||||
`gcontact`.`keywords` AS `gkeywords`, `gcontact`.`gender` AS `ggender`,
|
|
||||||
`gcontact`.`network` AS `gnetwork`, `gcontact`.`addr` AS `gaddr`
|
|
||||||
FROM `intro`
|
|
||||||
LEFT JOIN `contact` ON `contact`.`id` = `intro`.`contact-id`
|
|
||||||
LEFT JOIN `gcontact` ON `gcontact`.`nurl` = `contact`.`nurl`
|
|
||||||
LEFT JOIN `fcontact` ON `intro`.`fid` = `fcontact`.`id`
|
|
||||||
WHERE `intro`.`uid` = %d $sql_extra AND `intro`.`blocked` = 0
|
|
||||||
LIMIT %d, %d",
|
|
||||||
intval($_SESSION['uid']),
|
|
||||||
intval($start),
|
|
||||||
intval($limit)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
|
||||||
$notifs = $this->formatIntros($r);
|
|
||||||
|
|
||||||
$arr = array (
|
|
||||||
'ident' => $ident,
|
|
||||||
'total' => $total,
|
|
||||||
'notifications' => $notifs,
|
|
||||||
);
|
|
||||||
|
|
||||||
return $arr;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Format the notification query in an usable array
|
|
||||||
*
|
|
||||||
* @param array $intros The array from the db query
|
|
||||||
* @return array with the introductions
|
|
||||||
*/
|
|
||||||
private function formatIntros($intros) {
|
|
||||||
$knowyou = '';
|
|
||||||
|
|
||||||
foreach($intros as $it) {
|
|
||||||
// There are two kind of introduction. Contacts suggested by other contacts and normal connection requests.
|
|
||||||
// We have to distinguish between these two because they use different data.
|
|
||||||
|
|
||||||
// Contact suggestions
|
|
||||||
if($it['fid']) {
|
|
||||||
|
|
||||||
$return_addr = bin2hex($this->a->user['nickname'] . '@' . $this->a->get_hostname() . (($this->a->path) ? '/' . $this->a->path : ''));
|
|
||||||
|
|
||||||
$intro = array(
|
|
||||||
'label' => 'friend_suggestion',
|
|
||||||
'notify_type' => t('Friend Suggestion'),
|
|
||||||
'intro_id' => $it['intro_id'],
|
|
||||||
'madeby' => $it['name'],
|
|
||||||
'contact_id' => $it['contact-id'],
|
|
||||||
'photo' => ((x($it,'fphoto')) ? proxy_url($it['fphoto'], false, PROXY_SIZE_SMALL) : "images/person-175.jpg"),
|
|
||||||
'name' => $it['fname'],
|
|
||||||
'url' => zrl($it['furl']),
|
|
||||||
'hidden' => $it['hidden'] == 1,
|
|
||||||
'post_newfriend' => (intval(PConfig::get(local_user(),'system','post_newfriend')) ? '1' : 0),
|
|
||||||
|
|
||||||
'knowyou' => $knowyou,
|
|
||||||
'note' => $it['note'],
|
|
||||||
'request' => $it['frequest'] . '?addr=' . $return_addr,
|
|
||||||
|
|
||||||
);
|
|
||||||
|
|
||||||
// Normal connection requests
|
|
||||||
} else {
|
|
||||||
|
|
||||||
$it = $this->getMissingIntroData($it);
|
|
||||||
|
|
||||||
// Don't show these data until you are connected. Diaspora is doing the same.
|
|
||||||
if($it['gnetwork'] === NETWORK_DIASPORA) {
|
|
||||||
$it['glocation'] = "";
|
|
||||||
$it['gabout'] = "";
|
|
||||||
$it['ggender'] = "";
|
|
||||||
}
|
|
||||||
$intro = array(
|
|
||||||
'label' => (($it['network'] !== NETWORK_OSTATUS) ? 'friend_request' : 'follower'),
|
|
||||||
'notify_type' => (($it['network'] !== NETWORK_OSTATUS) ? t('Friend/Connect Request') : t('New Follower')),
|
|
||||||
'dfrn_id' => $it['issued-id'],
|
|
||||||
'uid' => $_SESSION['uid'],
|
|
||||||
'intro_id' => $it['intro_id'],
|
|
||||||
'contact_id' => $it['contact-id'],
|
|
||||||
'photo' => ((x($it,'photo')) ? proxy_url($it['photo'], false, PROXY_SIZE_SMALL) : "images/person-175.jpg"),
|
|
||||||
'name' => $it['name'],
|
|
||||||
'location' => bbcode($it['glocation'], false, false),
|
|
||||||
'about' => bbcode($it['gabout'], false, false),
|
|
||||||
'keywords' => $it['gkeywords'],
|
|
||||||
'gender' => $it['ggender'],
|
|
||||||
'hidden' => $it['hidden'] == 1,
|
|
||||||
'post_newfriend' => (intval(PConfig::get(local_user(),'system','post_newfriend')) ? '1' : 0),
|
|
||||||
'url' => $it['url'],
|
|
||||||
'zrl' => zrl($it['url']),
|
|
||||||
'addr' => $it['gaddr'],
|
|
||||||
'network' => $it['gnetwork'],
|
|
||||||
'knowyou' => $it['knowyou'],
|
|
||||||
'note' => $it['note'],
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$arr[] = $intro;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $arr;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Check for missing contact data and try to fetch the data from
|
|
||||||
* from other sources
|
|
||||||
*
|
|
||||||
* @param array $arr The input array with the intro data
|
|
||||||
*
|
|
||||||
* @return array The array with the intro data
|
|
||||||
*/
|
|
||||||
private function getMissingIntroData($arr) {
|
|
||||||
// If the network and the addr isn't available from the gcontact
|
|
||||||
// table entry, take the one of the contact table entry
|
|
||||||
if ($arr['gnetwork'] == "") {
|
|
||||||
$arr['gnetwork'] = $arr['network'];
|
|
||||||
}
|
|
||||||
if ($arr['gaddr'] == "") {
|
|
||||||
$arr['gaddr'] = $arr['addr'];
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the network and addr is still not available
|
|
||||||
// get the missing data data from other sources
|
|
||||||
if ($arr['gnetwork'] == "" || $arr['gaddr'] == "") {
|
|
||||||
$ret = get_contact_details_by_url($arr['url']);
|
|
||||||
|
|
||||||
if ($arr['gnetwork'] == "" && $ret['network'] != "") {
|
|
||||||
$arr['gnetwork'] = $ret['network'];
|
|
||||||
}
|
|
||||||
if ($arr['gaddr'] == "" && $ret['addr'] != "") {
|
|
||||||
$arr['gaddr'] = $ret['addr'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $arr;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -7,6 +7,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once("include/photos.php");
|
require_once("include/photos.php");
|
||||||
|
|
||||||
|
|
@ -630,7 +631,7 @@ class Photo {
|
||||||
public function store($uid, $cid, $rid, $filename, $album, $scale, $profile = 0, $allow_cid = '', $allow_gid = '', $deny_cid = '', $deny_gid = '', $desc = '') {
|
public function store($uid, $cid, $rid, $filename, $album, $scale, $profile = 0, $allow_cid = '', $allow_gid = '', $deny_cid = '', $deny_gid = '', $desc = '') {
|
||||||
|
|
||||||
$r = dba::select('photo', array('guid'), array("`resource-id` = ? AND `guid` != ?", $rid, ''), array('limit' => 1));
|
$r = dba::select('photo', array('guid'), array("`resource-id` = ? AND `guid` != ?", $rid, ''), array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$guid = $r['guid'];
|
$guid = $r['guid'];
|
||||||
} else {
|
} else {
|
||||||
$guid = get_guid();
|
$guid = get_guid();
|
||||||
|
|
@ -643,7 +644,7 @@ class Photo {
|
||||||
'datasize' => strlen($this->imageString()), 'data' => $this->imageString(), 'scale' => $scale, 'profile' => $profile,
|
'datasize' => strlen($this->imageString()), 'data' => $this->imageString(), 'scale' => $scale, 'profile' => $profile,
|
||||||
'allow_cid' => $allow_cid, 'allow_gid' => $allow_gid, 'deny_cid' => $deny_cid, 'deny_gid' => $deny_gid, 'desc' => $desc);
|
'allow_cid' => $allow_cid, 'allow_gid' => $allow_gid, 'deny_cid' => $deny_cid, 'deny_gid' => $deny_gid, 'desc' => $desc);
|
||||||
|
|
||||||
if (dbm::is_result($x)) {
|
if (DBM::is_result($x)) {
|
||||||
$r = dba::update('photo', $fields, array('id' => $x['id']));
|
$r = dba::update('photo', $fields, array('id' => $x['id']));
|
||||||
} else {
|
} else {
|
||||||
$r = dba::insert('photo', $fields);
|
$r = dba::insert('photo', $fields);
|
||||||
|
|
@ -713,7 +714,7 @@ function guess_image_type($filename, $fromcurl=false) {
|
||||||
*/
|
*/
|
||||||
function update_contact_avatar($avatar, $uid, $cid, $force = false) {
|
function update_contact_avatar($avatar, $uid, $cid, $force = false) {
|
||||||
$r = q("SELECT `avatar`, `photo`, `thumb`, `micro`, `nurl` FROM `contact` WHERE `id` = %d LIMIT 1", intval($cid));
|
$r = q("SELECT `avatar`, `photo`, `thumb`, `micro`, `nurl` FROM `contact` WHERE `id` = %d LIMIT 1", intval($cid));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
$data = array($r[0]["photo"], $r[0]["thumb"], $r[0]["micro"]);
|
$data = array($r[0]["photo"], $r[0]["thumb"], $r[0]["micro"]);
|
||||||
|
|
@ -730,7 +731,7 @@ function update_contact_avatar($avatar, $uid, $cid, $force = false) {
|
||||||
// Update the public contact (contact id = 0)
|
// Update the public contact (contact id = 0)
|
||||||
if ($uid != 0) {
|
if ($uid != 0) {
|
||||||
$pcontact = dba::select('contact', array('id'), array('nurl' => $r[0]['nurl']), array('limit' => 1));
|
$pcontact = dba::select('contact', array('id'), array('nurl' => $r[0]['nurl']), array('limit' => 1));
|
||||||
if (dbm::is_result($pcontact)) {
|
if (DBM::is_result($pcontact)) {
|
||||||
update_contact_avatar($avatar, 0, $pcontact['id'], $force);
|
update_contact_avatar($avatar, 0, $pcontact['id'], $force);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -748,7 +749,7 @@ function import_profile_photo($photo, $uid, $cid, $quit_on_error = false) {
|
||||||
intval($uid),
|
intval($uid),
|
||||||
intval($cid)
|
intval($cid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r) && strlen($r[0]['resource-id'])) {
|
if (DBM::is_result($r) && strlen($r[0]['resource-id'])) {
|
||||||
$hash = $r[0]['resource-id'];
|
$hash = $r[0]['resource-id'];
|
||||||
} else {
|
} else {
|
||||||
$hash = photo_new_resource();
|
$hash = photo_new_resource();
|
||||||
|
|
@ -919,7 +920,7 @@ function store_photo(App $a, $uid, $imagedata = "", $url = "") {
|
||||||
WHERE `user`.`uid` = %d AND `user`.`blocked` = 0 AND `contact`.`self` = 1 LIMIT 1",
|
WHERE `user`.`uid` = %d AND `user`.`blocked` = 0 AND `contact`.`self` = 1 LIMIT 1",
|
||||||
intval($uid));
|
intval($uid));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger("Can't detect user data for uid ".$uid, LOGGER_DEBUG);
|
logger("Can't detect user data for uid ".$uid, LOGGER_DEBUG);
|
||||||
return(array());
|
return(array());
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once "include/contact_selectors.php";
|
require_once "include/contact_selectors.php";
|
||||||
require_once "include/contact_widgets.php";
|
require_once "include/contact_widgets.php";
|
||||||
|
|
@ -36,7 +37,7 @@ function group_select($selname,$selclass,$preselected = false,$size = 4) {
|
||||||
|
|
||||||
call_hooks($a->module . '_pre_' . $selname, $arr);
|
call_hooks($a->module . '_pre_' . $selname, $arr);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if ((is_array($preselected)) && in_array($rr['id'], $preselected)) {
|
if ((is_array($preselected)) && in_array($rr['id'], $preselected)) {
|
||||||
$selected = " selected=\"selected\" ";
|
$selected = " selected=\"selected\" ";
|
||||||
|
|
@ -159,7 +160,7 @@ function contact_selector($selname, $selclass, $preselected = false, $options) {
|
||||||
|
|
||||||
call_hooks($a->module . '_pre_' . $selname, $arr);
|
call_hooks($a->module . '_pre_' . $selname, $arr);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if ((is_array($preselected)) && in_array($rr['id'], $preselected)) {
|
if ((is_array($preselected)) && in_array($rr['id'], $preselected)) {
|
||||||
$selected = " selected=\"selected\" ";
|
$selected = " selected=\"selected\" ";
|
||||||
|
|
@ -239,7 +240,7 @@ function contact_select($selname, $selclass, $preselected = false, $size = 4, $p
|
||||||
|
|
||||||
$receiverlist = array();
|
$receiverlist = array();
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if ((is_array($preselected)) && in_array($rr['id'], $preselected)) {
|
if ((is_array($preselected)) && in_array($rr['id'], $preselected)) {
|
||||||
$selected = " selected=\"selected\" ";
|
$selected = " selected=\"selected\" ";
|
||||||
|
|
@ -286,7 +287,7 @@ function prune_deadguys($arr) {
|
||||||
|
|
||||||
$r = q("SELECT `id` FROM `contact` WHERE `id` IN ( " . $str . ") AND `blocked` = 0 AND `pending` = 0 AND `archive` = 0 ");
|
$r = q("SELECT `id` FROM `contact` WHERE `id` IN ( " . $str . ") AND `blocked` = 0 AND `pending` = 0 AND `archive` = 0 ");
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$ret = array();
|
$ret = array();
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$ret[] = intval($rr['id']);
|
$ret[] = intval($rr['id']);
|
||||||
|
|
@ -342,7 +343,7 @@ function populate_acl($user = null, $show_jotnets = false) {
|
||||||
$r = q("SELECT `pubmail` FROM `mailacct` WHERE `uid` = %d AND `server` != '' LIMIT 1",
|
$r = q("SELECT `pubmail` FROM `mailacct` WHERE `uid` = %d AND `server` != '' LIMIT 1",
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$mail_enabled = true;
|
$mail_enabled = true;
|
||||||
if (intval($r[0]['pubmail'])) {
|
if (intval($r[0]['pubmail'])) {
|
||||||
$pubmail_enabled = true;
|
$pubmail_enabled = true;
|
||||||
|
|
@ -635,7 +636,7 @@ function acl_lookup(App $a, $out_type = 'json') {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$forums = array();
|
$forums = array();
|
||||||
foreach ($r as $g) {
|
foreach ($r as $g) {
|
||||||
$entry = array(
|
$entry = array(
|
||||||
|
|
@ -689,7 +690,7 @@ function acl_lookup(App $a, $out_type = 'json') {
|
||||||
dbesc($search),
|
dbesc($search),
|
||||||
implode("', '", $known_contacts)
|
implode("', '", $known_contacts)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $row) {
|
foreach ($r as $row) {
|
||||||
$contact = get_contact_details_by_url($row['author-link']);
|
$contact = get_contact_details_by_url($row['author-link']);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -11,6 +11,7 @@ use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\NotificationsManager;
|
use Friendica\Core\NotificationsManager;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/HTTPExceptions.php';
|
require_once 'include/HTTPExceptions.php';
|
||||||
require_once 'include/bbcode.php';
|
require_once 'include/bbcode.php';
|
||||||
|
|
@ -211,7 +212,7 @@ $called_api = null;
|
||||||
dbesc(trim($user)),
|
dbesc(trim($user)),
|
||||||
dbesc($encrypted)
|
dbesc($encrypted)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$record = $r[0];
|
$record = $r[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -460,7 +461,7 @@ $called_api = null;
|
||||||
function api_unique_id_to_url($id) {
|
function api_unique_id_to_url($id) {
|
||||||
$r = dba::select('contact', array('url'), array('uid' => 0, 'id' => $id), array('limit' => 1));
|
$r = dba::select('contact', array('url'), array('uid' => 0, 'id' => $id), array('limit' => 1));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r["url"];
|
return $r["url"];
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
|
@ -591,14 +592,14 @@ $called_api = null;
|
||||||
api_best_nickname($uinfo);
|
api_best_nickname($uinfo);
|
||||||
|
|
||||||
// if the contact wasn't found, fetch it from the contacts with uid = 0
|
// if the contact wasn't found, fetch it from the contacts with uid = 0
|
||||||
if (!dbm::is_result($uinfo)) {
|
if (!DBM::is_result($uinfo)) {
|
||||||
$r = array();
|
$r = array();
|
||||||
|
|
||||||
if ($url != "") {
|
if ($url != "") {
|
||||||
$r = q("SELECT * FROM `contact` WHERE `uid` = 0 AND `nurl` = '%s' LIMIT 1", dbesc(normalise_link($url)));
|
$r = q("SELECT * FROM `contact` WHERE `uid` = 0 AND `nurl` = '%s' LIMIT 1", dbesc(normalise_link($url)));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$network_name = network_to_name($r[0]['network'], $r[0]['url']);
|
$network_name = network_to_name($r[0]['network'], $r[0]['url']);
|
||||||
|
|
||||||
// If no nick where given, extract it from the address
|
// If no nick where given, extract it from the address
|
||||||
|
|
@ -1092,7 +1093,7 @@ $called_api = null;
|
||||||
AND `created` > '%s' AND `id` = `parent`",
|
AND `created` > '%s' AND `id` = `parent`",
|
||||||
intval(api_user()), dbesc($datefrom));
|
intval(api_user()), dbesc($datefrom));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$posts_day = $r[0]["posts_day"];
|
$posts_day = $r[0]["posts_day"];
|
||||||
} else {
|
} else {
|
||||||
$posts_day = 0;
|
$posts_day = 0;
|
||||||
|
|
@ -1113,7 +1114,7 @@ $called_api = null;
|
||||||
AND `created` > '%s' AND `id` = `parent`",
|
AND `created` > '%s' AND `id` = `parent`",
|
||||||
intval(api_user()), dbesc($datefrom));
|
intval(api_user()), dbesc($datefrom));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$posts_week = $r[0]["posts_week"];
|
$posts_week = $r[0]["posts_week"];
|
||||||
} else {
|
} else {
|
||||||
$posts_week = 0;
|
$posts_week = 0;
|
||||||
|
|
@ -1134,7 +1135,7 @@ $called_api = null;
|
||||||
AND `created` > '%s' AND `id` = `parent`",
|
AND `created` > '%s' AND `id` = `parent`",
|
||||||
intval(api_user()), dbesc($datefrom));
|
intval(api_user()), dbesc($datefrom));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$posts_month = $r[0]["posts_month"];
|
$posts_month = $r[0]["posts_month"];
|
||||||
} else {
|
} else {
|
||||||
$posts_month = 0;
|
$posts_month = 0;
|
||||||
|
|
@ -1163,7 +1164,7 @@ $called_api = null;
|
||||||
if (requestdata('media_ids')) {
|
if (requestdata('media_ids')) {
|
||||||
$r = q("SELECT `resource-id`, `scale`, `nickname`, `type` FROM `photo` INNER JOIN `user` ON `user`.`uid` = `photo`.`uid` WHERE `resource-id` IN (SELECT `resource-id` FROM `photo` WHERE `id` = %d) AND `scale` > 0 AND `photo`.`uid` = %d ORDER BY `photo`.`width` DESC LIMIT 1",
|
$r = q("SELECT `resource-id`, `scale`, `nickname`, `type` FROM `photo` INNER JOIN `user` ON `user`.`uid` = `photo`.`uid` WHERE `resource-id` IN (SELECT `resource-id` FROM `photo` WHERE `id` = %d) AND `scale` > 0 AND `photo`.`uid` = %d ORDER BY `photo`.`width` DESC LIMIT 1",
|
||||||
intval(requestdata('media_ids')), api_user());
|
intval(requestdata('media_ids')), api_user());
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$phototypes = Photo::supportedTypes();
|
$phototypes = Photo::supportedTypes();
|
||||||
$ext = $phototypes[$r[0]['type']];
|
$ext = $phototypes[$r[0]['type']];
|
||||||
$_REQUEST['body'] .= "\n\n" . '[url=' . System::baseUrl() . '/photos/' . $r[0]['nickname'] . '/image/' . $r[0]['resource-id'] . ']';
|
$_REQUEST['body'] .= "\n\n" . '[url=' . System::baseUrl() . '/photos/' . $r[0]['nickname'] . '/image/' . $r[0]['resource-id'] . ']';
|
||||||
|
|
@ -1258,7 +1259,7 @@ $called_api = null;
|
||||||
dbesc(normalise_link($user_info['url']))
|
dbesc(normalise_link($user_info['url']))
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($lastwall)) {
|
if (DBM::is_result($lastwall)) {
|
||||||
$lastwall = $lastwall[0];
|
$lastwall = $lastwall[0];
|
||||||
|
|
||||||
$in_reply_to = api_in_reply_to($lastwall);
|
$in_reply_to = api_in_reply_to($lastwall);
|
||||||
|
|
@ -1356,7 +1357,7 @@ $called_api = null;
|
||||||
dbesc(normalise_link($user_info['url']))
|
dbesc(normalise_link($user_info['url']))
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($lastwall)) {
|
if (DBM::is_result($lastwall)) {
|
||||||
$lastwall = $lastwall[0];
|
$lastwall = $lastwall[0];
|
||||||
|
|
||||||
$in_reply_to = api_in_reply_to($lastwall);
|
$in_reply_to = api_in_reply_to($lastwall);
|
||||||
|
|
@ -1428,11 +1429,11 @@ $called_api = null;
|
||||||
if (x($_GET, 'q')) {
|
if (x($_GET, 'q')) {
|
||||||
$r = q("SELECT id FROM `contact` WHERE `uid` = 0 AND `name` = '%s'", dbesc($_GET["q"]));
|
$r = q("SELECT id FROM `contact` WHERE `uid` = 0 AND `name` = '%s'", dbesc($_GET["q"]));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `id` FROM `contact` WHERE `uid` = 0 AND `nick` = '%s'", dbesc($_GET["q"]));
|
$r = q("SELECT `id` FROM `contact` WHERE `uid` = 0 AND `nick` = '%s'", dbesc($_GET["q"]));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$k = 0;
|
$k = 0;
|
||||||
foreach ($r AS $user) {
|
foreach ($r AS $user) {
|
||||||
$user_info = api_get_user($a, $user["id"], "json");
|
$user_info = api_get_user($a, $user["id"], "json");
|
||||||
|
|
@ -1681,7 +1682,7 @@ $called_api = null;
|
||||||
);
|
);
|
||||||
|
|
||||||
/// @TODO How about copying this to above methods which don't check $r ?
|
/// @TODO How about copying this to above methods which don't check $r ?
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
throw new BadRequestException("There is no status with this id.");
|
throw new BadRequestException("There is no status with this id.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1736,7 +1737,7 @@ $called_api = null;
|
||||||
logger('API: api_conversation_show: '.$id);
|
logger('API: api_conversation_show: '.$id);
|
||||||
|
|
||||||
$r = q("SELECT `parent` FROM `item` WHERE `id` = %d", intval($id));
|
$r = q("SELECT `parent` FROM `item` WHERE `id` = %d", intval($id));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$id = $r[0]["parent"];
|
$id = $r[0]["parent"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1769,7 +1770,7 @@ $called_api = null;
|
||||||
intval($start), intval($count)
|
intval($start), intval($count)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
throw new BadRequestException("There is no status with this id.");
|
throw new BadRequestException("There is no status with this id.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1827,7 +1828,7 @@ $called_api = null;
|
||||||
);
|
);
|
||||||
|
|
||||||
/// @TODO other style than above functions!
|
/// @TODO other style than above functions!
|
||||||
if (dbm::is_result($r) && $r[0]['body'] != "") {
|
if (DBM::is_result($r) && $r[0]['body'] != "") {
|
||||||
if (strpos($r[0]['body'], "[/share]") !== false) {
|
if (strpos($r[0]['body'], "[/share]") !== false) {
|
||||||
$pos = strpos($r[0]['body'], "[share");
|
$pos = strpos($r[0]['body'], "[share");
|
||||||
$post = substr($r[0]['body'], $pos);
|
$post = substr($r[0]['body'], $pos);
|
||||||
|
|
@ -2093,7 +2094,7 @@ $called_api = null;
|
||||||
$item = q("SELECT * FROM `item` WHERE `id`=%d AND `uid`=%d LIMIT 1",
|
$item = q("SELECT * FROM `item` WHERE `id`=%d AND `uid`=%d LIMIT 1",
|
||||||
$itemid, api_user());
|
$itemid, api_user());
|
||||||
|
|
||||||
if (!dbm::is_result($item) || count($item) == 0) {
|
if (!DBM::is_result($item) || count($item) == 0) {
|
||||||
throw new BadRequestException("Invalid item.");
|
throw new BadRequestException("Invalid item.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -3004,7 +3005,7 @@ $called_api = null;
|
||||||
intval(api_user())
|
intval(api_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -3138,7 +3139,7 @@ $called_api = null;
|
||||||
intval($id));
|
intval($id));
|
||||||
|
|
||||||
// error message if specified id is not in database
|
// error message if specified id is not in database
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
if ($verbose == "true") {
|
if ($verbose == "true") {
|
||||||
$answer = array('result' => 'error', 'message' => 'message id not in database');
|
$answer = array('result' => 'error', 'message' => 'message id not in database');
|
||||||
return api_format_data("direct_messages_delete", $type, array('$result' => $answer));
|
return api_format_data("direct_messages_delete", $type, array('$result' => $answer));
|
||||||
|
|
@ -3229,7 +3230,7 @@ $called_api = null;
|
||||||
intval($since_id),
|
intval($since_id),
|
||||||
intval($start), intval($count)
|
intval($start), intval($count)
|
||||||
);
|
);
|
||||||
if ($verbose == "true" && !dbm::is_result($r)) {
|
if ($verbose == "true" && !DBM::is_result($r)) {
|
||||||
$answer = array('result' => 'error', 'message' => 'no mails available');
|
$answer = array('result' => 'error', 'message' => 'no mails available');
|
||||||
return api_format_data("direct_messages_all", $type, array('$result' => $answer));
|
return api_format_data("direct_messages_all", $type, array('$result' => $answer));
|
||||||
}
|
}
|
||||||
|
|
@ -3334,7 +3335,7 @@ $called_api = null;
|
||||||
$r = q("SELECT DISTINCT `resource-id` FROM `photo` WHERE `uid` = %d AND `album` = '%s'",
|
$r = q("SELECT DISTINCT `resource-id` FROM `photo` WHERE `uid` = %d AND `album` = '%s'",
|
||||||
intval(api_user()),
|
intval(api_user()),
|
||||||
dbesc($album));
|
dbesc($album));
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
throw new BadRequestException("album not available");
|
throw new BadRequestException("album not available");
|
||||||
|
|
||||||
// function for setting the items to "deleted = 1" which ensures that comments, likes etc. are not shown anymore
|
// function for setting the items to "deleted = 1" which ensures that comments, likes etc. are not shown anymore
|
||||||
|
|
@ -3345,7 +3346,7 @@ $called_api = null;
|
||||||
dbesc($rr['resource-id'])
|
dbesc($rr['resource-id'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($photo_item)) {
|
if (!DBM::is_result($photo_item)) {
|
||||||
throw new InternalServerErrorException("problem with deleting items occured");
|
throw new InternalServerErrorException("problem with deleting items occured");
|
||||||
}
|
}
|
||||||
drop_item($photo_item[0]['id'],false);
|
drop_item($photo_item[0]['id'],false);
|
||||||
|
|
@ -3391,7 +3392,7 @@ $called_api = null;
|
||||||
$r = q("SELECT `id` FROM `photo` WHERE `uid` = %d AND `album` = '%s'",
|
$r = q("SELECT `id` FROM `photo` WHERE `uid` = %d AND `album` = '%s'",
|
||||||
intval(api_user()),
|
intval(api_user()),
|
||||||
dbesc($album));
|
dbesc($album));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
throw new BadRequestException("album not available");
|
throw new BadRequestException("album not available");
|
||||||
}
|
}
|
||||||
// now let's update all photos to the albumname
|
// now let's update all photos to the albumname
|
||||||
|
|
@ -3431,7 +3432,7 @@ $called_api = null;
|
||||||
'image/gif' => 'gif'
|
'image/gif' => 'gif'
|
||||||
);
|
);
|
||||||
$data = array('photo'=>array());
|
$data = array('photo'=>array());
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$photo = array();
|
$photo = array();
|
||||||
$photo['id'] = $rr['resource-id'];
|
$photo['id'] = $rr['resource-id'];
|
||||||
|
|
@ -3500,7 +3501,7 @@ $called_api = null;
|
||||||
intval(api_user()),
|
intval(api_user()),
|
||||||
dbesc($photo_id),
|
dbesc($photo_id),
|
||||||
dbesc($album));
|
dbesc($album));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
throw new BadRequestException("photo not available");
|
throw new BadRequestException("photo not available");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -3620,7 +3621,7 @@ $called_api = null;
|
||||||
intval(api_user()),
|
intval(api_user()),
|
||||||
dbesc($photo_id)
|
dbesc($photo_id)
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
throw new BadRequestException("photo not available");
|
throw new BadRequestException("photo not available");
|
||||||
}
|
}
|
||||||
// now we can perform on the deletion of the photo
|
// now we can perform on the deletion of the photo
|
||||||
|
|
@ -3636,7 +3637,7 @@ $called_api = null;
|
||||||
dbesc($photo_id)
|
dbesc($photo_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($photo_item)) {
|
if (!DBM::is_result($photo_item)) {
|
||||||
throw new InternalServerErrorException("problem with deleting items occured");
|
throw new InternalServerErrorException("problem with deleting items occured");
|
||||||
}
|
}
|
||||||
// function for setting the items to "deleted = 1" which ensures that comments, likes etc. are not shown anymore
|
// function for setting the items to "deleted = 1" which ensures that comments, likes etc. are not shown anymore
|
||||||
|
|
@ -3699,7 +3700,7 @@ $called_api = null;
|
||||||
intval(api_user()),
|
intval(api_user()),
|
||||||
intval($profileid));
|
intval($profileid));
|
||||||
// error message if specified profile id is not in database
|
// error message if specified profile id is not in database
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
throw new BadRequestException("profile_id not available");
|
throw new BadRequestException("profile_id not available");
|
||||||
}
|
}
|
||||||
$is_default_profile = $r['profile'];
|
$is_default_profile = $r['profile'];
|
||||||
|
|
@ -3804,7 +3805,7 @@ $called_api = null;
|
||||||
$contact = q("SELECT * FROM `contact` WHERE `id` = %d AND `uid` = %d",
|
$contact = q("SELECT * FROM `contact` WHERE `id` = %d AND `uid` = %d",
|
||||||
intval($cid),
|
intval($cid),
|
||||||
intval(api_user()));
|
intval(api_user()));
|
||||||
$contact_not_found |= !dbm::is_result($contact);
|
$contact_not_found |= !DBM::is_result($contact);
|
||||||
}
|
}
|
||||||
return $contact_not_found;
|
return $contact_not_found;
|
||||||
}
|
}
|
||||||
|
|
@ -4020,7 +4021,7 @@ $called_api = null;
|
||||||
);
|
);
|
||||||
|
|
||||||
// prepare output data for photo
|
// prepare output data for photo
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$data = array('photo' => $r[0]);
|
$data = array('photo' => $r[0]);
|
||||||
$data['photo']['id'] = $data['photo']['resource-id'];
|
$data['photo']['id'] = $data['photo']['resource-id'];
|
||||||
if ($scale !== false) {
|
if ($scale !== false) {
|
||||||
|
|
@ -4129,7 +4130,7 @@ $called_api = null;
|
||||||
intval(api_user())
|
intval(api_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if ((! dbm::is_result($r)) || ($r[0]['network'] !== NETWORK_DFRN)) {
|
if ((! DBM::is_result($r)) || ($r[0]['network'] !== NETWORK_DFRN)) {
|
||||||
throw new BadRequestException("Unknown contact");
|
throw new BadRequestException("Unknown contact");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -4276,7 +4277,7 @@ $called_api = null;
|
||||||
$r = q("SELECT `nick` FROM `contact` WHERE `uid` = 0 AND `nurl` = '%s'",
|
$r = q("SELECT `nick` FROM `contact` WHERE `uid` = 0 AND `nurl` = '%s'",
|
||||||
dbesc(normalise_link($profile)));
|
dbesc(normalise_link($profile)));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$nick = $r[0]["nick"];
|
$nick = $r[0]["nick"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -4284,7 +4285,7 @@ $called_api = null;
|
||||||
$r = q("SELECT `nick` FROM `contact` WHERE `uid` = 0 AND `nurl` = '%s'",
|
$r = q("SELECT `nick` FROM `contact` WHERE `uid` = 0 AND `nurl` = '%s'",
|
||||||
dbesc(normalise_link($profile)));
|
dbesc(normalise_link($profile)));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$nick = $r[0]["nick"];
|
$nick = $r[0]["nick"];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -4355,7 +4356,7 @@ $called_api = null;
|
||||||
intval($item['uid']),
|
intval($item['uid']),
|
||||||
dbesc($item['thr-parent']));
|
dbesc($item['thr-parent']));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$in_reply_to['status_id'] = intval($r[0]['id']);
|
$in_reply_to['status_id'] = intval($r[0]['id']);
|
||||||
} else {
|
} else {
|
||||||
$in_reply_to['status_id'] = intval($item['parent']);
|
$in_reply_to['status_id'] = intval($item['parent']);
|
||||||
|
|
@ -4369,7 +4370,7 @@ $called_api = null;
|
||||||
intval($in_reply_to['status_id'])
|
intval($in_reply_to['status_id'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if ($r[0]['nick'] == "") {
|
if ($r[0]['nick'] == "") {
|
||||||
$r[0]['nick'] = api_get_nick($r[0]["url"]);
|
$r[0]['nick'] = api_get_nick($r[0]["url"]);
|
||||||
}
|
}
|
||||||
|
|
@ -4503,7 +4504,7 @@ $called_api = null;
|
||||||
intval($uid),
|
intval($uid),
|
||||||
intval($gid));
|
intval($gid));
|
||||||
// error message if specified gid is not in database
|
// error message if specified gid is not in database
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
throw new BadRequestException("gid not available");
|
throw new BadRequestException("gid not available");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
@ -4558,7 +4559,7 @@ $called_api = null;
|
||||||
intval($uid),
|
intval($uid),
|
||||||
intval($gid));
|
intval($gid));
|
||||||
// error message if specified gid is not in database
|
// error message if specified gid is not in database
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
throw new BadRequestException('gid not available');
|
throw new BadRequestException('gid not available');
|
||||||
|
|
||||||
// get data of the specified group id and group name
|
// get data of the specified group id and group name
|
||||||
|
|
@ -4567,7 +4568,7 @@ $called_api = null;
|
||||||
intval($gid),
|
intval($gid),
|
||||||
dbesc($name));
|
dbesc($name));
|
||||||
// error message if specified gid is not in database
|
// error message if specified gid is not in database
|
||||||
if (!dbm::is_result($rname))
|
if (!DBM::is_result($rname))
|
||||||
throw new BadRequestException('wrong group name');
|
throw new BadRequestException('wrong group name');
|
||||||
|
|
||||||
// delete group
|
// delete group
|
||||||
|
|
@ -4606,7 +4607,7 @@ $called_api = null;
|
||||||
intval($uid),
|
intval($uid),
|
||||||
dbesc($name));
|
dbesc($name));
|
||||||
// error message if specified group name already exists
|
// error message if specified group name already exists
|
||||||
if (dbm::is_result($rname))
|
if (DBM::is_result($rname))
|
||||||
throw new BadRequestException('group name already exists');
|
throw new BadRequestException('group name already exists');
|
||||||
|
|
||||||
// check if specified group name is a deleted group
|
// check if specified group name is a deleted group
|
||||||
|
|
@ -4614,7 +4615,7 @@ $called_api = null;
|
||||||
intval($uid),
|
intval($uid),
|
||||||
dbesc($name));
|
dbesc($name));
|
||||||
// error message if specified group name already exists
|
// error message if specified group name already exists
|
||||||
if (dbm::is_result($rname))
|
if (DBM::is_result($rname))
|
||||||
$reactivate_group = true;
|
$reactivate_group = true;
|
||||||
|
|
||||||
// create group
|
// create group
|
||||||
|
|
@ -4845,7 +4846,7 @@ $called_api = null;
|
||||||
intval($uid));
|
intval($uid));
|
||||||
|
|
||||||
// error message if specified id is not in database
|
// error message if specified id is not in database
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$answer = array('result' => 'error', 'message' => 'message id not in database');
|
$answer = array('result' => 'error', 'message' => 'message id not in database');
|
||||||
return api_format_data("direct_messages_setseen", $type, array('$result' => $answer));
|
return api_format_data("direct_messages_setseen", $type, array('$result' => $answer));
|
||||||
}
|
}
|
||||||
|
|
@ -4903,7 +4904,7 @@ $called_api = null;
|
||||||
$profile_url = $user_info["url"];
|
$profile_url = $user_info["url"];
|
||||||
|
|
||||||
// message if nothing was found
|
// message if nothing was found
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$success = array('success' => false, 'search_results' => 'problem with query');
|
$success = array('success' => false, 'search_results' => 'problem with query');
|
||||||
} elseif (count($r) == 0) {
|
} elseif (count($r) == 0) {
|
||||||
$success = array('success' => false, 'search_results' => 'nothing found');
|
$success = array('success' => false, 'search_results' => 'nothing found');
|
||||||
|
|
@ -4956,7 +4957,7 @@ $called_api = null;
|
||||||
intval($profileid));
|
intval($profileid));
|
||||||
|
|
||||||
// error message if specified gid is not in database
|
// error message if specified gid is not in database
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
throw new BadRequestException("profile_id not available");
|
throw new BadRequestException("profile_id not available");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/security.php');
|
require_once('include/security.php');
|
||||||
require_once('include/datetime.php');
|
require_once('include/datetime.php');
|
||||||
|
|
@ -58,7 +59,7 @@ if (isset($_SESSION) && x($_SESSION,'authenticated') && (!x($_POST,'auth-params'
|
||||||
$r = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1",
|
$r = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1",
|
||||||
intval($_SESSION['visitor_id'])
|
intval($_SESSION['visitor_id'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->contact = $r[0];
|
$a->contact = $r[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -81,7 +82,7 @@ if (isset($_SESSION) && x($_SESSION,'authenticated') && (!x($_POST,'auth-params'
|
||||||
intval($_SESSION['uid'])
|
intval($_SESSION['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
nuke_session();
|
nuke_session();
|
||||||
goaway(System::baseUrl());
|
goaway(System::baseUrl());
|
||||||
}
|
}
|
||||||
|
|
@ -177,7 +178,7 @@ if (isset($_SESSION) && x($_SESSION,'authenticated') && (!x($_POST,'auth-params'
|
||||||
dbesc(trim($_POST['username'])),
|
dbesc(trim($_POST['username'])),
|
||||||
dbesc($encrypted)
|
dbesc($encrypted)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$record = $r[0];
|
$record = $r[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -34,6 +34,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
if (sizeof($_SERVER["argv"]) == 0)
|
if (sizeof($_SERVER["argv"]) == 0)
|
||||||
die();
|
die();
|
||||||
|
|
@ -152,7 +153,7 @@ class exAuth {
|
||||||
$sQuery = "SELECT `uid` FROM `user` WHERE `nickname`='".dbesc($sUser)."'";
|
$sQuery = "SELECT `uid` FROM `user` WHERE `nickname`='".dbesc($sUser)."'";
|
||||||
$this->writeLog(LOG_DEBUG, "using query ". $sQuery);
|
$this->writeLog(LOG_DEBUG, "using query ". $sQuery);
|
||||||
$r = q($sQuery);
|
$r = q($sQuery);
|
||||||
$found = dbm::is_result($r);
|
$found = DBM::is_result($r);
|
||||||
} else {
|
} else {
|
||||||
$found = false;
|
$found = false;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -7,6 +7,7 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
class Cache {
|
class Cache {
|
||||||
/**
|
/**
|
||||||
|
|
@ -104,7 +105,7 @@ class Cache {
|
||||||
dbesc($key)
|
dbesc($key)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$cached = $r[0]['v'];
|
$cached = $r[0]['v'];
|
||||||
$value = @unserialize($cached);
|
$value = @unserialize($cached);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
|
|
||||||
function contact_profile_assign($current,$foreign_net) {
|
function contact_profile_assign($current,$foreign_net) {
|
||||||
|
|
@ -13,7 +14,7 @@ function contact_profile_assign($current,$foreign_net) {
|
||||||
$r = q("SELECT `id`, `profile-name`, `is-default` FROM `profile` WHERE `uid` = %d",
|
$r = q("SELECT `id`, `profile-name`, `is-default` FROM `profile` WHERE `uid` = %d",
|
||||||
intval($_SESSION['uid']));
|
intval($_SESSION['uid']));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$selected = (($rr['id'] == $current || ($current == 0 && $rr['is-default'] == 1)) ? " selected=\"selected\" " : "");
|
$selected = (($rr['id'] == $current || ($current == 0 && $rr['is-default'] == 1)) ? " selected=\"selected\" " : "");
|
||||||
$o .= "<option value=\"{$rr['id']}\" $selected >{$rr['profile-name']}</option>\r\n";
|
$o .= "<option value=\"{$rr['id']}\" $selected >{$rr['profile-name']}</option>\r\n";
|
||||||
|
|
@ -106,7 +107,7 @@ function network_to_name($s, $profile = "") {
|
||||||
INNER JOIN `gserver` ON `gserver`.`nurl` = `gcontact`.`server_url`
|
INNER JOIN `gserver` ON `gserver`.`nurl` = `gcontact`.`server_url`
|
||||||
WHERE `gcontact`.`nurl` = ? AND `platform` != ''", normalise_link($profile));
|
WHERE `gcontact`.`nurl` = ? AND `platform` != ''", normalise_link($profile));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$networkname = $r['platform'];
|
$networkname = $r['platform'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/contact_selectors.php';
|
require_once 'include/contact_selectors.php';
|
||||||
|
|
||||||
|
|
@ -233,11 +234,11 @@ function common_friends_visitor_widget($profile_uid) {
|
||||||
if (get_my_url()) {
|
if (get_my_url()) {
|
||||||
$r = dba::select('contact', array('id'),
|
$r = dba::select('contact', array('id'),
|
||||||
array('nurl' => normalise_link(get_my_url()), 'uid' => $profile_uid), array('limit' => 1));
|
array('nurl' => normalise_link(get_my_url()), 'uid' => $profile_uid), array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$cid = $r['id'];
|
$cid = $r['id'];
|
||||||
} else {
|
} else {
|
||||||
$r = dba::select('gcontact', array('id'), array('nurl' => normalise_link(get_my_url())), array('limit' => 1));
|
$r = dba::select('gcontact', array('id'), array('nurl' => normalise_link(get_my_url())), array('limit' => 1));
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$zcid = $r['id'];
|
$zcid = $r['id'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once "include/bbcode.php";
|
require_once "include/bbcode.php";
|
||||||
require_once "include/acl_selectors.php";
|
require_once "include/acl_selectors.php";
|
||||||
|
|
@ -122,7 +123,7 @@ function localize_item(&$item) {
|
||||||
WHERE `item`.`contact-id`=`contact`.`id`
|
WHERE `item`.`contact-id`=`contact`.`id`
|
||||||
AND `item`.`uri`='%s'",
|
AND `item`.`uri`='%s'",
|
||||||
dbesc($item['parent-uri']));
|
dbesc($item['parent-uri']));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$obj = $r[0];
|
$obj = $r[0];
|
||||||
|
|
@ -273,7 +274,7 @@ function localize_item(&$item) {
|
||||||
AND `item`.`uri`='%s'",
|
AND `item`.`uri`='%s'",
|
||||||
dbesc($item['parent-uri']));
|
dbesc($item['parent-uri']));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -329,7 +330,7 @@ function localize_item(&$item) {
|
||||||
intval($item['uid'])
|
intval($item['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r) && $r[0]['plink']) {
|
if (DBM::is_result($r) && $r[0]['plink']) {
|
||||||
$target = $r[0];
|
$target = $r[0];
|
||||||
$Bname = $target['author-name'];
|
$Bname = $target['author-name'];
|
||||||
$Blink = $target['author-link'];
|
$Blink = $target['author-link'];
|
||||||
|
|
@ -941,7 +942,7 @@ function best_link_url($item, &$sparkle, $url = '') {
|
||||||
$r = dba::select('contact', array('id'),
|
$r = dba::select('contact', array('id'),
|
||||||
array('network' => NETWORK_DFRN, 'uid' => local_user(), 'nurl' => normalise_link($clean_url), 'pending' => false),
|
array('network' => NETWORK_DFRN, 'uid' => local_user(), 'nurl' => normalise_link($clean_url), 'pending' => false),
|
||||||
array('limit' => 1));
|
array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$best_url = 'redir/' . $r['id'];
|
$best_url = 'redir/' . $r['id'];
|
||||||
$sparkle = true;
|
$sparkle = true;
|
||||||
if ($url != '') {
|
if ($url != '') {
|
||||||
|
|
@ -992,7 +993,7 @@ function item_photo_menu($item) {
|
||||||
$network = '';
|
$network = '';
|
||||||
$rel = 0;
|
$rel = 0;
|
||||||
$r = dba::select('contact', array('id', 'network', 'rel'), array('uid' => local_user(), 'nurl' => normalise_link($item['author-link'])), array('limit' => 1));
|
$r = dba::select('contact', array('id', 'network', 'rel'), array('uid' => local_user(), 'nurl' => normalise_link($item['author-link'])), array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$cid = $r['id'];
|
$cid = $r['id'];
|
||||||
$network = $r['network'];
|
$network = $r['network'];
|
||||||
$rel = $r['rel'];
|
$rel = $r['rel'];
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function cron_run(&$argv, &$argc){
|
function cron_run(&$argv, &$argc){
|
||||||
global $a;
|
global $a;
|
||||||
|
|
@ -161,7 +162,7 @@ function cron_poll_contacts($argc, $argv) {
|
||||||
dbesc(NETWORK_MAIL2)
|
dbesc(NETWORK_MAIL2)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($contacts)) {
|
if (!DBM::is_result($contacts)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -171,7 +172,7 @@ function cron_poll_contacts($argc, $argv) {
|
||||||
intval($c['id'])
|
intval($c['id'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($res)) {
|
if (!DBM::is_result($res)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
|
|
||||||
function cronjobs_run(&$argv, &$argc){
|
function cronjobs_run(&$argv, &$argc){
|
||||||
|
|
@ -78,7 +79,7 @@ function cronjobs_run(&$argv, &$argc){
|
||||||
*/
|
*/
|
||||||
function cron_update_photo_albums() {
|
function cron_update_photo_albums() {
|
||||||
$r = q("SELECT `uid` FROM `user` WHERE NOT `account_expired` AND NOT `account_removed`");
|
$r = q("SELECT `uid` FROM `user` WHERE NOT `account_expired` AND NOT `account_removed`");
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -98,7 +99,7 @@ function cron_expire_and_remove_users() {
|
||||||
|
|
||||||
// delete user records for recently removed accounts
|
// delete user records for recently removed accounts
|
||||||
$r = q("SELECT * FROM `user` WHERE `account_removed` AND `account_expires_on` < UTC_TIMESTAMP() - INTERVAL 3 DAY");
|
$r = q("SELECT * FROM `user` WHERE `account_removed` AND `account_expires_on` < UTC_TIMESTAMP() - INTERVAL 3 DAY");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $user) {
|
foreach ($r as $user) {
|
||||||
dba::delete('user', array('uid' => $user['uid']));
|
dba::delete('user', array('uid' => $user['uid']));
|
||||||
}
|
}
|
||||||
|
|
@ -211,7 +212,7 @@ function cron_repair_diaspora(App $a) {
|
||||||
$r = q("SELECT `id`, `url` FROM `contact`
|
$r = q("SELECT `id`, `url` FROM `contact`
|
||||||
WHERE `network` = '%s' AND (`batch` = '' OR `notify` = '' OR `poll` = '' OR pubkey = '')
|
WHERE `network` = '%s' AND (`batch` = '' OR `notify` = '' OR `poll` = '' OR pubkey = '')
|
||||||
ORDER BY RAND() LIMIT 50", dbesc(NETWORK_DIASPORA));
|
ORDER BY RAND() LIMIT 50", dbesc(NETWORK_DIASPORA));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -246,7 +247,7 @@ function cron_repair_database() {
|
||||||
// Sometimes there seem to be issues where the "self" contact vanishes.
|
// Sometimes there seem to be issues where the "self" contact vanishes.
|
||||||
// We haven't found the origin of the problem by now.
|
// We haven't found the origin of the problem by now.
|
||||||
$r = q("SELECT `uid` FROM `user` WHERE NOT EXISTS (SELECT `uid` FROM `contact` WHERE `contact`.`uid` = `user`.`uid` AND `contact`.`self`)");
|
$r = q("SELECT `uid` FROM `user` WHERE NOT EXISTS (SELECT `uid` FROM `contact` WHERE `contact`.`uid` = `user`.`uid` AND `contact`.`self`)");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r AS $user) {
|
foreach ($r AS $user) {
|
||||||
logger('Create missing self contact for user '.$user['uid']);
|
logger('Create missing self contact for user '.$user['uid']);
|
||||||
user_create_self_contact($user['uid']);
|
user_create_self_contact($user['uid']);
|
||||||
|
|
@ -262,7 +263,7 @@ function cron_repair_database() {
|
||||||
|
|
||||||
// Update the global contacts for local users
|
// Update the global contacts for local users
|
||||||
$r = q("SELECT `uid` FROM `user` WHERE `verified` AND NOT `blocked` AND NOT `account_removed` AND NOT `account_expired`");
|
$r = q("SELECT `uid` FROM `user` WHERE `verified` AND NOT `blocked` AND NOT `account_removed` AND NOT `account_expired`");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r AS $user) {
|
foreach ($r AS $user) {
|
||||||
update_gcontact_for_user($user["uid"]);
|
update_gcontact_for_user($user["uid"]);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,7 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Two-level sort for timezones.
|
* @brief Two-level sort for timezones.
|
||||||
|
|
@ -589,7 +590,7 @@ function update_contact_birthdays() {
|
||||||
// In-network birthdays are handled within local_delivery
|
// In-network birthdays are handled within local_delivery
|
||||||
|
|
||||||
$r = q("SELECT * FROM `contact` WHERE `bd` != '' AND `bd` > '0001-01-01' AND SUBSTRING(`bd`, 1, 4) != `bdyear` ");
|
$r = q("SELECT * FROM `contact` WHERE `bd` != '' AND `bd` > '0001-01-01' AND SUBSTRING(`bd`, 1, 4) != `bdyear` ");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
|
|
||||||
logger('update_contact_birthday: ' . $rr['bd']);
|
logger('update_contact_birthday: ' . $rr['bd']);
|
||||||
|
|
@ -611,7 +612,7 @@ function update_contact_birthdays() {
|
||||||
dbesc(datetime_convert('UTC','UTC', $nextbd)),
|
dbesc(datetime_convert('UTC','UTC', $nextbd)),
|
||||||
dbesc('birthday'));
|
dbesc('birthday'));
|
||||||
|
|
||||||
if (dbm::is_result($s)) {
|
if (DBM::is_result($s)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
use \Friendica\Core\System;
|
use \Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once("dbm.php");
|
|
||||||
require_once('include/datetime.php');
|
require_once('include/datetime.php');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -176,7 +176,7 @@ class dba {
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = self::p("EXPLAIN ".$query);
|
$r = self::p("EXPLAIN ".$query);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -227,7 +227,7 @@ class dba {
|
||||||
switch (self::$driver) {
|
switch (self::$driver) {
|
||||||
case 'pdo':
|
case 'pdo':
|
||||||
$r = dba::p("SELECT 1");
|
$r = dba::p("SELECT 1");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$row = dba::inArray($r);
|
$row = dba::inArray($r);
|
||||||
$connected = ($row[0]['1'] == '1');
|
$connected = ($row[0]['1'] == '1');
|
||||||
}
|
}
|
||||||
|
|
|
||||||
112
include/dbm.php
112
include/dbm.php
|
|
@ -1,112 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* @brief This class contain functions for the database management
|
|
||||||
*
|
|
||||||
* This class contains functions that doesn't need to know if pdo, mysqli or whatever is used.
|
|
||||||
*/
|
|
||||||
class dbm {
|
|
||||||
/**
|
|
||||||
* @brief Return a list of database processes
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
* 'list' => List of processes, separated in their different states
|
|
||||||
* 'amount' => Number of concurrent database processes
|
|
||||||
*/
|
|
||||||
public static function processlist() {
|
|
||||||
$r = q("SHOW PROCESSLIST");
|
|
||||||
$s = array();
|
|
||||||
|
|
||||||
$processes = 0;
|
|
||||||
$states = array();
|
|
||||||
foreach ($r AS $process) {
|
|
||||||
$state = trim($process["State"]);
|
|
||||||
|
|
||||||
// Filter out all non blocking processes
|
|
||||||
if (!in_array($state, array("", "init", "statistics", "updating"))) {
|
|
||||||
++$states[$state];
|
|
||||||
++$processes;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$statelist = "";
|
|
||||||
foreach ($states AS $state => $usage) {
|
|
||||||
if ($statelist != "")
|
|
||||||
$statelist .= ", ";
|
|
||||||
$statelist .= $state.": ".$usage;
|
|
||||||
}
|
|
||||||
return(array("list" => $statelist, "amount" => $processes));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks if $array is a filled array with at least one entry.
|
|
||||||
*
|
|
||||||
* @param $array mixed A filled array with at least one entry
|
|
||||||
* @return Whether $array is a filled array or an object with rows
|
|
||||||
*/
|
|
||||||
public static function is_result($array) {
|
|
||||||
// It could be a return value from an update statement
|
|
||||||
if (is_bool($array)) {
|
|
||||||
return $array;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (is_object($array)) {
|
|
||||||
return dba::num_rows($array) > 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (is_array($array) && (count($array) > 0));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Callback function for "esc_array"
|
|
||||||
*
|
|
||||||
* @param mixed $value Array value
|
|
||||||
* @param string $key Array key
|
|
||||||
* @param boolean $add_quotation add quotation marks for string values
|
|
||||||
*/
|
|
||||||
private static function esc_array_callback(&$value, $key, $add_quotation) {
|
|
||||||
|
|
||||||
if (!$add_quotation) {
|
|
||||||
if (is_bool($value)) {
|
|
||||||
$value = ($value ? '1' : '0');
|
|
||||||
} else {
|
|
||||||
$value = dbesc($value);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (is_bool($value)) {
|
|
||||||
$value = ($value ? 'true' : 'false');
|
|
||||||
} elseif (is_float($value) || is_integer($value)) {
|
|
||||||
$value = (string)$value;
|
|
||||||
} else {
|
|
||||||
$value = "'".dbesc($value)."'";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Escapes a whole array
|
|
||||||
*
|
|
||||||
* @param mixed $arr Array with values to be escaped
|
|
||||||
* @param boolean $add_quotation add quotation marks for string values
|
|
||||||
*/
|
|
||||||
public static function esc_array(&$arr, $add_quotation = false) {
|
|
||||||
array_walk($arr, 'self::esc_array_callback', $add_quotation);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks Converts any date string into a SQL compatible date string
|
|
||||||
*
|
|
||||||
* @param string $date a date string in any format
|
|
||||||
* @return string SQL style date string
|
|
||||||
*/
|
|
||||||
public static function date($date = 'now') {
|
|
||||||
$timestamp = strtotime($date);
|
|
||||||
|
|
||||||
// Don't allow lower date strings as '0001-01-01 00:00:00'
|
|
||||||
if ($timestamp < -62135596800) {
|
|
||||||
$timestamp = -62135596800;
|
|
||||||
}
|
|
||||||
|
|
||||||
return date('Y-m-d H:i:s', (int)$timestamp);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once "boot.php";
|
require_once "boot.php";
|
||||||
require_once "include/text.php";
|
require_once "include/text.php";
|
||||||
|
|
@ -20,7 +21,7 @@ function convert_to_innodb() {
|
||||||
$r = q("SELECT `TABLE_NAME` FROM `information_schema`.`tables` WHERE `engine` = 'MyISAM' AND `table_schema` = '%s'",
|
$r = q("SELECT `TABLE_NAME` FROM `information_schema`.`tables` WHERE `engine` = 'MyISAM' AND `table_schema` = '%s'",
|
||||||
dbesc(dba::database_name()));
|
dbesc(dba::database_name()));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
echo t('There are no tables on MyISAM.')."\n";
|
echo t('There are no tables on MyISAM.')."\n";
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -30,7 +31,7 @@ function convert_to_innodb() {
|
||||||
echo $sql."\n";
|
echo $sql."\n";
|
||||||
|
|
||||||
$result = dba::e($sql);
|
$result = dba::e($sql);
|
||||||
if (!dbm::is_result($result)) {
|
if (!DBM::is_result($result)) {
|
||||||
print_update_error($sql);
|
print_update_error($sql);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -50,7 +51,7 @@ function update_fail($update_id, $error_message) {
|
||||||
);
|
);
|
||||||
|
|
||||||
// No valid result?
|
// No valid result?
|
||||||
if (!dbm::is_result($adminlist)) {
|
if (!DBM::is_result($adminlist)) {
|
||||||
logger(sprintf('Cannot notify administrators about update_id=%d, error_message=%s', $update_id, $error_message), LOGGER_NORMAL);
|
logger(sprintf('Cannot notify administrators about update_id=%d, error_message=%s', $update_id, $error_message), LOGGER_NORMAL);
|
||||||
|
|
||||||
// Don't continue
|
// Don't continue
|
||||||
|
|
@ -114,7 +115,7 @@ function table_structure($table) {
|
||||||
|
|
||||||
$table_status = q("SHOW TABLE STATUS WHERE `name` = '%s'", $table);
|
$table_status = q("SHOW TABLE STATUS WHERE `name` = '%s'", $table);
|
||||||
|
|
||||||
if (dbm::is_result($table_status)) {
|
if (DBM::is_result($table_status)) {
|
||||||
$table_status = $table_status[0];
|
$table_status = $table_status[0];
|
||||||
} else {
|
} else {
|
||||||
$table_status = array();
|
$table_status = array();
|
||||||
|
|
@ -123,7 +124,7 @@ function table_structure($table) {
|
||||||
$fielddata = array();
|
$fielddata = array();
|
||||||
$indexdata = array();
|
$indexdata = array();
|
||||||
|
|
||||||
if (dbm::is_result($indexes))
|
if (DBM::is_result($indexes))
|
||||||
foreach ($indexes AS $index) {
|
foreach ($indexes AS $index) {
|
||||||
if ($index['Key_name'] != 'PRIMARY' && $index['Non_unique'] == '0' && !isset($indexdata[$index["Key_name"]])) {
|
if ($index['Key_name'] != 'PRIMARY' && $index['Non_unique'] == '0' && !isset($indexdata[$index["Key_name"]])) {
|
||||||
$indexdata[$index["Key_name"]] = array('UNIQUE');
|
$indexdata[$index["Key_name"]] = array('UNIQUE');
|
||||||
|
|
@ -137,7 +138,7 @@ function table_structure($table) {
|
||||||
|
|
||||||
$indexdata[$index["Key_name"]][] = $column;
|
$indexdata[$index["Key_name"]][] = $column;
|
||||||
}
|
}
|
||||||
if (dbm::is_result($structures)) {
|
if (DBM::is_result($structures)) {
|
||||||
foreach ($structures AS $field) {
|
foreach ($structures AS $field) {
|
||||||
$fielddata[$field["Field"]]["type"] = $field["Type"];
|
$fielddata[$field["Field"]]["type"] = $field["Type"];
|
||||||
if ($field["Null"] == "NO") {
|
if ($field["Null"] == "NO") {
|
||||||
|
|
@ -157,7 +158,7 @@ function table_structure($table) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (dbm::is_result($full_columns)) {
|
if (DBM::is_result($full_columns)) {
|
||||||
foreach ($full_columns AS $column) {
|
foreach ($full_columns AS $column) {
|
||||||
$fielddata[$column["Field"]]["Collation"] = $column["Collation"];
|
$fielddata[$column["Field"]]["Collation"] = $column["Collation"];
|
||||||
}
|
}
|
||||||
|
|
@ -200,7 +201,7 @@ function update_structure($verbose, $action, $tables=null, $definition=null) {
|
||||||
|
|
||||||
if ($action) {
|
if ($action) {
|
||||||
Config::set('system', 'maintenance', 1);
|
Config::set('system', 'maintenance', 1);
|
||||||
Config::set('system', 'maintenance_reason', sprintf(t(': Database update'), dbm::date().' '.date('e')));
|
Config::set('system', 'maintenance_reason', sprintf(t(': Database update'), DBM::date().' '.date('e')));
|
||||||
}
|
}
|
||||||
|
|
||||||
$errors = false;
|
$errors = false;
|
||||||
|
|
@ -214,7 +215,7 @@ function update_structure($verbose, $action, $tables=null, $definition=null) {
|
||||||
$tables = q("SHOW TABLES");
|
$tables = q("SHOW TABLES");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($tables)) {
|
if (DBM::is_result($tables)) {
|
||||||
foreach ($tables AS $table) {
|
foreach ($tables AS $table) {
|
||||||
$table = current($table);
|
$table = current($table);
|
||||||
|
|
||||||
|
|
@ -243,7 +244,7 @@ function update_structure($verbose, $action, $tables=null, $definition=null) {
|
||||||
$sql3 = "";
|
$sql3 = "";
|
||||||
if (!isset($database[$name])) {
|
if (!isset($database[$name])) {
|
||||||
$r = db_create_table($name, $structure["fields"], $verbose, $action, $structure['indexes']);
|
$r = db_create_table($name, $structure["fields"], $verbose, $action, $structure['indexes']);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$errors .= print_update_error($name);
|
$errors .= print_update_error($name);
|
||||||
}
|
}
|
||||||
$is_new_table = True;
|
$is_new_table = True;
|
||||||
|
|
@ -433,7 +434,7 @@ function update_structure($verbose, $action, $tables=null, $definition=null) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($action) {
|
if ($action) {
|
||||||
Config::set('system', 'maintenance_reason', sprintf(t('%s: updating %s table.'), dbm::date().' '.date('e'), $name));
|
Config::set('system', 'maintenance_reason', sprintf(t('%s: updating %s table.'), DBM::date().' '.date('e'), $name));
|
||||||
|
|
||||||
// Ensure index conversion to unique removes duplicates
|
// Ensure index conversion to unique removes duplicates
|
||||||
if ($is_unique && ($temp_name != $name)) {
|
if ($is_unique && ($temp_name != $name)) {
|
||||||
|
|
@ -441,13 +442,13 @@ function update_structure($verbose, $action, $tables=null, $definition=null) {
|
||||||
dba::e("SET session old_alter_table=1;");
|
dba::e("SET session old_alter_table=1;");
|
||||||
} else {
|
} else {
|
||||||
dba::e("DROP TABLE IF EXISTS `".$temp_name."`;");
|
dba::e("DROP TABLE IF EXISTS `".$temp_name."`;");
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$errors .= print_update_error($sql3);
|
$errors .= print_update_error($sql3);
|
||||||
return $errors;
|
return $errors;
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = dba::e("CREATE TABLE `".$temp_name."` LIKE `".$name."`;");
|
$r = dba::e("CREATE TABLE `".$temp_name."` LIKE `".$name."`;");
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$errors .= print_update_error($sql3);
|
$errors .= print_update_error($sql3);
|
||||||
return $errors;
|
return $errors;
|
||||||
}
|
}
|
||||||
|
|
@ -455,7 +456,7 @@ function update_structure($verbose, $action, $tables=null, $definition=null) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = @dba::e($sql3);
|
$r = @dba::e($sql3);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$errors .= print_update_error($sql3);
|
$errors .= print_update_error($sql3);
|
||||||
}
|
}
|
||||||
if ($is_unique && ($temp_name != $name)) {
|
if ($is_unique && ($temp_name != $name)) {
|
||||||
|
|
@ -463,17 +464,17 @@ function update_structure($verbose, $action, $tables=null, $definition=null) {
|
||||||
dba::e("SET session old_alter_table=0;");
|
dba::e("SET session old_alter_table=0;");
|
||||||
} else {
|
} else {
|
||||||
$r = dba::e("INSERT INTO `".$temp_name."` SELECT ".$field_list." FROM `".$name."`".$group_by.";");
|
$r = dba::e("INSERT INTO `".$temp_name."` SELECT ".$field_list." FROM `".$name."`".$group_by.";");
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$errors .= print_update_error($sql3);
|
$errors .= print_update_error($sql3);
|
||||||
return $errors;
|
return $errors;
|
||||||
}
|
}
|
||||||
$r = dba::e("DROP TABLE `".$name."`;");
|
$r = dba::e("DROP TABLE `".$name."`;");
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$errors .= print_update_error($sql3);
|
$errors .= print_update_error($sql3);
|
||||||
return $errors;
|
return $errors;
|
||||||
}
|
}
|
||||||
$r = dba::e("RENAME TABLE `".$temp_name."` TO `".$name."`;");
|
$r = dba::e("RENAME TABLE `".$temp_name."` TO `".$name."`;");
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$errors .= print_update_error($sql3);
|
$errors .= print_update_error($sql3);
|
||||||
return $errors;
|
return $errors;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -3,8 +3,9 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
use Friendica\Protocol\Dfrn;
|
use Friendica\Protocol\DFRN;
|
||||||
|
|
||||||
require_once 'include/queue_fn.php';
|
require_once 'include/queue_fn.php';
|
||||||
require_once 'include/html2plain.php';
|
require_once 'include/html2plain.php';
|
||||||
|
|
@ -95,7 +96,7 @@ function delivery_run(&$argv, &$argc){
|
||||||
intval($item_id)
|
intval($item_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if ((!dbm::is_result($r)) || (!intval($r[0]['parent']))) {
|
if ((!DBM::is_result($r)) || (!intval($r[0]['parent']))) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -155,7 +156,7 @@ function delivery_run(&$argv, &$argc){
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -226,7 +227,7 @@ function delivery_run(&$argv, &$argc){
|
||||||
intval($contact_id)
|
intval($contact_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
}
|
}
|
||||||
if ($contact['self']) {
|
if ($contact['self']) {
|
||||||
|
|
@ -243,12 +244,12 @@ function delivery_run(&$argv, &$argc){
|
||||||
|
|
||||||
if ($mail) {
|
if ($mail) {
|
||||||
$item['body'] = fix_private_photos($item['body'],$owner['uid'],null,$message[0]['contact-id']);
|
$item['body'] = fix_private_photos($item['body'],$owner['uid'],null,$message[0]['contact-id']);
|
||||||
$atom = Dfrn::mail($item, $owner);
|
$atom = DFRN::mail($item, $owner);
|
||||||
} elseif ($fsuggest) {
|
} elseif ($fsuggest) {
|
||||||
$atom = Dfrn::fsuggest($item, $owner);
|
$atom = DFRN::fsuggest($item, $owner);
|
||||||
q("DELETE FROM `fsuggest` WHERE `id` = %d LIMIT 1", intval($item['id']));
|
q("DELETE FROM `fsuggest` WHERE `id` = %d LIMIT 1", intval($item['id']));
|
||||||
} elseif ($relocate) {
|
} elseif ($relocate) {
|
||||||
$atom = Dfrn::relocate($owner, $uid);
|
$atom = DFRN::relocate($owner, $uid);
|
||||||
} elseif ($followup) {
|
} elseif ($followup) {
|
||||||
$msgitems = array();
|
$msgitems = array();
|
||||||
foreach ($items as $item) { // there is only one item
|
foreach ($items as $item) { // there is only one item
|
||||||
|
|
@ -260,7 +261,7 @@ function delivery_run(&$argv, &$argc){
|
||||||
$msgitems[] = $item;
|
$msgitems[] = $item;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$atom = Dfrn::entries($msgitems,$owner);
|
$atom = DFRN::entries($msgitems,$owner);
|
||||||
} else {
|
} else {
|
||||||
$msgitems = array();
|
$msgitems = array();
|
||||||
foreach ($items as $item) {
|
foreach ($items as $item) {
|
||||||
|
|
@ -289,7 +290,7 @@ function delivery_run(&$argv, &$argc){
|
||||||
$msgitems[] = $item;
|
$msgitems[] = $item;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$atom = Dfrn::entries($msgitems,$owner);
|
$atom = DFRN::entries($msgitems,$owner);
|
||||||
}
|
}
|
||||||
|
|
||||||
logger('notifier entry: '.$contact["url"].' '.$target_item["guid"].' entry: '.$atom, LOGGER_DEBUG);
|
logger('notifier entry: '.$contact["url"].' '.$target_item["guid"].' entry: '.$atom, LOGGER_DEBUG);
|
||||||
|
|
@ -343,13 +344,13 @@ function delivery_run(&$argv, &$argc){
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
logger('mod-delivery: local delivery');
|
logger('mod-delivery: local delivery');
|
||||||
Dfrn::import($atom, $x[0]);
|
DFRN::import($atom, $x[0]);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!was_recently_delayed($contact['id'])) {
|
if (!was_recently_delayed($contact['id'])) {
|
||||||
$deliver_status = Dfrn::deliver($owner,$contact,$atom);
|
$deliver_status = DFRN::deliver($owner,$contact,$atom);
|
||||||
} else {
|
} else {
|
||||||
$deliver_status = (-1);
|
$deliver_status = (-1);
|
||||||
}
|
}
|
||||||
|
|
@ -405,7 +406,7 @@ function delivery_run(&$argv, &$argc){
|
||||||
intval($argv[2]),
|
intval($argv[2]),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$it = $r[0];
|
$it = $r[0];
|
||||||
}
|
}
|
||||||
if (!$it)
|
if (!$it)
|
||||||
|
|
@ -462,14 +463,14 @@ function delivery_run(&$argv, &$argc){
|
||||||
dbesc($it['parent-uri']),
|
dbesc($it['parent-uri']),
|
||||||
intval($uid));
|
intval($uid));
|
||||||
|
|
||||||
if (dbm::is_result($r) && ($r[0]['title'] != '')) {
|
if (DBM::is_result($r) && ($r[0]['title'] != '')) {
|
||||||
$subject = $r[0]['title'];
|
$subject = $r[0]['title'];
|
||||||
} else {
|
} else {
|
||||||
$r = q("SELECT `title` FROM `item` WHERE `parent-uri` = '%s' AND `uid` = %d LIMIT 1",
|
$r = q("SELECT `title` FROM `item` WHERE `parent-uri` = '%s' AND `uid` = %d LIMIT 1",
|
||||||
dbesc($it['parent-uri']),
|
dbesc($it['parent-uri']),
|
||||||
intval($uid));
|
intval($uid));
|
||||||
|
|
||||||
if (dbm::is_result($r) && ($r[0]['title'] != ''))
|
if (DBM::is_result($r) && ($r[0]['title'] != ''))
|
||||||
$subject = $r[0]['title'];
|
$subject = $r[0]['title'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
2966
include/dfrn.php
2966
include/dfrn.php
|
|
@ -1,2966 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* @file include/dfrn.php
|
|
||||||
* @brief The implementation of the dfrn protocol
|
|
||||||
*
|
|
||||||
* @see https://github.com/friendica/friendica/wiki/Protocol and
|
|
||||||
* https://github.com/friendica/friendica/blob/master/spec/dfrn2.pdf
|
|
||||||
*/
|
|
||||||
|
|
||||||
use Friendica\App;
|
|
||||||
use Friendica\Core\Config;
|
|
||||||
use Friendica\Core\System;
|
|
||||||
use Friendica\Core\Worker;
|
|
||||||
|
|
||||||
require_once("include/Contact.php");
|
|
||||||
require_once("include/ostatus.php");
|
|
||||||
require_once("include/enotify.php");
|
|
||||||
require_once("include/threads.php");
|
|
||||||
require_once("include/socgraph.php");
|
|
||||||
require_once("include/items.php");
|
|
||||||
require_once("include/tags.php");
|
|
||||||
require_once("include/files.php");
|
|
||||||
require_once("include/event.php");
|
|
||||||
require_once("include/text.php");
|
|
||||||
require_once("include/oembed.php");
|
|
||||||
require_once("include/html2bbcode.php");
|
|
||||||
require_once("include/bbcode.php");
|
|
||||||
require_once("include/xml.php");
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief This class contain functions to create and send DFRN XML files
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
class dfrn {
|
|
||||||
|
|
||||||
const DFRN_TOP_LEVEL = 0; // Top level posting
|
|
||||||
const DFRN_REPLY = 1; // Regular reply that is stored locally
|
|
||||||
const DFRN_REPLY_RC = 2; // Reply that will be relayed
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Generates the atom entries for delivery.php
|
|
||||||
*
|
|
||||||
* This function is used whenever content is transmitted via DFRN.
|
|
||||||
*
|
|
||||||
* @param array $items Item elements
|
|
||||||
* @param array $owner Owner record
|
|
||||||
*
|
|
||||||
* @return string DFRN entries
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
public static function entries($items,$owner) {
|
|
||||||
|
|
||||||
$doc = new DOMDocument('1.0', 'utf-8');
|
|
||||||
$doc->formatOutput = true;
|
|
||||||
|
|
||||||
$root = self::add_header($doc, $owner, "dfrn:owner", "", false);
|
|
||||||
|
|
||||||
if (! count($items)) {
|
|
||||||
return trim($doc->saveXML());
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($items as $item) {
|
|
||||||
$entry = self::entry($doc, "text", $item, $owner, $item["entry:comment-allow"], $item["entry:cid"]);
|
|
||||||
$root->appendChild($entry);
|
|
||||||
}
|
|
||||||
|
|
||||||
return(trim($doc->saveXML()));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Generate an atom feed for the given user
|
|
||||||
*
|
|
||||||
* This function is called when another server is pulling data from the user feed.
|
|
||||||
*
|
|
||||||
* @param string $dfrn_id DFRN ID from the requesting party
|
|
||||||
* @param string $owner_nick Owner nick name
|
|
||||||
* @param string $last_update Date of the last update
|
|
||||||
* @param int $direction Can be -1, 0 or 1.
|
|
||||||
* @param boolean $onlyheader Output only the header without content? (Default is "no")
|
|
||||||
*
|
|
||||||
* @return string DFRN feed entries
|
|
||||||
*/
|
|
||||||
public static function feed($dfrn_id, $owner_nick, $last_update, $direction = 0, $onlyheader = false) {
|
|
||||||
|
|
||||||
$a = get_app();
|
|
||||||
|
|
||||||
$sitefeed = ((strlen($owner_nick)) ? false : true); // not yet implemented, need to rewrite huge chunks of following logic
|
|
||||||
$public_feed = (($dfrn_id) ? false : true);
|
|
||||||
$starred = false; // not yet implemented, possible security issues
|
|
||||||
$converse = false;
|
|
||||||
|
|
||||||
if ($public_feed && $a->argc > 2) {
|
|
||||||
for ($x = 2; $x < $a->argc; $x++) {
|
|
||||||
if ($a->argv[$x] == 'converse') {
|
|
||||||
$converse = true;
|
|
||||||
}
|
|
||||||
if ($a->argv[$x] == 'starred') {
|
|
||||||
$starred = true;
|
|
||||||
}
|
|
||||||
if ($a->argv[$x] == 'category' && $a->argc > ($x + 1) && strlen($a->argv[$x+1])) {
|
|
||||||
$category = $a->argv[$x+1];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// default permissions - anonymous user
|
|
||||||
|
|
||||||
$sql_extra = " AND `item`.`allow_cid` = '' AND `item`.`allow_gid` = '' AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = '' ";
|
|
||||||
|
|
||||||
$r = q("SELECT `contact`.*, `user`.`nickname`, `user`.`timezone`, `user`.`page-flags`, `user`.`account-type`
|
|
||||||
FROM `contact` INNER JOIN `user` ON `user`.`uid` = `contact`.`uid`
|
|
||||||
WHERE `contact`.`self` AND `user`.`nickname` = '%s' LIMIT 1",
|
|
||||||
dbesc($owner_nick)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
|
||||||
killme();
|
|
||||||
}
|
|
||||||
|
|
||||||
$owner = $r[0];
|
|
||||||
$owner_id = $owner['uid'];
|
|
||||||
$owner_nick = $owner['nickname'];
|
|
||||||
|
|
||||||
$sql_post_table = "";
|
|
||||||
|
|
||||||
if (! $public_feed) {
|
|
||||||
|
|
||||||
$sql_extra = '';
|
|
||||||
switch($direction) {
|
|
||||||
case (-1):
|
|
||||||
$sql_extra = sprintf(" AND `issued-id` = '%s' ", dbesc($dfrn_id));
|
|
||||||
$my_id = $dfrn_id;
|
|
||||||
break;
|
|
||||||
case 0:
|
|
||||||
$sql_extra = sprintf(" AND `issued-id` = '%s' AND `duplex` = 1 ", dbesc($dfrn_id));
|
|
||||||
$my_id = '1:' . $dfrn_id;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
$sql_extra = sprintf(" AND `dfrn-id` = '%s' AND `duplex` = 1 ", dbesc($dfrn_id));
|
|
||||||
$my_id = '0:' . $dfrn_id;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return false;
|
|
||||||
break; // NOTREACHED
|
|
||||||
}
|
|
||||||
|
|
||||||
$r = q("SELECT * FROM `contact` WHERE NOT `blocked` AND `contact`.`uid` = %d $sql_extra LIMIT 1",
|
|
||||||
intval($owner_id)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
|
||||||
killme();
|
|
||||||
}
|
|
||||||
|
|
||||||
$contact = $r[0];
|
|
||||||
require_once('include/security.php');
|
|
||||||
$groups = init_groups_visitor($contact['id']);
|
|
||||||
|
|
||||||
if (count($groups)) {
|
|
||||||
for ($x = 0; $x < count($groups); $x ++)
|
|
||||||
$groups[$x] = '<' . intval($groups[$x]) . '>' ;
|
|
||||||
$gs = implode('|', $groups);
|
|
||||||
} else {
|
|
||||||
$gs = '<<>>' ; // Impossible to match
|
|
||||||
}
|
|
||||||
|
|
||||||
$sql_extra = sprintf("
|
|
||||||
AND ( `allow_cid` = '' OR `allow_cid` REGEXP '<%d>' )
|
|
||||||
AND ( `deny_cid` = '' OR NOT `deny_cid` REGEXP '<%d>' )
|
|
||||||
AND ( `allow_gid` = '' OR `allow_gid` REGEXP '%s' )
|
|
||||||
AND ( `deny_gid` = '' OR NOT `deny_gid` REGEXP '%s')
|
|
||||||
",
|
|
||||||
intval($contact['id']),
|
|
||||||
intval($contact['id']),
|
|
||||||
dbesc($gs),
|
|
||||||
dbesc($gs)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($public_feed) {
|
|
||||||
$sort = 'DESC';
|
|
||||||
} else {
|
|
||||||
$sort = 'ASC';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (! strlen($last_update)) {
|
|
||||||
$last_update = 'now -30 days';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($category)) {
|
|
||||||
$sql_post_table = sprintf("INNER JOIN (SELECT `oid` FROM `term` WHERE `term` = '%s' AND `otype` = %d AND `type` = %d AND `uid` = %d ORDER BY `tid` DESC) AS `term` ON `item`.`id` = `term`.`oid` ",
|
|
||||||
dbesc(protect_sprintf($category)), intval(TERM_OBJ_POST), intval(TERM_CATEGORY), intval($owner_id));
|
|
||||||
//$sql_extra .= file_tag_file_query('item',$category,'category');
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($public_feed) {
|
|
||||||
if (! $converse) {
|
|
||||||
$sql_extra .= " AND `contact`.`self` = 1 ";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$check_date = datetime_convert('UTC','UTC',$last_update,'Y-m-d H:i:s');
|
|
||||||
|
|
||||||
$r = q("SELECT `item`.*, `item`.`id` AS `item_id`,
|
|
||||||
`contact`.`name`, `contact`.`network`, `contact`.`photo`, `contact`.`url`,
|
|
||||||
`contact`.`name-date`, `contact`.`uri-date`, `contact`.`avatar-date`,
|
|
||||||
`contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`,
|
|
||||||
`sign`.`signed_text`, `sign`.`signature`, `sign`.`signer`
|
|
||||||
FROM `item` USE INDEX (`uid_wall_changed`) $sql_post_table
|
|
||||||
STRAIGHT_JOIN `contact` ON `contact`.`id` = `item`.`contact-id`
|
|
||||||
AND (NOT `contact`.`blocked` OR `contact`.`pending`)
|
|
||||||
LEFT JOIN `sign` ON `sign`.`iid` = `item`.`id`
|
|
||||||
WHERE `item`.`uid` = %d AND `item`.`visible` AND NOT `item`.`moderated` AND `item`.`parent` != 0
|
|
||||||
AND `item`.`wall` AND `item`.`changed` > '%s'
|
|
||||||
$sql_extra
|
|
||||||
ORDER BY `item`.`parent` ".$sort.", `item`.`created` ASC LIMIT 0, 300",
|
|
||||||
intval($owner_id),
|
|
||||||
dbesc($check_date),
|
|
||||||
dbesc($sort)
|
|
||||||
);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Will check further below if this actually returned results.
|
|
||||||
* We will provide an empty feed if that is the case.
|
|
||||||
*/
|
|
||||||
|
|
||||||
$items = $r;
|
|
||||||
|
|
||||||
$doc = new DOMDocument('1.0', 'utf-8');
|
|
||||||
$doc->formatOutput = true;
|
|
||||||
|
|
||||||
$alternatelink = $owner['url'];
|
|
||||||
|
|
||||||
if (isset($category)) {
|
|
||||||
$alternatelink .= "/category/".$category;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($public_feed) {
|
|
||||||
$author = "dfrn:owner";
|
|
||||||
} else {
|
|
||||||
$author = "author";
|
|
||||||
}
|
|
||||||
|
|
||||||
$root = self::add_header($doc, $owner, $author, $alternatelink, true);
|
|
||||||
|
|
||||||
/// @TODO This hook can't work anymore
|
|
||||||
// call_hooks('atom_feed', $atom);
|
|
||||||
|
|
||||||
if (!dbm::is_result($items) || $onlyheader) {
|
|
||||||
$atom = trim($doc->saveXML());
|
|
||||||
|
|
||||||
call_hooks('atom_feed_end', $atom);
|
|
||||||
|
|
||||||
return $atom;
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($items as $item) {
|
|
||||||
|
|
||||||
// prevent private email from leaking.
|
|
||||||
if ($item['network'] == NETWORK_MAIL) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// public feeds get html, our own nodes use bbcode
|
|
||||||
|
|
||||||
if ($public_feed) {
|
|
||||||
$type = 'html';
|
|
||||||
// catch any email that's in a public conversation and make sure it doesn't leak
|
|
||||||
if ($item['private']) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$type = 'text';
|
|
||||||
}
|
|
||||||
|
|
||||||
$entry = self::entry($doc, $type, $item, $owner, true);
|
|
||||||
$root->appendChild($entry);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
$atom = trim($doc->saveXML());
|
|
||||||
|
|
||||||
call_hooks('atom_feed_end', $atom);
|
|
||||||
|
|
||||||
return $atom;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Generate an atom entry for a given item id
|
|
||||||
*
|
|
||||||
* @param int $item_id The item id
|
|
||||||
* @param boolean $conversation Show the conversation. If false show the single post.
|
|
||||||
*
|
|
||||||
* @return string DFRN feed entry
|
|
||||||
*/
|
|
||||||
public static function itemFeed($item_id, $conversation = false) {
|
|
||||||
if ($conversation) {
|
|
||||||
$condition = '`item`.`parent`';
|
|
||||||
} else {
|
|
||||||
$condition = '`item`.`id`';
|
|
||||||
}
|
|
||||||
|
|
||||||
$r = q("SELECT `item`.*, `item`.`id` AS `item_id`,
|
|
||||||
`contact`.`name`, `contact`.`network`, `contact`.`photo`, `contact`.`url`,
|
|
||||||
`contact`.`name-date`, `contact`.`uri-date`, `contact`.`avatar-date`,
|
|
||||||
`contact`.`thumb`, `contact`.`dfrn-id`, `contact`.`self`,
|
|
||||||
`sign`.`signed_text`, `sign`.`signature`, `sign`.`signer`
|
|
||||||
FROM `item`
|
|
||||||
STRAIGHT_JOIN `contact` ON `contact`.`id` = `item`.`contact-id`
|
|
||||||
AND (NOT `contact`.`blocked` OR `contact`.`pending`)
|
|
||||||
LEFT JOIN `sign` ON `sign`.`iid` = `item`.`id`
|
|
||||||
WHERE %s = %d AND `item`.`visible` AND NOT `item`.`moderated` AND `item`.`parent` != 0
|
|
||||||
AND NOT `item`.`private`",
|
|
||||||
$condition,
|
|
||||||
intval($item_id)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
killme();
|
|
||||||
}
|
|
||||||
|
|
||||||
$items = $r;
|
|
||||||
$item = $r[0];
|
|
||||||
|
|
||||||
$r = q("SELECT `contact`.*, `user`.`nickname`, `user`.`timezone`, `user`.`page-flags`, `user`.`account-type`
|
|
||||||
FROM `contact` INNER JOIN `user` ON `user`.`uid` = `contact`.`uid`
|
|
||||||
WHERE `contact`.`self` AND `user`.`uid` = %d LIMIT 1",
|
|
||||||
intval($item['uid'])
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
killme();
|
|
||||||
}
|
|
||||||
|
|
||||||
$owner = $r[0];
|
|
||||||
|
|
||||||
$doc = new DOMDocument('1.0', 'utf-8');
|
|
||||||
$doc->formatOutput = true;
|
|
||||||
$type = 'html';
|
|
||||||
|
|
||||||
if ($conversation) {
|
|
||||||
$root = $doc->createElementNS(NAMESPACE_ATOM1, 'feed');
|
|
||||||
$doc->appendChild($root);
|
|
||||||
|
|
||||||
$root->setAttribute("xmlns:thr", NAMESPACE_THREAD);
|
|
||||||
$root->setAttribute("xmlns:at", NAMESPACE_TOMB);
|
|
||||||
$root->setAttribute("xmlns:media", NAMESPACE_MEDIA);
|
|
||||||
$root->setAttribute("xmlns:dfrn", NAMESPACE_DFRN);
|
|
||||||
$root->setAttribute("xmlns:activity", NAMESPACE_ACTIVITY);
|
|
||||||
$root->setAttribute("xmlns:georss", NAMESPACE_GEORSS);
|
|
||||||
$root->setAttribute("xmlns:poco", NAMESPACE_POCO);
|
|
||||||
$root->setAttribute("xmlns:ostatus", NAMESPACE_OSTATUS);
|
|
||||||
$root->setAttribute("xmlns:statusnet", NAMESPACE_STATUSNET);
|
|
||||||
|
|
||||||
//$root = self::add_header($doc, $owner, "dfrn:owner", "", false);
|
|
||||||
|
|
||||||
foreach ($items as $item) {
|
|
||||||
$entry = self::entry($doc, $type, $item, $owner, true, 0);
|
|
||||||
$root->appendChild($entry);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$root = self::entry($doc, $type, $item, $owner, true, 0, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
$atom = trim($doc->saveXML());
|
|
||||||
return $atom;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Create XML text for DFRN mails
|
|
||||||
*
|
|
||||||
* @param array $item message elements
|
|
||||||
* @param array $owner Owner record
|
|
||||||
*
|
|
||||||
* @return string DFRN mail
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
public static function mail($item, $owner) {
|
|
||||||
$doc = new DOMDocument('1.0', 'utf-8');
|
|
||||||
$doc->formatOutput = true;
|
|
||||||
|
|
||||||
$root = self::add_header($doc, $owner, "dfrn:owner", "", false);
|
|
||||||
|
|
||||||
$mail = $doc->createElement("dfrn:mail");
|
|
||||||
$sender = $doc->createElement("dfrn:sender");
|
|
||||||
|
|
||||||
xml::add_element($doc, $sender, "dfrn:name", $owner['name']);
|
|
||||||
xml::add_element($doc, $sender, "dfrn:uri", $owner['url']);
|
|
||||||
xml::add_element($doc, $sender, "dfrn:avatar", $owner['thumb']);
|
|
||||||
|
|
||||||
$mail->appendChild($sender);
|
|
||||||
|
|
||||||
xml::add_element($doc, $mail, "dfrn:id", $item['uri']);
|
|
||||||
xml::add_element($doc, $mail, "dfrn:in-reply-to", $item['parent-uri']);
|
|
||||||
xml::add_element($doc, $mail, "dfrn:sentdate", datetime_convert('UTC', 'UTC', $item['created'] . '+00:00' , ATOM_TIME));
|
|
||||||
xml::add_element($doc, $mail, "dfrn:subject", $item['title']);
|
|
||||||
xml::add_element($doc, $mail, "dfrn:content", $item['body']);
|
|
||||||
|
|
||||||
$root->appendChild($mail);
|
|
||||||
|
|
||||||
return(trim($doc->saveXML()));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Create XML text for DFRN friend suggestions
|
|
||||||
*
|
|
||||||
* @param array $item suggestion elements
|
|
||||||
* @param array $owner Owner record
|
|
||||||
*
|
|
||||||
* @return string DFRN suggestions
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
public static function fsuggest($item, $owner) {
|
|
||||||
$doc = new DOMDocument('1.0', 'utf-8');
|
|
||||||
$doc->formatOutput = true;
|
|
||||||
|
|
||||||
$root = self::add_header($doc, $owner, "dfrn:owner", "", false);
|
|
||||||
|
|
||||||
$suggest = $doc->createElement("dfrn:suggest");
|
|
||||||
|
|
||||||
xml::add_element($doc, $suggest, "dfrn:url", $item['url']);
|
|
||||||
xml::add_element($doc, $suggest, "dfrn:name", $item['name']);
|
|
||||||
xml::add_element($doc, $suggest, "dfrn:photo", $item['photo']);
|
|
||||||
xml::add_element($doc, $suggest, "dfrn:request", $item['request']);
|
|
||||||
xml::add_element($doc, $suggest, "dfrn:note", $item['note']);
|
|
||||||
|
|
||||||
$root->appendChild($suggest);
|
|
||||||
|
|
||||||
return(trim($doc->saveXML()));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Create XML text for DFRN relocations
|
|
||||||
*
|
|
||||||
* @param array $owner Owner record
|
|
||||||
* @param int $uid User ID
|
|
||||||
*
|
|
||||||
* @return string DFRN relocations
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
public static function relocate($owner, $uid) {
|
|
||||||
|
|
||||||
/* get site pubkey. this could be a new installation with no site keys*/
|
|
||||||
$pubkey = Config::get('system','site_pubkey');
|
|
||||||
if (! $pubkey) {
|
|
||||||
$res = new_keypair(1024);
|
|
||||||
Config::set('system','site_prvkey', $res['prvkey']);
|
|
||||||
Config::set('system','site_pubkey', $res['pubkey']);
|
|
||||||
}
|
|
||||||
|
|
||||||
$rp = q("SELECT `resource-id` , `scale`, type FROM `photo`
|
|
||||||
WHERE `profile` = 1 AND `uid` = %d ORDER BY scale;", $uid);
|
|
||||||
$photos = array();
|
|
||||||
$ext = Photo::supportedTypes();
|
|
||||||
|
|
||||||
foreach ($rp as $p) {
|
|
||||||
$photos[$p['scale']] = System::baseUrl().'/photo/'.$p['resource-id'].'-'.$p['scale'].'.'.$ext[$p['type']];
|
|
||||||
}
|
|
||||||
|
|
||||||
unset($rp, $ext);
|
|
||||||
|
|
||||||
$doc = new DOMDocument('1.0', 'utf-8');
|
|
||||||
$doc->formatOutput = true;
|
|
||||||
|
|
||||||
$root = self::add_header($doc, $owner, "dfrn:owner", "", false);
|
|
||||||
|
|
||||||
$relocate = $doc->createElement("dfrn:relocate");
|
|
||||||
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:url", $owner['url']);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:name", $owner['name']);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:addr", $owner['addr']);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:avatar", $owner['avatar']);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:photo", $photos[4]);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:thumb", $photos[5]);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:micro", $photos[6]);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:request", $owner['request']);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:confirm", $owner['confirm']);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:notify", $owner['notify']);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:poll", $owner['poll']);
|
|
||||||
xml::add_element($doc, $relocate, "dfrn:sitepubkey", Config::get('system','site_pubkey'));
|
|
||||||
|
|
||||||
$root->appendChild($relocate);
|
|
||||||
|
|
||||||
return(trim($doc->saveXML()));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Adds the header elements for the DFRN protocol
|
|
||||||
*
|
|
||||||
* @param object $doc XML document
|
|
||||||
* @param array $owner Owner record
|
|
||||||
* @param string $authorelement Element name for the author
|
|
||||||
* @param string $alternatelink link to profile or category
|
|
||||||
* @param bool $public Is it a header for public posts?
|
|
||||||
*
|
|
||||||
* @return object XML root object
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
private static function add_header($doc, $owner, $authorelement, $alternatelink = "", $public = false) {
|
|
||||||
|
|
||||||
if ($alternatelink == "") {
|
|
||||||
$alternatelink = $owner['url'];
|
|
||||||
}
|
|
||||||
|
|
||||||
$root = $doc->createElementNS(NAMESPACE_ATOM1, 'feed');
|
|
||||||
$doc->appendChild($root);
|
|
||||||
|
|
||||||
$root->setAttribute("xmlns:thr", NAMESPACE_THREAD);
|
|
||||||
$root->setAttribute("xmlns:at", NAMESPACE_TOMB);
|
|
||||||
$root->setAttribute("xmlns:media", NAMESPACE_MEDIA);
|
|
||||||
$root->setAttribute("xmlns:dfrn", NAMESPACE_DFRN);
|
|
||||||
$root->setAttribute("xmlns:activity", NAMESPACE_ACTIVITY);
|
|
||||||
$root->setAttribute("xmlns:georss", NAMESPACE_GEORSS);
|
|
||||||
$root->setAttribute("xmlns:poco", NAMESPACE_POCO);
|
|
||||||
$root->setAttribute("xmlns:ostatus", NAMESPACE_OSTATUS);
|
|
||||||
$root->setAttribute("xmlns:statusnet", NAMESPACE_STATUSNET);
|
|
||||||
|
|
||||||
xml::add_element($doc, $root, "id", System::baseUrl()."/profile/".$owner["nick"]);
|
|
||||||
xml::add_element($doc, $root, "title", $owner["name"]);
|
|
||||||
|
|
||||||
$attributes = array("uri" => "https://friendi.ca", "version" => FRIENDICA_VERSION."-".DB_UPDATE_VERSION);
|
|
||||||
xml::add_element($doc, $root, "generator", FRIENDICA_PLATFORM, $attributes);
|
|
||||||
|
|
||||||
$attributes = array("rel" => "license", "href" => "http://creativecommons.org/licenses/by/3.0/");
|
|
||||||
xml::add_element($doc, $root, "link", "", $attributes);
|
|
||||||
|
|
||||||
$attributes = array("rel" => "alternate", "type" => "text/html", "href" => $alternatelink);
|
|
||||||
xml::add_element($doc, $root, "link", "", $attributes);
|
|
||||||
|
|
||||||
|
|
||||||
if ($public) {
|
|
||||||
// DFRN itself doesn't uses this. But maybe someone else wants to subscribe to the public feed.
|
|
||||||
ostatus::hublinks($doc, $root, $owner["nick"]);
|
|
||||||
|
|
||||||
$attributes = array("rel" => "salmon", "href" => System::baseUrl()."/salmon/".$owner["nick"]);
|
|
||||||
xml::add_element($doc, $root, "link", "", $attributes);
|
|
||||||
|
|
||||||
$attributes = array("rel" => "http://salmon-protocol.org/ns/salmon-replies", "href" => System::baseUrl()."/salmon/".$owner["nick"]);
|
|
||||||
xml::add_element($doc, $root, "link", "", $attributes);
|
|
||||||
|
|
||||||
$attributes = array("rel" => "http://salmon-protocol.org/ns/salmon-mention", "href" => System::baseUrl()."/salmon/".$owner["nick"]);
|
|
||||||
xml::add_element($doc, $root, "link", "", $attributes);
|
|
||||||
}
|
|
||||||
|
|
||||||
// For backward compatibility we keep this element
|
|
||||||
if ($owner['page-flags'] == PAGE_COMMUNITY) {
|
|
||||||
xml::add_element($doc, $root, "dfrn:community", 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
// The former element is replaced by this one
|
|
||||||
xml::add_element($doc, $root, "dfrn:account_type", $owner["account-type"]);
|
|
||||||
|
|
||||||
/// @todo We need a way to transmit the different page flags like "PAGE_PRVGROUP"
|
|
||||||
|
|
||||||
xml::add_element($doc, $root, "updated", datetime_convert("UTC", "UTC", "now", ATOM_TIME));
|
|
||||||
|
|
||||||
$author = self::add_author($doc, $owner, $authorelement, $public);
|
|
||||||
$root->appendChild($author);
|
|
||||||
|
|
||||||
return $root;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Adds the author element in the header for the DFRN protocol
|
|
||||||
*
|
|
||||||
* @param object $doc XML document
|
|
||||||
* @param array $owner Owner record
|
|
||||||
* @param string $authorelement Element name for the author
|
|
||||||
*
|
|
||||||
* @return object XML author object
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
private static function add_author($doc, $owner, $authorelement, $public) {
|
|
||||||
|
|
||||||
// Is the profile hidden or shouldn't be published in the net? Then add the "hide" element
|
|
||||||
$r = q("SELECT `id` FROM `profile` INNER JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
|
||||||
WHERE (`hidewall` OR NOT `net-publish`) AND `user`.`uid` = %d",
|
|
||||||
intval($owner['uid']));
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$hidewall = true;
|
|
||||||
} else {
|
|
||||||
$hidewall = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$author = $doc->createElement($authorelement);
|
|
||||||
|
|
||||||
$namdate = datetime_convert('UTC', 'UTC', $owner['name-date'].'+00:00', ATOM_TIME);
|
|
||||||
$uridate = datetime_convert('UTC', 'UTC', $owner['uri-date'].'+00:00', ATOM_TIME);
|
|
||||||
$picdate = datetime_convert('UTC', 'UTC', $owner['avatar-date'].'+00:00', ATOM_TIME);
|
|
||||||
|
|
||||||
$attributes = array();
|
|
||||||
|
|
||||||
if (!$public || !$hidewall) {
|
|
||||||
$attributes = array("dfrn:updated" => $namdate);
|
|
||||||
}
|
|
||||||
|
|
||||||
xml::add_element($doc, $author, "name", $owner["name"], $attributes);
|
|
||||||
xml::add_element($doc, $author, "uri", System::baseUrl().'/profile/'.$owner["nickname"], $attributes);
|
|
||||||
xml::add_element($doc, $author, "dfrn:handle", $owner["addr"], $attributes);
|
|
||||||
|
|
||||||
$attributes = array("rel" => "photo", "type" => "image/jpeg",
|
|
||||||
"media:width" => 175, "media:height" => 175, "href" => $owner['photo']);
|
|
||||||
|
|
||||||
if (!$public || !$hidewall) {
|
|
||||||
$attributes["dfrn:updated"] = $picdate;
|
|
||||||
}
|
|
||||||
|
|
||||||
xml::add_element($doc, $author, "link", "", $attributes);
|
|
||||||
|
|
||||||
$attributes["rel"] = "avatar";
|
|
||||||
xml::add_element($doc, $author, "link", "", $attributes);
|
|
||||||
|
|
||||||
if ($hidewall) {
|
|
||||||
xml::add_element($doc, $author, "dfrn:hide", "true");
|
|
||||||
}
|
|
||||||
|
|
||||||
// The following fields will only be generated if the data isn't meant for a public feed
|
|
||||||
if ($public) {
|
|
||||||
return $author;
|
|
||||||
}
|
|
||||||
|
|
||||||
$birthday = feed_birthday($owner['uid'], $owner['timezone']);
|
|
||||||
|
|
||||||
if ($birthday)
|
|
||||||
xml::add_element($doc, $author, "dfrn:birthday", $birthday);
|
|
||||||
|
|
||||||
// Only show contact details when we are allowed to
|
|
||||||
$r = q("SELECT `profile`.`about`, `profile`.`name`, `profile`.`homepage`, `user`.`nickname`,
|
|
||||||
`user`.`timezone`, `profile`.`locality`, `profile`.`region`, `profile`.`country-name`,
|
|
||||||
`profile`.`pub_keywords`, `profile`.`xmpp`, `profile`.`dob`
|
|
||||||
FROM `profile`
|
|
||||||
INNER JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
|
||||||
WHERE `profile`.`is-default` AND NOT `user`.`hidewall` AND `user`.`uid` = %d",
|
|
||||||
intval($owner['uid']));
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$profile = $r[0];
|
|
||||||
|
|
||||||
xml::add_element($doc, $author, "poco:displayName", $profile["name"]);
|
|
||||||
xml::add_element($doc, $author, "poco:updated", $namdate);
|
|
||||||
|
|
||||||
if (trim($profile["dob"]) > '0001-01-01') {
|
|
||||||
xml::add_element($doc, $author, "poco:birthday", "0000-".date("m-d", strtotime($profile["dob"])));
|
|
||||||
}
|
|
||||||
|
|
||||||
xml::add_element($doc, $author, "poco:note", $profile["about"]);
|
|
||||||
xml::add_element($doc, $author, "poco:preferredUsername", $profile["nickname"]);
|
|
||||||
|
|
||||||
$savetz = date_default_timezone_get();
|
|
||||||
date_default_timezone_set($profile["timezone"]);
|
|
||||||
xml::add_element($doc, $author, "poco:utcOffset", date("P"));
|
|
||||||
date_default_timezone_set($savetz);
|
|
||||||
|
|
||||||
if (trim($profile["homepage"]) != "") {
|
|
||||||
$urls = $doc->createElement("poco:urls");
|
|
||||||
xml::add_element($doc, $urls, "poco:type", "homepage");
|
|
||||||
xml::add_element($doc, $urls, "poco:value", $profile["homepage"]);
|
|
||||||
xml::add_element($doc, $urls, "poco:primary", "true");
|
|
||||||
$author->appendChild($urls);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (trim($profile["pub_keywords"]) != "") {
|
|
||||||
$keywords = explode(",", $profile["pub_keywords"]);
|
|
||||||
|
|
||||||
foreach ($keywords AS $keyword) {
|
|
||||||
xml::add_element($doc, $author, "poco:tags", trim($keyword));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if (trim($profile["xmpp"]) != "") {
|
|
||||||
$ims = $doc->createElement("poco:ims");
|
|
||||||
xml::add_element($doc, $ims, "poco:type", "xmpp");
|
|
||||||
xml::add_element($doc, $ims, "poco:value", $profile["xmpp"]);
|
|
||||||
xml::add_element($doc, $ims, "poco:primary", "true");
|
|
||||||
$author->appendChild($ims);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (trim($profile["locality"].$profile["region"].$profile["country-name"]) != "") {
|
|
||||||
$element = $doc->createElement("poco:address");
|
|
||||||
|
|
||||||
xml::add_element($doc, $element, "poco:formatted", formatted_location($profile));
|
|
||||||
|
|
||||||
if (trim($profile["locality"]) != "") {
|
|
||||||
xml::add_element($doc, $element, "poco:locality", $profile["locality"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (trim($profile["region"]) != "") {
|
|
||||||
xml::add_element($doc, $element, "poco:region", $profile["region"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (trim($profile["country-name"]) != "") {
|
|
||||||
xml::add_element($doc, $element, "poco:country", $profile["country-name"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
$author->appendChild($element);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $author;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Adds the author elements in the "entry" elements of the DFRN protocol
|
|
||||||
*
|
|
||||||
* @param object $doc XML document
|
|
||||||
* @param string $element Element name for the author
|
|
||||||
* @param string $contact_url Link of the contact
|
|
||||||
* @param array $items Item elements
|
|
||||||
*
|
|
||||||
* @return object XML author object
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
private static function add_entry_author($doc, $element, $contact_url, $item) {
|
|
||||||
|
|
||||||
$contact = get_contact_details_by_url($contact_url, $item["uid"]);
|
|
||||||
|
|
||||||
$author = $doc->createElement($element);
|
|
||||||
xml::add_element($doc, $author, "name", $contact["name"]);
|
|
||||||
xml::add_element($doc, $author, "uri", $contact["url"]);
|
|
||||||
xml::add_element($doc, $author, "dfrn:handle", $contact["addr"]);
|
|
||||||
|
|
||||||
/// @Todo
|
|
||||||
/// - Check real image type and image size
|
|
||||||
/// - Check which of these boths elements we should use
|
|
||||||
$attributes = array(
|
|
||||||
"rel" => "photo",
|
|
||||||
"type" => "image/jpeg",
|
|
||||||
"media:width" => 80,
|
|
||||||
"media:height" => 80,
|
|
||||||
"href" => $contact["photo"]);
|
|
||||||
xml::add_element($doc, $author, "link", "", $attributes);
|
|
||||||
|
|
||||||
$attributes = array(
|
|
||||||
"rel" => "avatar",
|
|
||||||
"type" => "image/jpeg",
|
|
||||||
"media:width" => 80,
|
|
||||||
"media:height" => 80,
|
|
||||||
"href" => $contact["photo"]);
|
|
||||||
xml::add_element($doc, $author, "link", "", $attributes);
|
|
||||||
|
|
||||||
return $author;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Adds the activity elements
|
|
||||||
*
|
|
||||||
* @param object $doc XML document
|
|
||||||
* @param string $element Element name for the activity
|
|
||||||
* @param string $activity activity value
|
|
||||||
*
|
|
||||||
* @return object XML activity object
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
private static function create_activity($doc, $element, $activity) {
|
|
||||||
|
|
||||||
if ($activity) {
|
|
||||||
$entry = $doc->createElement($element);
|
|
||||||
|
|
||||||
$r = parse_xml_string($activity, false);
|
|
||||||
if (!$r) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if ($r->type) {
|
|
||||||
xml::add_element($doc, $entry, "activity:object-type", $r->type);
|
|
||||||
}
|
|
||||||
if ($r->id) {
|
|
||||||
xml::add_element($doc, $entry, "id", $r->id);
|
|
||||||
}
|
|
||||||
if ($r->title) {
|
|
||||||
xml::add_element($doc, $entry, "title", $r->title);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($r->link) {
|
|
||||||
if (substr($r->link, 0, 1) == '<') {
|
|
||||||
if (strstr($r->link, '&') && (! strstr($r->link, '&'))) {
|
|
||||||
$r->link = str_replace('&', '&', $r->link);
|
|
||||||
}
|
|
||||||
|
|
||||||
$r->link = preg_replace('/\<link(.*?)\"\>/', '<link$1"/>', $r->link);
|
|
||||||
|
|
||||||
// XML does need a single element as root element so we add a dummy element here
|
|
||||||
$data = parse_xml_string("<dummy>" . $r->link . "</dummy>", false);
|
|
||||||
if (is_object($data)) {
|
|
||||||
foreach ($data->link AS $link) {
|
|
||||||
$attributes = array();
|
|
||||||
foreach ($link->attributes() AS $parameter => $value) {
|
|
||||||
$attributes[$parameter] = $value;
|
|
||||||
}
|
|
||||||
xml::add_element($doc, $entry, "link", "", $attributes);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$attributes = array("rel" => "alternate", "type" => "text/html", "href" => $r->link);
|
|
||||||
xml::add_element($doc, $entry, "link", "", $attributes);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($r->content) {
|
|
||||||
xml::add_element($doc, $entry, "content", bbcode($r->content), array("type" => "html"));
|
|
||||||
}
|
|
||||||
|
|
||||||
return $entry;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Adds the elements for attachments
|
|
||||||
*
|
|
||||||
* @param object $doc XML document
|
|
||||||
* @param object $root XML root
|
|
||||||
* @param array $item Item element
|
|
||||||
*
|
|
||||||
* @return object XML attachment object
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
private static function get_attachment($doc, $root, $item) {
|
|
||||||
$arr = explode('[/attach],',$item['attach']);
|
|
||||||
if (count($arr)) {
|
|
||||||
foreach ($arr as $r) {
|
|
||||||
$matches = false;
|
|
||||||
$cnt = preg_match('|\[attach\]href=\"(.*?)\" length=\"(.*?)\" type=\"(.*?)\" title=\"(.*?)\"|',$r,$matches);
|
|
||||||
if ($cnt) {
|
|
||||||
$attributes = array("rel" => "enclosure",
|
|
||||||
"href" => $matches[1],
|
|
||||||
"type" => $matches[3]);
|
|
||||||
|
|
||||||
if (intval($matches[2])) {
|
|
||||||
$attributes["length"] = intval($matches[2]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (trim($matches[4]) != "") {
|
|
||||||
$attributes["title"] = trim($matches[4]);
|
|
||||||
}
|
|
||||||
|
|
||||||
xml::add_element($doc, $root, "link", "", $attributes);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Adds the "entry" elements for the DFRN protocol
|
|
||||||
*
|
|
||||||
* @param object $doc XML document
|
|
||||||
* @param string $type "text" or "html"
|
|
||||||
* @param array $item Item element
|
|
||||||
* @param array $owner Owner record
|
|
||||||
* @param bool $comment Trigger the sending of the "comment" element
|
|
||||||
* @param int $cid Contact ID of the recipient
|
|
||||||
* @param bool $single If set, the entry is created as an XML document with a single "entry" element
|
|
||||||
*
|
|
||||||
* @return object XML entry object
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
private static function entry($doc, $type, $item, $owner, $comment = false, $cid = 0, $single = false) {
|
|
||||||
|
|
||||||
$mentioned = array();
|
|
||||||
|
|
||||||
if (!$item['parent']) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item['deleted']) {
|
|
||||||
$attributes = array("ref" => $item['uri'], "when" => datetime_convert('UTC','UTC',$item['edited'] . '+00:00',ATOM_TIME));
|
|
||||||
return xml::create_element($doc, "at:deleted-entry", "", $attributes);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$single) {
|
|
||||||
$entry = $doc->createElement("entry");
|
|
||||||
} else {
|
|
||||||
$entry = $doc->createElementNS(NAMESPACE_ATOM1, 'entry');
|
|
||||||
$doc->appendChild($entry);
|
|
||||||
|
|
||||||
$entry->setAttribute("xmlns:thr", NAMESPACE_THREAD);
|
|
||||||
$entry->setAttribute("xmlns:at", NAMESPACE_TOMB);
|
|
||||||
$entry->setAttribute("xmlns:media", NAMESPACE_MEDIA);
|
|
||||||
$entry->setAttribute("xmlns:dfrn", NAMESPACE_DFRN);
|
|
||||||
$entry->setAttribute("xmlns:activity", NAMESPACE_ACTIVITY);
|
|
||||||
$entry->setAttribute("xmlns:georss", NAMESPACE_GEORSS);
|
|
||||||
$entry->setAttribute("xmlns:poco", NAMESPACE_POCO);
|
|
||||||
$entry->setAttribute("xmlns:ostatus", NAMESPACE_OSTATUS);
|
|
||||||
$entry->setAttribute("xmlns:statusnet", NAMESPACE_STATUSNET);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item['allow_cid'] || $item['allow_gid'] || $item['deny_cid'] || $item['deny_gid']) {
|
|
||||||
$body = fix_private_photos($item['body'],$owner['uid'],$item,$cid);
|
|
||||||
} else {
|
|
||||||
$body = $item['body'];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Remove the abstract element. It is only locally important.
|
|
||||||
$body = remove_abstract($body);
|
|
||||||
|
|
||||||
if ($type == 'html') {
|
|
||||||
$htmlbody = $body;
|
|
||||||
|
|
||||||
if ($item['title'] != "") {
|
|
||||||
$htmlbody = "[b]".$item['title']."[/b]\n\n".$htmlbody;
|
|
||||||
}
|
|
||||||
|
|
||||||
$htmlbody = bbcode($htmlbody, false, false, 7);
|
|
||||||
}
|
|
||||||
|
|
||||||
$author = self::add_entry_author($doc, "author", $item["author-link"], $item);
|
|
||||||
$entry->appendChild($author);
|
|
||||||
|
|
||||||
$dfrnowner = self::add_entry_author($doc, "dfrn:owner", $item["owner-link"], $item);
|
|
||||||
$entry->appendChild($dfrnowner);
|
|
||||||
|
|
||||||
if (($item['parent'] != $item['id']) || ($item['parent-uri'] !== $item['uri']) || (($item['thr-parent'] !== '') && ($item['thr-parent'] !== $item['uri']))) {
|
|
||||||
$parent_item = (($item['thr-parent']) ? $item['thr-parent'] : $item['parent-uri']);
|
|
||||||
$parent = q("SELECT `guid`,`plink` FROM `item` WHERE `uri` = '%s' AND `uid` = %d", dbesc($parent_item), intval($item['uid']));
|
|
||||||
$attributes = array("ref" => $parent_item, "type" => "text/html",
|
|
||||||
"href" => $parent[0]['plink'],
|
|
||||||
"dfrn:diaspora_guid" => $parent[0]['guid']);
|
|
||||||
xml::add_element($doc, $entry, "thr:in-reply-to", "", $attributes);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add conversation data. This is used for OStatus
|
|
||||||
$conversation_href = System::baseUrl()."/display/".$owner["nick"]."/".$item["parent"];
|
|
||||||
$conversation_uri = $conversation_href;
|
|
||||||
|
|
||||||
if (isset($parent_item)) {
|
|
||||||
$r = dba::fetch_first("SELECT `conversation-uri`, `conversation-href` FROM `conversation` WHERE `item-uri` = ?", $item['parent-uri']);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
if ($r['conversation-uri'] != '') {
|
|
||||||
$conversation_uri = $r['conversation-uri'];
|
|
||||||
}
|
|
||||||
if ($r['conversation-href'] != '') {
|
|
||||||
$conversation_href = $r['conversation-href'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$attributes = array(
|
|
||||||
"href" => $conversation_href,
|
|
||||||
"ref" => $conversation_uri);
|
|
||||||
|
|
||||||
xml::add_element($doc, $entry, "ostatus:conversation", $conversation_uri, $attributes);
|
|
||||||
|
|
||||||
xml::add_element($doc, $entry, "id", $item["uri"]);
|
|
||||||
xml::add_element($doc, $entry, "title", $item["title"]);
|
|
||||||
|
|
||||||
xml::add_element($doc, $entry, "published", datetime_convert("UTC","UTC",$item["created"]."+00:00",ATOM_TIME));
|
|
||||||
xml::add_element($doc, $entry, "updated", datetime_convert("UTC","UTC",$item["edited"]."+00:00",ATOM_TIME));
|
|
||||||
|
|
||||||
// "dfrn:env" is used to read the content
|
|
||||||
xml::add_element($doc, $entry, "dfrn:env", base64url_encode($body, true));
|
|
||||||
|
|
||||||
// The "content" field is not read by the receiver. We could remove it when the type is "text"
|
|
||||||
// We keep it at the moment, maybe there is some old version that doesn't read "dfrn:env"
|
|
||||||
xml::add_element($doc, $entry, "content", (($type == 'html') ? $htmlbody : $body), array("type" => $type));
|
|
||||||
|
|
||||||
// We save this value in "plink". Maybe we should read it from there as well?
|
|
||||||
xml::add_element($doc, $entry, "link", "", array("rel" => "alternate", "type" => "text/html",
|
|
||||||
"href" => System::baseUrl()."/display/".$item["guid"]));
|
|
||||||
|
|
||||||
// "comment-allow" is some old fashioned stuff for old Friendica versions.
|
|
||||||
// It is included in the rewritten code for completeness
|
|
||||||
if ($comment) {
|
|
||||||
xml::add_element($doc, $entry, "dfrn:comment-allow", intval($item['last-child']));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item['location']) {
|
|
||||||
xml::add_element($doc, $entry, "dfrn:location", $item['location']);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item['coord']) {
|
|
||||||
xml::add_element($doc, $entry, "georss:point", $item['coord']);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($item['private']) || strlen($item['allow_cid']) || strlen($item['allow_gid']) || strlen($item['deny_cid']) || strlen($item['deny_gid'])) {
|
|
||||||
xml::add_element($doc, $entry, "dfrn:private", (($item['private']) ? $item['private'] : 1));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item['extid']) {
|
|
||||||
xml::add_element($doc, $entry, "dfrn:extid", $item['extid']);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item['bookmark']) {
|
|
||||||
xml::add_element($doc, $entry, "dfrn:bookmark", "true");
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item['app']) {
|
|
||||||
xml::add_element($doc, $entry, "statusnet:notice_info", "", array("local_id" => $item['id'], "source" => $item['app']));
|
|
||||||
}
|
|
||||||
|
|
||||||
xml::add_element($doc, $entry, "dfrn:diaspora_guid", $item["guid"]);
|
|
||||||
|
|
||||||
// The signed text contains the content in Markdown, the sender handle and the signatur for the content
|
|
||||||
// It is needed for relayed comments to Diaspora.
|
|
||||||
if ($item['signed_text']) {
|
|
||||||
$sign = base64_encode(json_encode(array('signed_text' => $item['signed_text'],'signature' => $item['signature'],'signer' => $item['signer'])));
|
|
||||||
xml::add_element($doc, $entry, "dfrn:diaspora_signature", $sign);
|
|
||||||
}
|
|
||||||
|
|
||||||
xml::add_element($doc, $entry, "activity:verb", construct_verb($item));
|
|
||||||
|
|
||||||
if ($item['object-type'] != "") {
|
|
||||||
xml::add_element($doc, $entry, "activity:object-type", $item['object-type']);
|
|
||||||
} elseif ($item['id'] == $item['parent']) {
|
|
||||||
xml::add_element($doc, $entry, "activity:object-type", ACTIVITY_OBJ_NOTE);
|
|
||||||
} else {
|
|
||||||
xml::add_element($doc, $entry, "activity:object-type", ACTIVITY_OBJ_COMMENT);
|
|
||||||
}
|
|
||||||
|
|
||||||
$actobj = self::create_activity($doc, "activity:object", $item['object']);
|
|
||||||
if ($actobj) {
|
|
||||||
$entry->appendChild($actobj);
|
|
||||||
}
|
|
||||||
|
|
||||||
$actarg = self::create_activity($doc, "activity:target", $item['target']);
|
|
||||||
if ($actarg) {
|
|
||||||
$entry->appendChild($actarg);
|
|
||||||
}
|
|
||||||
|
|
||||||
$tags = item_getfeedtags($item);
|
|
||||||
|
|
||||||
if (count($tags)) {
|
|
||||||
foreach ($tags as $t) {
|
|
||||||
if (($type != 'html') || ($t[0] != "@")) {
|
|
||||||
xml::add_element($doc, $entry, "category", "", array("scheme" => "X-DFRN:".$t[0].":".$t[1], "term" => $t[2]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (count($tags)) {
|
|
||||||
foreach ($tags as $t) {
|
|
||||||
if ($t[0] == "@") {
|
|
||||||
$mentioned[$t[1]] = $t[1];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($mentioned AS $mention) {
|
|
||||||
$r = q("SELECT `forum`, `prv` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s'",
|
|
||||||
intval($owner["uid"]),
|
|
||||||
dbesc(normalise_link($mention)));
|
|
||||||
|
|
||||||
if (dbm::is_result($r) && ($r[0]["forum"] || $r[0]["prv"])) {
|
|
||||||
xml::add_element($doc, $entry, "link", "", array("rel" => "mentioned",
|
|
||||||
"ostatus:object-type" => ACTIVITY_OBJ_GROUP,
|
|
||||||
"href" => $mention));
|
|
||||||
} else {
|
|
||||||
xml::add_element($doc, $entry, "link", "", array("rel" => "mentioned",
|
|
||||||
"ostatus:object-type" => ACTIVITY_OBJ_PERSON,
|
|
||||||
"href" => $mention));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
self::get_attachment($doc, $entry, $item);
|
|
||||||
|
|
||||||
return $entry;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief encrypts data via AES
|
|
||||||
*
|
|
||||||
* @param string $data The data that is to be encrypted
|
|
||||||
* @param string $key The AES key
|
|
||||||
*
|
|
||||||
* @return string encrypted data
|
|
||||||
*/
|
|
||||||
private static function aes_encrypt($data, $key) {
|
|
||||||
return openssl_encrypt($data, 'aes-128-ecb', $key, OPENSSL_RAW_DATA);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief decrypts data via AES
|
|
||||||
*
|
|
||||||
* @param string $encrypted The encrypted data
|
|
||||||
* @param string $key The AES key
|
|
||||||
*
|
|
||||||
* @return string decrypted data
|
|
||||||
*/
|
|
||||||
public static function aes_decrypt($encrypted, $key) {
|
|
||||||
return openssl_decrypt($encrypted, 'aes-128-ecb', $key, OPENSSL_RAW_DATA);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Delivers the atom content to the contacts
|
|
||||||
*
|
|
||||||
* @param array $owner Owner record
|
|
||||||
* @param array $contactr Contact record of the receiver
|
|
||||||
* @param string $atom Content that will be transmitted
|
|
||||||
* @param bool $dissolve (to be documented)
|
|
||||||
*
|
|
||||||
* @return int Deliver status. -1 means an error.
|
|
||||||
* @todo Add array type-hint for $owner, $contact
|
|
||||||
*/
|
|
||||||
public static function deliver($owner,$contact,$atom, $dissolve = false) {
|
|
||||||
|
|
||||||
$a = get_app();
|
|
||||||
|
|
||||||
$idtosend = $orig_id = (($contact['dfrn-id']) ? $contact['dfrn-id'] : $contact['issued-id']);
|
|
||||||
|
|
||||||
if ($contact['duplex'] && $contact['dfrn-id']) {
|
|
||||||
$idtosend = '0:' . $orig_id;
|
|
||||||
}
|
|
||||||
if ($contact['duplex'] && $contact['issued-id']) {
|
|
||||||
$idtosend = '1:' . $orig_id;
|
|
||||||
}
|
|
||||||
|
|
||||||
$rino = Config::get('system', 'rino_encrypt');
|
|
||||||
$rino = intval($rino);
|
|
||||||
|
|
||||||
logger("Local rino version: ". $rino, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$ssl_val = intval(Config::get('system','ssl_policy'));
|
|
||||||
$ssl_policy = '';
|
|
||||||
|
|
||||||
switch ($ssl_val) {
|
|
||||||
case SSL_POLICY_FULL:
|
|
||||||
$ssl_policy = 'full';
|
|
||||||
break;
|
|
||||||
case SSL_POLICY_SELFSIGN:
|
|
||||||
$ssl_policy = 'self';
|
|
||||||
break;
|
|
||||||
case SSL_POLICY_NONE:
|
|
||||||
default:
|
|
||||||
$ssl_policy = 'none';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
$url = $contact['notify'] . '&dfrn_id=' . $idtosend . '&dfrn_version=' . DFRN_PROTOCOL_VERSION . (($rino) ? '&rino='.$rino : '');
|
|
||||||
|
|
||||||
logger('dfrn_deliver: ' . $url);
|
|
||||||
|
|
||||||
$ret = z_fetch_url($url);
|
|
||||||
|
|
||||||
if ($ret['errno'] == CURLE_OPERATION_TIMEDOUT) {
|
|
||||||
return -2; // timed out
|
|
||||||
}
|
|
||||||
|
|
||||||
$xml = $ret['body'];
|
|
||||||
|
|
||||||
$curl_stat = $a->get_curl_code();
|
|
||||||
if (!$curl_stat) {
|
|
||||||
return -3; // timed out
|
|
||||||
}
|
|
||||||
|
|
||||||
logger('dfrn_deliver: ' . $xml, LOGGER_DATA);
|
|
||||||
|
|
||||||
if (! $xml) {
|
|
||||||
return 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strpos($xml,'<?xml') === false) {
|
|
||||||
logger('dfrn_deliver: no valid XML returned');
|
|
||||||
logger('dfrn_deliver: returned XML: ' . $xml, LOGGER_DATA);
|
|
||||||
return 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
$res = parse_xml_string($xml);
|
|
||||||
|
|
||||||
if ((intval($res->status) != 0) || (! strlen($res->challenge)) || (! strlen($res->dfrn_id))) {
|
|
||||||
return (($res->status) ? $res->status : 3);
|
|
||||||
}
|
|
||||||
|
|
||||||
$postvars = array();
|
|
||||||
$sent_dfrn_id = hex2bin((string) $res->dfrn_id);
|
|
||||||
$challenge = hex2bin((string) $res->challenge);
|
|
||||||
$perm = (($res->perm) ? $res->perm : null);
|
|
||||||
$dfrn_version = (float) (($res->dfrn_version) ? $res->dfrn_version : 2.0);
|
|
||||||
$rino_remote_version = intval($res->rino);
|
|
||||||
$page = (($owner['page-flags'] == PAGE_COMMUNITY) ? 1 : 0);
|
|
||||||
|
|
||||||
logger("Remote rino version: ".$rino_remote_version." for ".$contact["url"], LOGGER_DEBUG);
|
|
||||||
|
|
||||||
if ($owner['page-flags'] == PAGE_PRVGROUP) {
|
|
||||||
$page = 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
$final_dfrn_id = '';
|
|
||||||
|
|
||||||
if ($perm) {
|
|
||||||
if ((($perm == 'rw') && (! intval($contact['writable'])))
|
|
||||||
|| (($perm == 'r') && (intval($contact['writable'])))) {
|
|
||||||
q("update contact set writable = %d where id = %d",
|
|
||||||
intval(($perm == 'rw') ? 1 : 0),
|
|
||||||
intval($contact['id'])
|
|
||||||
);
|
|
||||||
$contact['writable'] = (string) 1 - intval($contact['writable']);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($contact['duplex'] && strlen($contact['pubkey']))
|
|
||||||
|| ($owner['page-flags'] == PAGE_COMMUNITY && strlen($contact['pubkey']))
|
|
||||||
|| ($contact['rel'] == CONTACT_IS_SHARING && strlen($contact['pubkey']))) {
|
|
||||||
openssl_public_decrypt($sent_dfrn_id,$final_dfrn_id,$contact['pubkey']);
|
|
||||||
openssl_public_decrypt($challenge,$postvars['challenge'],$contact['pubkey']);
|
|
||||||
} else {
|
|
||||||
openssl_private_decrypt($sent_dfrn_id,$final_dfrn_id,$contact['prvkey']);
|
|
||||||
openssl_private_decrypt($challenge,$postvars['challenge'],$contact['prvkey']);
|
|
||||||
}
|
|
||||||
|
|
||||||
$final_dfrn_id = substr($final_dfrn_id, 0, strpos($final_dfrn_id, '.'));
|
|
||||||
|
|
||||||
if (strpos($final_dfrn_id,':') == 1) {
|
|
||||||
$final_dfrn_id = substr($final_dfrn_id,2);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($final_dfrn_id != $orig_id) {
|
|
||||||
logger('dfrn_deliver: wrong dfrn_id.');
|
|
||||||
// did not decode properly - cannot trust this site
|
|
||||||
return 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
$postvars['dfrn_id'] = $idtosend;
|
|
||||||
$postvars['dfrn_version'] = DFRN_PROTOCOL_VERSION;
|
|
||||||
if ($dissolve) {
|
|
||||||
$postvars['dissolve'] = '1';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if ((($contact['rel']) && ($contact['rel'] != CONTACT_IS_SHARING) && (! $contact['blocked'])) || ($owner['page-flags'] == PAGE_COMMUNITY)) {
|
|
||||||
$postvars['data'] = $atom;
|
|
||||||
$postvars['perm'] = 'rw';
|
|
||||||
} else {
|
|
||||||
$postvars['data'] = str_replace('<dfrn:comment-allow>1','<dfrn:comment-allow>0',$atom);
|
|
||||||
$postvars['perm'] = 'r';
|
|
||||||
}
|
|
||||||
|
|
||||||
$postvars['ssl_policy'] = $ssl_policy;
|
|
||||||
|
|
||||||
if ($page) {
|
|
||||||
$postvars['page'] = $page;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if ($rino > 0 && $rino_remote_version > 0 && (! $dissolve)) {
|
|
||||||
logger('rino version: '. $rino_remote_version);
|
|
||||||
|
|
||||||
switch ($rino_remote_version) {
|
|
||||||
case 1:
|
|
||||||
// Deprecated rino version!
|
|
||||||
$key = openssl_random_pseudo_bytes(16);
|
|
||||||
$data = self::aes_encrypt($postvars['data'], $key);
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
// RINO 2 based on php-encryption
|
|
||||||
try {
|
|
||||||
$key = Crypto::createNewRandomKey();
|
|
||||||
} catch (CryptoTestFailed $ex) {
|
|
||||||
logger('Cannot safely create a key');
|
|
||||||
return -4;
|
|
||||||
} catch (CannotPerformOperation $ex) {
|
|
||||||
logger('Cannot safely create a key');
|
|
||||||
return -5;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
$data = Crypto::encrypt($postvars['data'], $key);
|
|
||||||
} catch (CryptoTestFailed $ex) {
|
|
||||||
logger('Cannot safely perform encryption');
|
|
||||||
return -6;
|
|
||||||
} catch (CannotPerformOperation $ex) {
|
|
||||||
logger('Cannot safely perform encryption');
|
|
||||||
return -7;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
logger("rino: invalid requested verision '$rino_remote_version'");
|
|
||||||
return -8;
|
|
||||||
}
|
|
||||||
|
|
||||||
$postvars['rino'] = $rino_remote_version;
|
|
||||||
$postvars['data'] = bin2hex($data);
|
|
||||||
|
|
||||||
//logger('rino: sent key = ' . $key, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
|
|
||||||
if ($dfrn_version >= 2.1) {
|
|
||||||
if (($contact['duplex'] && strlen($contact['pubkey']))
|
|
||||||
|| ($owner['page-flags'] == PAGE_COMMUNITY && strlen($contact['pubkey']))
|
|
||||||
|| ($contact['rel'] == CONTACT_IS_SHARING && strlen($contact['pubkey']))) {
|
|
||||||
openssl_public_encrypt($key,$postvars['key'],$contact['pubkey']);
|
|
||||||
} else {
|
|
||||||
openssl_private_encrypt($key,$postvars['key'],$contact['prvkey']);
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
|
||||||
if (($contact['duplex'] && strlen($contact['prvkey'])) || ($owner['page-flags'] == PAGE_COMMUNITY)) {
|
|
||||||
openssl_private_encrypt($key,$postvars['key'],$contact['prvkey']);
|
|
||||||
} else {
|
|
||||||
openssl_public_encrypt($key,$postvars['key'],$contact['pubkey']);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
logger('md5 rawkey ' . md5($postvars['key']));
|
|
||||||
|
|
||||||
$postvars['key'] = bin2hex($postvars['key']);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
logger('dfrn_deliver: ' . "SENDING: " . print_r($postvars,true), LOGGER_DATA);
|
|
||||||
|
|
||||||
$xml = post_url($contact['notify'], $postvars);
|
|
||||||
|
|
||||||
logger('dfrn_deliver: ' . "RECEIVED: " . $xml, LOGGER_DATA);
|
|
||||||
|
|
||||||
$curl_stat = $a->get_curl_code();
|
|
||||||
if ((!$curl_stat) || (!strlen($xml))) {
|
|
||||||
return -9; // timed out
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($curl_stat == 503) && (stristr($a->get_curl_headers(),'retry-after'))) {
|
|
||||||
return -10;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (strpos($xml,'<?xml') === false) {
|
|
||||||
logger('dfrn_deliver: phase 2: no valid XML returned');
|
|
||||||
logger('dfrn_deliver: phase 2: returned XML: ' . $xml, LOGGER_DATA);
|
|
||||||
return 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($contact['term-date'] > NULL_DATE) {
|
|
||||||
logger("dfrn_deliver: $url back from the dead - removing mark for death");
|
|
||||||
require_once('include/Contact.php');
|
|
||||||
unmark_for_death($contact);
|
|
||||||
}
|
|
||||||
|
|
||||||
$res = parse_xml_string($xml);
|
|
||||||
|
|
||||||
if (!isset($res->status)) {
|
|
||||||
return -11;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!empty($res->message)) {
|
|
||||||
logger('Delivery returned status '.$res->status.' - '.$res->message, LOGGER_DEBUG);
|
|
||||||
}
|
|
||||||
|
|
||||||
return intval($res->status);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Add new birthday event for this person
|
|
||||||
*
|
|
||||||
* @param array $contact Contact record
|
|
||||||
* @param string $birthday Birthday of the contact
|
|
||||||
* @todo Add array type-hint for $contact
|
|
||||||
*/
|
|
||||||
private static function birthday_event($contact, $birthday) {
|
|
||||||
|
|
||||||
// Check for duplicates
|
|
||||||
$r = q("SELECT `id` FROM `event` WHERE `uid` = %d AND `cid` = %d AND `start` = '%s' AND `type` = '%s' LIMIT 1",
|
|
||||||
intval($contact["uid"]),
|
|
||||||
intval($contact["id"]),
|
|
||||||
dbesc(datetime_convert("UTC","UTC", $birthday)),
|
|
||||||
dbesc("birthday"));
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("updating birthday: ".$birthday." for contact ".$contact["id"]);
|
|
||||||
|
|
||||||
$bdtext = sprintf(t("%s\'s birthday"), $contact["name"]);
|
|
||||||
$bdtext2 = sprintf(t("Happy Birthday %s"), " [url=".$contact["url"]."]".$contact["name"]."[/url]") ;
|
|
||||||
|
|
||||||
$r = q("INSERT INTO `event` (`uid`,`cid`,`created`,`edited`,`start`,`finish`,`summary`,`desc`,`type`)
|
|
||||||
VALUES ( %d, %d, '%s', '%s', '%s', '%s', '%s', '%s', '%s') ",
|
|
||||||
intval($contact["uid"]),
|
|
||||||
intval($contact["id"]),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc(datetime_convert("UTC","UTC", $birthday)),
|
|
||||||
dbesc(datetime_convert("UTC","UTC", $birthday." + 1 day ")),
|
|
||||||
dbesc($bdtext),
|
|
||||||
dbesc($bdtext2),
|
|
||||||
dbesc("birthday")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetch the author data from head or entry items
|
|
||||||
*
|
|
||||||
* @param object $xpath XPath object
|
|
||||||
* @param object $context In which context should the data be searched
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @param string $element Element name from which the data is fetched
|
|
||||||
* @param bool $onlyfetch Should the data only be fetched or should it update the contact record as well
|
|
||||||
*
|
|
||||||
* @return Returns an array with relevant data of the author
|
|
||||||
* @todo Find good type-hints for all parameter
|
|
||||||
*/
|
|
||||||
private static function fetchauthor($xpath, $context, $importer, $element, $onlyfetch, $xml = "") {
|
|
||||||
|
|
||||||
$author = array();
|
|
||||||
$author["name"] = $xpath->evaluate($element."/atom:name/text()", $context)->item(0)->nodeValue;
|
|
||||||
$author["link"] = $xpath->evaluate($element."/atom:uri/text()", $context)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
$r = q("SELECT `id`, `uid`, `url`, `network`, `avatar-date`, `name-date`, `uri-date`, `addr`,
|
|
||||||
`name`, `nick`, `about`, `location`, `keywords`, `xmpp`, `bdyear`, `bd`, `hidden`, `contact-type`
|
|
||||||
FROM `contact` WHERE `uid` = %d AND `nurl` = '%s' AND `network` != '%s'",
|
|
||||||
intval($importer["uid"]), dbesc(normalise_link($author["link"])), dbesc(NETWORK_STATUSNET));
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$contact = $r[0];
|
|
||||||
$author["contact-id"] = $r[0]["id"];
|
|
||||||
$author["network"] = $r[0]["network"];
|
|
||||||
} else {
|
|
||||||
if (!$onlyfetch) {
|
|
||||||
logger("Contact ".$author["link"]." wasn't found for user ".$importer["uid"]." XML: ".$xml, LOGGER_DEBUG);
|
|
||||||
}
|
|
||||||
|
|
||||||
$author["contact-id"] = $importer["id"];
|
|
||||||
$author["network"] = $importer["network"];
|
|
||||||
$onlyfetch = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Until now we aren't serving different sizes - but maybe later
|
|
||||||
$avatarlist = array();
|
|
||||||
/// @todo check if "avatar" or "photo" would be the best field in the specification
|
|
||||||
$avatars = $xpath->query($element."/atom:link[@rel='avatar']", $context);
|
|
||||||
foreach ($avatars AS $avatar) {
|
|
||||||
$href = "";
|
|
||||||
$width = 0;
|
|
||||||
foreach ($avatar->attributes AS $attributes) {
|
|
||||||
/// @TODO Rewrite these similar if () to one switch
|
|
||||||
if ($attributes->name == "href") {
|
|
||||||
$href = $attributes->textContent;
|
|
||||||
}
|
|
||||||
if ($attributes->name == "width") {
|
|
||||||
$width = $attributes->textContent;
|
|
||||||
}
|
|
||||||
if ($attributes->name == "updated") {
|
|
||||||
$contact["avatar-date"] = $attributes->textContent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (($width > 0) && ($href != "")) {
|
|
||||||
$avatarlist[$width] = $href;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (count($avatarlist) > 0) {
|
|
||||||
krsort($avatarlist);
|
|
||||||
$author["avatar"] = current($avatarlist);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (dbm::is_result($r) && !$onlyfetch) {
|
|
||||||
logger("Check if contact details for contact " . $r[0]["id"] . " (" . $r[0]["nick"] . ") have to be updated.", LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$poco = array("url" => $contact["url"]);
|
|
||||||
|
|
||||||
// When was the last change to name or uri?
|
|
||||||
$name_element = $xpath->query($element . "/atom:name", $context)->item(0);
|
|
||||||
foreach ($name_element->attributes AS $attributes) {
|
|
||||||
if ($attributes->name == "updated") {
|
|
||||||
$poco["name-date"] = $attributes->textContent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$link_element = $xpath->query($element . "/atom:link", $context)->item(0);
|
|
||||||
foreach ($link_element->attributes AS $attributes) {
|
|
||||||
if ($attributes->name == "updated") {
|
|
||||||
$poco["uri-date"] = $attributes->textContent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update contact data
|
|
||||||
$value = $xpath->evaluate($element . "/dfrn:handle/text()", $context)->item(0)->nodeValue;
|
|
||||||
if ($value != "") {
|
|
||||||
$poco["addr"] = $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
$value = $xpath->evaluate($element . "/poco:displayName/text()", $context)->item(0)->nodeValue;
|
|
||||||
if ($value != "") {
|
|
||||||
$poco["name"] = $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
$value = $xpath->evaluate($element . "/poco:preferredUsername/text()", $context)->item(0)->nodeValue;
|
|
||||||
if ($value != "") {
|
|
||||||
$poco["nick"] = $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
$value = $xpath->evaluate($element . "/poco:note/text()", $context)->item(0)->nodeValue;
|
|
||||||
if ($value != "") {
|
|
||||||
$poco["about"] = $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
$value = $xpath->evaluate($element . "/poco:address/poco:formatted/text()", $context)->item(0)->nodeValue;
|
|
||||||
if ($value != "") {
|
|
||||||
$poco["location"] = $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @todo Only search for elements with "poco:type" = "xmpp"
|
|
||||||
$value = $xpath->evaluate($element . "/poco:ims/poco:value/text()", $context)->item(0)->nodeValue;
|
|
||||||
if ($value != "") {
|
|
||||||
$poco["xmpp"] = $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @todo Add support for the following fields that we don't support by now in the contact table:
|
|
||||||
/// - poco:utcOffset
|
|
||||||
/// - poco:urls
|
|
||||||
/// - poco:locality
|
|
||||||
/// - poco:region
|
|
||||||
/// - poco:country
|
|
||||||
|
|
||||||
// If the "hide" element is present then the profile isn't searchable.
|
|
||||||
$hide = intval($xpath->evaluate($element . "/dfrn:hide/text()", $context)->item(0)->nodeValue == "true");
|
|
||||||
|
|
||||||
logger("Hidden status for contact " . $contact["url"] . ": " . $hide, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
// If the contact isn't searchable then set the contact to "hidden".
|
|
||||||
// Problem: This can be manually overridden by the user.
|
|
||||||
if ($hide) {
|
|
||||||
$contact["hidden"] = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Save the keywords into the contact table
|
|
||||||
$tags = array();
|
|
||||||
$tagelements = $xpath->evaluate($element . "/poco:tags/text()", $context);
|
|
||||||
foreach ($tagelements AS $tag) {
|
|
||||||
$tags[$tag->nodeValue] = $tag->nodeValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (count($tags)) {
|
|
||||||
$poco["keywords"] = implode(", ", $tags);
|
|
||||||
}
|
|
||||||
|
|
||||||
// "dfrn:birthday" contains the birthday converted to UTC
|
|
||||||
$old_bdyear = $contact["bdyear"];
|
|
||||||
|
|
||||||
$birthday = $xpath->evaluate($element . "/dfrn:birthday/text()", $context)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
if (strtotime($birthday) > time()) {
|
|
||||||
$bd_timestamp = strtotime($birthday);
|
|
||||||
|
|
||||||
$poco["bdyear"] = date("Y", $bd_timestamp);
|
|
||||||
}
|
|
||||||
|
|
||||||
// "poco:birthday" is the birthday in the format "yyyy-mm-dd"
|
|
||||||
$value = $xpath->evaluate($element . "/poco:birthday/text()", $context)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
if (!in_array($value, array("", "0000-00-00", "0001-01-01"))) {
|
|
||||||
$bdyear = date("Y");
|
|
||||||
$value = str_replace("0000", $bdyear, $value);
|
|
||||||
|
|
||||||
if (strtotime($value) < time()) {
|
|
||||||
$value = str_replace($bdyear, $bdyear + 1, $value);
|
|
||||||
$bdyear = $bdyear + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$poco["bd"] = $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
$contact = array_merge($contact, $poco);
|
|
||||||
|
|
||||||
if ($old_bdyear != $contact["bdyear"]) {
|
|
||||||
self::birthday_event($contact, $birthday);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get all field names
|
|
||||||
$fields = array();
|
|
||||||
foreach ($r[0] AS $field => $data) {
|
|
||||||
$fields[$field] = $data;
|
|
||||||
}
|
|
||||||
|
|
||||||
unset($fields["id"]);
|
|
||||||
unset($fields["uid"]);
|
|
||||||
unset($fields["url"]);
|
|
||||||
unset($fields["avatar-date"]);
|
|
||||||
unset($fields["name-date"]);
|
|
||||||
unset($fields["uri-date"]);
|
|
||||||
|
|
||||||
// Update check for this field has to be done differently
|
|
||||||
$datefields = array("name-date", "uri-date");
|
|
||||||
foreach ($datefields AS $field) {
|
|
||||||
if (strtotime($contact[$field]) > strtotime($r[0][$field])) {
|
|
||||||
logger("Difference for contact " . $contact["id"] . " in field '" . $field . "'. New value: '" . $contact[$field] . "', old value '" . $r[0][$field] . "'", LOGGER_DEBUG);
|
|
||||||
$update = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($fields AS $field => $data) {
|
|
||||||
if ($contact[$field] != $r[0][$field]) {
|
|
||||||
logger("Difference for contact " . $contact["id"] . " in field '" . $field . "'. New value: '" . $contact[$field] . "', old value '" . $r[0][$field] . "'", LOGGER_DEBUG);
|
|
||||||
$update = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($update) {
|
|
||||||
logger("Update contact data for contact " . $contact["id"] . " (" . $contact["nick"] . ")", LOGGER_DEBUG);
|
|
||||||
|
|
||||||
q("UPDATE `contact` SET `name` = '%s', `nick` = '%s', `about` = '%s', `location` = '%s',
|
|
||||||
`addr` = '%s', `keywords` = '%s', `bdyear` = '%s', `bd` = '%s', `hidden` = %d,
|
|
||||||
`xmpp` = '%s', `name-date` = '%s', `uri-date` = '%s'
|
|
||||||
WHERE `id` = %d AND `network` = '%s'",
|
|
||||||
dbesc($contact["name"]), dbesc($contact["nick"]), dbesc($contact["about"]), dbesc($contact["location"]),
|
|
||||||
dbesc($contact["addr"]), dbesc($contact["keywords"]), dbesc($contact["bdyear"]),
|
|
||||||
dbesc($contact["bd"]), intval($contact["hidden"]), dbesc($contact["xmpp"]),
|
|
||||||
dbesc(dbm::date($contact["name-date"])), dbesc(dbm::date($contact["uri-date"])),
|
|
||||||
intval($contact["id"]), dbesc($contact["network"]));
|
|
||||||
}
|
|
||||||
|
|
||||||
update_contact_avatar($author["avatar"], $importer["uid"], $contact["id"],
|
|
||||||
(strtotime($contact["avatar-date"]) > strtotime($r[0]["avatar-date"])));
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The generation is a sign for the reliability of the provided data.
|
|
||||||
* It is used in the socgraph.php to prevent that old contact data
|
|
||||||
* that was relayed over several servers can overwrite contact
|
|
||||||
* data that we received directly.
|
|
||||||
*/
|
|
||||||
|
|
||||||
$poco["generation"] = 2;
|
|
||||||
$poco["photo"] = $author["avatar"];
|
|
||||||
$poco["hide"] = $hide;
|
|
||||||
$poco["contact-type"] = $contact["contact-type"];
|
|
||||||
$gcid = update_gcontact($poco);
|
|
||||||
|
|
||||||
link_gcontact($gcid, $importer["uid"], $contact["id"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return($author);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Transforms activity objects into an XML string
|
|
||||||
*
|
|
||||||
* @param object $xpath XPath object
|
|
||||||
* @param object $activity Activity object
|
|
||||||
* @param text $element element name
|
|
||||||
*
|
|
||||||
* @return string XML string
|
|
||||||
* @todo Find good type-hints for all parameter
|
|
||||||
*/
|
|
||||||
private static function transform_activity($xpath, $activity, $element) {
|
|
||||||
if (!is_object($activity)) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
$obj_doc = new DOMDocument("1.0", "utf-8");
|
|
||||||
$obj_doc->formatOutput = true;
|
|
||||||
|
|
||||||
$obj_element = $obj_doc->createElementNS(NAMESPACE_ATOM1, $element);
|
|
||||||
|
|
||||||
$activity_type = $xpath->query("activity:object-type/text()", $activity)->item(0)->nodeValue;
|
|
||||||
xml::add_element($obj_doc, $obj_element, "type", $activity_type);
|
|
||||||
|
|
||||||
$id = $xpath->query("atom:id", $activity)->item(0);
|
|
||||||
if (is_object($id)) {
|
|
||||||
$obj_element->appendChild($obj_doc->importNode($id, true));
|
|
||||||
}
|
|
||||||
|
|
||||||
$title = $xpath->query("atom:title", $activity)->item(0);
|
|
||||||
if (is_object($title)) {
|
|
||||||
$obj_element->appendChild($obj_doc->importNode($title, true));
|
|
||||||
}
|
|
||||||
|
|
||||||
$links = $xpath->query("atom:link", $activity);
|
|
||||||
if (is_object($links)) {
|
|
||||||
foreach ($links AS $link) {
|
|
||||||
$obj_element->appendChild($obj_doc->importNode($link, true));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$content = $xpath->query("atom:content", $activity)->item(0);
|
|
||||||
if (is_object($content)) {
|
|
||||||
$obj_element->appendChild($obj_doc->importNode($content, true));
|
|
||||||
}
|
|
||||||
|
|
||||||
$obj_doc->appendChild($obj_element);
|
|
||||||
|
|
||||||
$objxml = $obj_doc->saveXML($obj_element);
|
|
||||||
|
|
||||||
/// @todo This isn't totally clean. We should find a way to transform the namespaces
|
|
||||||
$objxml = str_replace("<".$element.' xmlns="http://www.w3.org/2005/Atom">', "<".$element.">", $objxml);
|
|
||||||
return($objxml);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes the mail elements
|
|
||||||
*
|
|
||||||
* @param object $xpath XPath object
|
|
||||||
* @param object $mail mail elements
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @todo Find good type-hints for all parameter
|
|
||||||
*/
|
|
||||||
private static function process_mail($xpath, $mail, $importer) {
|
|
||||||
|
|
||||||
logger("Processing mails");
|
|
||||||
|
|
||||||
/// @TODO Rewrite this to one statement
|
|
||||||
$msg = array();
|
|
||||||
$msg["uid"] = $importer["importer_uid"];
|
|
||||||
$msg["from-name"] = $xpath->query("dfrn:sender/dfrn:name/text()", $mail)->item(0)->nodeValue;
|
|
||||||
$msg["from-url"] = $xpath->query("dfrn:sender/dfrn:uri/text()", $mail)->item(0)->nodeValue;
|
|
||||||
$msg["from-photo"] = $xpath->query("dfrn:sender/dfrn:avatar/text()", $mail)->item(0)->nodeValue;
|
|
||||||
$msg["contact-id"] = $importer["id"];
|
|
||||||
$msg["uri"] = $xpath->query("dfrn:id/text()", $mail)->item(0)->nodeValue;
|
|
||||||
$msg["parent-uri"] = $xpath->query("dfrn:in-reply-to/text()", $mail)->item(0)->nodeValue;
|
|
||||||
$msg["created"] = $xpath->query("dfrn:sentdate/text()", $mail)->item(0)->nodeValue;
|
|
||||||
$msg["title"] = $xpath->query("dfrn:subject/text()", $mail)->item(0)->nodeValue;
|
|
||||||
$msg["body"] = $xpath->query("dfrn:content/text()", $mail)->item(0)->nodeValue;
|
|
||||||
$msg["seen"] = 0;
|
|
||||||
$msg["replied"] = 0;
|
|
||||||
|
|
||||||
dba::insert('mail', $msg);
|
|
||||||
|
|
||||||
// send notifications.
|
|
||||||
/// @TODO Arange this mess
|
|
||||||
$notif_params = array(
|
|
||||||
"type" => NOTIFY_MAIL,
|
|
||||||
"notify_flags" => $importer["notify-flags"],
|
|
||||||
"language" => $importer["language"],
|
|
||||||
"to_name" => $importer["username"],
|
|
||||||
"to_email" => $importer["email"],
|
|
||||||
"uid" => $importer["importer_uid"],
|
|
||||||
"item" => $msg,
|
|
||||||
"source_name" => $msg["from-name"],
|
|
||||||
"source_link" => $importer["url"],
|
|
||||||
"source_photo" => $importer["thumb"],
|
|
||||||
"verb" => ACTIVITY_POST,
|
|
||||||
"otype" => "mail"
|
|
||||||
);
|
|
||||||
|
|
||||||
notification($notif_params);
|
|
||||||
|
|
||||||
logger("Mail is processed, notification was sent.");
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes the suggestion elements
|
|
||||||
*
|
|
||||||
* @param object $xpath XPath object
|
|
||||||
* @param object $suggestion suggestion elements
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @todo Find good type-hints for all parameter
|
|
||||||
*/
|
|
||||||
private static function process_suggestion($xpath, $suggestion, $importer) {
|
|
||||||
$a = get_app();
|
|
||||||
|
|
||||||
logger("Processing suggestions");
|
|
||||||
|
|
||||||
/// @TODO Rewrite this to one statement
|
|
||||||
$suggest = array();
|
|
||||||
$suggest["uid"] = $importer["importer_uid"];
|
|
||||||
$suggest["cid"] = $importer["id"];
|
|
||||||
$suggest["url"] = $xpath->query("dfrn:url/text()", $suggestion)->item(0)->nodeValue;
|
|
||||||
$suggest["name"] = $xpath->query("dfrn:name/text()", $suggestion)->item(0)->nodeValue;
|
|
||||||
$suggest["photo"] = $xpath->query("dfrn:photo/text()", $suggestion)->item(0)->nodeValue;
|
|
||||||
$suggest["request"] = $xpath->query("dfrn:request/text()", $suggestion)->item(0)->nodeValue;
|
|
||||||
$suggest["body"] = $xpath->query("dfrn:note/text()", $suggestion)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
// Does our member already have a friend matching this description?
|
|
||||||
|
|
||||||
$r = q("SELECT `id` FROM `contact` WHERE `name` = '%s' AND `nurl` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
dbesc($suggest["name"]),
|
|
||||||
dbesc(normalise_link($suggest["url"])),
|
|
||||||
intval($suggest["uid"])
|
|
||||||
);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The valid result means the friend we're about to send a friend
|
|
||||||
* suggestion already has them in their contact, which means no further
|
|
||||||
* action is required.
|
|
||||||
*
|
|
||||||
* @see https://github.com/friendica/friendica/pull/3254#discussion_r107315246
|
|
||||||
*/
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Do we already have an fcontact record for this person?
|
|
||||||
|
|
||||||
$fid = 0;
|
|
||||||
$r = q("SELECT `id` FROM `fcontact` WHERE `url` = '%s' AND `name` = '%s' AND `request` = '%s' LIMIT 1",
|
|
||||||
dbesc($suggest["url"]),
|
|
||||||
dbesc($suggest["name"]),
|
|
||||||
dbesc($suggest["request"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$fid = $r[0]["id"];
|
|
||||||
|
|
||||||
// OK, we do. Do we already have an introduction for this person ?
|
|
||||||
$r = q("SELECT `id` FROM `intro` WHERE `uid` = %d AND `fid` = %d LIMIT 1",
|
|
||||||
intval($suggest["uid"]),
|
|
||||||
intval($fid)
|
|
||||||
);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The valid result means the friend we're about to send a friend
|
|
||||||
* suggestion already has them in their contact, which means no further
|
|
||||||
* action is required.
|
|
||||||
*
|
|
||||||
* @see https://github.com/friendica/friendica/pull/3254#discussion_r107315246
|
|
||||||
*/
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!$fid) {
|
|
||||||
$r = q("INSERT INTO `fcontact` (`name`,`url`,`photo`,`request`) VALUES ('%s', '%s', '%s', '%s')",
|
|
||||||
dbesc($suggest["name"]),
|
|
||||||
dbesc($suggest["url"]),
|
|
||||||
dbesc($suggest["photo"]),
|
|
||||||
dbesc($suggest["request"])
|
|
||||||
);
|
|
||||||
}
|
|
||||||
$r = q("SELECT `id` FROM `fcontact` WHERE `url` = '%s' AND `name` = '%s' AND `request` = '%s' LIMIT 1",
|
|
||||||
dbesc($suggest["url"]),
|
|
||||||
dbesc($suggest["name"]),
|
|
||||||
dbesc($suggest["request"])
|
|
||||||
);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If no record in fcontact is found, below INSERT statement will not
|
|
||||||
* link an introduction to it.
|
|
||||||
*/
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
// database record did not get created. Quietly give up.
|
|
||||||
killme();
|
|
||||||
}
|
|
||||||
|
|
||||||
$fid = $r[0]["id"];
|
|
||||||
|
|
||||||
$hash = random_string();
|
|
||||||
|
|
||||||
$r = q("INSERT INTO `intro` (`uid`, `fid`, `contact-id`, `note`, `hash`, `datetime`, `blocked`)
|
|
||||||
VALUES(%d, %d, %d, '%s', '%s', '%s', %d)",
|
|
||||||
intval($suggest["uid"]),
|
|
||||||
intval($fid),
|
|
||||||
intval($suggest["cid"]),
|
|
||||||
dbesc($suggest["body"]),
|
|
||||||
dbesc($hash),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
intval(0)
|
|
||||||
);
|
|
||||||
|
|
||||||
notification(array(
|
|
||||||
"type" => NOTIFY_SUGGEST,
|
|
||||||
"notify_flags" => $importer["notify-flags"],
|
|
||||||
"language" => $importer["language"],
|
|
||||||
"to_name" => $importer["username"],
|
|
||||||
"to_email" => $importer["email"],
|
|
||||||
"uid" => $importer["importer_uid"],
|
|
||||||
"item" => $suggest,
|
|
||||||
"link" => System::baseUrl()."/notifications/intros",
|
|
||||||
"source_name" => $importer["name"],
|
|
||||||
"source_link" => $importer["url"],
|
|
||||||
"source_photo" => $importer["photo"],
|
|
||||||
"verb" => ACTIVITY_REQ_FRIEND,
|
|
||||||
"otype" => "intro"
|
|
||||||
));
|
|
||||||
|
|
||||||
return true;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes the relocation elements
|
|
||||||
*
|
|
||||||
* @param object $xpath XPath object
|
|
||||||
* @param object $relocation relocation elements
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @todo Find good type-hints for all parameter
|
|
||||||
*/
|
|
||||||
private static function process_relocation($xpath, $relocation, $importer) {
|
|
||||||
|
|
||||||
logger("Processing relocations");
|
|
||||||
|
|
||||||
/// @TODO Rewrite this to one statement
|
|
||||||
$relocate = array();
|
|
||||||
$relocate["uid"] = $importer["importer_uid"];
|
|
||||||
$relocate["cid"] = $importer["id"];
|
|
||||||
$relocate["url"] = $xpath->query("dfrn:url/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["addr"] = $xpath->query("dfrn:addr/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["name"] = $xpath->query("dfrn:name/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["avatar"] = $xpath->query("dfrn:avatar/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["photo"] = $xpath->query("dfrn:photo/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["thumb"] = $xpath->query("dfrn:thumb/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["micro"] = $xpath->query("dfrn:micro/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["request"] = $xpath->query("dfrn:request/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["confirm"] = $xpath->query("dfrn:confirm/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["notify"] = $xpath->query("dfrn:notify/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["poll"] = $xpath->query("dfrn:poll/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
$relocate["sitepubkey"] = $xpath->query("dfrn:sitepubkey/text()", $relocation)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
if (($relocate["avatar"] == "") && ($relocate["photo"] != "")) {
|
|
||||||
$relocate["avatar"] = $relocate["photo"];
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($relocate["addr"] == "") {
|
|
||||||
$relocate["addr"] = preg_replace("=(https?://)(.*)/profile/(.*)=ism", "$3@$2", $relocate["url"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
// update contact
|
|
||||||
$r = q("SELECT `photo`, `url` FROM `contact` WHERE `id` = %d AND `uid` = %d;",
|
|
||||||
intval($importer["id"]),
|
|
||||||
intval($importer["importer_uid"]));
|
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
logger("Query failed to execute, no result returned in " . __FUNCTION__);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$old = $r[0];
|
|
||||||
|
|
||||||
// Update the gcontact entry
|
|
||||||
$relocate["server_url"] = preg_replace("=(https?://)(.*)/profile/(.*)=ism", "$1$2", $relocate["url"]);
|
|
||||||
|
|
||||||
$x = q("UPDATE `gcontact` SET
|
|
||||||
`name` = '%s',
|
|
||||||
`photo` = '%s',
|
|
||||||
`url` = '%s',
|
|
||||||
`nurl` = '%s',
|
|
||||||
`addr` = '%s',
|
|
||||||
`connect` = '%s',
|
|
||||||
`notify` = '%s',
|
|
||||||
`server_url` = '%s'
|
|
||||||
WHERE `nurl` = '%s';",
|
|
||||||
dbesc($relocate["name"]),
|
|
||||||
dbesc($relocate["avatar"]),
|
|
||||||
dbesc($relocate["url"]),
|
|
||||||
dbesc(normalise_link($relocate["url"])),
|
|
||||||
dbesc($relocate["addr"]),
|
|
||||||
dbesc($relocate["addr"]),
|
|
||||||
dbesc($relocate["notify"]),
|
|
||||||
dbesc($relocate["server_url"]),
|
|
||||||
dbesc(normalise_link($old["url"])));
|
|
||||||
|
|
||||||
// Update the contact table. We try to find every entry.
|
|
||||||
$x = q("UPDATE `contact` SET
|
|
||||||
`name` = '%s',
|
|
||||||
`avatar` = '%s',
|
|
||||||
`url` = '%s',
|
|
||||||
`nurl` = '%s',
|
|
||||||
`addr` = '%s',
|
|
||||||
`request` = '%s',
|
|
||||||
`confirm` = '%s',
|
|
||||||
`notify` = '%s',
|
|
||||||
`poll` = '%s',
|
|
||||||
`site-pubkey` = '%s'
|
|
||||||
WHERE (`id` = %d AND `uid` = %d) OR (`nurl` = '%s');",
|
|
||||||
dbesc($relocate["name"]),
|
|
||||||
dbesc($relocate["avatar"]),
|
|
||||||
dbesc($relocate["url"]),
|
|
||||||
dbesc(normalise_link($relocate["url"])),
|
|
||||||
dbesc($relocate["addr"]),
|
|
||||||
dbesc($relocate["request"]),
|
|
||||||
dbesc($relocate["confirm"]),
|
|
||||||
dbesc($relocate["notify"]),
|
|
||||||
dbesc($relocate["poll"]),
|
|
||||||
dbesc($relocate["sitepubkey"]),
|
|
||||||
intval($importer["id"]),
|
|
||||||
intval($importer["importer_uid"]),
|
|
||||||
dbesc(normalise_link($old["url"])));
|
|
||||||
|
|
||||||
update_contact_avatar($relocate["avatar"], $importer["importer_uid"], $importer["id"], true);
|
|
||||||
|
|
||||||
if ($x === false) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// update items
|
|
||||||
/// @todo This is an extreme performance killer
|
|
||||||
$fields = array(
|
|
||||||
'owner-link' => array($old["url"], $relocate["url"]),
|
|
||||||
'author-link' => array($old["url"], $relocate["url"]),
|
|
||||||
//'owner-avatar' => array($old["photo"], $relocate["photo"]),
|
|
||||||
//'author-avatar' => array($old["photo"], $relocate["photo"]),
|
|
||||||
);
|
|
||||||
foreach ($fields as $n=>$f) {
|
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `%s` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
$n, dbesc($f[0]),
|
|
||||||
intval($importer["importer_uid"]));
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$x = q("UPDATE `item` SET `%s` = '%s' WHERE `%s` = '%s' AND `uid` = %d",
|
|
||||||
$n, dbesc($f[1]),
|
|
||||||
$n, dbesc($f[0]),
|
|
||||||
intval($importer["importer_uid"]));
|
|
||||||
|
|
||||||
if ($x === false) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @TODO
|
|
||||||
/// merge with current record, current contents have priority
|
|
||||||
/// update record, set url-updated
|
|
||||||
/// update profile photos
|
|
||||||
/// schedule a scan?
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Updates an item
|
|
||||||
*
|
|
||||||
* @param array $current the current item record
|
|
||||||
* @param array $item the new item record
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @param int $entrytype Is it a toplevel entry, a comment or a relayed comment?
|
|
||||||
* @todo set proper type-hints (array?)
|
|
||||||
*/
|
|
||||||
private static function update_content($current, $item, $importer, $entrytype) {
|
|
||||||
$changed = false;
|
|
||||||
|
|
||||||
if (edited_timestamp_is_newer($current, $item)) {
|
|
||||||
|
|
||||||
// do not accept (ignore) an earlier edit than one we currently have.
|
|
||||||
if (datetime_convert("UTC","UTC",$item["edited"]) < $current["edited"]) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$fields = array('title' => $item["title"], 'body' => $item["body"],
|
|
||||||
'tag' => $item["tag"], 'changed' => datetime_convert(),
|
|
||||||
'edited' => datetime_convert("UTC", "UTC", $item["edited"]));
|
|
||||||
|
|
||||||
$condition = array("`uri` = ? AND `uid` IN (0, ?)", $item["uri"], $importer["importer_uid"]);
|
|
||||||
dba::update('item', $fields, $condition);
|
|
||||||
|
|
||||||
create_tags_from_itemuri($item["uri"], $importer["importer_uid"]);
|
|
||||||
update_thread_uri($item["uri"], $importer["importer_uid"]);
|
|
||||||
|
|
||||||
$changed = true;
|
|
||||||
|
|
||||||
if ($entrytype == DFRN_REPLY_RC) {
|
|
||||||
Worker::add(PRIORITY_HIGH, "notifier","comment-import", $current["id"]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// update last-child if it changes
|
|
||||||
if ($item["last-child"] && ($item["last-child"] != $current["last-child"])) {
|
|
||||||
$r = q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` IN (0, %d)",
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc($item["parent-uri"]),
|
|
||||||
intval($importer["importer_uid"])
|
|
||||||
);
|
|
||||||
$r = q("UPDATE `item` SET `last-child` = %d , `changed` = '%s' WHERE `uri` = '%s' AND `uid` IN (0, %d)",
|
|
||||||
intval($item["last-child"]),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc($item["uri"]),
|
|
||||||
intval($importer["importer_uid"])
|
|
||||||
);
|
|
||||||
}
|
|
||||||
return $changed;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Detects the entry type of the item
|
|
||||||
*
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @param array $item the new item record
|
|
||||||
*
|
|
||||||
* @return int Is it a toplevel entry, a comment or a relayed comment?
|
|
||||||
* @todo set proper type-hints (array?)
|
|
||||||
*/
|
|
||||||
private static function get_entry_type($importer, $item) {
|
|
||||||
if ($item["parent-uri"] != $item["uri"]) {
|
|
||||||
$community = false;
|
|
||||||
|
|
||||||
if ($importer["page-flags"] == PAGE_COMMUNITY || $importer["page-flags"] == PAGE_PRVGROUP) {
|
|
||||||
$sql_extra = "";
|
|
||||||
$community = true;
|
|
||||||
logger("possible community action");
|
|
||||||
} else {
|
|
||||||
$sql_extra = " AND `contact`.`self` AND `item`.`wall` ";
|
|
||||||
}
|
|
||||||
|
|
||||||
// was the top-level post for this action written by somebody on this site?
|
|
||||||
// Specifically, the recipient?
|
|
||||||
|
|
||||||
$is_a_remote_action = false;
|
|
||||||
|
|
||||||
$r = q("SELECT `item`.`parent-uri` FROM `item`
|
|
||||||
WHERE `item`.`uri` = '%s'
|
|
||||||
LIMIT 1",
|
|
||||||
dbesc($item["parent-uri"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$r = q("SELECT `item`.`forum_mode`, `item`.`wall` FROM `item`
|
|
||||||
INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id`
|
|
||||||
WHERE `item`.`uri` = '%s' AND (`item`.`parent-uri` = '%s' OR `item`.`thr-parent` = '%s')
|
|
||||||
AND `item`.`uid` = %d
|
|
||||||
$sql_extra
|
|
||||||
LIMIT 1",
|
|
||||||
dbesc($r[0]["parent-uri"]),
|
|
||||||
dbesc($r[0]["parent-uri"]),
|
|
||||||
dbesc($r[0]["parent-uri"]),
|
|
||||||
intval($importer["importer_uid"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$is_a_remote_action = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Does this have the characteristics of a community or private group action?
|
|
||||||
* If it's an action to a wall post on a community/prvgroup page it's a
|
|
||||||
* valid community action. Also forum_mode makes it valid for sure.
|
|
||||||
* If neither, it's not.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/// @TODO Maybe merge these if() blocks into one?
|
|
||||||
if ($is_a_remote_action && $community && (!$r[0]["forum_mode"]) && (!$r[0]["wall"])) {
|
|
||||||
$is_a_remote_action = false;
|
|
||||||
logger("not a community action");
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($is_a_remote_action) {
|
|
||||||
return DFRN_REPLY_RC;
|
|
||||||
} else {
|
|
||||||
return DFRN_REPLY;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return DFRN_TOP_LEVEL;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Send a "poke"
|
|
||||||
*
|
|
||||||
* @param array $item the new item record
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @param int $posted_id The record number of item record that was just posted
|
|
||||||
* @todo set proper type-hints (array?)
|
|
||||||
*/
|
|
||||||
private static function do_poke($item, $importer, $posted_id) {
|
|
||||||
$verb = urldecode(substr($item["verb"],strpos($item["verb"], "#")+1));
|
|
||||||
if (!$verb) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
$xo = parse_xml_string($item["object"],false);
|
|
||||||
|
|
||||||
if (($xo->type == ACTIVITY_OBJ_PERSON) && ($xo->id)) {
|
|
||||||
|
|
||||||
// somebody was poked/prodded. Was it me?
|
|
||||||
foreach ($xo->link as $l) {
|
|
||||||
$atts = $l->attributes();
|
|
||||||
switch ($atts["rel"]) {
|
|
||||||
case "alternate":
|
|
||||||
$Blink = $atts["href"];
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($Blink && link_compare($Blink, System::baseUrl() . "/profile/" . $importer["nickname"])) {
|
|
||||||
|
|
||||||
// send a notification
|
|
||||||
notification(array(
|
|
||||||
"type" => NOTIFY_POKE,
|
|
||||||
"notify_flags" => $importer["notify-flags"],
|
|
||||||
"language" => $importer["language"],
|
|
||||||
"to_name" => $importer["username"],
|
|
||||||
"to_email" => $importer["email"],
|
|
||||||
"uid" => $importer["importer_uid"],
|
|
||||||
"item" => $item,
|
|
||||||
"link" => System::baseUrl()."/display/".urlencode(get_item_guid($posted_id)),
|
|
||||||
"source_name" => stripslashes($item["author-name"]),
|
|
||||||
"source_link" => $item["author-link"],
|
|
||||||
"source_photo" => ((link_compare($item["author-link"],$importer["url"]))
|
|
||||||
? $importer["thumb"] : $item["author-avatar"]),
|
|
||||||
"verb" => $item["verb"],
|
|
||||||
"otype" => "person",
|
|
||||||
"activity" => $verb,
|
|
||||||
"parent" => $item["parent"]
|
|
||||||
));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes several actions, depending on the verb
|
|
||||||
*
|
|
||||||
* @param int $entrytype Is it a toplevel entry, a comment or a relayed comment?
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @param array $item the new item record
|
|
||||||
* @param bool $is_like Is the verb a "like"?
|
|
||||||
*
|
|
||||||
* @return bool Should the processing of the entries be continued?
|
|
||||||
* @todo set proper type-hints (array?)
|
|
||||||
*/
|
|
||||||
private static function process_verbs($entrytype, $importer, &$item, &$is_like) {
|
|
||||||
|
|
||||||
logger("Process verb ".$item["verb"]." and object-type ".$item["object-type"]." for entrytype ".$entrytype, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
if (($entrytype == DFRN_TOP_LEVEL)) {
|
|
||||||
// The filling of the the "contact" variable is done for legcy reasons
|
|
||||||
// The functions below are partly used by ostatus.php as well - where we have this variable
|
|
||||||
$r = q("SELECT * FROM `contact` WHERE `id` = %d", intval($importer["id"]));
|
|
||||||
$contact = $r[0];
|
|
||||||
$nickname = $contact["nick"];
|
|
||||||
|
|
||||||
// Big question: Do we need these functions? They were part of the "consume_feed" function.
|
|
||||||
// This function once was responsible for DFRN and OStatus.
|
|
||||||
if (activity_match($item["verb"], ACTIVITY_FOLLOW)) {
|
|
||||||
logger("New follower");
|
|
||||||
new_follower($importer, $contact, $item, $nickname);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (activity_match($item["verb"], ACTIVITY_UNFOLLOW)) {
|
|
||||||
logger("Lost follower");
|
|
||||||
lose_follower($importer, $contact, $item);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (activity_match($item["verb"], ACTIVITY_REQ_FRIEND)) {
|
|
||||||
logger("New friend request");
|
|
||||||
new_follower($importer, $contact, $item, $nickname, true);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (activity_match($item["verb"], ACTIVITY_UNFRIEND)) {
|
|
||||||
logger("Lost sharer");
|
|
||||||
lose_sharer($importer, $contact, $item);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (($item["verb"] == ACTIVITY_LIKE)
|
|
||||||
|| ($item["verb"] == ACTIVITY_DISLIKE)
|
|
||||||
|| ($item["verb"] == ACTIVITY_ATTEND)
|
|
||||||
|| ($item["verb"] == ACTIVITY_ATTENDNO)
|
|
||||||
|| ($item["verb"] == ACTIVITY_ATTENDMAYBE)) {
|
|
||||||
$is_like = true;
|
|
||||||
$item["type"] = "activity";
|
|
||||||
$item["gravity"] = GRAVITY_LIKE;
|
|
||||||
// only one like or dislike per person
|
|
||||||
// splitted into two queries for performance issues
|
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `uid` = %d AND `author-link` = '%s' AND `verb` = '%s' AND `parent-uri` = '%s' AND NOT `deleted` LIMIT 1",
|
|
||||||
intval($item["uid"]),
|
|
||||||
dbesc($item["author-link"]),
|
|
||||||
dbesc($item["verb"]),
|
|
||||||
dbesc($item["parent-uri"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `uid` = %d AND `author-link` = '%s' AND `verb` = '%s' AND `thr-parent` = '%s' AND NOT `deleted` LIMIT 1",
|
|
||||||
intval($item["uid"]),
|
|
||||||
dbesc($item["author-link"]),
|
|
||||||
dbesc($item["verb"]),
|
|
||||||
dbesc($item["parent-uri"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$is_like = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($item["verb"] == ACTIVITY_TAG) && ($item["object-type"] == ACTIVITY_OBJ_TAGTERM)) {
|
|
||||||
|
|
||||||
$xo = parse_xml_string($item["object"],false);
|
|
||||||
$xt = parse_xml_string($item["target"],false);
|
|
||||||
|
|
||||||
if ($xt->type == ACTIVITY_OBJ_NOTE) {
|
|
||||||
$r = q("SELECT `id`, `tag` FROM `item` WHERE `uri` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
dbesc($xt->id),
|
|
||||||
intval($importer["importer_uid"])
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
logger("Query failed to execute, no result returned in " . __FUNCTION__);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// extract tag, if not duplicate, add to parent item
|
|
||||||
if ($xo->content) {
|
|
||||||
if (!(stristr($r[0]["tag"],trim($xo->content)))) {
|
|
||||||
q("UPDATE `item` SET `tag` = '%s' WHERE `id` = %d",
|
|
||||||
dbesc($r[0]["tag"] . (strlen($r[0]["tag"]) ? ',' : '') . '#[url=' . $xo->id . ']'. $xo->content . '[/url]'),
|
|
||||||
intval($r[0]["id"])
|
|
||||||
);
|
|
||||||
create_tags_from_item($r[0]["id"]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes the link elements
|
|
||||||
*
|
|
||||||
* @param object $links link elements
|
|
||||||
* @param array $item the item record
|
|
||||||
* @todo set proper type-hints
|
|
||||||
*/
|
|
||||||
private static function parse_links($links, &$item) {
|
|
||||||
$rel = "";
|
|
||||||
$href = "";
|
|
||||||
$type = "";
|
|
||||||
$length = "0";
|
|
||||||
$title = "";
|
|
||||||
foreach ($links AS $link) {
|
|
||||||
foreach ($link->attributes AS $attributes) {
|
|
||||||
/// @TODO Rewrite these repeated (same) if () statements to a switch()
|
|
||||||
if ($attributes->name == "href") {
|
|
||||||
$href = $attributes->textContent;
|
|
||||||
}
|
|
||||||
if ($attributes->name == "rel") {
|
|
||||||
$rel = $attributes->textContent;
|
|
||||||
}
|
|
||||||
if ($attributes->name == "type") {
|
|
||||||
$type = $attributes->textContent;
|
|
||||||
}
|
|
||||||
if ($attributes->name == "length") {
|
|
||||||
$length = $attributes->textContent;
|
|
||||||
}
|
|
||||||
if ($attributes->name == "title") {
|
|
||||||
$title = $attributes->textContent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (($rel != "") && ($href != "")) {
|
|
||||||
switch ($rel) {
|
|
||||||
case "alternate":
|
|
||||||
$item["plink"] = $href;
|
|
||||||
break;
|
|
||||||
case "enclosure":
|
|
||||||
$enclosure = $href;
|
|
||||||
if (strlen($item["attach"])) {
|
|
||||||
$item["attach"] .= ",";
|
|
||||||
}
|
|
||||||
|
|
||||||
$item["attach"] .= '[attach]href="' . $href . '" length="' . $length . '" type="' . $type . '" title="' . $title . '"[/attach]';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes the entry elements which contain the items and comments
|
|
||||||
*
|
|
||||||
* @param array $header Array of the header elements that always stay the same
|
|
||||||
* @param object $xpath XPath object
|
|
||||||
* @param object $entry entry elements
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @todo Add type-hints
|
|
||||||
*/
|
|
||||||
private static function process_entry($header, $xpath, $entry, $importer, $xml) {
|
|
||||||
|
|
||||||
logger("Processing entries");
|
|
||||||
|
|
||||||
$item = $header;
|
|
||||||
|
|
||||||
$item["protocol"] = PROTOCOL_DFRN;
|
|
||||||
|
|
||||||
$item["source"] = $xml;
|
|
||||||
|
|
||||||
// Get the uri
|
|
||||||
$item["uri"] = $xpath->query("atom:id/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
$item["edited"] = $xpath->query("atom:updated/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
$current = q("SELECT `id`, `uid`, `last-child`, `edited`, `body` FROM `item` WHERE `uri` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
dbesc($item["uri"]),
|
|
||||||
intval($importer["importer_uid"])
|
|
||||||
);
|
|
||||||
|
|
||||||
// Is there an existing item?
|
|
||||||
if (dbm::is_result($current) && edited_timestamp_is_newer($current[0], $item) &&
|
|
||||||
(datetime_convert("UTC","UTC",$item["edited"]) < $current[0]["edited"])) {
|
|
||||||
logger("Item ".$item["uri"]." already existed.", LOGGER_DEBUG);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fetch the owner
|
|
||||||
$owner = self::fetchauthor($xpath, $entry, $importer, "dfrn:owner", true);
|
|
||||||
|
|
||||||
$item["owner-name"] = $owner["name"];
|
|
||||||
$item["owner-link"] = $owner["link"];
|
|
||||||
$item["owner-avatar"] = $owner["avatar"];
|
|
||||||
|
|
||||||
// fetch the author
|
|
||||||
$author = self::fetchauthor($xpath, $entry, $importer, "atom:author", true);
|
|
||||||
|
|
||||||
$item["author-name"] = $author["name"];
|
|
||||||
$item["author-link"] = $author["link"];
|
|
||||||
$item["author-avatar"] = $author["avatar"];
|
|
||||||
|
|
||||||
$item["title"] = $xpath->query("atom:title/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
$item["created"] = $xpath->query("atom:published/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
$item["body"] = $xpath->query("dfrn:env/text()", $entry)->item(0)->nodeValue;
|
|
||||||
$item["body"] = str_replace(array(' ',"\t","\r","\n"), array('','','',''),$item["body"]);
|
|
||||||
// make sure nobody is trying to sneak some html tags by us
|
|
||||||
$item["body"] = notags(base64url_decode($item["body"]));
|
|
||||||
|
|
||||||
$item["body"] = limit_body_size($item["body"]);
|
|
||||||
|
|
||||||
/// @todo Do we really need this check for HTML elements? (It was copied from the old function)
|
|
||||||
if ((strpos($item['body'],'<') !== false) && (strpos($item['body'],'>') !== false)) {
|
|
||||||
|
|
||||||
$item['body'] = reltoabs($item['body'],$base_url);
|
|
||||||
|
|
||||||
$item['body'] = html2bb_video($item['body']);
|
|
||||||
|
|
||||||
$item['body'] = oembed_html2bbcode($item['body']);
|
|
||||||
|
|
||||||
$config = HTMLPurifier_Config::createDefault();
|
|
||||||
$config->set('Cache.DefinitionImpl', null);
|
|
||||||
|
|
||||||
// we shouldn't need a whitelist, because the bbcode converter
|
|
||||||
// will strip out any unsupported tags.
|
|
||||||
|
|
||||||
$purifier = new HTMLPurifier($config);
|
|
||||||
$item['body'] = $purifier->purify($item['body']);
|
|
||||||
|
|
||||||
$item['body'] = @html2bbcode($item['body']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @todo We should check for a repeated post and if we know the repeated author.
|
|
||||||
|
|
||||||
// We don't need the content element since "dfrn:env" is always present
|
|
||||||
//$item["body"] = $xpath->query("atom:content/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
$item["last-child"] = $xpath->query("dfrn:comment-allow/text()", $entry)->item(0)->nodeValue;
|
|
||||||
$item["location"] = $xpath->query("dfrn:location/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
$georsspoint = $xpath->query("georss:point", $entry);
|
|
||||||
if ($georsspoint) {
|
|
||||||
$item["coord"] = $georsspoint->item(0)->nodeValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
$item["private"] = $xpath->query("dfrn:private/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
$item["extid"] = $xpath->query("dfrn:extid/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
if ($xpath->query("dfrn:bookmark/text()", $entry)->item(0)->nodeValue == "true") {
|
|
||||||
$item["bookmark"] = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$notice_info = $xpath->query("statusnet:notice_info", $entry);
|
|
||||||
if ($notice_info && ($notice_info->length > 0)) {
|
|
||||||
foreach ($notice_info->item(0)->attributes AS $attributes) {
|
|
||||||
if ($attributes->name == "source") {
|
|
||||||
$item["app"] = strip_tags($attributes->textContent);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$item["guid"] = $xpath->query("dfrn:diaspora_guid/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
// We store the data from "dfrn:diaspora_signature" in a different table, this is done in "item_store"
|
|
||||||
$dsprsig = unxmlify($xpath->query("dfrn:diaspora_signature/text()", $entry)->item(0)->nodeValue);
|
|
||||||
if ($dsprsig != "") {
|
|
||||||
$item["dsprsig"] = $dsprsig;
|
|
||||||
}
|
|
||||||
|
|
||||||
$item["verb"] = $xpath->query("activity:verb/text()", $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
if ($xpath->query("activity:object-type/text()", $entry)->item(0)->nodeValue != "") {
|
|
||||||
$item["object-type"] = $xpath->query("activity:object-type/text()", $entry)->item(0)->nodeValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
$object = $xpath->query("activity:object", $entry)->item(0);
|
|
||||||
$item["object"] = self::transform_activity($xpath, $object, "object");
|
|
||||||
|
|
||||||
if (trim($item["object"]) != "") {
|
|
||||||
$r = parse_xml_string($item["object"], false);
|
|
||||||
if (isset($r->type)) {
|
|
||||||
$item["object-type"] = $r->type;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$target = $xpath->query("activity:target", $entry)->item(0);
|
|
||||||
$item["target"] = self::transform_activity($xpath, $target, "target");
|
|
||||||
|
|
||||||
$categories = $xpath->query("atom:category", $entry);
|
|
||||||
if ($categories) {
|
|
||||||
foreach ($categories AS $category) {
|
|
||||||
$term = "";
|
|
||||||
$scheme = "";
|
|
||||||
foreach ($category->attributes AS $attributes) {
|
|
||||||
if ($attributes->name == "term") {
|
|
||||||
$term = $attributes->textContent;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($attributes->name == "scheme") {
|
|
||||||
$scheme = $attributes->textContent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($term != "") && ($scheme != "")) {
|
|
||||||
$parts = explode(":", $scheme);
|
|
||||||
if ((count($parts) >= 4) && (array_shift($parts) == "X-DFRN")) {
|
|
||||||
$termhash = array_shift($parts);
|
|
||||||
$termurl = implode(":", $parts);
|
|
||||||
|
|
||||||
if (strlen($item["tag"])) {
|
|
||||||
$item["tag"] .= ",";
|
|
||||||
}
|
|
||||||
|
|
||||||
$item["tag"] .= $termhash . "[url=" . $termurl . "]" . $term . "[/url]";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$enclosure = "";
|
|
||||||
|
|
||||||
$links = $xpath->query("atom:link", $entry);
|
|
||||||
if ($links) {
|
|
||||||
self::parse_links($links, $item);
|
|
||||||
}
|
|
||||||
|
|
||||||
$item['conversation-uri'] = $xpath->query('ostatus:conversation/text()', $entry)->item(0)->nodeValue;
|
|
||||||
|
|
||||||
$conv = $xpath->query('ostatus:conversation', $entry);
|
|
||||||
if (is_object($conv->item(0))) {
|
|
||||||
foreach ($conv->item(0)->attributes AS $attributes) {
|
|
||||||
if ($attributes->name == "ref") {
|
|
||||||
$item['conversation-uri'] = $attributes->textContent;
|
|
||||||
}
|
|
||||||
if ($attributes->name == "href") {
|
|
||||||
$item['conversation-href'] = $attributes->textContent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Is it a reply or a top level posting?
|
|
||||||
$item["parent-uri"] = $item["uri"];
|
|
||||||
|
|
||||||
$inreplyto = $xpath->query("thr:in-reply-to", $entry);
|
|
||||||
if (is_object($inreplyto->item(0))) {
|
|
||||||
foreach ($inreplyto->item(0)->attributes AS $attributes) {
|
|
||||||
if ($attributes->name == "ref") {
|
|
||||||
$item["parent-uri"] = $attributes->textContent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get the type of the item (Top level post, reply or remote reply)
|
|
||||||
$entrytype = self::get_entry_type($importer, $item);
|
|
||||||
|
|
||||||
// Now assign the rest of the values that depend on the type of the message
|
|
||||||
if (in_array($entrytype, array(DFRN_REPLY, DFRN_REPLY_RC))) {
|
|
||||||
if (!isset($item["object-type"])) {
|
|
||||||
$item["object-type"] = ACTIVITY_OBJ_COMMENT;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item["contact-id"] != $owner["contact-id"]) {
|
|
||||||
$item["contact-id"] = $owner["contact-id"];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($item["network"] != $owner["network"]) && ($owner["network"] != "")) {
|
|
||||||
$item["network"] = $owner["network"];
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item["contact-id"] != $author["contact-id"]) {
|
|
||||||
$item["contact-id"] = $author["contact-id"];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($item["network"] != $author["network"]) && ($author["network"] != "")) {
|
|
||||||
$item["network"] = $author["network"];
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @TODO maybe remove this old-lost code then?
|
|
||||||
// This code was taken from the old DFRN code
|
|
||||||
// When activated, forums don't work.
|
|
||||||
// And: Why should we disallow commenting by followers?
|
|
||||||
// the behaviour is now similar to the Diaspora part.
|
|
||||||
//if ($importer["rel"] == CONTACT_IS_FOLLOWER) {
|
|
||||||
// logger("Contact ".$importer["id"]." is only follower. Quitting", LOGGER_DEBUG);
|
|
||||||
// return;
|
|
||||||
//}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($entrytype == DFRN_REPLY_RC) {
|
|
||||||
$item["type"] = "remote-comment";
|
|
||||||
$item["wall"] = 1;
|
|
||||||
} elseif ($entrytype == DFRN_TOP_LEVEL) {
|
|
||||||
if (!isset($item["object-type"])) {
|
|
||||||
$item["object-type"] = ACTIVITY_OBJ_NOTE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Is it an event?
|
|
||||||
if ($item["object-type"] == ACTIVITY_OBJ_EVENT) {
|
|
||||||
logger("Item ".$item["uri"]." seems to contain an event.", LOGGER_DEBUG);
|
|
||||||
$ev = bbtoevent($item["body"]);
|
|
||||||
if ((x($ev, "desc") || x($ev, "summary")) && x($ev, "start")) {
|
|
||||||
logger("Event in item ".$item["uri"]." was found.", LOGGER_DEBUG);
|
|
||||||
/// @TODO Mixure of "/' ahead ...
|
|
||||||
$ev["cid"] = $importer["id"];
|
|
||||||
$ev["uid"] = $importer["uid"];
|
|
||||||
$ev["uri"] = $item["uri"];
|
|
||||||
$ev["edited"] = $item["edited"];
|
|
||||||
$ev['private'] = $item['private'];
|
|
||||||
$ev["guid"] = $item["guid"];
|
|
||||||
|
|
||||||
$r = q("SELECT `id` FROM `event` WHERE `uri` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
dbesc($item["uri"]),
|
|
||||||
intval($importer["uid"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$ev["id"] = $r[0]["id"];
|
|
||||||
}
|
|
||||||
|
|
||||||
$event_id = event_store($ev);
|
|
||||||
logger("Event ".$event_id." was stored", LOGGER_DEBUG);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!self::process_verbs($entrytype, $importer, $item, $is_like)) {
|
|
||||||
logger("Exiting because 'process_verbs' told us so", LOGGER_DEBUG);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update content if 'updated' changes
|
|
||||||
if (dbm::is_result($current)) {
|
|
||||||
if (self::update_content($r[0], $item, $importer, $entrytype)) {
|
|
||||||
logger("Item ".$item["uri"]." was updated.", LOGGER_DEBUG);
|
|
||||||
} else {
|
|
||||||
logger("Item ".$item["uri"]." already existed.", LOGGER_DEBUG);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (in_array($entrytype, array(DFRN_REPLY, DFRN_REPLY_RC))) {
|
|
||||||
$posted_id = item_store($item);
|
|
||||||
$parent = 0;
|
|
||||||
|
|
||||||
if ($posted_id) {
|
|
||||||
|
|
||||||
logger("Reply from contact ".$item["contact-id"]." was stored with id ".$posted_id, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$item["id"] = $posted_id;
|
|
||||||
|
|
||||||
$r = q("SELECT `parent`, `parent-uri` FROM `item` WHERE `id` = %d AND `uid` = %d LIMIT 1",
|
|
||||||
intval($posted_id),
|
|
||||||
intval($importer["importer_uid"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$parent = $r[0]["parent"];
|
|
||||||
$parent_uri = $r[0]["parent-uri"];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$is_like) {
|
|
||||||
$r1 = q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `uid` = %d AND `parent` = %d",
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
intval($importer["importer_uid"]),
|
|
||||||
intval($r[0]["parent"])
|
|
||||||
);
|
|
||||||
|
|
||||||
$r2 = q("UPDATE `item` SET `last-child` = 1, `changed` = '%s' WHERE `uid` = %d AND `id` = %d",
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
intval($importer["importer_uid"]),
|
|
||||||
intval($posted_id)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($posted_id && $parent && ($entrytype == DFRN_REPLY_RC)) {
|
|
||||||
logger("Notifying followers about comment ".$posted_id, LOGGER_DEBUG);
|
|
||||||
Worker::add(PRIORITY_HIGH, "notifier", "comment-import", $posted_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
} else { // $entrytype == DFRN_TOP_LEVEL
|
|
||||||
if (!link_compare($item["owner-link"],$importer["url"])) {
|
|
||||||
/*
|
|
||||||
* The item owner info is not our contact. It's OK and is to be expected if this is a tgroup delivery,
|
|
||||||
* but otherwise there's a possible data mixup on the sender's system.
|
|
||||||
* the tgroup delivery code called from item_store will correct it if it's a forum,
|
|
||||||
* but we're going to unconditionally correct it here so that the post will always be owned by our contact.
|
|
||||||
*/
|
|
||||||
logger('Correcting item owner.', LOGGER_DEBUG);
|
|
||||||
$item["owner-name"] = $importer["senderName"];
|
|
||||||
$item["owner-link"] = $importer["url"];
|
|
||||||
$item["owner-avatar"] = $importer["thumb"];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($importer["rel"] == CONTACT_IS_FOLLOWER) && (!tgroup_check($importer["importer_uid"], $item))) {
|
|
||||||
logger("Contact ".$importer["id"]." is only follower and tgroup check was negative.", LOGGER_DEBUG);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// This is my contact on another system, but it's really me.
|
|
||||||
// Turn this into a wall post.
|
|
||||||
$notify = item_is_remote_self($importer, $item);
|
|
||||||
|
|
||||||
$posted_id = item_store($item, false, $notify);
|
|
||||||
|
|
||||||
logger("Item was stored with id ".$posted_id, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
if (stristr($item["verb"],ACTIVITY_POKE))
|
|
||||||
self::do_poke($item, $importer, $posted_id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Deletes items
|
|
||||||
*
|
|
||||||
* @param object $xpath XPath object
|
|
||||||
* @param object $deletion deletion elements
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @todo set proper type-hints
|
|
||||||
*/
|
|
||||||
private static function process_deletion($xpath, $deletion, $importer) {
|
|
||||||
|
|
||||||
logger("Processing deletions");
|
|
||||||
|
|
||||||
foreach ($deletion->attributes AS $attributes) {
|
|
||||||
if ($attributes->name == "ref") {
|
|
||||||
$uri = $attributes->textContent;
|
|
||||||
}
|
|
||||||
if ($attributes->name == "when") {
|
|
||||||
$when = $attributes->textContent;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($when) {
|
|
||||||
$when = datetime_convert("UTC", "UTC", $when, "Y-m-d H:i:s");
|
|
||||||
} else {
|
|
||||||
$when = datetime_convert("UTC", "UTC", "now", "Y-m-d H:i:s");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$uri || !$importer["id"]) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @todo Only select the used fields
|
|
||||||
$r = q("SELECT `item`.*, `contact`.`self` FROM `item` INNER JOIN `contact` on `item`.`contact-id` = `contact`.`id`
|
|
||||||
WHERE `uri` = '%s' AND `item`.`uid` = %d AND `contact-id` = %d AND NOT `item`.`file` LIKE '%%[%%' LIMIT 1",
|
|
||||||
dbesc($uri),
|
|
||||||
intval($importer["uid"]),
|
|
||||||
intval($importer["id"])
|
|
||||||
);
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
logger("Item with uri " . $uri . " from contact " . $importer["id"] . " for user " . $importer["uid"] . " wasn't found.", LOGGER_DEBUG);
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
|
|
||||||
$item = $r[0];
|
|
||||||
|
|
||||||
$entrytype = self::get_entry_type($importer, $item);
|
|
||||||
|
|
||||||
if (!$item["deleted"]) {
|
|
||||||
logger('deleting item '.$item["id"].' uri='.$uri, LOGGER_DEBUG);
|
|
||||||
} else {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item["object-type"] == ACTIVITY_OBJ_EVENT) {
|
|
||||||
logger("Deleting event ".$item["event-id"], LOGGER_DEBUG);
|
|
||||||
event_delete($item["event-id"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($item["verb"] == ACTIVITY_TAG) && ($item["object-type"] == ACTIVITY_OBJ_TAGTERM)) {
|
|
||||||
|
|
||||||
$xo = parse_xml_string($item["object"],false);
|
|
||||||
$xt = parse_xml_string($item["target"],false);
|
|
||||||
|
|
||||||
if ($xt->type == ACTIVITY_OBJ_NOTE) {
|
|
||||||
$i = q("SELECT `id`, `contact-id`, `tag` FROM `item` WHERE `uri` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
dbesc($xt->id),
|
|
||||||
intval($importer["importer_uid"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($i)) {
|
|
||||||
|
|
||||||
// For tags, the owner cannot remove the tag on the author's copy of the post.
|
|
||||||
|
|
||||||
$owner_remove = (($item["contact-id"] == $i[0]["contact-id"]) ? true: false);
|
|
||||||
$author_remove = (($item["origin"] && $item["self"]) ? true : false);
|
|
||||||
$author_copy = (($item["origin"]) ? true : false);
|
|
||||||
|
|
||||||
if ($owner_remove && $author_copy) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if ($author_remove || $owner_remove) {
|
|
||||||
$tags = explode(',',$i[0]["tag"]);
|
|
||||||
$newtags = array();
|
|
||||||
if (count($tags)) {
|
|
||||||
foreach ($tags as $tag) {
|
|
||||||
if (trim($tag) !== trim($xo->body)) {
|
|
||||||
$newtags[] = trim($tag);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
q("UPDATE `item` SET `tag` = '%s' WHERE `id` = %d",
|
|
||||||
dbesc(implode(',', $newtags)),
|
|
||||||
intval($i[0]["id"])
|
|
||||||
);
|
|
||||||
create_tags_from_item($i[0]["id"]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($entrytype == DFRN_TOP_LEVEL) {
|
|
||||||
$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s',
|
|
||||||
`body` = '', `title` = ''
|
|
||||||
WHERE `parent-uri` = '%s' AND `uid` IN (0, %d)",
|
|
||||||
dbesc($when),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc($uri),
|
|
||||||
intval($importer["uid"])
|
|
||||||
);
|
|
||||||
create_tags_from_itemuri($uri, $importer["uid"]);
|
|
||||||
create_files_from_itemuri($uri, $importer["uid"]);
|
|
||||||
update_thread_uri($uri, $importer["uid"]);
|
|
||||||
} else {
|
|
||||||
$r = q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s',
|
|
||||||
`body` = '', `title` = ''
|
|
||||||
WHERE `uri` = '%s' AND `uid` IN (0, %d)",
|
|
||||||
dbesc($when),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc($uri),
|
|
||||||
intval($importer["uid"])
|
|
||||||
);
|
|
||||||
create_tags_from_itemuri($uri, $importer["uid"]);
|
|
||||||
create_files_from_itemuri($uri, $importer["uid"]);
|
|
||||||
update_thread_uri($uri, $importer["importer_uid"]);
|
|
||||||
if ($item["last-child"]) {
|
|
||||||
// ensure that last-child is set in case the comment that had it just got wiped.
|
|
||||||
q("UPDATE `item` SET `last-child` = 0, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` IN (0, %d)",
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc($item["parent-uri"]),
|
|
||||||
intval($item["uid"])
|
|
||||||
);
|
|
||||||
// who is the last child now?
|
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `parent-uri` = '%s' AND `type` != 'activity' AND `deleted` = 0 AND `moderated` = 0 AND `uid` = %d
|
|
||||||
ORDER BY `created` DESC LIMIT 1",
|
|
||||||
dbesc($item["parent-uri"]),
|
|
||||||
intval($importer["uid"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
q("UPDATE `item` SET `last-child` = 1 WHERE `id` = %d",
|
|
||||||
intval($r[0]["id"])
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// if this is a relayed delete, propagate it to other recipients
|
|
||||||
|
|
||||||
if ($entrytype == DFRN_REPLY_RC) {
|
|
||||||
logger("Notifying followers about deletion of post " . $item["id"], LOGGER_DEBUG);
|
|
||||||
Worker::add(PRIORITY_HIGH, "notifier","drop", $item["id"]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Imports a DFRN message
|
|
||||||
*
|
|
||||||
* @param text $xml The DFRN message
|
|
||||||
* @param array $importer Record of the importer user mixed with contact of the content
|
|
||||||
* @param bool $sort_by_date Is used when feeds are polled
|
|
||||||
* @return integer Import status
|
|
||||||
* @todo set proper type-hints
|
|
||||||
*/
|
|
||||||
public static function import($xml, $importer, $sort_by_date = false) {
|
|
||||||
|
|
||||||
if ($xml == "") {
|
|
||||||
return 400;
|
|
||||||
}
|
|
||||||
|
|
||||||
$doc = new DOMDocument();
|
|
||||||
@$doc->loadXML($xml);
|
|
||||||
|
|
||||||
$xpath = new DomXPath($doc);
|
|
||||||
$xpath->registerNamespace("atom", NAMESPACE_ATOM1);
|
|
||||||
$xpath->registerNamespace("thr", NAMESPACE_THREAD);
|
|
||||||
$xpath->registerNamespace("at", NAMESPACE_TOMB);
|
|
||||||
$xpath->registerNamespace("media", NAMESPACE_MEDIA);
|
|
||||||
$xpath->registerNamespace("dfrn", NAMESPACE_DFRN);
|
|
||||||
$xpath->registerNamespace("activity", NAMESPACE_ACTIVITY);
|
|
||||||
$xpath->registerNamespace("georss", NAMESPACE_GEORSS);
|
|
||||||
$xpath->registerNamespace("poco", NAMESPACE_POCO);
|
|
||||||
$xpath->registerNamespace("ostatus", NAMESPACE_OSTATUS);
|
|
||||||
$xpath->registerNamespace("statusnet", NAMESPACE_STATUSNET);
|
|
||||||
|
|
||||||
$header = array();
|
|
||||||
$header["uid"] = $importer["uid"];
|
|
||||||
$header["network"] = NETWORK_DFRN;
|
|
||||||
$header["type"] = "remote";
|
|
||||||
$header["wall"] = 0;
|
|
||||||
$header["origin"] = 0;
|
|
||||||
$header["contact-id"] = $importer["id"];
|
|
||||||
|
|
||||||
// Update the contact table if the data has changed
|
|
||||||
|
|
||||||
// The "atom:author" is only present in feeds
|
|
||||||
if ($xpath->query("/atom:feed/atom:author")->length > 0) {
|
|
||||||
self::fetchauthor($xpath, $doc->firstChild, $importer, "atom:author", false, $xml);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Only the "dfrn:owner" in the head section contains all data
|
|
||||||
if ($xpath->query("/atom:feed/dfrn:owner")->length > 0) {
|
|
||||||
self::fetchauthor($xpath, $doc->firstChild, $importer, "dfrn:owner", false, $xml);
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("Import DFRN message for user " . $importer["uid"] . " from contact " . $importer["id"], LOGGER_DEBUG);
|
|
||||||
|
|
||||||
// The account type is new since 3.5.1
|
|
||||||
if ($xpath->query("/atom:feed/dfrn:account_type")->length > 0) {
|
|
||||||
$accounttype = intval($xpath->evaluate("/atom:feed/dfrn:account_type/text()", $context)->item(0)->nodeValue);
|
|
||||||
|
|
||||||
if ($accounttype != $importer["contact-type"]) {
|
|
||||||
dba::update('contact', array('contact-type' => $accounttype), array('id' => $importer["id"]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// is it a public forum? Private forums aren't supported with this method
|
|
||||||
// This is deprecated since 3.5.1
|
|
||||||
$forum = intval($xpath->evaluate("/atom:feed/dfrn:community/text()", $context)->item(0)->nodeValue);
|
|
||||||
|
|
||||||
if ($forum != $importer["forum"]) {
|
|
||||||
$condition = array('`forum` != ? AND `id` = ?', $forum, $importer["id"]);
|
|
||||||
dba::update('contact', array('forum' => $forum), $condition);
|
|
||||||
}
|
|
||||||
|
|
||||||
// We are processing relocations even if we are ignoring a contact
|
|
||||||
$relocations = $xpath->query("/atom:feed/dfrn:relocate");
|
|
||||||
foreach ($relocations AS $relocation) {
|
|
||||||
self::process_relocation($xpath, $relocation, $importer);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($importer["readonly"]) {
|
|
||||||
// We aren't receiving stuff from this person. But we will quietly ignore them
|
|
||||||
// rather than a blatant "go away" message.
|
|
||||||
logger('ignoring contact '.$importer["id"]);
|
|
||||||
return 403;
|
|
||||||
}
|
|
||||||
|
|
||||||
$mails = $xpath->query("/atom:feed/dfrn:mail");
|
|
||||||
foreach ($mails AS $mail) {
|
|
||||||
self::process_mail($xpath, $mail, $importer);
|
|
||||||
}
|
|
||||||
|
|
||||||
$suggestions = $xpath->query("/atom:feed/dfrn:suggest");
|
|
||||||
foreach ($suggestions AS $suggestion) {
|
|
||||||
self::process_suggestion($xpath, $suggestion, $importer);
|
|
||||||
}
|
|
||||||
|
|
||||||
$deletions = $xpath->query("/atom:feed/at:deleted-entry");
|
|
||||||
foreach ($deletions AS $deletion) {
|
|
||||||
self::process_deletion($xpath, $deletion, $importer);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$sort_by_date) {
|
|
||||||
$entries = $xpath->query("/atom:feed/atom:entry");
|
|
||||||
foreach ($entries AS $entry) {
|
|
||||||
self::process_entry($header, $xpath, $entry, $importer, $xml);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$newentries = array();
|
|
||||||
$entries = $xpath->query("/atom:feed/atom:entry");
|
|
||||||
foreach ($entries AS $entry) {
|
|
||||||
$created = $xpath->query("atom:published/text()", $entry)->item(0)->nodeValue;
|
|
||||||
$newentries[strtotime($created)] = $entry;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Now sort after the publishing date
|
|
||||||
ksort($newentries);
|
|
||||||
|
|
||||||
foreach ($newentries AS $entry) {
|
|
||||||
self::process_entry($header, $xpath, $entry, $importer, $xml);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
logger("Import done for user " . $importer["uid"] . " from contact " . $importer["id"], LOGGER_DEBUG);
|
|
||||||
return 200;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
3943
include/diaspora.php
3943
include/diaspora.php
|
|
@ -1,3943 +0,0 @@
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* @file include/diaspora.php
|
|
||||||
* @brief The implementation of the diaspora protocol
|
|
||||||
*
|
|
||||||
* The new protocol is described here: http://diaspora.github.io/diaspora_federation/index.html
|
|
||||||
* This implementation here interprets the old and the new protocol and sends the new one.
|
|
||||||
* In the future we will remove most stuff from "valid_posting" and interpret only the new protocol.
|
|
||||||
*/
|
|
||||||
|
|
||||||
use Friendica\App;
|
|
||||||
use Friendica\Core\System;
|
|
||||||
use Friendica\Core\Config;
|
|
||||||
use Friendica\Core\PConfig;
|
|
||||||
use Friendica\Core\Worker;
|
|
||||||
use Friendica\Network\Probe;
|
|
||||||
|
|
||||||
require_once 'include/items.php';
|
|
||||||
require_once 'include/bb2diaspora.php';
|
|
||||||
require_once 'include/Contact.php';
|
|
||||||
require_once 'include/Photo.php';
|
|
||||||
require_once 'include/socgraph.php';
|
|
||||||
require_once 'include/group.php';
|
|
||||||
require_once 'include/xml.php';
|
|
||||||
require_once 'include/datetime.php';
|
|
||||||
require_once 'include/queue_fn.php';
|
|
||||||
require_once 'include/cache.php';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief This class contain functions to create and send Diaspora XML files
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
class Diaspora {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Return a list of relay servers
|
|
||||||
*
|
|
||||||
* This is an experimental Diaspora feature.
|
|
||||||
*
|
|
||||||
* @return array of relay servers
|
|
||||||
*/
|
|
||||||
public static function relay_list() {
|
|
||||||
|
|
||||||
$serverdata = Config::get("system", "relay_server");
|
|
||||||
if ($serverdata == "")
|
|
||||||
return array();
|
|
||||||
|
|
||||||
$relay = array();
|
|
||||||
|
|
||||||
$servers = explode(",", $serverdata);
|
|
||||||
|
|
||||||
foreach ($servers AS $server) {
|
|
||||||
$server = trim($server);
|
|
||||||
$addr = "relay@".str_replace("http://", "", normalise_link($server));
|
|
||||||
$batch = $server."/receive/public";
|
|
||||||
|
|
||||||
$relais = q("SELECT `batch`, `id`, `name`,`network` FROM `contact` WHERE `uid` = 0 AND `batch` = '%s' AND `addr` = '%s' AND `nurl` = '%s' LIMIT 1",
|
|
||||||
dbesc($batch), dbesc($addr), dbesc(normalise_link($server)));
|
|
||||||
|
|
||||||
if (!$relais) {
|
|
||||||
$r = q("INSERT INTO `contact` (`uid`, `created`, `name`, `nick`, `addr`, `url`, `nurl`, `batch`, `network`, `rel`, `blocked`, `pending`, `writable`, `name-date`, `uri-date`, `avatar-date`)
|
|
||||||
VALUES (0, '%s', '%s', 'relay', '%s', '%s', '%s', '%s', '%s', %d, 0, 0, 1, '%s', '%s', '%s')",
|
|
||||||
datetime_convert(),
|
|
||||||
dbesc($addr),
|
|
||||||
dbesc($addr),
|
|
||||||
dbesc($server),
|
|
||||||
dbesc(normalise_link($server)),
|
|
||||||
dbesc($batch),
|
|
||||||
dbesc(NETWORK_DIASPORA),
|
|
||||||
intval(CONTACT_IS_FOLLOWER),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc(datetime_convert())
|
|
||||||
);
|
|
||||||
|
|
||||||
$relais = q("SELECT `batch`, `id`, `name`,`network` FROM `contact` WHERE `uid` = 0 AND `batch` = '%s' LIMIT 1", dbesc($batch));
|
|
||||||
if ($relais)
|
|
||||||
$relay[] = $relais[0];
|
|
||||||
} else
|
|
||||||
$relay[] = $relais[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
return $relay;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief repairs a signature that was double encoded
|
|
||||||
*
|
|
||||||
* The function is unused at the moment. It was copied from the old implementation.
|
|
||||||
*
|
|
||||||
* @param string $signature The signature
|
|
||||||
* @param string $handle The handle of the signature owner
|
|
||||||
* @param integer $level This value is only set inside this function to avoid endless loops
|
|
||||||
*
|
|
||||||
* @return string the repaired signature
|
|
||||||
*/
|
|
||||||
private static function repair_signature($signature, $handle = "", $level = 1) {
|
|
||||||
|
|
||||||
if ($signature == "")
|
|
||||||
return ($signature);
|
|
||||||
|
|
||||||
if (base64_encode(base64_decode(base64_decode($signature))) == base64_decode($signature)) {
|
|
||||||
$signature = base64_decode($signature);
|
|
||||||
logger("Repaired double encoded signature from Diaspora/Hubzilla handle ".$handle." - level ".$level, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
// Do a recursive call to be able to fix even multiple levels
|
|
||||||
if ($level < 10)
|
|
||||||
$signature = self::repair_signature($signature, $handle, ++$level);
|
|
||||||
}
|
|
||||||
|
|
||||||
return($signature);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief verify the envelope and return the verified data
|
|
||||||
*
|
|
||||||
* @param string $envelope The magic envelope
|
|
||||||
*
|
|
||||||
* @return string verified data
|
|
||||||
*/
|
|
||||||
private static function verify_magic_envelope($envelope) {
|
|
||||||
|
|
||||||
$basedom = parse_xml_string($envelope);
|
|
||||||
|
|
||||||
if (!is_object($basedom)) {
|
|
||||||
logger("Envelope is no XML file");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$children = $basedom->children('http://salmon-protocol.org/ns/magic-env');
|
|
||||||
|
|
||||||
if (sizeof($children) == 0) {
|
|
||||||
logger("XML has no children");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$handle = "";
|
|
||||||
|
|
||||||
$data = base64url_decode($children->data);
|
|
||||||
$type = $children->data->attributes()->type[0];
|
|
||||||
|
|
||||||
$encoding = $children->encoding;
|
|
||||||
|
|
||||||
$alg = $children->alg;
|
|
||||||
|
|
||||||
$sig = base64url_decode($children->sig);
|
|
||||||
$key_id = $children->sig->attributes()->key_id[0];
|
|
||||||
if ($key_id != "")
|
|
||||||
$handle = base64url_decode($key_id);
|
|
||||||
|
|
||||||
$b64url_data = base64url_encode($data);
|
|
||||||
$msg = str_replace(array("\n", "\r", " ", "\t"), array("", "", "", ""), $b64url_data);
|
|
||||||
|
|
||||||
$signable_data = $msg.".".base64url_encode($type).".".base64url_encode($encoding).".".base64url_encode($alg);
|
|
||||||
|
|
||||||
$key = self::key($handle);
|
|
||||||
|
|
||||||
$verify = rsa_verify($signable_data, $sig, $key);
|
|
||||||
if (!$verify) {
|
|
||||||
logger('Message did not verify. Discarding.');
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $data;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief encrypts data via AES
|
|
||||||
*
|
|
||||||
* @param string $key The AES key
|
|
||||||
* @param string $iv The IV (is used for CBC encoding)
|
|
||||||
* @param string $data The data that is to be encrypted
|
|
||||||
*
|
|
||||||
* @return string encrypted data
|
|
||||||
*/
|
|
||||||
private static function aes_encrypt($key, $iv, $data) {
|
|
||||||
return openssl_encrypt($data, 'aes-256-cbc', str_pad($key, 32, "\0"), OPENSSL_RAW_DATA, str_pad($iv, 16, "\0"));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief decrypts data via AES
|
|
||||||
*
|
|
||||||
* @param string $key The AES key
|
|
||||||
* @param string $iv The IV (is used for CBC encoding)
|
|
||||||
* @param string $encrypted The encrypted data
|
|
||||||
*
|
|
||||||
* @return string decrypted data
|
|
||||||
*/
|
|
||||||
private static function aes_decrypt($key, $iv, $encrypted) {
|
|
||||||
return openssl_decrypt($encrypted,'aes-256-cbc', str_pad($key, 32, "\0"), OPENSSL_RAW_DATA,str_pad($iv, 16, "\0"));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief: Decodes incoming Diaspora message in the new format
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param string $raw raw post message
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
* 'message' -> decoded Diaspora XML message
|
|
||||||
* 'author' -> author diaspora handle
|
|
||||||
* 'key' -> author public key (converted to pkcs#8)
|
|
||||||
*/
|
|
||||||
public static function decode_raw($importer, $raw) {
|
|
||||||
$data = json_decode($raw);
|
|
||||||
|
|
||||||
// Is it a private post? Then decrypt the outer Salmon
|
|
||||||
if (is_object($data)) {
|
|
||||||
$encrypted_aes_key_bundle = base64_decode($data->aes_key);
|
|
||||||
$ciphertext = base64_decode($data->encrypted_magic_envelope);
|
|
||||||
|
|
||||||
$outer_key_bundle = '';
|
|
||||||
@openssl_private_decrypt($encrypted_aes_key_bundle, $outer_key_bundle, $importer['prvkey']);
|
|
||||||
$j_outer_key_bundle = json_decode($outer_key_bundle);
|
|
||||||
|
|
||||||
if (!is_object($j_outer_key_bundle)) {
|
|
||||||
logger('Outer Salmon did not verify. Discarding.');
|
|
||||||
http_status_exit(400);
|
|
||||||
}
|
|
||||||
|
|
||||||
$outer_iv = base64_decode($j_outer_key_bundle->iv);
|
|
||||||
$outer_key = base64_decode($j_outer_key_bundle->key);
|
|
||||||
|
|
||||||
$xml = diaspora::aes_decrypt($outer_key, $outer_iv, $ciphertext);
|
|
||||||
} else {
|
|
||||||
$xml = $raw;
|
|
||||||
}
|
|
||||||
|
|
||||||
$basedom = parse_xml_string($xml);
|
|
||||||
|
|
||||||
if (!is_object($basedom)) {
|
|
||||||
logger('Received data does not seem to be an XML. Discarding. '.$xml);
|
|
||||||
http_status_exit(400);
|
|
||||||
}
|
|
||||||
|
|
||||||
$base = $basedom->children(NAMESPACE_SALMON_ME);
|
|
||||||
|
|
||||||
// Not sure if this cleaning is needed
|
|
||||||
$data = str_replace(array(" ", "\t", "\r", "\n"), array("", "", "", ""), $base->data);
|
|
||||||
|
|
||||||
// Build the signed data
|
|
||||||
$type = $base->data[0]->attributes()->type[0];
|
|
||||||
$encoding = $base->encoding;
|
|
||||||
$alg = $base->alg;
|
|
||||||
$signed_data = $data.'.'.base64url_encode($type).'.'.base64url_encode($encoding).'.'.base64url_encode($alg);
|
|
||||||
|
|
||||||
// This is the signature
|
|
||||||
$signature = base64url_decode($base->sig);
|
|
||||||
|
|
||||||
// Get the senders' public key
|
|
||||||
$key_id = $base->sig[0]->attributes()->key_id[0];
|
|
||||||
$author_addr = base64_decode($key_id);
|
|
||||||
$key = diaspora::key($author_addr);
|
|
||||||
|
|
||||||
$verify = rsa_verify($signed_data, $signature, $key);
|
|
||||||
if (!$verify) {
|
|
||||||
logger('Message did not verify. Discarding.');
|
|
||||||
http_status_exit(400);
|
|
||||||
}
|
|
||||||
|
|
||||||
return array('message' => (string)base64url_decode($base->data),
|
|
||||||
'author' => unxmlify($author_addr),
|
|
||||||
'key' => (string)$key);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief: Decodes incoming Diaspora message in the deprecated format
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param string $xml urldecoded Diaspora salmon
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
* 'message' -> decoded Diaspora XML message
|
|
||||||
* 'author' -> author diaspora handle
|
|
||||||
* 'key' -> author public key (converted to pkcs#8)
|
|
||||||
*/
|
|
||||||
public static function decode($importer, $xml) {
|
|
||||||
|
|
||||||
$public = false;
|
|
||||||
$basedom = parse_xml_string($xml);
|
|
||||||
|
|
||||||
if (!is_object($basedom)) {
|
|
||||||
logger("XML is not parseable.");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
$children = $basedom->children('https://joindiaspora.com/protocol');
|
|
||||||
|
|
||||||
if ($children->header) {
|
|
||||||
$public = true;
|
|
||||||
$author_link = str_replace('acct:','',$children->header->author_id);
|
|
||||||
} else {
|
|
||||||
// This happens with posts from a relais
|
|
||||||
if (!$importer) {
|
|
||||||
logger("This is no private post in the old format", LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$encrypted_header = json_decode(base64_decode($children->encrypted_header));
|
|
||||||
|
|
||||||
$encrypted_aes_key_bundle = base64_decode($encrypted_header->aes_key);
|
|
||||||
$ciphertext = base64_decode($encrypted_header->ciphertext);
|
|
||||||
|
|
||||||
$outer_key_bundle = '';
|
|
||||||
openssl_private_decrypt($encrypted_aes_key_bundle,$outer_key_bundle,$importer['prvkey']);
|
|
||||||
|
|
||||||
$j_outer_key_bundle = json_decode($outer_key_bundle);
|
|
||||||
|
|
||||||
$outer_iv = base64_decode($j_outer_key_bundle->iv);
|
|
||||||
$outer_key = base64_decode($j_outer_key_bundle->key);
|
|
||||||
|
|
||||||
$decrypted = self::aes_decrypt($outer_key, $outer_iv, $ciphertext);
|
|
||||||
|
|
||||||
logger('decrypted: '.$decrypted, LOGGER_DEBUG);
|
|
||||||
$idom = parse_xml_string($decrypted);
|
|
||||||
|
|
||||||
$inner_iv = base64_decode($idom->iv);
|
|
||||||
$inner_aes_key = base64_decode($idom->aes_key);
|
|
||||||
|
|
||||||
$author_link = str_replace('acct:','',$idom->author_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
$dom = $basedom->children(NAMESPACE_SALMON_ME);
|
|
||||||
|
|
||||||
// figure out where in the DOM tree our data is hiding
|
|
||||||
|
|
||||||
if ($dom->provenance->data)
|
|
||||||
$base = $dom->provenance;
|
|
||||||
elseif ($dom->env->data)
|
|
||||||
$base = $dom->env;
|
|
||||||
elseif ($dom->data)
|
|
||||||
$base = $dom;
|
|
||||||
|
|
||||||
if (!$base) {
|
|
||||||
logger('unable to locate salmon data in xml');
|
|
||||||
http_status_exit(400);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Stash the signature away for now. We have to find their key or it won't be good for anything.
|
|
||||||
$signature = base64url_decode($base->sig);
|
|
||||||
|
|
||||||
// unpack the data
|
|
||||||
|
|
||||||
// strip whitespace so our data element will return to one big base64 blob
|
|
||||||
$data = str_replace(array(" ","\t","\r","\n"),array("","","",""),$base->data);
|
|
||||||
|
|
||||||
|
|
||||||
// stash away some other stuff for later
|
|
||||||
|
|
||||||
$type = $base->data[0]->attributes()->type[0];
|
|
||||||
$keyhash = $base->sig[0]->attributes()->keyhash[0];
|
|
||||||
$encoding = $base->encoding;
|
|
||||||
$alg = $base->alg;
|
|
||||||
|
|
||||||
|
|
||||||
$signed_data = $data.'.'.base64url_encode($type).'.'.base64url_encode($encoding).'.'.base64url_encode($alg);
|
|
||||||
|
|
||||||
|
|
||||||
// decode the data
|
|
||||||
$data = base64url_decode($data);
|
|
||||||
|
|
||||||
|
|
||||||
if ($public)
|
|
||||||
$inner_decrypted = $data;
|
|
||||||
else {
|
|
||||||
|
|
||||||
// Decode the encrypted blob
|
|
||||||
|
|
||||||
$inner_encrypted = base64_decode($data);
|
|
||||||
$inner_decrypted = self::aes_decrypt($inner_aes_key, $inner_iv, $inner_encrypted);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$author_link) {
|
|
||||||
logger('Could not retrieve author URI.');
|
|
||||||
http_status_exit(400);
|
|
||||||
}
|
|
||||||
// Once we have the author URI, go to the web and try to find their public key
|
|
||||||
// (first this will look it up locally if it is in the fcontact cache)
|
|
||||||
// This will also convert diaspora public key from pkcs#1 to pkcs#8
|
|
||||||
|
|
||||||
logger('Fetching key for '.$author_link);
|
|
||||||
$key = self::key($author_link);
|
|
||||||
|
|
||||||
if (!$key) {
|
|
||||||
logger('Could not retrieve author key.');
|
|
||||||
http_status_exit(400);
|
|
||||||
}
|
|
||||||
|
|
||||||
$verify = rsa_verify($signed_data,$signature,$key);
|
|
||||||
|
|
||||||
if (!$verify) {
|
|
||||||
logger('Message did not verify. Discarding.');
|
|
||||||
http_status_exit(400);
|
|
||||||
}
|
|
||||||
|
|
||||||
logger('Message verified.');
|
|
||||||
|
|
||||||
return array('message' => (string)$inner_decrypted,
|
|
||||||
'author' => unxmlify($author_link),
|
|
||||||
'key' => (string)$key);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Dispatches public messages and find the fitting receivers
|
|
||||||
*
|
|
||||||
* @param array $msg The post that will be dispatched
|
|
||||||
*
|
|
||||||
* @return int The message id of the generated message, "true" or "false" if there was an error
|
|
||||||
*/
|
|
||||||
public static function dispatch_public($msg) {
|
|
||||||
|
|
||||||
$enabled = intval(Config::get("system", "diaspora_enabled"));
|
|
||||||
if (!$enabled) {
|
|
||||||
logger("diaspora is disabled");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!($postdata = self::valid_posting($msg))) {
|
|
||||||
logger("Invalid posting");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$fields = $postdata['fields'];
|
|
||||||
|
|
||||||
// Is it a an action (comment, like, ...) for our own post?
|
|
||||||
if (isset($fields->parent_guid) && !$postdata["relayed"]) {
|
|
||||||
$guid = notags(unxmlify($fields->parent_guid));
|
|
||||||
$importer = self::importer_for_guid($guid);
|
|
||||||
if (is_array($importer)) {
|
|
||||||
logger("delivering to origin: ".$importer["name"]);
|
|
||||||
$message_id = self::dispatch($importer, $msg, $fields);
|
|
||||||
return $message_id;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Process item retractions. This has to be done separated from the other stuff,
|
|
||||||
// since retractions for comments could come even from non followers.
|
|
||||||
if (!empty($fields) && in_array($fields->getName(), array('retraction'))) {
|
|
||||||
$target = notags(unxmlify($fields->target_type));
|
|
||||||
if (in_array($target, array("Comment", "Like", "Post", "Reshare", "StatusMessage"))) {
|
|
||||||
logger('processing retraction for '.$target, LOGGER_DEBUG);
|
|
||||||
$importer = array("uid" => 0, "page-flags" => PAGE_FREELOVE);
|
|
||||||
$message_id = self::dispatch($importer, $msg, $fields);
|
|
||||||
return $message_id;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Now distribute it to the followers
|
|
||||||
$r = q("SELECT `user`.* FROM `user` WHERE `user`.`uid` IN
|
|
||||||
(SELECT `contact`.`uid` FROM `contact` WHERE `contact`.`network` = '%s' AND `contact`.`addr` = '%s')
|
|
||||||
AND NOT `account_expired` AND NOT `account_removed`",
|
|
||||||
dbesc(NETWORK_DIASPORA),
|
|
||||||
dbesc($msg["author"])
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
foreach ($r as $rr) {
|
|
||||||
logger("delivering to: ".$rr["username"]);
|
|
||||||
self::dispatch($rr, $msg, $fields);
|
|
||||||
}
|
|
||||||
} elseif (!Config::get('system', 'relay_subscribe', false)) {
|
|
||||||
logger("Unwanted message from ".$msg["author"]." send by ".$_SERVER["REMOTE_ADDR"]." with ".$_SERVER["HTTP_USER_AGENT"].": ".print_r($msg, true), LOGGER_DEBUG);
|
|
||||||
} else {
|
|
||||||
// Use a dummy importer to import the data for the public copy
|
|
||||||
$importer = array("uid" => 0, "page-flags" => PAGE_FREELOVE);
|
|
||||||
$message_id = self::dispatch($importer, $msg, $fields);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $message_id;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Dispatches the different message types to the different functions
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param array $msg The post that will be dispatched
|
|
||||||
* @param object $fields SimpleXML object that contains the message
|
|
||||||
*
|
|
||||||
* @return int The message id of the generated message, "true" or "false" if there was an error
|
|
||||||
*/
|
|
||||||
public static function dispatch($importer, $msg, $fields = null) {
|
|
||||||
|
|
||||||
// The sender is the handle of the contact that sent the message.
|
|
||||||
// This will often be different with relayed messages (for example "like" and "comment")
|
|
||||||
$sender = $msg["author"];
|
|
||||||
|
|
||||||
// This is only needed for private postings since this is already done for public ones before
|
|
||||||
if (is_null($fields)) {
|
|
||||||
if (!($postdata = self::valid_posting($msg))) {
|
|
||||||
logger("Invalid posting");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
$fields = $postdata['fields'];
|
|
||||||
}
|
|
||||||
|
|
||||||
$type = $fields->getName();
|
|
||||||
|
|
||||||
logger("Received message type ".$type." from ".$sender." for user ".$importer["uid"], LOGGER_DEBUG);
|
|
||||||
|
|
||||||
switch ($type) {
|
|
||||||
case "account_migration":
|
|
||||||
return self::receiveAccountMigration($importer, $fields);
|
|
||||||
|
|
||||||
case "account_deletion":
|
|
||||||
return self::receive_account_deletion($importer, $fields);
|
|
||||||
|
|
||||||
case "comment":
|
|
||||||
return self::receive_comment($importer, $sender, $fields, $msg["message"]);
|
|
||||||
|
|
||||||
case "contact":
|
|
||||||
return self::receive_contact_request($importer, $fields);
|
|
||||||
|
|
||||||
case "conversation":
|
|
||||||
return self::receive_conversation($importer, $msg, $fields);
|
|
||||||
|
|
||||||
case "like":
|
|
||||||
return self::receive_like($importer, $sender, $fields);
|
|
||||||
|
|
||||||
case "message":
|
|
||||||
return self::receive_message($importer, $fields);
|
|
||||||
|
|
||||||
case "participation": // Not implemented
|
|
||||||
return self::receive_participation($importer, $fields);
|
|
||||||
|
|
||||||
case "photo": // Not implemented
|
|
||||||
return self::receive_photo($importer, $fields);
|
|
||||||
|
|
||||||
case "poll_participation": // Not implemented
|
|
||||||
return self::receive_poll_participation($importer, $fields);
|
|
||||||
|
|
||||||
case "profile":
|
|
||||||
return self::receive_profile($importer, $fields);
|
|
||||||
|
|
||||||
case "reshare":
|
|
||||||
return self::receive_reshare($importer, $fields, $msg["message"]);
|
|
||||||
|
|
||||||
case "retraction":
|
|
||||||
return self::receive_retraction($importer, $sender, $fields);
|
|
||||||
|
|
||||||
case "status_message":
|
|
||||||
return self::receive_status_message($importer, $fields, $msg["message"]);
|
|
||||||
|
|
||||||
default:
|
|
||||||
logger("Unknown message type ".$type);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Checks if a posting is valid and fetches the data fields.
|
|
||||||
*
|
|
||||||
* This function does not only check the signature.
|
|
||||||
* It also does the conversion between the old and the new diaspora format.
|
|
||||||
*
|
|
||||||
* @param array $msg Array with the XML, the sender handle and the sender signature
|
|
||||||
*
|
|
||||||
* @return bool|array If the posting is valid then an array with an SimpleXML object is returned
|
|
||||||
*/
|
|
||||||
private static function valid_posting($msg) {
|
|
||||||
|
|
||||||
$data = parse_xml_string($msg["message"]);
|
|
||||||
|
|
||||||
if (!is_object($data)) {
|
|
||||||
logger("No valid XML ".$msg["message"], LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$first_child = $data->getName();
|
|
||||||
|
|
||||||
// Is this the new or the old version?
|
|
||||||
if ($data->getName() == "XML") {
|
|
||||||
$oldXML = true;
|
|
||||||
foreach ($data->post->children() as $child)
|
|
||||||
$element = $child;
|
|
||||||
} else {
|
|
||||||
$oldXML = false;
|
|
||||||
$element = $data;
|
|
||||||
}
|
|
||||||
|
|
||||||
$type = $element->getName();
|
|
||||||
$orig_type = $type;
|
|
||||||
|
|
||||||
logger("Got message type ".$type.": ".$msg["message"], LOGGER_DATA);
|
|
||||||
|
|
||||||
// All retractions are handled identically from now on.
|
|
||||||
// In the new version there will only be "retraction".
|
|
||||||
if (in_array($type, array("signed_retraction", "relayable_retraction")))
|
|
||||||
$type = "retraction";
|
|
||||||
|
|
||||||
if ($type == "request")
|
|
||||||
$type = "contact";
|
|
||||||
|
|
||||||
$fields = new SimpleXMLElement("<".$type."/>");
|
|
||||||
|
|
||||||
$signed_data = "";
|
|
||||||
|
|
||||||
foreach ($element->children() AS $fieldname => $entry) {
|
|
||||||
if ($oldXML) {
|
|
||||||
// Translation for the old XML structure
|
|
||||||
if ($fieldname == "diaspora_handle") {
|
|
||||||
$fieldname = "author";
|
|
||||||
}
|
|
||||||
if ($fieldname == "participant_handles") {
|
|
||||||
$fieldname = "participants";
|
|
||||||
}
|
|
||||||
if (in_array($type, array("like", "participation"))) {
|
|
||||||
if ($fieldname == "target_type") {
|
|
||||||
$fieldname = "parent_type";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($fieldname == "sender_handle") {
|
|
||||||
$fieldname = "author";
|
|
||||||
}
|
|
||||||
if ($fieldname == "recipient_handle") {
|
|
||||||
$fieldname = "recipient";
|
|
||||||
}
|
|
||||||
if ($fieldname == "root_diaspora_id") {
|
|
||||||
$fieldname = "root_author";
|
|
||||||
}
|
|
||||||
if ($type == "status_message") {
|
|
||||||
if ($fieldname == "raw_message") {
|
|
||||||
$fieldname = "text";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if ($type == "retraction") {
|
|
||||||
if ($fieldname == "post_guid") {
|
|
||||||
$fieldname = "target_guid";
|
|
||||||
}
|
|
||||||
if ($fieldname == "type") {
|
|
||||||
$fieldname = "target_type";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($fieldname == "author_signature") && ($entry != ""))
|
|
||||||
$author_signature = base64_decode($entry);
|
|
||||||
elseif (($fieldname == "parent_author_signature") && ($entry != ""))
|
|
||||||
$parent_author_signature = base64_decode($entry);
|
|
||||||
elseif (!in_array($fieldname, array("author_signature", "parent_author_signature", "target_author_signature"))) {
|
|
||||||
if ($signed_data != "") {
|
|
||||||
$signed_data .= ";";
|
|
||||||
$signed_data_parent .= ";";
|
|
||||||
}
|
|
||||||
|
|
||||||
$signed_data .= $entry;
|
|
||||||
}
|
|
||||||
if (!in_array($fieldname, array("parent_author_signature", "target_author_signature")) ||
|
|
||||||
($orig_type == "relayable_retraction"))
|
|
||||||
xml::copy($entry, $fields, $fieldname);
|
|
||||||
}
|
|
||||||
|
|
||||||
// This is something that shouldn't happen at all.
|
|
||||||
if (in_array($type, array("status_message", "reshare", "profile")))
|
|
||||||
if ($msg["author"] != $fields->author) {
|
|
||||||
logger("Message handle is not the same as envelope sender. Quitting this message.");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Only some message types have signatures. So we quit here for the other types.
|
|
||||||
if (!in_array($type, array("comment", "like"))) {
|
|
||||||
return array("fields" => $fields, "relayed" => false);
|
|
||||||
}
|
|
||||||
// No author_signature? This is a must, so we quit.
|
|
||||||
if (!isset($author_signature)) {
|
|
||||||
logger("No author signature for type ".$type." - Message: ".$msg["message"], LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($parent_author_signature)) {
|
|
||||||
$relayed = true;
|
|
||||||
|
|
||||||
$key = self::key($msg["author"]);
|
|
||||||
|
|
||||||
if (!rsa_verify($signed_data, $parent_author_signature, $key, "sha256")) {
|
|
||||||
logger("No valid parent author signature for parent author ".$msg["author"]. " in type ".$type." - signed data: ".$signed_data." - Message: ".$msg["message"]." - Signature ".$parent_author_signature, LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$relayed = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$key = self::key($fields->author);
|
|
||||||
|
|
||||||
if (!rsa_verify($signed_data, $author_signature, $key, "sha256")) {
|
|
||||||
logger("No valid author signature for author ".$fields->author. " in type ".$type." - signed data: ".$signed_data." - Message: ".$msg["message"]." - Signature ".$author_signature, LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
return array("fields" => $fields, "relayed" => $relayed);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetches the public key for a given handle
|
|
||||||
*
|
|
||||||
* @param string $handle The handle
|
|
||||||
*
|
|
||||||
* @return string The public key
|
|
||||||
*/
|
|
||||||
private static function key($handle) {
|
|
||||||
$handle = strval($handle);
|
|
||||||
|
|
||||||
logger("Fetching diaspora key for: ".$handle);
|
|
||||||
|
|
||||||
$r = self::person_by_handle($handle);
|
|
||||||
if ($r)
|
|
||||||
return $r["pubkey"];
|
|
||||||
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetches data for a given handle
|
|
||||||
*
|
|
||||||
* @param string $handle The handle
|
|
||||||
*
|
|
||||||
* @return array the queried data
|
|
||||||
*/
|
|
||||||
public static function person_by_handle($handle) {
|
|
||||||
|
|
||||||
$r = q("SELECT * FROM `fcontact` WHERE `network` = '%s' AND `addr` = '%s' LIMIT 1",
|
|
||||||
dbesc(NETWORK_DIASPORA),
|
|
||||||
dbesc($handle)
|
|
||||||
);
|
|
||||||
if ($r) {
|
|
||||||
$person = $r[0];
|
|
||||||
logger("In cache ".print_r($r,true), LOGGER_DEBUG);
|
|
||||||
|
|
||||||
// update record occasionally so it doesn't get stale
|
|
||||||
$d = strtotime($person["updated"]." +00:00");
|
|
||||||
if ($d < strtotime("now - 14 days"))
|
|
||||||
$update = true;
|
|
||||||
|
|
||||||
if ($person["guid"] == "")
|
|
||||||
$update = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$person || $update) {
|
|
||||||
logger("create or refresh", LOGGER_DEBUG);
|
|
||||||
$r = Probe::uri($handle, NETWORK_DIASPORA);
|
|
||||||
|
|
||||||
// Note that Friendica contacts will return a "Diaspora person"
|
|
||||||
// if Diaspora connectivity is enabled on their server
|
|
||||||
if ($r && ($r["network"] === NETWORK_DIASPORA)) {
|
|
||||||
self::add_fcontact($r, $update);
|
|
||||||
$person = $r;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return $person;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Updates the fcontact table
|
|
||||||
*
|
|
||||||
* @param array $arr The fcontact data
|
|
||||||
* @param bool $update Update or insert?
|
|
||||||
*
|
|
||||||
* @return string The id of the fcontact entry
|
|
||||||
*/
|
|
||||||
private static function add_fcontact($arr, $update = false) {
|
|
||||||
|
|
||||||
if ($update) {
|
|
||||||
$r = q("UPDATE `fcontact` SET
|
|
||||||
`name` = '%s',
|
|
||||||
`photo` = '%s',
|
|
||||||
`request` = '%s',
|
|
||||||
`nick` = '%s',
|
|
||||||
`addr` = '%s',
|
|
||||||
`guid` = '%s',
|
|
||||||
`batch` = '%s',
|
|
||||||
`notify` = '%s',
|
|
||||||
`poll` = '%s',
|
|
||||||
`confirm` = '%s',
|
|
||||||
`alias` = '%s',
|
|
||||||
`pubkey` = '%s',
|
|
||||||
`updated` = '%s'
|
|
||||||
WHERE `url` = '%s' AND `network` = '%s'",
|
|
||||||
dbesc($arr["name"]),
|
|
||||||
dbesc($arr["photo"]),
|
|
||||||
dbesc($arr["request"]),
|
|
||||||
dbesc($arr["nick"]),
|
|
||||||
dbesc(strtolower($arr["addr"])),
|
|
||||||
dbesc($arr["guid"]),
|
|
||||||
dbesc($arr["batch"]),
|
|
||||||
dbesc($arr["notify"]),
|
|
||||||
dbesc($arr["poll"]),
|
|
||||||
dbesc($arr["confirm"]),
|
|
||||||
dbesc($arr["alias"]),
|
|
||||||
dbesc($arr["pubkey"]),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc($arr["url"]),
|
|
||||||
dbesc($arr["network"])
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
$r = q("INSERT INTO `fcontact` (`url`,`name`,`photo`,`request`,`nick`,`addr`, `guid`,
|
|
||||||
`batch`, `notify`,`poll`,`confirm`,`network`,`alias`,`pubkey`,`updated`)
|
|
||||||
VALUES ('%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s')",
|
|
||||||
dbesc($arr["url"]),
|
|
||||||
dbesc($arr["name"]),
|
|
||||||
dbesc($arr["photo"]),
|
|
||||||
dbesc($arr["request"]),
|
|
||||||
dbesc($arr["nick"]),
|
|
||||||
dbesc($arr["addr"]),
|
|
||||||
dbesc($arr["guid"]),
|
|
||||||
dbesc($arr["batch"]),
|
|
||||||
dbesc($arr["notify"]),
|
|
||||||
dbesc($arr["poll"]),
|
|
||||||
dbesc($arr["confirm"]),
|
|
||||||
dbesc($arr["network"]),
|
|
||||||
dbesc($arr["alias"]),
|
|
||||||
dbesc($arr["pubkey"]),
|
|
||||||
dbesc(datetime_convert())
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $r;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief get a handle (user@domain.tld) from a given contact id or gcontact id
|
|
||||||
*
|
|
||||||
* @param int $contact_id The id in the contact table
|
|
||||||
* @param int $gcontact_id The id in the gcontact table
|
|
||||||
*
|
|
||||||
* @return string the handle
|
|
||||||
*/
|
|
||||||
public static function handle_from_contact($contact_id, $gcontact_id = 0) {
|
|
||||||
$handle = false;
|
|
||||||
|
|
||||||
logger("contact id is ".$contact_id." - gcontact id is ".$gcontact_id, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
if ($gcontact_id != 0) {
|
|
||||||
$r = q("SELECT `addr` FROM `gcontact` WHERE `id` = %d AND `addr` != ''",
|
|
||||||
intval($gcontact_id));
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return strtolower($r[0]["addr"]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$r = q("SELECT `network`, `addr`, `self`, `url`, `nick` FROM `contact` WHERE `id` = %d",
|
|
||||||
intval($contact_id));
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$contact = $r[0];
|
|
||||||
|
|
||||||
logger("contact 'self' = ".$contact['self']." 'url' = ".$contact['url'], LOGGER_DEBUG);
|
|
||||||
|
|
||||||
if ($contact['addr'] != "") {
|
|
||||||
$handle = $contact['addr'];
|
|
||||||
} else {
|
|
||||||
$baseurl_start = strpos($contact['url'],'://') + 3;
|
|
||||||
$baseurl_length = strpos($contact['url'],'/profile') - $baseurl_start; // allows installations in a subdirectory--not sure how Diaspora will handle
|
|
||||||
$baseurl = substr($contact['url'], $baseurl_start, $baseurl_length);
|
|
||||||
$handle = $contact['nick'].'@'.$baseurl;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return strtolower($handle);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief get a url (scheme://domain.tld/u/user) from a given Diaspora*
|
|
||||||
* fcontact guid
|
|
||||||
*
|
|
||||||
* @param mixed $fcontact_guid Hexadecimal string guid
|
|
||||||
*
|
|
||||||
* @return string the contact url or null
|
|
||||||
*/
|
|
||||||
public static function url_from_contact_guid($fcontact_guid) {
|
|
||||||
logger("fcontact guid is ".$fcontact_guid, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$r = q("SELECT `url` FROM `fcontact` WHERE `url` != '' AND `network` = '%s' AND `guid` = '%s'",
|
|
||||||
dbesc(NETWORK_DIASPORA),
|
|
||||||
dbesc($fcontact_guid)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return $r[0]['url'];
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Get a contact id for a given handle
|
|
||||||
*
|
|
||||||
* @param int $uid The user id
|
|
||||||
* @param string $handle The handle in the format user@domain.tld
|
|
||||||
*
|
|
||||||
* @return The contact id
|
|
||||||
*/
|
|
||||||
private static function contact_by_handle($uid, $handle) {
|
|
||||||
|
|
||||||
// First do a direct search on the contact table
|
|
||||||
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND `addr` = '%s' LIMIT 1",
|
|
||||||
intval($uid),
|
|
||||||
dbesc($handle)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return $r[0];
|
|
||||||
} else {
|
|
||||||
/*
|
|
||||||
* We haven't found it?
|
|
||||||
* We use another function for it that will possibly create a contact entry.
|
|
||||||
*/
|
|
||||||
$cid = get_contact($handle, $uid);
|
|
||||||
|
|
||||||
if ($cid > 0) {
|
|
||||||
/// @TODO Contact retrieval should be encapsulated into an "entity" class like `Contact`
|
|
||||||
$r = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1", intval($cid));
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return $r[0];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$handle_parts = explode("@", $handle);
|
|
||||||
$nurl_sql = "%%://".$handle_parts[1]."%%/profile/".$handle_parts[0];
|
|
||||||
$r = q("SELECT * FROM `contact` WHERE `network` = '%s' AND `uid` = %d AND `nurl` LIKE '%s' LIMIT 1",
|
|
||||||
dbesc(NETWORK_DFRN),
|
|
||||||
intval($uid),
|
|
||||||
dbesc($nurl_sql)
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return $r[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("Haven't found contact for user ".$uid." and handle ".$handle, LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Check if posting is allowed for this contact
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param array $contact The contact that is checked
|
|
||||||
* @param bool $is_comment Is the check for a comment?
|
|
||||||
*
|
|
||||||
* @return bool is the contact allowed to post?
|
|
||||||
*/
|
|
||||||
private static function post_allow($importer, $contact, $is_comment = false) {
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Perhaps we were already sharing with this person. Now they're sharing with us.
|
|
||||||
* That makes us friends.
|
|
||||||
* Normally this should have handled by getting a request - but this could get lost
|
|
||||||
*/
|
|
||||||
if ($contact["rel"] == CONTACT_IS_FOLLOWER && in_array($importer["page-flags"], array(PAGE_FREELOVE))) {
|
|
||||||
dba::update('contact', array('rel' => CONTACT_IS_FRIEND, 'writable' => true),
|
|
||||||
array('id' => $contact["id"], 'uid' => $contact["uid"]));
|
|
||||||
|
|
||||||
$contact["rel"] = CONTACT_IS_FRIEND;
|
|
||||||
logger("defining user ".$contact["nick"]." as friend");
|
|
||||||
}
|
|
||||||
|
|
||||||
// We don't seem to like that person
|
|
||||||
if ($contact["blocked"] || $contact["readonly"] || $contact["archive"]) {
|
|
||||||
// Maybe blocked, don't accept.
|
|
||||||
return false;
|
|
||||||
// We are following this person?
|
|
||||||
} elseif (($contact["rel"] == CONTACT_IS_SHARING) || ($contact["rel"] == CONTACT_IS_FRIEND)) {
|
|
||||||
// Yes, then it is fine.
|
|
||||||
return true;
|
|
||||||
// Is it a post to a community?
|
|
||||||
} elseif (($contact["rel"] == CONTACT_IS_FOLLOWER) && ($importer["page-flags"] == PAGE_COMMUNITY)) {
|
|
||||||
// That's good
|
|
||||||
return true;
|
|
||||||
// Is the message a global user or a comment?
|
|
||||||
} elseif (($importer["uid"] == 0) || $is_comment) {
|
|
||||||
// Messages for the global users and comments are always accepted
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetches the contact id for a handle and checks if posting is allowed
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param string $handle The checked handle in the format user@domain.tld
|
|
||||||
* @param bool $is_comment Is the check for a comment?
|
|
||||||
*
|
|
||||||
* @return array The contact data
|
|
||||||
*/
|
|
||||||
private static function allowed_contact_by_handle($importer, $handle, $is_comment = false) {
|
|
||||||
$contact = self::contact_by_handle($importer["uid"], $handle);
|
|
||||||
if (!$contact) {
|
|
||||||
logger("A Contact for handle ".$handle." and user ".$importer["uid"]." was not found");
|
|
||||||
// If a contact isn't found, we accept it anyway if it is a comment
|
|
||||||
if ($is_comment) {
|
|
||||||
return $importer;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!self::post_allow($importer, $contact, $is_comment)) {
|
|
||||||
logger("The handle: ".$handle." is not allowed to post to user ".$importer["uid"]);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return $contact;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Does the message already exists on the system?
|
|
||||||
*
|
|
||||||
* @param int $uid The user id
|
|
||||||
* @param string $guid The guid of the message
|
|
||||||
*
|
|
||||||
* @return int|bool message id if the message already was stored into the system - or false.
|
|
||||||
*/
|
|
||||||
private static function message_exists($uid, $guid) {
|
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `uid` = %d AND `guid` = '%s' LIMIT 1",
|
|
||||||
intval($uid),
|
|
||||||
dbesc($guid)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
logger("message ".$guid." already exists for user ".$uid);
|
|
||||||
return $r[0]["id"];
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Checks for links to posts in a message
|
|
||||||
*
|
|
||||||
* @param array $item The item array
|
|
||||||
*/
|
|
||||||
private static function fetch_guid($item) {
|
|
||||||
$expression = "=diaspora://.*?/post/([0-9A-Za-z\-_@.:]{15,254}[0-9A-Za-z])=ism";
|
|
||||||
preg_replace_callback($expression,
|
|
||||||
function ($match) use ($item) {
|
|
||||||
return self::fetch_guid_sub($match, $item);
|
|
||||||
}, $item["body"]);
|
|
||||||
|
|
||||||
preg_replace_callback("&\[url=/posts/([^\[\]]*)\](.*)\[\/url\]&Usi",
|
|
||||||
function ($match) use ($item) {
|
|
||||||
return self::fetch_guid_sub($match, $item);
|
|
||||||
}, $item["body"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Checks for relative /people/* links in an item body to match local
|
|
||||||
* contacts or prepends the remote host taken from the author link.
|
|
||||||
*
|
|
||||||
* @param string $body The item body to replace links from
|
|
||||||
* @param string $author_link The author link for missing local contact fallback
|
|
||||||
*
|
|
||||||
* @return the replaced string
|
|
||||||
*/
|
|
||||||
public static function replace_people_guid($body, $author_link) {
|
|
||||||
$return = preg_replace_callback("&\[url=/people/([^\[\]]*)\](.*)\[\/url\]&Usi",
|
|
||||||
function ($match) use ($author_link) {
|
|
||||||
// $match
|
|
||||||
// 0 => '[url=/people/0123456789abcdef]Foo Bar[/url]'
|
|
||||||
// 1 => '0123456789abcdef'
|
|
||||||
// 2 => 'Foo Bar'
|
|
||||||
$handle = self::url_from_contact_guid($match[1]);
|
|
||||||
|
|
||||||
if ($handle) {
|
|
||||||
$return = '@[url='.$handle.']'.$match[2].'[/url]';
|
|
||||||
} else {
|
|
||||||
// No local match, restoring absolute remote URL from author scheme and host
|
|
||||||
$author_url = parse_url($author_link);
|
|
||||||
$return = '[url='.$author_url['scheme'].'://'.$author_url['host'].'/people/'.$match[1].']'.$match[2].'[/url]';
|
|
||||||
}
|
|
||||||
|
|
||||||
return $return;
|
|
||||||
}, $body);
|
|
||||||
|
|
||||||
return $return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief sub function of "fetch_guid" which checks for links in messages
|
|
||||||
*
|
|
||||||
* @param array $match array containing a link that has to be checked for a message link
|
|
||||||
* @param array $item The item array
|
|
||||||
*/
|
|
||||||
private static function fetch_guid_sub($match, $item) {
|
|
||||||
if (!self::store_by_guid($match[1], $item["author-link"]))
|
|
||||||
self::store_by_guid($match[1], $item["owner-link"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetches an item with a given guid from a given server
|
|
||||||
*
|
|
||||||
* @param string $guid the message guid
|
|
||||||
* @param string $server The server address
|
|
||||||
* @param int $uid The user id of the user
|
|
||||||
*
|
|
||||||
* @return int the message id of the stored message or false
|
|
||||||
*/
|
|
||||||
private static function store_by_guid($guid, $server, $uid = 0) {
|
|
||||||
$serverparts = parse_url($server);
|
|
||||||
$server = $serverparts["scheme"]."://".$serverparts["host"];
|
|
||||||
|
|
||||||
logger("Trying to fetch item ".$guid." from ".$server, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$msg = self::message($guid, $server);
|
|
||||||
|
|
||||||
if (!$msg)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
logger("Successfully fetched item ".$guid." from ".$server, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
// Now call the dispatcher
|
|
||||||
return self::dispatch_public($msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetches a message from a server
|
|
||||||
*
|
|
||||||
* @param string $guid message guid
|
|
||||||
* @param string $server The url of the server
|
|
||||||
* @param int $level Endless loop prevention
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
* 'message' => The message XML
|
|
||||||
* 'author' => The author handle
|
|
||||||
* 'key' => The public key of the author
|
|
||||||
*/
|
|
||||||
private static function message($guid, $server, $level = 0) {
|
|
||||||
|
|
||||||
if ($level > 5)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// This will work for new Diaspora servers and Friendica servers from 3.5
|
|
||||||
$source_url = $server."/fetch/post/".urlencode($guid);
|
|
||||||
|
|
||||||
logger("Fetch post from ".$source_url, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$envelope = fetch_url($source_url);
|
|
||||||
if ($envelope) {
|
|
||||||
logger("Envelope was fetched.", LOGGER_DEBUG);
|
|
||||||
$x = self::verify_magic_envelope($envelope);
|
|
||||||
if (!$x)
|
|
||||||
logger("Envelope could not be verified.", LOGGER_DEBUG);
|
|
||||||
else
|
|
||||||
logger("Envelope was verified.", LOGGER_DEBUG);
|
|
||||||
} else
|
|
||||||
$x = false;
|
|
||||||
|
|
||||||
// This will work for older Diaspora and Friendica servers
|
|
||||||
if (!$x) {
|
|
||||||
$source_url = $server."/p/".urlencode($guid).".xml";
|
|
||||||
logger("Fetch post from ".$source_url, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$x = fetch_url($source_url);
|
|
||||||
if (!$x)
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$source_xml = parse_xml_string($x);
|
|
||||||
|
|
||||||
if (!is_object($source_xml))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if ($source_xml->post->reshare) {
|
|
||||||
// Reshare of a reshare - old Diaspora version
|
|
||||||
logger("Message is a reshare", LOGGER_DEBUG);
|
|
||||||
return self::message($source_xml->post->reshare->root_guid, $server, ++$level);
|
|
||||||
} elseif ($source_xml->getName() == "reshare") {
|
|
||||||
// Reshare of a reshare - new Diaspora version
|
|
||||||
logger("Message is a new reshare", LOGGER_DEBUG);
|
|
||||||
return self::message($source_xml->root_guid, $server, ++$level);
|
|
||||||
}
|
|
||||||
|
|
||||||
$author = "";
|
|
||||||
|
|
||||||
// Fetch the author - for the old and the new Diaspora version
|
|
||||||
if ($source_xml->post->status_message->diaspora_handle)
|
|
||||||
$author = (string)$source_xml->post->status_message->diaspora_handle;
|
|
||||||
elseif ($source_xml->author && ($source_xml->getName() == "status_message"))
|
|
||||||
$author = (string)$source_xml->author;
|
|
||||||
|
|
||||||
// If this isn't a "status_message" then quit
|
|
||||||
if (!$author) {
|
|
||||||
logger("Message doesn't seem to be a status message", LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$msg = array("message" => $x, "author" => $author);
|
|
||||||
|
|
||||||
$msg["key"] = self::key($msg["author"]);
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetches the item record of a given guid
|
|
||||||
*
|
|
||||||
* @param int $uid The user id
|
|
||||||
* @param string $guid message guid
|
|
||||||
* @param string $author The handle of the item
|
|
||||||
* @param array $contact The contact of the item owner
|
|
||||||
*
|
|
||||||
* @return array the item record
|
|
||||||
*/
|
|
||||||
private static function parent_item($uid, $guid, $author, $contact) {
|
|
||||||
$r = q("SELECT `id`, `parent`, `body`, `wall`, `uri`, `guid`, `private`, `origin`,
|
|
||||||
`author-name`, `author-link`, `author-avatar`,
|
|
||||||
`owner-name`, `owner-link`, `owner-avatar`
|
|
||||||
FROM `item` WHERE `uid` = %d AND `guid` = '%s' LIMIT 1",
|
|
||||||
intval($uid), dbesc($guid));
|
|
||||||
|
|
||||||
if (!$r) {
|
|
||||||
$result = self::store_by_guid($guid, $contact["url"], $uid);
|
|
||||||
|
|
||||||
if (!$result) {
|
|
||||||
$person = self::person_by_handle($author);
|
|
||||||
$result = self::store_by_guid($guid, $person["url"], $uid);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($result) {
|
|
||||||
logger("Fetched missing item ".$guid." - result: ".$result, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$r = q("SELECT `id`, `body`, `wall`, `uri`, `private`, `origin`,
|
|
||||||
`author-name`, `author-link`, `author-avatar`,
|
|
||||||
`owner-name`, `owner-link`, `owner-avatar`
|
|
||||||
FROM `item` WHERE `uid` = %d AND `guid` = '%s' LIMIT 1",
|
|
||||||
intval($uid), dbesc($guid));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$r) {
|
|
||||||
logger("parent item not found: parent: ".$guid." - user: ".$uid);
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
logger("parent item found: parent: ".$guid." - user: ".$uid);
|
|
||||||
return $r[0];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief returns contact details
|
|
||||||
*
|
|
||||||
* @param array $contact The default contact if the person isn't found
|
|
||||||
* @param array $person The record of the person
|
|
||||||
* @param int $uid The user id
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
* 'cid' => contact id
|
|
||||||
* 'network' => network type
|
|
||||||
*/
|
|
||||||
private static function author_contact_by_url($contact, $person, $uid) {
|
|
||||||
|
|
||||||
$r = q("SELECT `id`, `network`, `url` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
dbesc(normalise_link($person["url"])), intval($uid));
|
|
||||||
if ($r) {
|
|
||||||
$cid = $r[0]["id"];
|
|
||||||
$network = $r[0]["network"];
|
|
||||||
|
|
||||||
// We are receiving content from a user that possibly is about to be terminated
|
|
||||||
// This means the user is vital, so we remove a possible termination date.
|
|
||||||
unmark_for_death($r[0]);
|
|
||||||
} else {
|
|
||||||
$cid = $contact["id"];
|
|
||||||
$network = NETWORK_DIASPORA;
|
|
||||||
}
|
|
||||||
|
|
||||||
return array("cid" => $cid, "network" => $network);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Is the profile a hubzilla profile?
|
|
||||||
*
|
|
||||||
* @param string $url The profile link
|
|
||||||
*
|
|
||||||
* @return bool is it a hubzilla server?
|
|
||||||
*/
|
|
||||||
public static function is_redmatrix($url) {
|
|
||||||
return(strstr($url, "/channel/"));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Generate a post link with a given handle and message guid
|
|
||||||
*
|
|
||||||
* @param string $addr The user handle
|
|
||||||
* @param string $guid message guid
|
|
||||||
*
|
|
||||||
* @return string the post link
|
|
||||||
*/
|
|
||||||
private static function plink($addr, $guid, $parent_guid = '') {
|
|
||||||
$r = q("SELECT `url`, `nick`, `network` FROM `fcontact` WHERE `addr`='%s' LIMIT 1", dbesc($addr));
|
|
||||||
|
|
||||||
// Fallback
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
if ($parent_guid != '') {
|
|
||||||
return "https://".substr($addr,strpos($addr,"@") + 1)."/posts/".$parent_guid."#".$guid;
|
|
||||||
} else {
|
|
||||||
return "https://".substr($addr,strpos($addr,"@") + 1)."/posts/".$guid;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Friendica contacts are often detected as Diaspora contacts in the "fcontact" table
|
|
||||||
// So we try another way as well.
|
|
||||||
$s = q("SELECT `network` FROM `gcontact` WHERE `nurl`='%s' LIMIT 1", dbesc(normalise_link($r[0]["url"])));
|
|
||||||
if (dbm::is_result($s)) {
|
|
||||||
$r[0]["network"] = $s[0]["network"];
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($r[0]["network"] == NETWORK_DFRN) {
|
|
||||||
return str_replace("/profile/".$r[0]["nick"]."/", "/display/".$guid, $r[0]["url"]."/");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (self::is_redmatrix($r[0]["url"])) {
|
|
||||||
return $r[0]["url"]."/?f=&mid=".$guid;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($parent_guid != '') {
|
|
||||||
return "https://".substr($addr,strpos($addr,"@")+1)."/posts/".$parent_guid."#".$guid;
|
|
||||||
} else {
|
|
||||||
return "https://".substr($addr,strpos($addr,"@")+1)."/posts/".$guid;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Receives account migration
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool Success
|
|
||||||
*/
|
|
||||||
private static function receiveAccountMigration($importer, $data) {
|
|
||||||
$old_handle = notags(unxmlify($data->author));
|
|
||||||
$new_handle = notags(unxmlify($data->profile->author));
|
|
||||||
$signature = notags(unxmlify($data->signature));
|
|
||||||
|
|
||||||
$contact = self::contact_by_handle($importer["uid"], $old_handle);
|
|
||||||
if (!$contact) {
|
|
||||||
logger("cannot find contact for sender: ".$old_handle." and user ".$importer["uid"]);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("Got migration for ".$old_handle.", to ".$new_handle." with user ".$importer["uid"]);
|
|
||||||
|
|
||||||
// Check signature
|
|
||||||
$signed_text = 'AccountMigration:'.$old_handle.':'.$new_handle;
|
|
||||||
$key = self::key($old_handle);
|
|
||||||
if (!rsa_verify($signed_text, $signature, $key, "sha256")) {
|
|
||||||
logger('No valid signature for migration.');
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update the profile
|
|
||||||
self::receive_profile($importer, $data->profile);
|
|
||||||
|
|
||||||
// change the technical stuff in contact and gcontact
|
|
||||||
$data = Probe::uri($new_handle);
|
|
||||||
if ($data['network'] == NETWORK_PHANTOM) {
|
|
||||||
logger('Account for '.$new_handle." couldn't be probed.");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$fields = array('url' => $data['url'], 'nurl' => normalise_link($data['url']),
|
|
||||||
'name' => $data['name'], 'nick' => $data['nick'],
|
|
||||||
'addr' => $data['addr'], 'batch' => $data['batch'],
|
|
||||||
'notify' => $data['notify'], 'poll' => $data['poll'],
|
|
||||||
'network' => $data['network']);
|
|
||||||
|
|
||||||
dba::update('contact', $fields, array('addr' => $old_handle));
|
|
||||||
|
|
||||||
$fields = array('url' => $data['url'], 'nurl' => normalise_link($data['url']),
|
|
||||||
'name' => $data['name'], 'nick' => $data['nick'],
|
|
||||||
'addr' => $data['addr'], 'connect' => $data['addr'],
|
|
||||||
'notify' => $data['notify'], 'photo' => $data['photo'],
|
|
||||||
'server_url' => $data['baseurl'], 'network' => $data['network']);
|
|
||||||
|
|
||||||
dba::update('gcontact', $fields, array('addr' => $old_handle));
|
|
||||||
|
|
||||||
logger('Contacts are updated.');
|
|
||||||
|
|
||||||
// update items
|
|
||||||
/// @todo This is an extreme performance killer
|
|
||||||
$fields = array(
|
|
||||||
'owner-link' => array($contact["url"], $data["url"]),
|
|
||||||
'author-link' => array($contact["url"], $data["url"]),
|
|
||||||
);
|
|
||||||
foreach ($fields as $n=>$f) {
|
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `%s` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
$n, dbesc($f[0]),
|
|
||||||
intval($importer["uid"]));
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
$x = q("UPDATE `item` SET `%s` = '%s' WHERE `%s` = '%s' AND `uid` = %d",
|
|
||||||
$n, dbesc($f[1]),
|
|
||||||
$n, dbesc($f[0]),
|
|
||||||
intval($importer["uid"]));
|
|
||||||
|
|
||||||
if ($x === false) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
logger('Items are updated.');
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes an account deletion
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool Success
|
|
||||||
*/
|
|
||||||
private static function receive_account_deletion($importer, $data) {
|
|
||||||
|
|
||||||
/// @todo Account deletion should remove the contact from the global contacts as well
|
|
||||||
|
|
||||||
$author = notags(unxmlify($data->author));
|
|
||||||
|
|
||||||
$contact = self::contact_by_handle($importer["uid"], $author);
|
|
||||||
if (!$contact) {
|
|
||||||
logger("cannot find contact for author: ".$author);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// We now remove the contact
|
|
||||||
contact_remove($contact["id"]);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetch the uri from our database if we already have this item (maybe from ourselves)
|
|
||||||
*
|
|
||||||
* @param string $author Author handle
|
|
||||||
* @param string $guid Message guid
|
|
||||||
* @param boolean $onlyfound Only return uri when found in the database
|
|
||||||
*
|
|
||||||
* @return string The constructed uri or the one from our database
|
|
||||||
*/
|
|
||||||
private static function get_uri_from_guid($author, $guid, $onlyfound = false) {
|
|
||||||
|
|
||||||
$r = q("SELECT `uri` FROM `item` WHERE `guid` = '%s' LIMIT 1", dbesc($guid));
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return $r[0]["uri"];
|
|
||||||
} elseif (!$onlyfound) {
|
|
||||||
return $author.":".$guid;
|
|
||||||
}
|
|
||||||
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetch the guid from our database with a given uri
|
|
||||||
*
|
|
||||||
* @param string $author Author handle
|
|
||||||
* @param string $uri Message uri
|
|
||||||
*
|
|
||||||
* @return string The post guid
|
|
||||||
*/
|
|
||||||
private static function get_guid_from_uri($uri, $uid) {
|
|
||||||
|
|
||||||
$r = q("SELECT `guid` FROM `item` WHERE `uri` = '%s' AND `uid` = %d LIMIT 1", dbesc($uri), intval($uid));
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
return $r[0]["guid"];
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Find the best importer for a comment, like, ...
|
|
||||||
*
|
|
||||||
* @param string $guid The guid of the item
|
|
||||||
*
|
|
||||||
* @return array|boolean the origin owner of that post - or false
|
|
||||||
*/
|
|
||||||
private static function importer_for_guid($guid) {
|
|
||||||
$item = dba::fetch_first("SELECT `uid` FROM `item` WHERE `origin` AND `guid` = ? LIMIT 1", $guid);
|
|
||||||
|
|
||||||
if (dbm::is_result($item)) {
|
|
||||||
logger("Found user ".$item['uid']." as owner of item ".$guid, LOGGER_DEBUG);
|
|
||||||
$contact = dba::fetch_first("SELECT * FROM `contact` WHERE `self` AND `uid` = ?", $item['uid']);
|
|
||||||
if (dbm::is_result($contact)) {
|
|
||||||
return $contact;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes an incoming comment
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param string $sender The sender of the message
|
|
||||||
* @param object $data The message object
|
|
||||||
* @param string $xml The original XML of the message
|
|
||||||
*
|
|
||||||
* @return int The message id of the generated comment or "false" if there was an error
|
|
||||||
*/
|
|
||||||
private static function receive_comment($importer, $sender, $data, $xml) {
|
|
||||||
$author = notags(unxmlify($data->author));
|
|
||||||
$guid = notags(unxmlify($data->guid));
|
|
||||||
$parent_guid = notags(unxmlify($data->parent_guid));
|
|
||||||
$text = unxmlify($data->text);
|
|
||||||
|
|
||||||
if (isset($data->created_at)) {
|
|
||||||
$created_at = datetime_convert("UTC", "UTC", notags(unxmlify($data->created_at)));
|
|
||||||
} else {
|
|
||||||
$created_at = datetime_convert();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($data->thread_parent_guid)) {
|
|
||||||
$thread_parent_guid = notags(unxmlify($data->thread_parent_guid));
|
|
||||||
$thr_uri = self::get_uri_from_guid("", $thread_parent_guid, true);
|
|
||||||
} else {
|
|
||||||
$thr_uri = "";
|
|
||||||
}
|
|
||||||
|
|
||||||
$contact = self::allowed_contact_by_handle($importer, $sender, true);
|
|
||||||
if (!$contact) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$message_id = self::message_exists($importer["uid"], $guid);
|
|
||||||
if ($message_id) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$parent_item = self::parent_item($importer["uid"], $parent_guid, $author, $contact);
|
|
||||||
if (!$parent_item) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$person = self::person_by_handle($author);
|
|
||||||
if (!is_array($person)) {
|
|
||||||
logger("unable to find author details");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fetch the contact id - if we know this contact
|
|
||||||
$author_contact = self::author_contact_by_url($contact, $person, $importer["uid"]);
|
|
||||||
|
|
||||||
$datarray = array();
|
|
||||||
|
|
||||||
$datarray["uid"] = $importer["uid"];
|
|
||||||
$datarray["contact-id"] = $author_contact["cid"];
|
|
||||||
$datarray["network"] = $author_contact["network"];
|
|
||||||
|
|
||||||
$datarray["author-name"] = $person["name"];
|
|
||||||
$datarray["author-link"] = $person["url"];
|
|
||||||
$datarray["author-avatar"] = ((x($person,"thumb")) ? $person["thumb"] : $person["photo"]);
|
|
||||||
|
|
||||||
$datarray["owner-name"] = $contact["name"];
|
|
||||||
$datarray["owner-link"] = $contact["url"];
|
|
||||||
$datarray["owner-avatar"] = ((x($contact,"thumb")) ? $contact["thumb"] : $contact["photo"]);
|
|
||||||
|
|
||||||
$datarray["guid"] = $guid;
|
|
||||||
$datarray["uri"] = self::get_uri_from_guid($author, $guid);
|
|
||||||
|
|
||||||
$datarray["type"] = "remote-comment";
|
|
||||||
$datarray["verb"] = ACTIVITY_POST;
|
|
||||||
$datarray["gravity"] = GRAVITY_COMMENT;
|
|
||||||
|
|
||||||
if ($thr_uri != "") {
|
|
||||||
$datarray["parent-uri"] = $thr_uri;
|
|
||||||
} else {
|
|
||||||
$datarray["parent-uri"] = $parent_item["uri"];
|
|
||||||
}
|
|
||||||
|
|
||||||
$datarray["object-type"] = ACTIVITY_OBJ_COMMENT;
|
|
||||||
|
|
||||||
$datarray["protocol"] = PROTOCOL_DIASPORA;
|
|
||||||
$datarray["source"] = $xml;
|
|
||||||
|
|
||||||
$datarray["changed"] = $datarray["created"] = $datarray["edited"] = $created_at;
|
|
||||||
|
|
||||||
$datarray["plink"] = self::plink($author, $guid, $parent_item['guid']);
|
|
||||||
|
|
||||||
$body = diaspora2bb($text);
|
|
||||||
|
|
||||||
$datarray["body"] = self::replace_people_guid($body, $person["url"]);
|
|
||||||
|
|
||||||
self::fetch_guid($datarray);
|
|
||||||
|
|
||||||
$message_id = item_store($datarray);
|
|
||||||
|
|
||||||
if ($message_id <= 0) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($message_id) {
|
|
||||||
logger("Stored comment ".$datarray["guid"]." with message id ".$message_id, LOGGER_DEBUG);
|
|
||||||
}
|
|
||||||
|
|
||||||
// If we are the origin of the parent we store the original data and notify our followers
|
|
||||||
if ($message_id && $parent_item["origin"]) {
|
|
||||||
|
|
||||||
// Formerly we stored the signed text, the signature and the author in different fields.
|
|
||||||
// We now store the raw data so that we are more flexible.
|
|
||||||
dba::insert('sign', array('iid' => $message_id, 'signed_text' => json_encode($data)));
|
|
||||||
|
|
||||||
// notify others
|
|
||||||
Worker::add(PRIORITY_HIGH, "notifier", "comment-import", $message_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief processes and stores private messages
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param array $contact The contact of the message
|
|
||||||
* @param object $data The message object
|
|
||||||
* @param array $msg Array of the processed message, author handle and key
|
|
||||||
* @param object $mesg The private message
|
|
||||||
* @param array $conversation The conversation record to which this message belongs
|
|
||||||
*
|
|
||||||
* @return bool "true" if it was successful
|
|
||||||
*/
|
|
||||||
private static function receive_conversation_message($importer, $contact, $data, $msg, $mesg, $conversation) {
|
|
||||||
$author = notags(unxmlify($data->author));
|
|
||||||
$guid = notags(unxmlify($data->guid));
|
|
||||||
$subject = notags(unxmlify($data->subject));
|
|
||||||
|
|
||||||
// "diaspora_handle" is the element name from the old version
|
|
||||||
// "author" is the element name from the new version
|
|
||||||
if ($mesg->author) {
|
|
||||||
$msg_author = notags(unxmlify($mesg->author));
|
|
||||||
} elseif ($mesg->diaspora_handle) {
|
|
||||||
$msg_author = notags(unxmlify($mesg->diaspora_handle));
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$msg_guid = notags(unxmlify($mesg->guid));
|
|
||||||
$msg_conversation_guid = notags(unxmlify($mesg->conversation_guid));
|
|
||||||
$msg_text = unxmlify($mesg->text);
|
|
||||||
$msg_created_at = datetime_convert("UTC", "UTC", notags(unxmlify($mesg->created_at)));
|
|
||||||
|
|
||||||
if ($msg_conversation_guid != $guid) {
|
|
||||||
logger("message conversation guid does not belong to the current conversation.");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$body = diaspora2bb($msg_text);
|
|
||||||
$message_uri = $msg_author.":".$msg_guid;
|
|
||||||
|
|
||||||
$person = self::person_by_handle($msg_author);
|
|
||||||
|
|
||||||
dba::lock('mail');
|
|
||||||
|
|
||||||
$r = q("SELECT `id` FROM `mail` WHERE `guid` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
dbesc($msg_guid),
|
|
||||||
intval($importer["uid"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
logger("duplicate message already delivered.", LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
q("INSERT INTO `mail` (`uid`, `guid`, `convid`, `from-name`,`from-photo`,`from-url`,`contact-id`,`title`,`body`,`seen`,`reply`,`uri`,`parent-uri`,`created`)
|
|
||||||
VALUES (%d, '%s', %d, '%s', '%s', '%s', %d, '%s', '%s', %d, %d, '%s','%s','%s')",
|
|
||||||
intval($importer["uid"]),
|
|
||||||
dbesc($msg_guid),
|
|
||||||
intval($conversation["id"]),
|
|
||||||
dbesc($person["name"]),
|
|
||||||
dbesc($person["photo"]),
|
|
||||||
dbesc($person["url"]),
|
|
||||||
intval($contact["id"]),
|
|
||||||
dbesc($subject),
|
|
||||||
dbesc($body),
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
dbesc($message_uri),
|
|
||||||
dbesc($author.":".$guid),
|
|
||||||
dbesc($msg_created_at)
|
|
||||||
);
|
|
||||||
|
|
||||||
dba::unlock();
|
|
||||||
|
|
||||||
dba::update('conv', array('updated' => datetime_convert()), array('id' => $conversation["id"]));
|
|
||||||
|
|
||||||
notification(array(
|
|
||||||
"type" => NOTIFY_MAIL,
|
|
||||||
"notify_flags" => $importer["notify-flags"],
|
|
||||||
"language" => $importer["language"],
|
|
||||||
"to_name" => $importer["username"],
|
|
||||||
"to_email" => $importer["email"],
|
|
||||||
"uid" =>$importer["uid"],
|
|
||||||
"item" => array("subject" => $subject, "body" => $body),
|
|
||||||
"source_name" => $person["name"],
|
|
||||||
"source_link" => $person["url"],
|
|
||||||
"source_photo" => $person["thumb"],
|
|
||||||
"verb" => ACTIVITY_POST,
|
|
||||||
"otype" => "mail"
|
|
||||||
));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes new private messages (answers to private messages are processed elsewhere)
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param array $msg Array of the processed message, author handle and key
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool Success
|
|
||||||
*/
|
|
||||||
private static function receive_conversation($importer, $msg, $data) {
|
|
||||||
$author = notags(unxmlify($data->author));
|
|
||||||
$guid = notags(unxmlify($data->guid));
|
|
||||||
$subject = notags(unxmlify($data->subject));
|
|
||||||
$created_at = datetime_convert("UTC", "UTC", notags(unxmlify($data->created_at)));
|
|
||||||
$participants = notags(unxmlify($data->participants));
|
|
||||||
|
|
||||||
$messages = $data->message;
|
|
||||||
|
|
||||||
if (!count($messages)) {
|
|
||||||
logger("empty conversation");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$contact = self::allowed_contact_by_handle($importer, $msg["author"], true);
|
|
||||||
if (!$contact)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
$conversation = null;
|
|
||||||
|
|
||||||
$c = q("SELECT * FROM `conv` WHERE `uid` = %d AND `guid` = '%s' LIMIT 1",
|
|
||||||
intval($importer["uid"]),
|
|
||||||
dbesc($guid)
|
|
||||||
);
|
|
||||||
if ($c)
|
|
||||||
$conversation = $c[0];
|
|
||||||
else {
|
|
||||||
$r = q("INSERT INTO `conv` (`uid`, `guid`, `creator`, `created`, `updated`, `subject`, `recips`)
|
|
||||||
VALUES (%d, '%s', '%s', '%s', '%s', '%s', '%s')",
|
|
||||||
intval($importer["uid"]),
|
|
||||||
dbesc($guid),
|
|
||||||
dbesc($author),
|
|
||||||
dbesc($created_at),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc($subject),
|
|
||||||
dbesc($participants)
|
|
||||||
);
|
|
||||||
if ($r)
|
|
||||||
$c = q("SELECT * FROM `conv` WHERE `uid` = %d AND `guid` = '%s' LIMIT 1",
|
|
||||||
intval($importer["uid"]),
|
|
||||||
dbesc($guid)
|
|
||||||
);
|
|
||||||
|
|
||||||
if ($c)
|
|
||||||
$conversation = $c[0];
|
|
||||||
}
|
|
||||||
if (!$conversation) {
|
|
||||||
logger("unable to create conversation.");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($messages as $mesg)
|
|
||||||
self::receive_conversation_message($importer, $contact, $data, $msg, $mesg, $conversation);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates the body for a "like" message
|
|
||||||
*
|
|
||||||
* @param array $contact The contact that send us the "like"
|
|
||||||
* @param array $parent_item The item array of the parent item
|
|
||||||
* @param string $guid message guid
|
|
||||||
*
|
|
||||||
* @return string the body
|
|
||||||
*/
|
|
||||||
private static function construct_like_body($contact, $parent_item, $guid) {
|
|
||||||
$bodyverb = t('%1$s likes %2$s\'s %3$s');
|
|
||||||
|
|
||||||
$ulink = "[url=".$contact["url"]."]".$contact["name"]."[/url]";
|
|
||||||
$alink = "[url=".$parent_item["author-link"]."]".$parent_item["author-name"]."[/url]";
|
|
||||||
$plink = "[url=".System::baseUrl()."/display/".urlencode($guid)."]".t("status")."[/url]";
|
|
||||||
|
|
||||||
return sprintf($bodyverb, $ulink, $alink, $plink);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates a XML object for a "like"
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param array $parent_item The item array of the parent item
|
|
||||||
*
|
|
||||||
* @return string The XML
|
|
||||||
*/
|
|
||||||
private static function construct_like_object($importer, $parent_item) {
|
|
||||||
$objtype = ACTIVITY_OBJ_NOTE;
|
|
||||||
$link = '<link rel="alternate" type="text/html" href="'.System::baseUrl()."/display/".$importer["nickname"]."/".$parent_item["id"].'" />';
|
|
||||||
$parent_body = $parent_item["body"];
|
|
||||||
|
|
||||||
$xmldata = array("object" => array("type" => $objtype,
|
|
||||||
"local" => "1",
|
|
||||||
"id" => $parent_item["uri"],
|
|
||||||
"link" => $link,
|
|
||||||
"title" => "",
|
|
||||||
"content" => $parent_body));
|
|
||||||
|
|
||||||
return xml::from_array($xmldata, $xml, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes "like" messages
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param string $sender The sender of the message
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return int The message id of the generated like or "false" if there was an error
|
|
||||||
*/
|
|
||||||
private static function receive_like($importer, $sender, $data) {
|
|
||||||
$author = notags(unxmlify($data->author));
|
|
||||||
$guid = notags(unxmlify($data->guid));
|
|
||||||
$parent_guid = notags(unxmlify($data->parent_guid));
|
|
||||||
$parent_type = notags(unxmlify($data->parent_type));
|
|
||||||
$positive = notags(unxmlify($data->positive));
|
|
||||||
|
|
||||||
// likes on comments aren't supported by Diaspora - only on posts
|
|
||||||
// But maybe this will be supported in the future, so we will accept it.
|
|
||||||
if (!in_array($parent_type, array("Post", "Comment")))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
$contact = self::allowed_contact_by_handle($importer, $sender, true);
|
|
||||||
if (!$contact)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
$message_id = self::message_exists($importer["uid"], $guid);
|
|
||||||
if ($message_id)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
$parent_item = self::parent_item($importer["uid"], $parent_guid, $author, $contact);
|
|
||||||
if (!$parent_item)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
$person = self::person_by_handle($author);
|
|
||||||
if (!is_array($person)) {
|
|
||||||
logger("unable to find author details");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fetch the contact id - if we know this contact
|
|
||||||
$author_contact = self::author_contact_by_url($contact, $person, $importer["uid"]);
|
|
||||||
|
|
||||||
// "positive" = "false" would be a Dislike - wich isn't currently supported by Diaspora
|
|
||||||
// We would accept this anyhow.
|
|
||||||
if ($positive == "true")
|
|
||||||
$verb = ACTIVITY_LIKE;
|
|
||||||
else
|
|
||||||
$verb = ACTIVITY_DISLIKE;
|
|
||||||
|
|
||||||
$datarray = array();
|
|
||||||
|
|
||||||
$datarray["protocol"] = PROTOCOL_DIASPORA;
|
|
||||||
|
|
||||||
$datarray["uid"] = $importer["uid"];
|
|
||||||
$datarray["contact-id"] = $author_contact["cid"];
|
|
||||||
$datarray["network"] = $author_contact["network"];
|
|
||||||
|
|
||||||
$datarray["author-name"] = $person["name"];
|
|
||||||
$datarray["author-link"] = $person["url"];
|
|
||||||
$datarray["author-avatar"] = ((x($person,"thumb")) ? $person["thumb"] : $person["photo"]);
|
|
||||||
|
|
||||||
$datarray["owner-name"] = $contact["name"];
|
|
||||||
$datarray["owner-link"] = $contact["url"];
|
|
||||||
$datarray["owner-avatar"] = ((x($contact,"thumb")) ? $contact["thumb"] : $contact["photo"]);
|
|
||||||
|
|
||||||
$datarray["guid"] = $guid;
|
|
||||||
$datarray["uri"] = self::get_uri_from_guid($author, $guid);
|
|
||||||
|
|
||||||
$datarray["type"] = "activity";
|
|
||||||
$datarray["verb"] = $verb;
|
|
||||||
$datarray["gravity"] = GRAVITY_LIKE;
|
|
||||||
$datarray["parent-uri"] = $parent_item["uri"];
|
|
||||||
|
|
||||||
$datarray["object-type"] = ACTIVITY_OBJ_NOTE;
|
|
||||||
$datarray["object"] = self::construct_like_object($importer, $parent_item);
|
|
||||||
|
|
||||||
$datarray["body"] = self::construct_like_body($contact, $parent_item, $guid);
|
|
||||||
|
|
||||||
$message_id = item_store($datarray);
|
|
||||||
|
|
||||||
if ($message_id <= 0) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($message_id) {
|
|
||||||
logger("Stored like ".$datarray["guid"]." with message id ".$message_id, LOGGER_DEBUG);
|
|
||||||
}
|
|
||||||
|
|
||||||
// like on comments have the comment as parent. So we need to fetch the toplevel parent
|
|
||||||
if ($parent_item["id"] != $parent_item["parent"]) {
|
|
||||||
$toplevel = dba::select('item', array('origin'), array('id' => $parent_item["parent"]), array('limit' => 1));
|
|
||||||
$origin = $toplevel["origin"];
|
|
||||||
} else {
|
|
||||||
$origin = $parent_item["origin"];
|
|
||||||
}
|
|
||||||
|
|
||||||
// If we are the origin of the parent we store the original data and notify our followers
|
|
||||||
if ($message_id && $origin) {
|
|
||||||
|
|
||||||
// Formerly we stored the signed text, the signature and the author in different fields.
|
|
||||||
// We now store the raw data so that we are more flexible.
|
|
||||||
dba::insert('sign', array('iid' => $message_id, 'signed_text' => json_encode($data)));
|
|
||||||
|
|
||||||
// notify others
|
|
||||||
Worker::add(PRIORITY_HIGH, "notifier", "comment-import", $message_id);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes private messages
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool Success?
|
|
||||||
*/
|
|
||||||
private static function receive_message($importer, $data) {
|
|
||||||
$author = notags(unxmlify($data->author));
|
|
||||||
$guid = notags(unxmlify($data->guid));
|
|
||||||
$conversation_guid = notags(unxmlify($data->conversation_guid));
|
|
||||||
$text = unxmlify($data->text);
|
|
||||||
$created_at = datetime_convert("UTC", "UTC", notags(unxmlify($data->created_at)));
|
|
||||||
|
|
||||||
$contact = self::allowed_contact_by_handle($importer, $author, true);
|
|
||||||
if (!$contact) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$conversation = null;
|
|
||||||
|
|
||||||
$c = q("SELECT * FROM `conv` WHERE `uid` = %d AND `guid` = '%s' LIMIT 1",
|
|
||||||
intval($importer["uid"]),
|
|
||||||
dbesc($conversation_guid)
|
|
||||||
);
|
|
||||||
if ($c) {
|
|
||||||
$conversation = $c[0];
|
|
||||||
} else {
|
|
||||||
logger("conversation not available.");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$message_uri = $author.":".$guid;
|
|
||||||
|
|
||||||
$person = self::person_by_handle($author);
|
|
||||||
if (!$person) {
|
|
||||||
logger("unable to find author details");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$body = diaspora2bb($text);
|
|
||||||
|
|
||||||
$body = self::replace_people_guid($body, $person["url"]);
|
|
||||||
|
|
||||||
dba::lock('mail');
|
|
||||||
|
|
||||||
$r = q("SELECT `id` FROM `mail` WHERE `guid` = '%s' AND `uid` = %d LIMIT 1",
|
|
||||||
dbesc($guid),
|
|
||||||
intval($importer["uid"])
|
|
||||||
);
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
logger("duplicate message already delivered.", LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
q("INSERT INTO `mail` (`uid`, `guid`, `convid`, `from-name`,`from-photo`,`from-url`,`contact-id`,`title`,`body`,`seen`,`reply`,`uri`,`parent-uri`,`created`)
|
|
||||||
VALUES ( %d, '%s', %d, '%s', '%s', '%s', %d, '%s', '%s', %d, %d, '%s','%s','%s')",
|
|
||||||
intval($importer["uid"]),
|
|
||||||
dbesc($guid),
|
|
||||||
intval($conversation["id"]),
|
|
||||||
dbesc($person["name"]),
|
|
||||||
dbesc($person["photo"]),
|
|
||||||
dbesc($person["url"]),
|
|
||||||
intval($contact["id"]),
|
|
||||||
dbesc($conversation["subject"]),
|
|
||||||
dbesc($body),
|
|
||||||
0,
|
|
||||||
1,
|
|
||||||
dbesc($message_uri),
|
|
||||||
dbesc($author.":".$conversation["guid"]),
|
|
||||||
dbesc($created_at)
|
|
||||||
);
|
|
||||||
|
|
||||||
dba::unlock();
|
|
||||||
|
|
||||||
dba::update('conv', array('updated' => datetime_convert()), array('id' => $conversation["id"]));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes participations - unsupported by now
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool always true
|
|
||||||
*/
|
|
||||||
private static function receive_participation($importer, $data) {
|
|
||||||
// I'm not sure if we can fully support this message type
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes photos - unneeded
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool always true
|
|
||||||
*/
|
|
||||||
private static function receive_photo($importer, $data) {
|
|
||||||
// There doesn't seem to be a reason for this function, since the photo data is transmitted in the status message as well
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes poll participations - unssupported
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool always true
|
|
||||||
*/
|
|
||||||
private static function receive_poll_participation($importer, $data) {
|
|
||||||
// We don't support polls by now
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes incoming profile updates
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool Success
|
|
||||||
*/
|
|
||||||
private static function receive_profile($importer, $data) {
|
|
||||||
$author = strtolower(notags(unxmlify($data->author)));
|
|
||||||
|
|
||||||
$contact = self::contact_by_handle($importer["uid"], $author);
|
|
||||||
if (!$contact)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
$name = unxmlify($data->first_name).((strlen($data->last_name)) ? " ".unxmlify($data->last_name) : "");
|
|
||||||
$image_url = unxmlify($data->image_url);
|
|
||||||
$birthday = unxmlify($data->birthday);
|
|
||||||
$gender = unxmlify($data->gender);
|
|
||||||
$about = diaspora2bb(unxmlify($data->bio));
|
|
||||||
$location = diaspora2bb(unxmlify($data->location));
|
|
||||||
$searchable = (unxmlify($data->searchable) == "true");
|
|
||||||
$nsfw = (unxmlify($data->nsfw) == "true");
|
|
||||||
$tags = unxmlify($data->tag_string);
|
|
||||||
|
|
||||||
$tags = explode("#", $tags);
|
|
||||||
|
|
||||||
$keywords = array();
|
|
||||||
foreach ($tags as $tag) {
|
|
||||||
$tag = trim(strtolower($tag));
|
|
||||||
if ($tag != "")
|
|
||||||
$keywords[] = $tag;
|
|
||||||
}
|
|
||||||
|
|
||||||
$keywords = implode(", ", $keywords);
|
|
||||||
|
|
||||||
$handle_parts = explode("@", $author);
|
|
||||||
$nick = $handle_parts[0];
|
|
||||||
|
|
||||||
if ($name === "")
|
|
||||||
$name = $handle_parts[0];
|
|
||||||
|
|
||||||
if ( preg_match("|^https?://|", $image_url) === 0)
|
|
||||||
$image_url = "http://".$handle_parts[1].$image_url;
|
|
||||||
|
|
||||||
update_contact_avatar($image_url, $importer["uid"], $contact["id"]);
|
|
||||||
|
|
||||||
// Generic birthday. We don't know the timezone. The year is irrelevant.
|
|
||||||
|
|
||||||
$birthday = str_replace("1000", "1901", $birthday);
|
|
||||||
|
|
||||||
if ($birthday != "")
|
|
||||||
$birthday = datetime_convert("UTC", "UTC", $birthday, "Y-m-d");
|
|
||||||
|
|
||||||
// this is to prevent multiple birthday notifications in a single year
|
|
||||||
// if we already have a stored birthday and the 'm-d' part hasn't changed, preserve the entry, which will preserve the notify year
|
|
||||||
|
|
||||||
if (substr($birthday,5) === substr($contact["bd"],5))
|
|
||||||
$birthday = $contact["bd"];
|
|
||||||
|
|
||||||
$r = q("UPDATE `contact` SET `name` = '%s', `nick` = '%s', `addr` = '%s', `name-date` = '%s', `bd` = '%s',
|
|
||||||
`location` = '%s', `about` = '%s', `keywords` = '%s', `gender` = '%s' WHERE `id` = %d AND `uid` = %d",
|
|
||||||
dbesc($name),
|
|
||||||
dbesc($nick),
|
|
||||||
dbesc($author),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc($birthday),
|
|
||||||
dbesc($location),
|
|
||||||
dbesc($about),
|
|
||||||
dbesc($keywords),
|
|
||||||
dbesc($gender),
|
|
||||||
intval($contact["id"]),
|
|
||||||
intval($importer["uid"])
|
|
||||||
);
|
|
||||||
|
|
||||||
$gcontact = array("url" => $contact["url"], "network" => NETWORK_DIASPORA, "generation" => 2,
|
|
||||||
"photo" => $image_url, "name" => $name, "location" => $location,
|
|
||||||
"about" => $about, "birthday" => $birthday, "gender" => $gender,
|
|
||||||
"addr" => $author, "nick" => $nick, "keywords" => $keywords,
|
|
||||||
"hide" => !$searchable, "nsfw" => $nsfw);
|
|
||||||
|
|
||||||
$gcid = update_gcontact($gcontact);
|
|
||||||
|
|
||||||
link_gcontact($gcid, $importer["uid"], $contact["id"]);
|
|
||||||
|
|
||||||
logger("Profile of contact ".$contact["id"]." stored for user ".$importer["uid"], LOGGER_DEBUG);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes incoming friend requests
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param array $contact The contact that send the request
|
|
||||||
*/
|
|
||||||
private static function receive_request_make_friend($importer, $contact) {
|
|
||||||
|
|
||||||
$a = get_app();
|
|
||||||
|
|
||||||
if ($contact["rel"] == CONTACT_IS_SHARING) {
|
|
||||||
dba::update('contact', array('rel' => CONTACT_IS_FRIEND, 'writable' => true),
|
|
||||||
array('id' => $contact["id"], 'uid' => $importer["uid"]));
|
|
||||||
}
|
|
||||||
// send notification
|
|
||||||
|
|
||||||
$r = q("SELECT `hide-friends` FROM `profile` WHERE `uid` = %d AND `is-default` = 1 LIMIT 1",
|
|
||||||
intval($importer["uid"])
|
|
||||||
);
|
|
||||||
|
|
||||||
if ($r && !$r[0]["hide-friends"] && !$contact["hidden"] && intval(PConfig::get($importer["uid"], "system", "post_newfriend"))) {
|
|
||||||
|
|
||||||
$self = q("SELECT * FROM `contact` WHERE `self` AND `uid` = %d LIMIT 1",
|
|
||||||
intval($importer["uid"])
|
|
||||||
);
|
|
||||||
|
|
||||||
// they are not CONTACT_IS_FOLLOWER anymore but that's what we have in the array
|
|
||||||
|
|
||||||
if ($self && $contact["rel"] == CONTACT_IS_FOLLOWER) {
|
|
||||||
|
|
||||||
$arr = array();
|
|
||||||
$arr["protocol"] = PROTOCOL_DIASPORA;
|
|
||||||
$arr["uri"] = $arr["parent-uri"] = item_new_uri($a->get_hostname(), $importer["uid"]);
|
|
||||||
$arr["uid"] = $importer["uid"];
|
|
||||||
$arr["contact-id"] = $self[0]["id"];
|
|
||||||
$arr["wall"] = 1;
|
|
||||||
$arr["type"] = 'wall';
|
|
||||||
$arr["gravity"] = 0;
|
|
||||||
$arr["origin"] = 1;
|
|
||||||
$arr["author-name"] = $arr["owner-name"] = $self[0]["name"];
|
|
||||||
$arr["author-link"] = $arr["owner-link"] = $self[0]["url"];
|
|
||||||
$arr["author-avatar"] = $arr["owner-avatar"] = $self[0]["thumb"];
|
|
||||||
$arr["verb"] = ACTIVITY_FRIEND;
|
|
||||||
$arr["object-type"] = ACTIVITY_OBJ_PERSON;
|
|
||||||
|
|
||||||
$A = "[url=".$self[0]["url"]."]".$self[0]["name"]."[/url]";
|
|
||||||
$B = "[url=".$contact["url"]."]".$contact["name"]."[/url]";
|
|
||||||
$BPhoto = "[url=".$contact["url"]."][img]".$contact["thumb"]."[/img][/url]";
|
|
||||||
$arr["body"] = sprintf(t("%1$s is now friends with %2$s"), $A, $B)."\n\n\n".$Bphoto;
|
|
||||||
|
|
||||||
$arr["object"] = self::construct_new_friend_object($contact);
|
|
||||||
|
|
||||||
$arr["last-child"] = 1;
|
|
||||||
|
|
||||||
$arr["allow_cid"] = $user[0]["allow_cid"];
|
|
||||||
$arr["allow_gid"] = $user[0]["allow_gid"];
|
|
||||||
$arr["deny_cid"] = $user[0]["deny_cid"];
|
|
||||||
$arr["deny_gid"] = $user[0]["deny_gid"];
|
|
||||||
|
|
||||||
$i = item_store($arr);
|
|
||||||
if ($i)
|
|
||||||
Worker::add(PRIORITY_HIGH, "notifier", "activity", $i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates a XML object for a "new friend" message
|
|
||||||
*
|
|
||||||
* @param array $contact Array of the contact
|
|
||||||
*
|
|
||||||
* @return string The XML
|
|
||||||
*/
|
|
||||||
private static function construct_new_friend_object($contact) {
|
|
||||||
$objtype = ACTIVITY_OBJ_PERSON;
|
|
||||||
$link = '<link rel="alternate" type="text/html" href="'.$contact["url"].'" />'."\n".
|
|
||||||
'<link rel="photo" type="image/jpeg" href="'.$contact["thumb"].'" />'."\n";
|
|
||||||
|
|
||||||
$xmldata = array("object" => array("type" => $objtype,
|
|
||||||
"title" => $contact["name"],
|
|
||||||
"id" => $contact["url"]."/".$contact["name"],
|
|
||||||
"link" => $link));
|
|
||||||
|
|
||||||
return xml::from_array($xmldata, $xml, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes incoming sharing notification
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool Success
|
|
||||||
*/
|
|
||||||
private static function receive_contact_request($importer, $data) {
|
|
||||||
$author = unxmlify($data->author);
|
|
||||||
$recipient = unxmlify($data->recipient);
|
|
||||||
|
|
||||||
if (!$author || !$recipient) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// the current protocol version doesn't know these fields
|
|
||||||
// That means that we will assume their existance
|
|
||||||
if (isset($data->following)) {
|
|
||||||
$following = (unxmlify($data->following) == "true");
|
|
||||||
} else {
|
|
||||||
$following = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($data->sharing)) {
|
|
||||||
$sharing = (unxmlify($data->sharing) == "true");
|
|
||||||
} else {
|
|
||||||
$sharing = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$contact = self::contact_by_handle($importer["uid"],$author);
|
|
||||||
|
|
||||||
// perhaps we were already sharing with this person. Now they're sharing with us.
|
|
||||||
// That makes us friends.
|
|
||||||
if ($contact) {
|
|
||||||
if ($following) {
|
|
||||||
logger("Author ".$author." (Contact ".$contact["id"].") wants to follow us.", LOGGER_DEBUG);
|
|
||||||
self::receive_request_make_friend($importer, $contact);
|
|
||||||
|
|
||||||
// refetch the contact array
|
|
||||||
$contact = self::contact_by_handle($importer["uid"],$author);
|
|
||||||
|
|
||||||
// If we are now friends, we are sending a share message.
|
|
||||||
// Normally we needn't to do so, but the first message could have been vanished.
|
|
||||||
if (in_array($contact["rel"], array(CONTACT_IS_FRIEND))) {
|
|
||||||
$u = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1", intval($importer["uid"]));
|
|
||||||
if ($u) {
|
|
||||||
logger("Sending share message to author ".$author." - Contact: ".$contact["id"]." - User: ".$importer["uid"], LOGGER_DEBUG);
|
|
||||||
$ret = self::send_share($u[0], $contact);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
logger("Author ".$author." doesn't want to follow us anymore.", LOGGER_DEBUG);
|
|
||||||
lose_follower($importer, $contact);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$following && $sharing && in_array($importer["page-flags"], array(PAGE_SOAPBOX, PAGE_NORMAL))) {
|
|
||||||
logger("Author ".$author." wants to share with us - but doesn't want to listen. Request is ignored.", LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
} elseif (!$following && !$sharing) {
|
|
||||||
logger("Author ".$author." doesn't want anything - and we don't know the author. Request is ignored.", LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
} elseif (!$following && $sharing) {
|
|
||||||
logger("Author ".$author." wants to share with us.", LOGGER_DEBUG);
|
|
||||||
} elseif ($following && $sharing) {
|
|
||||||
logger("Author ".$author." wants to have a bidirectional conection.", LOGGER_DEBUG);
|
|
||||||
} elseif ($following && !$sharing) {
|
|
||||||
logger("Author ".$author." wants to listen to us.", LOGGER_DEBUG);
|
|
||||||
}
|
|
||||||
|
|
||||||
$ret = self::person_by_handle($author);
|
|
||||||
|
|
||||||
if (!$ret || ($ret["network"] != NETWORK_DIASPORA)) {
|
|
||||||
logger("Cannot resolve diaspora handle ".$author." for ".$recipient);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$batch = (($ret["batch"]) ? $ret["batch"] : implode("/", array_slice(explode("/", $ret["url"]), 0, 3))."/receive/public");
|
|
||||||
|
|
||||||
$r = q("INSERT INTO `contact` (`uid`, `network`,`addr`,`created`,`url`,`nurl`,`batch`,`name`,`nick`,`photo`,`pubkey`,`notify`,`poll`,`blocked`,`priority`)
|
|
||||||
VALUES (%d, '%s', '%s', '%s', '%s','%s','%s','%s','%s','%s','%s','%s','%s',%d,%d)",
|
|
||||||
intval($importer["uid"]),
|
|
||||||
dbesc($ret["network"]),
|
|
||||||
dbesc($ret["addr"]),
|
|
||||||
datetime_convert(),
|
|
||||||
dbesc($ret["url"]),
|
|
||||||
dbesc(normalise_link($ret["url"])),
|
|
||||||
dbesc($batch),
|
|
||||||
dbesc($ret["name"]),
|
|
||||||
dbesc($ret["nick"]),
|
|
||||||
dbesc($ret["photo"]),
|
|
||||||
dbesc($ret["pubkey"]),
|
|
||||||
dbesc($ret["notify"]),
|
|
||||||
dbesc($ret["poll"]),
|
|
||||||
1,
|
|
||||||
2
|
|
||||||
);
|
|
||||||
|
|
||||||
// find the contact record we just created
|
|
||||||
|
|
||||||
$contact_record = self::contact_by_handle($importer["uid"],$author);
|
|
||||||
|
|
||||||
if (!$contact_record) {
|
|
||||||
logger("unable to locate newly created contact record.");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("Author ".$author." was added as contact number ".$contact_record["id"].".", LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$def_gid = get_default_group($importer['uid'], $ret["network"]);
|
|
||||||
|
|
||||||
if (intval($def_gid))
|
|
||||||
group_add_member($importer["uid"], "", $contact_record["id"], $def_gid);
|
|
||||||
|
|
||||||
update_contact_avatar($ret["photo"], $importer['uid'], $contact_record["id"], true);
|
|
||||||
|
|
||||||
if ($importer["page-flags"] == PAGE_NORMAL) {
|
|
||||||
|
|
||||||
logger("Sending intra message for author ".$author.".", LOGGER_DEBUG);
|
|
||||||
|
|
||||||
$hash = random_string().(string)time(); // Generate a confirm_key
|
|
||||||
|
|
||||||
$ret = q("INSERT INTO `intro` (`uid`, `contact-id`, `blocked`, `knowyou`, `note`, `hash`, `datetime`)
|
|
||||||
VALUES (%d, %d, %d, %d, '%s', '%s', '%s')",
|
|
||||||
intval($importer["uid"]),
|
|
||||||
intval($contact_record["id"]),
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
dbesc(t("Sharing notification from Diaspora network")),
|
|
||||||
dbesc($hash),
|
|
||||||
dbesc(datetime_convert())
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
|
|
||||||
// automatic friend approval
|
|
||||||
|
|
||||||
logger("Does an automatic friend approval for author ".$author.".", LOGGER_DEBUG);
|
|
||||||
|
|
||||||
update_contact_avatar($contact_record["photo"],$importer["uid"],$contact_record["id"]);
|
|
||||||
|
|
||||||
// technically they are sharing with us (CONTACT_IS_SHARING),
|
|
||||||
// but if our page-type is PAGE_COMMUNITY or PAGE_SOAPBOX
|
|
||||||
// we are going to change the relationship and make them a follower.
|
|
||||||
|
|
||||||
if (($importer["page-flags"] == PAGE_FREELOVE) && $sharing && $following)
|
|
||||||
$new_relation = CONTACT_IS_FRIEND;
|
|
||||||
elseif (($importer["page-flags"] == PAGE_FREELOVE) && $sharing)
|
|
||||||
$new_relation = CONTACT_IS_SHARING;
|
|
||||||
else
|
|
||||||
$new_relation = CONTACT_IS_FOLLOWER;
|
|
||||||
|
|
||||||
$r = q("UPDATE `contact` SET `rel` = %d,
|
|
||||||
`name-date` = '%s',
|
|
||||||
`uri-date` = '%s',
|
|
||||||
`blocked` = 0,
|
|
||||||
`pending` = 0,
|
|
||||||
`writable` = 1
|
|
||||||
WHERE `id` = %d
|
|
||||||
",
|
|
||||||
intval($new_relation),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
dbesc(datetime_convert()),
|
|
||||||
intval($contact_record["id"])
|
|
||||||
);
|
|
||||||
|
|
||||||
$u = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1", intval($importer["uid"]));
|
|
||||||
if ($u) {
|
|
||||||
logger("Sending share message (Relation: ".$new_relation.") to author ".$author." - Contact: ".$contact_record["id"]." - User: ".$importer["uid"], LOGGER_DEBUG);
|
|
||||||
$ret = self::send_share($u[0], $contact_record);
|
|
||||||
|
|
||||||
// Send the profile data, maybe it weren't transmitted before
|
|
||||||
self::send_profile($importer["uid"], array($contact_record));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Fetches a message with a given guid
|
|
||||||
*
|
|
||||||
* @param string $guid message guid
|
|
||||||
* @param string $orig_author handle of the original post
|
|
||||||
* @param string $author handle of the sharer
|
|
||||||
*
|
|
||||||
* @return array The fetched item
|
|
||||||
*/
|
|
||||||
private static function original_item($guid, $orig_author, $author) {
|
|
||||||
|
|
||||||
// Do we already have this item?
|
|
||||||
$r = q("SELECT `body`, `tag`, `app`, `created`, `object-type`, `uri`, `guid`,
|
|
||||||
`author-name`, `author-link`, `author-avatar`
|
|
||||||
FROM `item` WHERE `guid` = '%s' AND `visible` AND NOT `deleted` AND `body` != '' LIMIT 1",
|
|
||||||
dbesc($guid));
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
logger("reshared message ".$guid." already exists on system.");
|
|
||||||
|
|
||||||
// Maybe it is already a reshared item?
|
|
||||||
// Then refetch the content, if it is a reshare from a reshare.
|
|
||||||
// If it is a reshared post from another network then reformat to avoid display problems with two share elements
|
|
||||||
if (self::is_reshare($r[0]["body"], true)) {
|
|
||||||
$r = array();
|
|
||||||
} elseif (self::is_reshare($r[0]["body"], false) || strstr($r[0]["body"], "[share")) {
|
|
||||||
$r[0]["body"] = diaspora2bb(bb2diaspora($r[0]["body"]));
|
|
||||||
|
|
||||||
$r[0]["body"] = self::replace_people_guid($r[0]["body"], $r[0]["author-link"]);
|
|
||||||
|
|
||||||
// Add OEmbed and other information to the body
|
|
||||||
$r[0]["body"] = add_page_info_to_body($r[0]["body"], false, true);
|
|
||||||
|
|
||||||
return $r[0];
|
|
||||||
} else {
|
|
||||||
return $r[0];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
$server = "https://".substr($orig_author, strpos($orig_author, "@") + 1);
|
|
||||||
logger("1st try: reshared message ".$guid." will be fetched via SSL from the server ".$server);
|
|
||||||
$item_id = self::store_by_guid($guid, $server);
|
|
||||||
|
|
||||||
if (!$item_id) {
|
|
||||||
$server = "http://".substr($orig_author, strpos($orig_author, "@") + 1);
|
|
||||||
logger("2nd try: reshared message ".$guid." will be fetched without SLL from the server ".$server);
|
|
||||||
$item_id = self::store_by_guid($guid, $server);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item_id) {
|
|
||||||
$r = q("SELECT `body`, `tag`, `app`, `created`, `object-type`, `uri`, `guid`,
|
|
||||||
`author-name`, `author-link`, `author-avatar`
|
|
||||||
FROM `item` WHERE `id` = %d AND `visible` AND NOT `deleted` AND `body` != '' LIMIT 1",
|
|
||||||
intval($item_id));
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
|
||||||
// If it is a reshared post from another network then reformat to avoid display problems with two share elements
|
|
||||||
if (self::is_reshare($r[0]["body"], false)) {
|
|
||||||
$r[0]["body"] = diaspora2bb(bb2diaspora($r[0]["body"]));
|
|
||||||
$r[0]["body"] = self::replace_people_guid($r[0]["body"], $r[0]["author-link"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $r[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes a reshare message
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
* @param string $xml The original XML of the message
|
|
||||||
*
|
|
||||||
* @return int the message id
|
|
||||||
*/
|
|
||||||
private static function receive_reshare($importer, $data, $xml) {
|
|
||||||
$author = notags(unxmlify($data->author));
|
|
||||||
$guid = notags(unxmlify($data->guid));
|
|
||||||
$created_at = datetime_convert("UTC", "UTC", notags(unxmlify($data->created_at)));
|
|
||||||
$root_author = notags(unxmlify($data->root_author));
|
|
||||||
$root_guid = notags(unxmlify($data->root_guid));
|
|
||||||
/// @todo handle unprocessed property "provider_display_name"
|
|
||||||
$public = notags(unxmlify($data->public));
|
|
||||||
|
|
||||||
$contact = self::allowed_contact_by_handle($importer, $author, false);
|
|
||||||
if (!$contact) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$message_id = self::message_exists($importer["uid"], $guid);
|
|
||||||
if ($message_id) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$original_item = self::original_item($root_guid, $root_author, $author);
|
|
||||||
if (!$original_item) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$orig_url = System::baseUrl()."/display/".$original_item["guid"];
|
|
||||||
|
|
||||||
$datarray = array();
|
|
||||||
|
|
||||||
$datarray["uid"] = $importer["uid"];
|
|
||||||
$datarray["contact-id"] = $contact["id"];
|
|
||||||
$datarray["network"] = NETWORK_DIASPORA;
|
|
||||||
|
|
||||||
$datarray["author-name"] = $contact["name"];
|
|
||||||
$datarray["author-link"] = $contact["url"];
|
|
||||||
$datarray["author-avatar"] = ((x($contact,"thumb")) ? $contact["thumb"] : $contact["photo"]);
|
|
||||||
|
|
||||||
$datarray["owner-name"] = $datarray["author-name"];
|
|
||||||
$datarray["owner-link"] = $datarray["author-link"];
|
|
||||||
$datarray["owner-avatar"] = $datarray["author-avatar"];
|
|
||||||
|
|
||||||
$datarray["guid"] = $guid;
|
|
||||||
$datarray["uri"] = $datarray["parent-uri"] = self::get_uri_from_guid($author, $guid);
|
|
||||||
|
|
||||||
$datarray["verb"] = ACTIVITY_POST;
|
|
||||||
$datarray["gravity"] = GRAVITY_PARENT;
|
|
||||||
|
|
||||||
$datarray["protocol"] = PROTOCOL_DIASPORA;
|
|
||||||
$datarray["source"] = $xml;
|
|
||||||
|
|
||||||
$prefix = share_header($original_item["author-name"], $original_item["author-link"], $original_item["author-avatar"],
|
|
||||||
$original_item["guid"], $original_item["created"], $orig_url);
|
|
||||||
$datarray["body"] = $prefix.$original_item["body"]."[/share]";
|
|
||||||
|
|
||||||
$datarray["tag"] = $original_item["tag"];
|
|
||||||
$datarray["app"] = $original_item["app"];
|
|
||||||
|
|
||||||
$datarray["plink"] = self::plink($author, $guid);
|
|
||||||
$datarray["private"] = (($public == "false") ? 1 : 0);
|
|
||||||
$datarray["changed"] = $datarray["created"] = $datarray["edited"] = $created_at;
|
|
||||||
|
|
||||||
$datarray["object-type"] = $original_item["object-type"];
|
|
||||||
|
|
||||||
self::fetch_guid($datarray);
|
|
||||||
$message_id = item_store($datarray);
|
|
||||||
|
|
||||||
if ($message_id) {
|
|
||||||
logger("Stored reshare ".$datarray["guid"]." with message id ".$message_id, LOGGER_DEBUG);
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Processes retractions
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param array $contact The contact of the item owner
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool success
|
|
||||||
*/
|
|
||||||
private static function item_retraction($importer, $contact, $data) {
|
|
||||||
$author = notags(unxmlify($data->author));
|
|
||||||
$target_guid = notags(unxmlify($data->target_guid));
|
|
||||||
$target_type = notags(unxmlify($data->target_type));
|
|
||||||
|
|
||||||
$person = self::person_by_handle($author);
|
|
||||||
if (!is_array($person)) {
|
|
||||||
logger("unable to find author detail for ".$author);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty($contact["url"])) {
|
|
||||||
$contact["url"] = $person["url"];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fetch items that are about to be deleted
|
|
||||||
$fields = array('uid', 'id', 'parent', 'parent-uri', 'author-link');
|
|
||||||
|
|
||||||
// When we receive a public retraction, we delete every item that we find.
|
|
||||||
if ($importer['uid'] == 0) {
|
|
||||||
$condition = array("`guid` = ? AND NOT `file` LIKE '%%[%%' AND NOT `deleted`", $target_guid);
|
|
||||||
} else {
|
|
||||||
$condition = array("`guid` = ? AND `uid` = ? AND NOT `file` LIKE '%%[%%' AND NOT `deleted`", $target_guid, $importer['uid']);
|
|
||||||
}
|
|
||||||
$r = dba::select('item', $fields, $condition);
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
logger("Target guid ".$target_guid." was not found on this system for user ".$importer['uid'].".");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
while ($item = dba::fetch($r)) {
|
|
||||||
// Fetch the parent item
|
|
||||||
$parent = dba::select('item', array('author-link', 'origin'), array('id' => $item["parent"]), array('limit' => 1));
|
|
||||||
|
|
||||||
// Only delete it if the parent author really fits
|
|
||||||
if (!link_compare($parent["author-link"], $contact["url"]) && !link_compare($item["author-link"], $contact["url"])) {
|
|
||||||
logger("Thread author ".$parent["author-link"]." and item author ".$item["author-link"]." don't fit to expected contact ".$contact["url"], LOGGER_DEBUG);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 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' => '',
|
|
||||||
'edited' => datetime_convert(), 'changed' => datetime_convert()),
|
|
||||||
array('id' => $item["id"]));
|
|
||||||
|
|
||||||
// Delete the thread - if it is a starting post and not a comment
|
|
||||||
if ($target_type != 'Comment') {
|
|
||||||
delete_thread($item["id"], $item["parent-uri"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("Deleted target ".$target_guid." (".$item["id"].") from user ".$item["uid"]." parent: ".$item["parent"], LOGGER_DEBUG);
|
|
||||||
|
|
||||||
// Now check if the retraction needs to be relayed by us
|
|
||||||
if ($parent["origin"]) {
|
|
||||||
// notify others
|
|
||||||
Worker::add(PRIORITY_HIGH, "notifier", "drop", $item["id"]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Receives retraction messages
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param string $sender The sender of the message
|
|
||||||
* @param object $data The message object
|
|
||||||
*
|
|
||||||
* @return bool Success
|
|
||||||
*/
|
|
||||||
private static function receive_retraction($importer, $sender, $data) {
|
|
||||||
$target_type = notags(unxmlify($data->target_type));
|
|
||||||
|
|
||||||
$contact = self::contact_by_handle($importer["uid"], $sender);
|
|
||||||
if (!$contact && (in_array($target_type, array("Contact", "Person")))) {
|
|
||||||
logger("cannot find contact for sender: ".$sender." and user ".$importer["uid"]);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("Got retraction for ".$target_type.", sender ".$sender." and user ".$importer["uid"], LOGGER_DEBUG);
|
|
||||||
|
|
||||||
switch ($target_type) {
|
|
||||||
case "Comment":
|
|
||||||
case "Like":
|
|
||||||
case "Post":
|
|
||||||
case "Reshare":
|
|
||||||
case "StatusMessage":
|
|
||||||
return self::item_retraction($importer, $contact, $data);
|
|
||||||
|
|
||||||
case "Contact":
|
|
||||||
case "Person":
|
|
||||||
/// @todo What should we do with an "unshare"?
|
|
||||||
// Removing the contact isn't correct since we still can read the public items
|
|
||||||
contact_remove($contact["id"]);
|
|
||||||
return true;
|
|
||||||
|
|
||||||
default:
|
|
||||||
logger("Unknown target type ".$target_type);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Receives status messages
|
|
||||||
*
|
|
||||||
* @param array $importer Array of the importer user
|
|
||||||
* @param object $data The message object
|
|
||||||
* @param string $xml The original XML of the message
|
|
||||||
*
|
|
||||||
* @return int The message id of the newly created item
|
|
||||||
*/
|
|
||||||
private static function receive_status_message($importer, $data, $xml) {
|
|
||||||
$author = notags(unxmlify($data->author));
|
|
||||||
$guid = notags(unxmlify($data->guid));
|
|
||||||
$created_at = datetime_convert("UTC", "UTC", notags(unxmlify($data->created_at)));
|
|
||||||
$public = notags(unxmlify($data->public));
|
|
||||||
$text = unxmlify($data->text);
|
|
||||||
$provider_display_name = notags(unxmlify($data->provider_display_name));
|
|
||||||
|
|
||||||
$contact = self::allowed_contact_by_handle($importer, $author, false);
|
|
||||||
if (!$contact) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$message_id = self::message_exists($importer["uid"], $guid);
|
|
||||||
if ($message_id) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$address = array();
|
|
||||||
if ($data->location) {
|
|
||||||
foreach ($data->location->children() AS $fieldname => $data) {
|
|
||||||
$address[$fieldname] = notags(unxmlify($data));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$body = diaspora2bb($text);
|
|
||||||
|
|
||||||
$datarray = array();
|
|
||||||
|
|
||||||
// Attach embedded pictures to the body
|
|
||||||
if ($data->photo) {
|
|
||||||
foreach ($data->photo AS $photo) {
|
|
||||||
$body = "[img]".unxmlify($photo->remote_photo_path).
|
|
||||||
unxmlify($photo->remote_photo_name)."[/img]\n".$body;
|
|
||||||
}
|
|
||||||
|
|
||||||
$datarray["object-type"] = ACTIVITY_OBJ_IMAGE;
|
|
||||||
} else {
|
|
||||||
$datarray["object-type"] = ACTIVITY_OBJ_NOTE;
|
|
||||||
|
|
||||||
// Add OEmbed and other information to the body
|
|
||||||
if (!self::is_redmatrix($contact["url"])) {
|
|
||||||
$body = add_page_info_to_body($body, false, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// @todo enable support for polls
|
|
||||||
//if ($data->poll) {
|
|
||||||
// foreach ($data->poll AS $poll)
|
|
||||||
// print_r($poll);
|
|
||||||
// die("poll!\n");
|
|
||||||
//}
|
|
||||||
|
|
||||||
/// @todo enable support for events
|
|
||||||
|
|
||||||
$datarray["uid"] = $importer["uid"];
|
|
||||||
$datarray["contact-id"] = $contact["id"];
|
|
||||||
$datarray["network"] = NETWORK_DIASPORA;
|
|
||||||
|
|
||||||
$datarray["author-name"] = $contact["name"];
|
|
||||||
$datarray["author-link"] = $contact["url"];
|
|
||||||
$datarray["author-avatar"] = ((x($contact,"thumb")) ? $contact["thumb"] : $contact["photo"]);
|
|
||||||
|
|
||||||
$datarray["owner-name"] = $datarray["author-name"];
|
|
||||||
$datarray["owner-link"] = $datarray["author-link"];
|
|
||||||
$datarray["owner-avatar"] = $datarray["author-avatar"];
|
|
||||||
|
|
||||||
$datarray["guid"] = $guid;
|
|
||||||
$datarray["uri"] = $datarray["parent-uri"] = self::get_uri_from_guid($author, $guid);
|
|
||||||
|
|
||||||
$datarray["verb"] = ACTIVITY_POST;
|
|
||||||
$datarray["gravity"] = GRAVITY_PARENT;
|
|
||||||
|
|
||||||
$datarray["protocol"] = PROTOCOL_DIASPORA;
|
|
||||||
$datarray["source"] = $xml;
|
|
||||||
|
|
||||||
$datarray["body"] = self::replace_people_guid($body, $contact["url"]);
|
|
||||||
|
|
||||||
if ($provider_display_name != "") {
|
|
||||||
$datarray["app"] = $provider_display_name;
|
|
||||||
}
|
|
||||||
|
|
||||||
$datarray["plink"] = self::plink($author, $guid);
|
|
||||||
$datarray["private"] = (($public == "false") ? 1 : 0);
|
|
||||||
$datarray["changed"] = $datarray["created"] = $datarray["edited"] = $created_at;
|
|
||||||
|
|
||||||
if (isset($address["address"])) {
|
|
||||||
$datarray["location"] = $address["address"];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isset($address["lat"]) && isset($address["lng"])) {
|
|
||||||
$datarray["coord"] = $address["lat"]." ".$address["lng"];
|
|
||||||
}
|
|
||||||
|
|
||||||
self::fetch_guid($datarray);
|
|
||||||
$message_id = item_store($datarray);
|
|
||||||
|
|
||||||
if ($message_id) {
|
|
||||||
logger("Stored item ".$datarray["guid"]." with message id ".$message_id, LOGGER_DEBUG);
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ************************************************************************************** *
|
|
||||||
* Here are all the functions that are needed to transmit data with the Diaspora protocol *
|
|
||||||
* ************************************************************************************** */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief returnes the handle of a contact
|
|
||||||
*
|
|
||||||
* @param array $me contact array
|
|
||||||
*
|
|
||||||
* @return string the handle in the format user@domain.tld
|
|
||||||
*/
|
|
||||||
private static function my_handle($contact) {
|
|
||||||
if ($contact["addr"] != "") {
|
|
||||||
return $contact["addr"];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Normally we should have a filled "addr" field - but in the past this wasn't the case
|
|
||||||
// So - just in case - we build the the address here.
|
|
||||||
if ($contact["nickname"] != "") {
|
|
||||||
$nick = $contact["nickname"];
|
|
||||||
} else {
|
|
||||||
$nick = $contact["nick"];
|
|
||||||
}
|
|
||||||
|
|
||||||
return $nick."@".substr(System::baseUrl(), strpos(System::baseUrl(),"://") + 3);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates the data for a private message in the new format
|
|
||||||
*
|
|
||||||
* @param string $msg The message that is to be transmitted
|
|
||||||
* @param array $user The record of the sender
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
* @param string $prvkey The private key of the sender
|
|
||||||
* @param string $pubkey The public key of the receiver
|
|
||||||
*
|
|
||||||
* @return string The encrypted data
|
|
||||||
*/
|
|
||||||
public static function encode_private_data($msg, $user, $contact, $prvkey, $pubkey) {
|
|
||||||
|
|
||||||
logger("Message: ".$msg, LOGGER_DATA);
|
|
||||||
|
|
||||||
// without a public key nothing will work
|
|
||||||
if (!$pubkey) {
|
|
||||||
logger("pubkey missing: contact id: ".$contact["id"]);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$aes_key = openssl_random_pseudo_bytes(32);
|
|
||||||
$b_aes_key = base64_encode($aes_key);
|
|
||||||
$iv = openssl_random_pseudo_bytes(16);
|
|
||||||
$b_iv = base64_encode($iv);
|
|
||||||
|
|
||||||
$ciphertext = self::aes_encrypt($aes_key, $iv, $msg);
|
|
||||||
|
|
||||||
$json = json_encode(array("iv" => $b_iv, "key" => $b_aes_key));
|
|
||||||
|
|
||||||
$encrypted_key_bundle = "";
|
|
||||||
openssl_public_encrypt($json, $encrypted_key_bundle, $pubkey);
|
|
||||||
|
|
||||||
$json_object = json_encode(array("aes_key" => base64_encode($encrypted_key_bundle),
|
|
||||||
"encrypted_magic_envelope" => base64_encode($ciphertext)));
|
|
||||||
|
|
||||||
return $json_object;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates the envelope for the "fetch" endpoint and for the new format
|
|
||||||
*
|
|
||||||
* @param string $msg The message that is to be transmitted
|
|
||||||
* @param array $user The record of the sender
|
|
||||||
*
|
|
||||||
* @return string The envelope
|
|
||||||
*/
|
|
||||||
public static function build_magic_envelope($msg, $user) {
|
|
||||||
|
|
||||||
$b64url_data = base64url_encode($msg);
|
|
||||||
$data = str_replace(array("\n", "\r", " ", "\t"), array("", "", "", ""), $b64url_data);
|
|
||||||
|
|
||||||
$key_id = base64url_encode(self::my_handle($user));
|
|
||||||
$type = "application/xml";
|
|
||||||
$encoding = "base64url";
|
|
||||||
$alg = "RSA-SHA256";
|
|
||||||
$signable_data = $data.".".base64url_encode($type).".".base64url_encode($encoding).".".base64url_encode($alg);
|
|
||||||
|
|
||||||
// Fallback if the private key wasn't transmitted in the expected field
|
|
||||||
if ($user['uprvkey'] == "")
|
|
||||||
$user['uprvkey'] = $user['prvkey'];
|
|
||||||
|
|
||||||
$signature = rsa_sign($signable_data, $user["uprvkey"]);
|
|
||||||
$sig = base64url_encode($signature);
|
|
||||||
|
|
||||||
$xmldata = array("me:env" => array("me:data" => $data,
|
|
||||||
"@attributes" => array("type" => $type),
|
|
||||||
"me:encoding" => $encoding,
|
|
||||||
"me:alg" => $alg,
|
|
||||||
"me:sig" => $sig,
|
|
||||||
"@attributes2" => array("key_id" => $key_id)));
|
|
||||||
|
|
||||||
$namespaces = array("me" => "http://salmon-protocol.org/ns/magic-env");
|
|
||||||
|
|
||||||
return xml::from_array($xmldata, $xml, false, $namespaces);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Create the envelope for a message
|
|
||||||
*
|
|
||||||
* @param string $msg The message that is to be transmitted
|
|
||||||
* @param array $user The record of the sender
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
* @param string $prvkey The private key of the sender
|
|
||||||
* @param string $pubkey The public key of the receiver
|
|
||||||
* @param bool $public Is the message public?
|
|
||||||
*
|
|
||||||
* @return string The message that will be transmitted to other servers
|
|
||||||
*/
|
|
||||||
private static function build_message($msg, $user, $contact, $prvkey, $pubkey, $public = false) {
|
|
||||||
|
|
||||||
// The message is put into an envelope with the sender's signature
|
|
||||||
$envelope = self::build_magic_envelope($msg, $user);
|
|
||||||
|
|
||||||
// Private messages are put into a second envelope, encrypted with the receivers public key
|
|
||||||
if (!$public) {
|
|
||||||
$envelope = self::encode_private_data($envelope, $user, $contact, $prvkey, $pubkey);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $envelope;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates a signature for a message
|
|
||||||
*
|
|
||||||
* @param array $owner the array of the owner of the message
|
|
||||||
* @param array $message The message that is to be signed
|
|
||||||
*
|
|
||||||
* @return string The signature
|
|
||||||
*/
|
|
||||||
private static function signature($owner, $message) {
|
|
||||||
$sigmsg = $message;
|
|
||||||
unset($sigmsg["author_signature"]);
|
|
||||||
unset($sigmsg["parent_author_signature"]);
|
|
||||||
|
|
||||||
$signed_text = implode(";", $sigmsg);
|
|
||||||
|
|
||||||
return base64_encode(rsa_sign($signed_text, $owner["uprvkey"], "sha256"));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Transmit a message to a target server
|
|
||||||
*
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
* @param string $envelope The message that is to be transmitted
|
|
||||||
* @param bool $public_batch Is it a public post?
|
|
||||||
* @param bool $queue_run Is the transmission called from the queue?
|
|
||||||
* @param string $guid message guid
|
|
||||||
*
|
|
||||||
* @return int Result of the transmission
|
|
||||||
*/
|
|
||||||
public static function transmit($owner, $contact, $envelope, $public_batch, $queue_run=false, $guid = "") {
|
|
||||||
|
|
||||||
$a = get_app();
|
|
||||||
|
|
||||||
$enabled = intval(Config::get("system", "diaspora_enabled"));
|
|
||||||
if (!$enabled)
|
|
||||||
return 200;
|
|
||||||
|
|
||||||
$logid = random_string(4);
|
|
||||||
$dest_url = (($public_batch) ? $contact["batch"] : $contact["notify"]);
|
|
||||||
if (!$dest_url) {
|
|
||||||
logger("no url for contact: ".$contact["id"]." batch mode =".$public_batch);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("transmit: ".$logid."-".$guid." ".$dest_url);
|
|
||||||
|
|
||||||
if (!$queue_run && was_recently_delayed($contact["id"])) {
|
|
||||||
$return_code = 0;
|
|
||||||
} else {
|
|
||||||
if (!intval(Config::get("system", "diaspora_test"))) {
|
|
||||||
$content_type = (($public_batch) ? "application/magic-envelope+xml" : "application/json");
|
|
||||||
|
|
||||||
post_url($dest_url."/", $envelope, array("Content-Type: ".$content_type));
|
|
||||||
$return_code = $a->get_curl_code();
|
|
||||||
} else {
|
|
||||||
logger("test_mode");
|
|
||||||
return 200;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("transmit: ".$logid."-".$guid." returns: ".$return_code);
|
|
||||||
|
|
||||||
if (!$return_code || (($return_code == 503) && (stristr($a->get_curl_headers(), "retry-after")))) {
|
|
||||||
logger("queue message");
|
|
||||||
|
|
||||||
$r = q("SELECT `id` FROM `queue` WHERE `cid` = %d AND `network` = '%s' AND `content` = '%s' AND `batch` = %d LIMIT 1",
|
|
||||||
intval($contact["id"]),
|
|
||||||
dbesc(NETWORK_DIASPORA),
|
|
||||||
dbesc($envelope),
|
|
||||||
intval($public_batch)
|
|
||||||
);
|
|
||||||
if ($r) {
|
|
||||||
logger("add_to_queue ignored - identical item already in queue");
|
|
||||||
} else {
|
|
||||||
// queue message for redelivery
|
|
||||||
add_to_queue($contact["id"], NETWORK_DIASPORA, $envelope, $public_batch);
|
|
||||||
|
|
||||||
// The message could not be delivered. We mark the contact as "dead"
|
|
||||||
mark_for_death($contact);
|
|
||||||
}
|
|
||||||
} elseif (($return_code >= 200) && ($return_code <= 299)) {
|
|
||||||
// We successfully delivered a message, the contact is alive
|
|
||||||
unmark_for_death($contact);
|
|
||||||
}
|
|
||||||
|
|
||||||
return(($return_code) ? $return_code : (-1));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Build the post xml
|
|
||||||
*
|
|
||||||
* @param string $type The message type
|
|
||||||
* @param array $message The message data
|
|
||||||
*
|
|
||||||
* @return string The post XML
|
|
||||||
*/
|
|
||||||
public static function build_post_xml($type, $message) {
|
|
||||||
|
|
||||||
$data = array($type => $message);
|
|
||||||
|
|
||||||
return xml::from_array($data, $xml);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Builds and transmit messages
|
|
||||||
*
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
* @param string $type The message type
|
|
||||||
* @param array $message The message data
|
|
||||||
* @param bool $public_batch Is it a public post?
|
|
||||||
* @param string $guid message guid
|
|
||||||
* @param bool $spool Should the transmission be spooled or transmitted?
|
|
||||||
*
|
|
||||||
* @return int Result of the transmission
|
|
||||||
*/
|
|
||||||
private static function build_and_transmit($owner, $contact, $type, $message, $public_batch = false, $guid = "", $spool = false) {
|
|
||||||
|
|
||||||
$msg = self::build_post_xml($type, $message);
|
|
||||||
|
|
||||||
logger('message: '.$msg, LOGGER_DATA);
|
|
||||||
logger('send guid '.$guid, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
// Fallback if the private key wasn't transmitted in the expected field
|
|
||||||
if ($owner['uprvkey'] == "")
|
|
||||||
$owner['uprvkey'] = $owner['prvkey'];
|
|
||||||
|
|
||||||
$envelope = self::build_message($msg, $owner, $contact, $owner['uprvkey'], $contact['pubkey'], $public_batch);
|
|
||||||
|
|
||||||
if ($spool) {
|
|
||||||
add_to_queue($contact['id'], NETWORK_DIASPORA, $envelope, $public_batch);
|
|
||||||
return true;
|
|
||||||
} else
|
|
||||||
$return_code = self::transmit($owner, $contact, $envelope, $public_batch, false, $guid);
|
|
||||||
|
|
||||||
logger("guid: ".$item["guid"]." result ".$return_code, LOGGER_DEBUG);
|
|
||||||
|
|
||||||
return $return_code;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief sends an account migration
|
|
||||||
*
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
* @param int $uid User ID
|
|
||||||
*
|
|
||||||
* @return int The result of the transmission
|
|
||||||
*/
|
|
||||||
public static function sendAccountMigration($owner, $contact, $uid) {
|
|
||||||
|
|
||||||
$old_handle = PConfig::get($uid, 'system', 'previous_addr');
|
|
||||||
$profile = self::createProfileData($uid);
|
|
||||||
|
|
||||||
$signed_text = 'AccountMigration:'.$old_handle.':'.$profile['author'];
|
|
||||||
$signature = base64_encode(rsa_sign($signed_text, $owner["uprvkey"], "sha256"));
|
|
||||||
|
|
||||||
$message = array("author" => $old_handle,
|
|
||||||
"profile" => $profile,
|
|
||||||
"signature" => $signature);
|
|
||||||
|
|
||||||
logger("Send account migration ".print_r($message, true), LOGGER_DEBUG);
|
|
||||||
|
|
||||||
return self::build_and_transmit($owner, $contact, "account_migration", $message);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Sends a "share" message
|
|
||||||
*
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
*
|
|
||||||
* @return int The result of the transmission
|
|
||||||
*/
|
|
||||||
public static function send_share($owner, $contact) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @todo support the different possible combinations of "following" and "sharing"
|
|
||||||
* Currently, Diaspora only interprets the "sharing" field
|
|
||||||
*
|
|
||||||
* Before switching this code productive, we have to check all "send_share" calls if "rel" is set correctly
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
switch ($contact["rel"]) {
|
|
||||||
case CONTACT_IS_FRIEND:
|
|
||||||
$following = true;
|
|
||||||
$sharing = true;
|
|
||||||
case CONTACT_IS_SHARING:
|
|
||||||
$following = false;
|
|
||||||
$sharing = true;
|
|
||||||
case CONTACT_IS_FOLLOWER:
|
|
||||||
$following = true;
|
|
||||||
$sharing = false;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
$message = array("author" => self::my_handle($owner),
|
|
||||||
"recipient" => $contact["addr"],
|
|
||||||
"following" => "true",
|
|
||||||
"sharing" => "true");
|
|
||||||
|
|
||||||
logger("Send share ".print_r($message, true), LOGGER_DEBUG);
|
|
||||||
|
|
||||||
return self::build_and_transmit($owner, $contact, "contact", $message);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief sends an "unshare"
|
|
||||||
*
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
*
|
|
||||||
* @return int The result of the transmission
|
|
||||||
*/
|
|
||||||
public static function send_unshare($owner, $contact) {
|
|
||||||
|
|
||||||
$message = array("author" => self::my_handle($owner),
|
|
||||||
"recipient" => $contact["addr"],
|
|
||||||
"following" => "false",
|
|
||||||
"sharing" => "false");
|
|
||||||
|
|
||||||
logger("Send unshare ".print_r($message, true), LOGGER_DEBUG);
|
|
||||||
|
|
||||||
return self::build_and_transmit($owner, $contact, "contact", $message);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Checks a message body if it is a reshare
|
|
||||||
*
|
|
||||||
* @param string $body The message body that is to be check
|
|
||||||
* @param bool $complete Should it be a complete check or a simple check?
|
|
||||||
*
|
|
||||||
* @return array|bool Reshare details or "false" if no reshare
|
|
||||||
*/
|
|
||||||
public static function is_reshare($body, $complete = true) {
|
|
||||||
$body = trim($body);
|
|
||||||
|
|
||||||
// Skip if it isn't a pure repeated messages
|
|
||||||
// Does it start with a share?
|
|
||||||
if ((strpos($body, "[share") > 0) && $complete)
|
|
||||||
return(false);
|
|
||||||
|
|
||||||
// Does it end with a share?
|
|
||||||
if (strlen($body) > (strrpos($body, "[/share]") + 8))
|
|
||||||
return(false);
|
|
||||||
|
|
||||||
$attributes = preg_replace("/\[share(.*?)\]\s?(.*?)\s?\[\/share\]\s?/ism","$1",$body);
|
|
||||||
// Skip if there is no shared message in there
|
|
||||||
if ($body == $attributes)
|
|
||||||
return(false);
|
|
||||||
|
|
||||||
// If we don't do the complete check we quit here
|
|
||||||
if (!$complete)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
$guid = "";
|
|
||||||
preg_match("/guid='(.*?)'/ism", $attributes, $matches);
|
|
||||||
if ($matches[1] != "")
|
|
||||||
$guid = $matches[1];
|
|
||||||
|
|
||||||
preg_match('/guid="(.*?)"/ism', $attributes, $matches);
|
|
||||||
if ($matches[1] != "")
|
|
||||||
$guid = $matches[1];
|
|
||||||
|
|
||||||
if ($guid != "") {
|
|
||||||
$r = q("SELECT `contact-id` FROM `item` WHERE `guid` = '%s' AND `network` IN ('%s', '%s') LIMIT 1",
|
|
||||||
dbesc($guid), NETWORK_DFRN, NETWORK_DIASPORA);
|
|
||||||
if ($r) {
|
|
||||||
$ret= array();
|
|
||||||
$ret["root_handle"] = self::handle_from_contact($r[0]["contact-id"]);
|
|
||||||
$ret["root_guid"] = $guid;
|
|
||||||
return($ret);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$profile = "";
|
|
||||||
preg_match("/profile='(.*?)'/ism", $attributes, $matches);
|
|
||||||
if ($matches[1] != "")
|
|
||||||
$profile = $matches[1];
|
|
||||||
|
|
||||||
preg_match('/profile="(.*?)"/ism', $attributes, $matches);
|
|
||||||
if ($matches[1] != "")
|
|
||||||
$profile = $matches[1];
|
|
||||||
|
|
||||||
$ret= array();
|
|
||||||
|
|
||||||
$ret["root_handle"] = preg_replace("=https?://(.*)/u/(.*)=ism", "$2@$1", $profile);
|
|
||||||
if (($ret["root_handle"] == $profile) || ($ret["root_handle"] == ""))
|
|
||||||
return(false);
|
|
||||||
|
|
||||||
$link = "";
|
|
||||||
preg_match("/link='(.*?)'/ism", $attributes, $matches);
|
|
||||||
if ($matches[1] != "")
|
|
||||||
$link = $matches[1];
|
|
||||||
|
|
||||||
preg_match('/link="(.*?)"/ism', $attributes, $matches);
|
|
||||||
if ($matches[1] != "")
|
|
||||||
$link = $matches[1];
|
|
||||||
|
|
||||||
$ret["root_guid"] = preg_replace("=https?://(.*)/posts/(.*)=ism", "$2", $link);
|
|
||||||
if (($ret["root_guid"] == $link) || (trim($ret["root_guid"]) == ""))
|
|
||||||
return(false);
|
|
||||||
|
|
||||||
return($ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Create an event array
|
|
||||||
*
|
|
||||||
* @param integer $event_id The id of the event
|
|
||||||
*
|
|
||||||
* @return array with event data
|
|
||||||
*/
|
|
||||||
private static function build_event($event_id) {
|
|
||||||
|
|
||||||
$r = q("SELECT `guid`, `uid`, `start`, `finish`, `nofinish`, `summary`, `desc`, `location`, `adjust` FROM `event` WHERE `id` = %d", intval($event_id));
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
return array();
|
|
||||||
}
|
|
||||||
|
|
||||||
$event = $r[0];
|
|
||||||
|
|
||||||
$eventdata = array();
|
|
||||||
|
|
||||||
$r = q("SELECT `timezone` FROM `user` WHERE `uid` = %d", intval($event['uid']));
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
return array();
|
|
||||||
}
|
|
||||||
|
|
||||||
$user = $r[0];
|
|
||||||
|
|
||||||
$r = q("SELECT `addr`, `nick` FROM `contact` WHERE `uid` = %d AND `self`", intval($event['uid']));
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
return array();
|
|
||||||
}
|
|
||||||
|
|
||||||
$owner = $r[0];
|
|
||||||
|
|
||||||
$eventdata['author'] = self::my_handle($owner);
|
|
||||||
|
|
||||||
if ($event['guid']) {
|
|
||||||
$eventdata['guid'] = $event['guid'];
|
|
||||||
}
|
|
||||||
|
|
||||||
$mask = 'Y-m-d\TH:i:s\Z';
|
|
||||||
|
|
||||||
/// @todo - establish "all day" events in Friendica
|
|
||||||
$eventdata["all_day"] = "false";
|
|
||||||
|
|
||||||
if (!$event['adjust']) {
|
|
||||||
$eventdata['timezone'] = $user['timezone'];
|
|
||||||
|
|
||||||
if ($eventdata['timezone'] == "") {
|
|
||||||
$eventdata['timezone'] = 'UTC';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($event['start']) {
|
|
||||||
$eventdata['start'] = datetime_convert($eventdata['timezone'], "UTC", $event['start'], $mask);
|
|
||||||
}
|
|
||||||
if ($event['finish'] && !$event['nofinish']) {
|
|
||||||
$eventdata['end'] = datetime_convert($eventdata['timezone'], "UTC", $event['finish'], $mask);
|
|
||||||
}
|
|
||||||
if ($event['summary']) {
|
|
||||||
$eventdata['summary'] = html_entity_decode(bb2diaspora($event['summary']));
|
|
||||||
}
|
|
||||||
if ($event['desc']) {
|
|
||||||
$eventdata['description'] = html_entity_decode(bb2diaspora($event['desc']));
|
|
||||||
}
|
|
||||||
if ($event['location']) {
|
|
||||||
$location = array();
|
|
||||||
$location["address"] = html_entity_decode(bb2diaspora($event['location']));
|
|
||||||
$location["lat"] = 0;
|
|
||||||
$location["lng"] = 0;
|
|
||||||
$eventdata['location'] = $location;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $eventdata;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Create a post (status message or reshare)
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
* 'type' -> Message type ("status_message" or "reshare")
|
|
||||||
* 'message' -> Array of XML elements of the status
|
|
||||||
*/
|
|
||||||
public static function build_status($item, $owner) {
|
|
||||||
|
|
||||||
$cachekey = "diaspora:build_status:".$item['guid'];
|
|
||||||
|
|
||||||
$result = Cache::get($cachekey);
|
|
||||||
if (!is_null($result)) {
|
|
||||||
return $result;
|
|
||||||
}
|
|
||||||
|
|
||||||
$myaddr = self::my_handle($owner);
|
|
||||||
|
|
||||||
$public = (($item["private"]) ? "false" : "true");
|
|
||||||
|
|
||||||
$created = datetime_convert("UTC", "UTC", $item["created"], 'Y-m-d\TH:i:s\Z');
|
|
||||||
|
|
||||||
// Detect a share element and do a reshare
|
|
||||||
if (!$item['private'] && ($ret = self::is_reshare($item["body"]))) {
|
|
||||||
$message = array("author" => $myaddr,
|
|
||||||
"guid" => $item["guid"],
|
|
||||||
"created_at" => $created,
|
|
||||||
"root_author" => $ret["root_handle"],
|
|
||||||
"root_guid" => $ret["root_guid"],
|
|
||||||
"provider_display_name" => $item["app"],
|
|
||||||
"public" => $public);
|
|
||||||
|
|
||||||
$type = "reshare";
|
|
||||||
} else {
|
|
||||||
$title = $item["title"];
|
|
||||||
$body = $item["body"];
|
|
||||||
|
|
||||||
// convert to markdown
|
|
||||||
$body = html_entity_decode(bb2diaspora($body));
|
|
||||||
|
|
||||||
// Adding the title
|
|
||||||
if (strlen($title))
|
|
||||||
$body = "## ".html_entity_decode($title)."\n\n".$body;
|
|
||||||
|
|
||||||
if ($item["attach"]) {
|
|
||||||
$cnt = preg_match_all('/href=\"(.*?)\"(.*?)title=\"(.*?)\"/ism', $item["attach"], $matches, PREG_SET_ORDER);
|
|
||||||
if (cnt) {
|
|
||||||
$body .= "\n".t("Attachments:")."\n";
|
|
||||||
foreach ($matches as $mtch)
|
|
||||||
$body .= "[".$mtch[3]."](".$mtch[1].")\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$location = array();
|
|
||||||
|
|
||||||
if ($item["location"] != "")
|
|
||||||
$location["address"] = $item["location"];
|
|
||||||
|
|
||||||
if ($item["coord"] != "") {
|
|
||||||
$coord = explode(" ", $item["coord"]);
|
|
||||||
$location["lat"] = $coord[0];
|
|
||||||
$location["lng"] = $coord[1];
|
|
||||||
}
|
|
||||||
|
|
||||||
$message = array("author" => $myaddr,
|
|
||||||
"guid" => $item["guid"],
|
|
||||||
"created_at" => $created,
|
|
||||||
"public" => $public,
|
|
||||||
"text" => $body,
|
|
||||||
"provider_display_name" => $item["app"],
|
|
||||||
"location" => $location);
|
|
||||||
|
|
||||||
// Diaspora rejects messages when they contain a location without "lat" or "lng"
|
|
||||||
if (!isset($location["lat"]) || !isset($location["lng"])) {
|
|
||||||
unset($message["location"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($item['event-id'] > 0) {
|
|
||||||
$event = self::build_event($item['event-id']);
|
|
||||||
if (count($event)) {
|
|
||||||
$message['event'] = $event;
|
|
||||||
|
|
||||||
/// @todo Once Diaspora supports it, we will remove the body
|
|
||||||
// $message['text'] = '';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$type = "status_message";
|
|
||||||
}
|
|
||||||
|
|
||||||
$msg = array("type" => $type, "message" => $message);
|
|
||||||
|
|
||||||
Cache::set($cachekey, $msg, CACHE_QUARTER_HOUR);
|
|
||||||
|
|
||||||
return $msg;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Sends a post
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
* @param bool $public_batch Is it a public post?
|
|
||||||
*
|
|
||||||
* @return int The result of the transmission
|
|
||||||
*/
|
|
||||||
public static function send_status($item, $owner, $contact, $public_batch = false) {
|
|
||||||
|
|
||||||
$status = self::build_status($item, $owner);
|
|
||||||
|
|
||||||
return self::build_and_transmit($owner, $contact, $status["type"], $status["message"], $public_batch, $item["guid"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates a "like" object
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
*
|
|
||||||
* @return array The data for a "like"
|
|
||||||
*/
|
|
||||||
private static function construct_like($item, $owner) {
|
|
||||||
|
|
||||||
$p = q("SELECT `guid`, `uri`, `parent-uri` FROM `item` WHERE `uri` = '%s' LIMIT 1",
|
|
||||||
dbesc($item["thr-parent"]));
|
|
||||||
if (!dbm::is_result($p))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
$parent = $p[0];
|
|
||||||
|
|
||||||
$target_type = ($parent["uri"] === $parent["parent-uri"] ? "Post" : "Comment");
|
|
||||||
if ($item['verb'] === ACTIVITY_LIKE) {
|
|
||||||
$positive = "true";
|
|
||||||
} elseif ($item['verb'] === ACTIVITY_DISLIKE) {
|
|
||||||
$positive = "false";
|
|
||||||
}
|
|
||||||
|
|
||||||
return(array("author" => self::my_handle($owner),
|
|
||||||
"guid" => $item["guid"],
|
|
||||||
"parent_guid" => $parent["guid"],
|
|
||||||
"parent_type" => $target_type,
|
|
||||||
"positive" => $positive,
|
|
||||||
"author_signature" => ""));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates an "EventParticipation" object
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
*
|
|
||||||
* @return array The data for an "EventParticipation"
|
|
||||||
*/
|
|
||||||
private static function construct_attend($item, $owner) {
|
|
||||||
|
|
||||||
$p = q("SELECT `guid`, `uri`, `parent-uri` FROM `item` WHERE `uri` = '%s' LIMIT 1",
|
|
||||||
dbesc($item["thr-parent"]));
|
|
||||||
if (!dbm::is_result($p))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
$parent = $p[0];
|
|
||||||
|
|
||||||
switch ($item['verb']) {
|
|
||||||
case ACTIVITY_ATTEND:
|
|
||||||
$attend_answer = 'accepted';
|
|
||||||
break;
|
|
||||||
case ACTIVITY_ATTENDNO:
|
|
||||||
$attend_answer = 'declined';
|
|
||||||
break;
|
|
||||||
case ACTIVITY_ATTENDMAYBE:
|
|
||||||
$attend_answer = 'tentative';
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
logger('Unknown verb '.$item['verb'].' in item '.$item['guid']);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return(array("author" => self::my_handle($owner),
|
|
||||||
"guid" => $item["guid"],
|
|
||||||
"parent_guid" => $parent["guid"],
|
|
||||||
"status" => $attend_answer,
|
|
||||||
"author_signature" => ""));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates the object for a comment
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
*
|
|
||||||
* @return array The data for a comment
|
|
||||||
*/
|
|
||||||
private static function construct_comment($item, $owner) {
|
|
||||||
|
|
||||||
$cachekey = "diaspora:construct_comment:".$item['guid'];
|
|
||||||
|
|
||||||
$result = Cache::get($cachekey);
|
|
||||||
if (!is_null($result)) {
|
|
||||||
return $result;
|
|
||||||
}
|
|
||||||
|
|
||||||
$p = q("SELECT `guid` FROM `item` WHERE `parent` = %d AND `id` = %d LIMIT 1",
|
|
||||||
intval($item["parent"]),
|
|
||||||
intval($item["parent"])
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!dbm::is_result($p))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
$parent = $p[0];
|
|
||||||
|
|
||||||
$text = html_entity_decode(bb2diaspora($item["body"]));
|
|
||||||
$created = datetime_convert("UTC", "UTC", $item["created"], 'Y-m-d\TH:i:s\Z');
|
|
||||||
|
|
||||||
$comment = array("author" => self::my_handle($owner),
|
|
||||||
"guid" => $item["guid"],
|
|
||||||
"created_at" => $created,
|
|
||||||
"parent_guid" => $parent["guid"],
|
|
||||||
"text" => $text,
|
|
||||||
"author_signature" => "");
|
|
||||||
|
|
||||||
// Send the thread parent guid only if it is a threaded comment
|
|
||||||
if ($item['thr-parent'] != $item['parent-uri']) {
|
|
||||||
$comment['thread_parent_guid'] = self::get_guid_from_uri($item['thr-parent'], $item['uid']);
|
|
||||||
}
|
|
||||||
|
|
||||||
Cache::set($cachekey, $comment, CACHE_QUARTER_HOUR);
|
|
||||||
|
|
||||||
return($comment);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Send a like or a comment
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
* @param bool $public_batch Is it a public post?
|
|
||||||
*
|
|
||||||
* @return int The result of the transmission
|
|
||||||
*/
|
|
||||||
public static function send_followup($item,$owner,$contact,$public_batch = false) {
|
|
||||||
|
|
||||||
if (in_array($item['verb'], array(ACTIVITY_ATTEND, ACTIVITY_ATTENDNO, ACTIVITY_ATTENDMAYBE))) {
|
|
||||||
$message = self::construct_attend($item, $owner);
|
|
||||||
$type = "event_participation";
|
|
||||||
} elseif (in_array($item["verb"], array(ACTIVITY_LIKE, ACTIVITY_DISLIKE))) {
|
|
||||||
$message = self::construct_like($item, $owner);
|
|
||||||
$type = "like";
|
|
||||||
} else {
|
|
||||||
$message = self::construct_comment($item, $owner);
|
|
||||||
$type = "comment";
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$message)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
$message["author_signature"] = self::signature($owner, $message);
|
|
||||||
|
|
||||||
return self::build_and_transmit($owner, $contact, $type, $message, $public_batch, $item["guid"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Creates a message from a signature record entry
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $signature The entry of the "sign" record
|
|
||||||
*
|
|
||||||
* @return string The message
|
|
||||||
*/
|
|
||||||
private static function message_from_signature($item, $signature) {
|
|
||||||
|
|
||||||
// Split the signed text
|
|
||||||
$signed_parts = explode(";", $signature['signed_text']);
|
|
||||||
|
|
||||||
if ($item["deleted"]) {
|
|
||||||
$message = array("author" => $signature['signer'],
|
|
||||||
"target_guid" => $signed_parts[0],
|
|
||||||
"target_type" => $signed_parts[1]);
|
|
||||||
} elseif (in_array($item["verb"], array(ACTIVITY_LIKE, ACTIVITY_DISLIKE))) {
|
|
||||||
$message = array("author" => $signed_parts[4],
|
|
||||||
"guid" => $signed_parts[1],
|
|
||||||
"parent_guid" => $signed_parts[3],
|
|
||||||
"parent_type" => $signed_parts[2],
|
|
||||||
"positive" => $signed_parts[0],
|
|
||||||
"author_signature" => $signature['signature'],
|
|
||||||
"parent_author_signature" => "");
|
|
||||||
} else {
|
|
||||||
// Remove the comment guid
|
|
||||||
$guid = array_shift($signed_parts);
|
|
||||||
|
|
||||||
// Remove the parent guid
|
|
||||||
$parent_guid = array_shift($signed_parts);
|
|
||||||
|
|
||||||
// Remove the handle
|
|
||||||
$handle = array_pop($signed_parts);
|
|
||||||
|
|
||||||
// Glue the parts together
|
|
||||||
$text = implode(";", $signed_parts);
|
|
||||||
|
|
||||||
$message = array("author" => $handle,
|
|
||||||
"guid" => $guid,
|
|
||||||
"parent_guid" => $parent_guid,
|
|
||||||
"text" => implode(";", $signed_parts),
|
|
||||||
"author_signature" => $signature['signature'],
|
|
||||||
"parent_author_signature" => "");
|
|
||||||
}
|
|
||||||
return $message;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Relays messages (like, comment, retraction) to other servers if we are the thread owner
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
* @param bool $public_batch Is it a public post?
|
|
||||||
*
|
|
||||||
* @return int The result of the transmission
|
|
||||||
*/
|
|
||||||
public static function send_relay($item, $owner, $contact, $public_batch = false) {
|
|
||||||
|
|
||||||
if ($item["deleted"]) {
|
|
||||||
return self::send_retraction($item, $owner, $contact, $public_batch, true);
|
|
||||||
} elseif (in_array($item["verb"], array(ACTIVITY_LIKE, ACTIVITY_DISLIKE))) {
|
|
||||||
$type = "like";
|
|
||||||
} else {
|
|
||||||
$type = "comment";
|
|
||||||
}
|
|
||||||
|
|
||||||
logger("Got relayable data ".$type." for item ".$item["guid"]." (".$item["id"].")", LOGGER_DEBUG);
|
|
||||||
|
|
||||||
// fetch the original signature
|
|
||||||
|
|
||||||
$r = q("SELECT `signed_text`, `signature`, `signer` FROM `sign` WHERE `iid` = %d LIMIT 1",
|
|
||||||
intval($item["id"]));
|
|
||||||
|
|
||||||
if (!$r) {
|
|
||||||
logger("Couldn't fetch signatur for item ".$item["guid"]." (".$item["id"].")", LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$signature = $r[0];
|
|
||||||
|
|
||||||
// Old way - is used by the internal Friendica functions
|
|
||||||
/// @todo Change all signatur storing functions to the new format
|
|
||||||
if ($signature['signed_text'] && $signature['signature'] && $signature['signer'])
|
|
||||||
$message = self::message_from_signature($item, $signature);
|
|
||||||
else {// New way
|
|
||||||
$msg = json_decode($signature['signed_text'], true);
|
|
||||||
|
|
||||||
$message = array();
|
|
||||||
if (is_array($msg)) {
|
|
||||||
foreach ($msg AS $field => $data) {
|
|
||||||
if (!$item["deleted"]) {
|
|
||||||
if ($field == "diaspora_handle") {
|
|
||||||
$field = "author";
|
|
||||||
}
|
|
||||||
if ($field == "target_type") {
|
|
||||||
$field = "parent_type";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$message[$field] = $data;
|
|
||||||
}
|
|
||||||
} else
|
|
||||||
logger("Signature text for item ".$item["guid"]." (".$item["id"].") couldn't be extracted: ".$signature['signed_text'], LOGGER_DEBUG);
|
|
||||||
}
|
|
||||||
|
|
||||||
$message["parent_author_signature"] = self::signature($owner, $message);
|
|
||||||
|
|
||||||
logger("Relayed data ".print_r($message, true), LOGGER_DEBUG);
|
|
||||||
|
|
||||||
return self::build_and_transmit($owner, $contact, $type, $message, $public_batch, $item["guid"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Sends a retraction (deletion) of a message, like or comment
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $owner the array of the item owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
* @param bool $public_batch Is it a public post?
|
|
||||||
* @param bool $relay Is the retraction transmitted from a relay?
|
|
||||||
*
|
|
||||||
* @return int The result of the transmission
|
|
||||||
*/
|
|
||||||
public static function send_retraction($item, $owner, $contact, $public_batch = false, $relay = false) {
|
|
||||||
|
|
||||||
$itemaddr = self::handle_from_contact($item["contact-id"], $item["gcontact-id"]);
|
|
||||||
|
|
||||||
$msg_type = "retraction";
|
|
||||||
|
|
||||||
if ($item['id'] == $item['parent']) {
|
|
||||||
$target_type = "Post";
|
|
||||||
} elseif (in_array($item["verb"], array(ACTIVITY_LIKE, ACTIVITY_DISLIKE))) {
|
|
||||||
$target_type = "Like";
|
|
||||||
} else {
|
|
||||||
$target_type = "Comment";
|
|
||||||
}
|
|
||||||
|
|
||||||
$message = array("author" => $itemaddr,
|
|
||||||
"target_guid" => $item['guid'],
|
|
||||||
"target_type" => $target_type);
|
|
||||||
|
|
||||||
logger("Got message ".print_r($message, true), LOGGER_DEBUG);
|
|
||||||
|
|
||||||
return self::build_and_transmit($owner, $contact, $msg_type, $message, $public_batch, $item["guid"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Sends a mail
|
|
||||||
*
|
|
||||||
* @param array $item The item that will be exported
|
|
||||||
* @param array $owner The owner
|
|
||||||
* @param array $contact Target of the communication
|
|
||||||
*
|
|
||||||
* @return int The result of the transmission
|
|
||||||
*/
|
|
||||||
public static function send_mail($item, $owner, $contact) {
|
|
||||||
|
|
||||||
$myaddr = self::my_handle($owner);
|
|
||||||
|
|
||||||
$r = q("SELECT * FROM `conv` WHERE `id` = %d AND `uid` = %d LIMIT 1",
|
|
||||||
intval($item["convid"]),
|
|
||||||
intval($item["uid"])
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
logger("conversation not found.");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
$cnv = $r[0];
|
|
||||||
|
|
||||||
$conv = array(
|
|
||||||
"author" => $cnv["creator"],
|
|
||||||
"guid" => $cnv["guid"],
|
|
||||||
"subject" => $cnv["subject"],
|
|
||||||
"created_at" => datetime_convert("UTC", "UTC", $cnv['created'], 'Y-m-d\TH:i:s\Z'),
|
|
||||||
"participants" => $cnv["recips"]
|
|
||||||
);
|
|
||||||
|
|
||||||
$body = bb2diaspora($item["body"]);
|
|
||||||
$created = datetime_convert("UTC", "UTC", $item["created"], 'Y-m-d\TH:i:s\Z');
|
|
||||||
|
|
||||||
$msg = array(
|
|
||||||
"author" => $myaddr,
|
|
||||||
"guid" => $item["guid"],
|
|
||||||
"conversation_guid" => $cnv["guid"],
|
|
||||||
"text" => $body,
|
|
||||||
"created_at" => $created,
|
|
||||||
);
|
|
||||||
|
|
||||||
if ($item["reply"]) {
|
|
||||||
$message = $msg;
|
|
||||||
$type = "message";
|
|
||||||
} else {
|
|
||||||
$message = array(
|
|
||||||
"author" => $cnv["creator"],
|
|
||||||
"guid" => $cnv["guid"],
|
|
||||||
"subject" => $cnv["subject"],
|
|
||||||
"created_at" => datetime_convert("UTC", "UTC", $cnv['created'], 'Y-m-d\TH:i:s\Z'),
|
|
||||||
"participants" => $cnv["recips"],
|
|
||||||
"message" => $msg);
|
|
||||||
|
|
||||||
$type = "conversation";
|
|
||||||
}
|
|
||||||
|
|
||||||
return self::build_and_transmit($owner, $contact, $type, $message, false, $item["guid"]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Create profile data
|
|
||||||
*
|
|
||||||
* @param int $uid The user id
|
|
||||||
*
|
|
||||||
* @return array The profile data
|
|
||||||
*/
|
|
||||||
private static function createProfileData($uid) {
|
|
||||||
$r = q("SELECT `profile`.`uid` AS `profile_uid`, `profile`.* , `user`.*, `user`.`prvkey` AS `uprvkey`, `contact`.`addr`
|
|
||||||
FROM `profile`
|
|
||||||
INNER JOIN `user` ON `profile`.`uid` = `user`.`uid`
|
|
||||||
INNER JOIN `contact` ON `profile`.`uid` = `contact`.`uid`
|
|
||||||
WHERE `user`.`uid` = %d AND `profile`.`is-default` AND `contact`.`self` LIMIT 1",
|
|
||||||
intval($uid)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (!$r) {
|
|
||||||
return array();
|
|
||||||
}
|
|
||||||
|
|
||||||
$profile = $r[0];
|
|
||||||
|
|
||||||
$handle = $profile["addr"];
|
|
||||||
$first = ((strpos($profile['name'],' ')
|
|
||||||
? trim(substr($profile['name'],0,strpos($profile['name'],' '))) : $profile['name']));
|
|
||||||
$last = (($first === $profile['name']) ? '' : trim(substr($profile['name'], strlen($first))));
|
|
||||||
$large = System::baseUrl().'/photo/custom/300/'.$profile['uid'].'.jpg';
|
|
||||||
$medium = System::baseUrl().'/photo/custom/100/'.$profile['uid'].'.jpg';
|
|
||||||
$small = System::baseUrl().'/photo/custom/50/' .$profile['uid'].'.jpg';
|
|
||||||
$searchable = (($profile['publish'] && $profile['net-publish']) ? 'true' : 'false');
|
|
||||||
|
|
||||||
if ($searchable === 'true') {
|
|
||||||
$dob = '1000-00-00';
|
|
||||||
|
|
||||||
if (($profile['dob']) && ($profile['dob'] > '0001-01-01'))
|
|
||||||
$dob = ((intval($profile['dob'])) ? intval($profile['dob']) : '1000') .'-'. datetime_convert('UTC','UTC',$profile['dob'],'m-d');
|
|
||||||
|
|
||||||
$about = $profile['about'];
|
|
||||||
$about = strip_tags(bbcode($about));
|
|
||||||
|
|
||||||
$location = formatted_location($profile);
|
|
||||||
$tags = '';
|
|
||||||
if ($profile['pub_keywords']) {
|
|
||||||
$kw = str_replace(',',' ',$profile['pub_keywords']);
|
|
||||||
$kw = str_replace(' ',' ',$kw);
|
|
||||||
$arr = explode(' ',$profile['pub_keywords']);
|
|
||||||
if (count($arr)) {
|
|
||||||
for ($x = 0; $x < 5; $x ++) {
|
|
||||||
if (trim($arr[$x]))
|
|
||||||
$tags .= '#'. trim($arr[$x]) .' ';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$tags = trim($tags);
|
|
||||||
}
|
|
||||||
|
|
||||||
return array("author" => $handle,
|
|
||||||
"first_name" => $first,
|
|
||||||
"last_name" => $last,
|
|
||||||
"image_url" => $large,
|
|
||||||
"image_url_medium" => $medium,
|
|
||||||
"image_url_small" => $small,
|
|
||||||
"birthday" => $dob,
|
|
||||||
"gender" => $profile['gender'],
|
|
||||||
"bio" => $about,
|
|
||||||
"location" => $location,
|
|
||||||
"searchable" => $searchable,
|
|
||||||
"nsfw" => "false",
|
|
||||||
"tag_string" => $tags);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Sends profile data
|
|
||||||
*
|
|
||||||
* @param int $uid The user id
|
|
||||||
*/
|
|
||||||
public static function send_profile($uid, $recips = false) {
|
|
||||||
|
|
||||||
if (!$uid)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (!$recips)
|
|
||||||
$recips = q("SELECT `id`,`name`,`network`,`pubkey`,`notify` FROM `contact` WHERE `network` = '%s'
|
|
||||||
AND `uid` = %d AND `rel` != %d",
|
|
||||||
dbesc(NETWORK_DIASPORA),
|
|
||||||
intval($uid),
|
|
||||||
intval(CONTACT_IS_SHARING)
|
|
||||||
);
|
|
||||||
if (!$recips)
|
|
||||||
return;
|
|
||||||
|
|
||||||
$message = self::createProfileData($uid);
|
|
||||||
|
|
||||||
foreach ($recips as $recip) {
|
|
||||||
logger("Send updated profile data for user ".$uid." to contact ".$recip["id"], LOGGER_DEBUG);
|
|
||||||
self::build_and_transmit($profile, $recip, "profile", $message, false, "", true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Stores the signature for likes that are created on our system
|
|
||||||
*
|
|
||||||
* @param array $contact The contact array of the "like"
|
|
||||||
* @param int $post_id The post id of the "like"
|
|
||||||
*
|
|
||||||
* @return bool Success
|
|
||||||
*/
|
|
||||||
public static function store_like_signature($contact, $post_id) {
|
|
||||||
|
|
||||||
// Is the contact the owner? Then fetch the private key
|
|
||||||
if (!$contact['self'] || ($contact['uid'] == 0)) {
|
|
||||||
logger("No owner post, so not storing signature", LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$r = q("SELECT `prvkey` FROM `user` WHERE `uid` = %d LIMIT 1", intval($contact['uid']));
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$contact["uprvkey"] = $r[0]['prvkey'];
|
|
||||||
|
|
||||||
$r = q("SELECT * FROM `item` WHERE `id` = %d LIMIT 1", intval($post_id));
|
|
||||||
if (!dbm::is_result($r)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!in_array($r[0]["verb"], array(ACTIVITY_LIKE, ACTIVITY_DISLIKE))) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$message = self::construct_like($r[0], $contact);
|
|
||||||
$message["author_signature"] = self::signature($contact, $message);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Now store the signature more flexible to dynamically support new fields.
|
|
||||||
* This will break Diaspora compatibility with Friendica versions prior to 3.5.
|
|
||||||
*/
|
|
||||||
dba::insert('sign', array('iid' => $post_id, 'signed_text' => json_encode($message)));
|
|
||||||
|
|
||||||
logger('Stored diaspora like signature');
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Stores the signature for comments that are created on our system
|
|
||||||
*
|
|
||||||
* @param array $item The item array of the comment
|
|
||||||
* @param array $contact The contact array of the item owner
|
|
||||||
* @param string $uprvkey The private key of the sender
|
|
||||||
* @param int $message_id The message id of the comment
|
|
||||||
*
|
|
||||||
* @return bool Success
|
|
||||||
*/
|
|
||||||
public static function store_comment_signature($item, $contact, $uprvkey, $message_id) {
|
|
||||||
|
|
||||||
if ($uprvkey == "") {
|
|
||||||
logger('No private key, so not storing comment signature', LOGGER_DEBUG);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$contact["uprvkey"] = $uprvkey;
|
|
||||||
|
|
||||||
$message = self::construct_comment($item, $contact);
|
|
||||||
$message["author_signature"] = self::signature($contact, $message);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Now store the signature more flexible to dynamically support new fields.
|
|
||||||
* This will break Diaspora compatibility with Friendica versions prior to 3.5.
|
|
||||||
*/
|
|
||||||
dba::insert('sign', array('iid' => $message_id, 'signed_text' => json_encode($message)));
|
|
||||||
|
|
||||||
logger('Stored diaspora comment signature');
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function directory_run(&$argv, &$argc){
|
function directory_run(&$argv, &$argc){
|
||||||
$dir = Config::get('system', 'directory');
|
$dir = Config::get('system', 'directory');
|
||||||
|
|
@ -36,7 +37,7 @@ function directory_update_all() {
|
||||||
WHERE `contact`.`self` AND `profile`.`net-publish` AND `profile`.`is-default` AND
|
WHERE `contact`.`self` AND `profile`.`net-publish` AND `profile`.`is-default` AND
|
||||||
NOT `user`.`account_expired` AND `user`.`verified`");
|
NOT `user`.`account_expired` AND `user`.`verified`");
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r AS $user) {
|
foreach ($r AS $user) {
|
||||||
Worker::add(PRIORITY_LOW, 'directory', $user['url']);
|
Worker::add(PRIORITY_LOW, 'directory', $user['url']);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
|
|
||||||
require_once 'include/socgraph.php';
|
require_once 'include/socgraph.php';
|
||||||
|
|
@ -107,7 +108,7 @@ function discover_poco_run(&$argv, &$argc) {
|
||||||
function update_server() {
|
function update_server() {
|
||||||
$r = q("SELECT `url`, `created`, `last_failure`, `last_contact` FROM `gserver` ORDER BY rand()");
|
$r = q("SELECT `url`, `created`, `last_failure`, `last_contact` FROM `gserver` ORDER BY rand()");
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -213,7 +214,7 @@ function discover_directory($search) {
|
||||||
foreach ($j->results as $jj) {
|
foreach ($j->results as $jj) {
|
||||||
// Check if the contact already exists
|
// Check if the contact already exists
|
||||||
$exists = q("SELECT `id`, `last_contact`, `last_failure`, `updated` FROM `gcontact` WHERE `nurl` = '%s'", normalise_link($jj->url));
|
$exists = q("SELECT `id`, `last_contact`, `last_failure`, `updated` FROM `gcontact` WHERE `nurl` = '%s'", normalise_link($jj->url));
|
||||||
if (dbm::is_result($exists)) {
|
if (DBM::is_result($exists)) {
|
||||||
logger("Profile ".$jj->url." already exists (".$search.")", LOGGER_DEBUG);
|
logger("Profile ".$jj->url." already exists (".$search.")", LOGGER_DEBUG);
|
||||||
|
|
||||||
if (($exists[0]["last_contact"] < $exists[0]["last_failure"]) &&
|
if (($exists[0]["last_contact"] < $exists[0]["last_failure"]) &&
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/Emailer.php');
|
require_once('include/Emailer.php');
|
||||||
require_once('include/email.php');
|
require_once('include/email.php');
|
||||||
|
|
@ -52,7 +53,7 @@ function notification($params) {
|
||||||
array('uid' => $params['uid']), array('limit' => 1));
|
array('uid' => $params['uid']), array('limit' => 1));
|
||||||
|
|
||||||
// There is no need to create notifications for forum accounts
|
// There is no need to create notifications for forum accounts
|
||||||
if (!dbm::is_result($user) || in_array($user["page-flags"], array(PAGE_COMMUNITY, PAGE_PRVGROUP))) {
|
if (!DBM::is_result($user) || in_array($user["page-flags"], array(PAGE_COMMUNITY, PAGE_PRVGROUP))) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -423,7 +424,7 @@ function notification($params) {
|
||||||
$hash = random_string();
|
$hash = random_string();
|
||||||
$r = q("SELECT `id` FROM `notify` WHERE `hash` = '%s' LIMIT 1",
|
$r = q("SELECT `id` FROM `notify` WHERE `hash` = '%s' LIMIT 1",
|
||||||
dbesc($hash));
|
dbesc($hash));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$dups = true;
|
$dups = true;
|
||||||
}
|
}
|
||||||
} while ($dups == true);
|
} while ($dups == true);
|
||||||
|
|
@ -743,17 +744,17 @@ function check_item_notification($itemid, $uid, $defaulttype = "") {
|
||||||
intval($item[0]['contact-id']),
|
intval($item[0]['contact-id']),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
$send_notification = dbm::is_result($r);
|
$send_notification = DBM::is_result($r);
|
||||||
|
|
||||||
if (!$send_notification) {
|
if (!$send_notification) {
|
||||||
$tags = q("SELECT `url` FROM `term` WHERE `otype` = %d AND `oid` = %d AND `type` = %d AND `uid` = %d",
|
$tags = q("SELECT `url` FROM `term` WHERE `otype` = %d AND `oid` = %d AND `type` = %d AND `uid` = %d",
|
||||||
intval(TERM_OBJ_POST), intval($itemid), intval(TERM_MENTION), intval($uid));
|
intval(TERM_OBJ_POST), intval($itemid), intval(TERM_MENTION), intval($uid));
|
||||||
|
|
||||||
if (dbm::is_result($tags)) {
|
if (DBM::is_result($tags)) {
|
||||||
foreach ($tags AS $tag) {
|
foreach ($tags AS $tag) {
|
||||||
$r = q("SELECT `id` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d AND `notify_new_posts`",
|
$r = q("SELECT `id` FROM `contact` WHERE `nurl` = '%s' AND `uid` = %d AND `notify_new_posts`",
|
||||||
normalise_link($tag["url"]), intval($uid));
|
normalise_link($tag["url"]), intval($uid));
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$send_notification = true;
|
$send_notification = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -7,6 +7,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/bbcode.php';
|
require_once 'include/bbcode.php';
|
||||||
require_once 'include/map.php';
|
require_once 'include/map.php';
|
||||||
|
|
@ -254,7 +255,7 @@ function event_store($arr) {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($c)) {
|
if (DBM::is_result($c)) {
|
||||||
$contact = $c[0];
|
$contact = $c[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -269,7 +270,7 @@ function event_store($arr) {
|
||||||
intval($arr['id']),
|
intval($arr['id']),
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
if ((! dbm::is_result($r)) || ($r[0]['edited'] === $arr['edited'])) {
|
if ((! DBM::is_result($r)) || ($r[0]['edited'] === $arr['edited'])) {
|
||||||
|
|
||||||
// Nothing has changed. Grab the item id to return.
|
// Nothing has changed. Grab the item id to return.
|
||||||
|
|
||||||
|
|
@ -277,7 +278,7 @@ function event_store($arr) {
|
||||||
intval($arr['id']),
|
intval($arr['id']),
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
return ((dbm::is_result($r)) ? $r[0]['id'] : 0);
|
return ((DBM::is_result($r)) ? $r[0]['id'] : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// The event changed. Update it.
|
// The event changed. Update it.
|
||||||
|
|
@ -310,7 +311,7 @@ function event_store($arr) {
|
||||||
intval($arr['id']),
|
intval($arr['id']),
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$object = '<object><type>' . xmlify(ACTIVITY_OBJ_EVENT) . '</type><title></title><id>' . xmlify($arr['uri']) . '</id>';
|
$object = '<object><type>' . xmlify(ACTIVITY_OBJ_EVENT) . '</type><title></title><id>' . xmlify($arr['uri']) . '</id>';
|
||||||
$object .= '<content>' . xmlify(format_event_bbcode($arr)) . '</content>';
|
$object .= '<content>' . xmlify(format_event_bbcode($arr)) . '</content>';
|
||||||
$object .= '</object>' . "\n";
|
$object .= '</object>' . "\n";
|
||||||
|
|
@ -361,7 +362,7 @@ function event_store($arr) {
|
||||||
dbesc($arr['uri']),
|
dbesc($arr['uri']),
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$event = $r[0];
|
$event = $r[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -404,7 +405,7 @@ function event_store($arr) {
|
||||||
$r = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1",
|
$r = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1",
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
//if (dbm::is_result($r))
|
//if (DBM::is_result($r))
|
||||||
// $plink = System::baseUrl() . '/display/' . $r[0]['nickname'] . '/' . $item_id;
|
// $plink = System::baseUrl() . '/display/' . $r[0]['nickname'] . '/' . $item_id;
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -547,7 +548,7 @@ function event_by_id($owner_uid = 0, $event_params, $sql_extra = '') {
|
||||||
intval($event_params["event_id"])
|
intval($event_params["event_id"])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return event_remove_duplicates($r);
|
return event_remove_duplicates($r);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -591,7 +592,7 @@ function events_by_date($owner_uid = 0, $event_params, $sql_extra = '') {
|
||||||
dbesc($event_params["adjust_finish"])
|
dbesc($event_params["adjust_finish"])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return event_remove_duplicates($r);
|
return event_remove_duplicates($r);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -805,7 +806,7 @@ function events_by_uid($uid = 0, $sql_extra = '') {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r;
|
return $r;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -829,7 +830,7 @@ function event_export($uid, $format = 'ical') {
|
||||||
// We are allowed to show events.
|
// We are allowed to show events.
|
||||||
// Get the timezone the user is in.
|
// Get the timezone the user is in.
|
||||||
$r = q("SELECT `timezone` FROM `user` WHERE `uid` = %d LIMIT 1", intval($uid));
|
$r = q("SELECT `timezone` FROM `user` WHERE `uid` = %d LIMIT 1", intval($uid));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$timezone = $r[0]['timezone'];
|
$timezone = $r[0]['timezone'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function expire_run(&$argv, &$argc){
|
function expire_run(&$argv, &$argc){
|
||||||
global $a;
|
global $a;
|
||||||
|
|
@ -30,7 +31,7 @@ function expire_run(&$argv, &$argc){
|
||||||
return;
|
return;
|
||||||
} elseif (($argc == 2) && (intval($argv[1]) > 0)) {
|
} elseif (($argc == 2) && (intval($argv[1]) > 0)) {
|
||||||
$user = dba::select('user', array('uid', 'username', 'expire'), array('uid' => $argv[1]), array('limit' => 1));
|
$user = dba::select('user', array('uid', 'username', 'expire'), array('uid' => $argv[1]), array('limit' => 1));
|
||||||
if (dbm::is_result($user)) {
|
if (DBM::is_result($user)) {
|
||||||
logger('Expire items for user '.$user['uid'].' ('.$user['username'].') - interval: '.$user['expire'], LOGGER_DEBUG);
|
logger('Expire items for user '.$user['uid'].' ('.$user['username'].') - interval: '.$user['expire'], LOGGER_DEBUG);
|
||||||
item_expire($user['uid'], $user['expire']);
|
item_expire($user['uid'], $user['expire']);
|
||||||
logger('Expire items for user '.$user['uid'].' ('.$user['username'].') - done ', LOGGER_DEBUG);
|
logger('Expire items for user '.$user['uid'].' ('.$user['username'].') - done ', LOGGER_DEBUG);
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function fcontact_store($url,$name,$photo) {
|
function fcontact_store($url,$name,$photo) {
|
||||||
|
|
||||||
|
|
@ -10,16 +10,16 @@ function fcontact_store($url,$name,$photo) {
|
||||||
dbesc($nurl)
|
dbesc($nurl)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0]['id'];
|
return $r[0]['id'];
|
||||||
|
|
||||||
$r = dba::insert('fcontact', array('url' => $nurl, 'name' => $name, 'photo' => $photo));
|
$r = dba::insert('fcontact', array('url' => $nurl, 'name' => $name, 'photo' => $photo));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$r = q("SELECT `id` FROM `fcontact` WHERE `url` = '%s' LIMIT 1",
|
$r = q("SELECT `id` FROM `fcontact` WHERE `url` = '%s' LIMIT 1",
|
||||||
dbesc($nurl)
|
dbesc($nurl)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0]['id'];
|
return $r[0]['id'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
use Friendica\Database\DBM;
|
||||||
require_once("include/html2bbcode.php");
|
require_once("include/html2bbcode.php");
|
||||||
require_once("include/items.php");
|
require_once("include/items.php");
|
||||||
|
|
||||||
|
|
@ -235,7 +236,7 @@ function feed_import($xml,$importer,&$contact, &$hub, $simulate = false) {
|
||||||
if (!$simulate) {
|
if (!$simulate) {
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `uid` = %d AND `uri` = '%s' AND `network` IN ('%s', '%s')",
|
$r = q("SELECT `id` FROM `item` WHERE `uid` = %d AND `uri` = '%s' AND `network` IN ('%s', '%s')",
|
||||||
intval($importer["uid"]), dbesc($item["uri"]), dbesc(NETWORK_FEED), dbesc(NETWORK_DFRN));
|
intval($importer["uid"]), dbesc($item["uri"]), dbesc(NETWORK_FEED), dbesc(NETWORK_DFRN));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger("Item with uri ".$item["uri"]." for user ".$importer["uid"]." already existed under id ".$r[0]["id"], LOGGER_DEBUG);
|
logger("Item with uri ".$item["uri"]." for user ".$importer["uid"]." already existed under id ".$r[0]["id"], LOGGER_DEBUG);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
|
|
||||||
|
|
@ -186,12 +187,12 @@ function new_contact($uid, $url, $interactive = false, $network = '') {
|
||||||
dbesc($ret['network'])
|
dbesc($ret['network'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND `nurl` = '%s' AND `network` = '%s' LIMIT 1",
|
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND `nurl` = '%s' AND `network` = '%s' LIMIT 1",
|
||||||
intval($uid), dbesc(normalise_link($url)), dbesc($ret['network'])
|
intval($uid), dbesc(normalise_link($url)), dbesc($ret['network'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
// update contact
|
// update contact
|
||||||
$new_relation = (($r[0]['rel'] == CONTACT_IS_FOLLOWER) ? CONTACT_IS_FRIEND : CONTACT_IS_SHARING);
|
$new_relation = (($r[0]['rel'] == CONTACT_IS_FOLLOWER) ? CONTACT_IS_FRIEND : CONTACT_IS_SHARING);
|
||||||
|
|
||||||
|
|
@ -232,7 +233,7 @@ function new_contact($uid, $url, $interactive = false, $network = '') {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$result['message'] .= t('Unable to retrieve contact information.') . EOL;
|
$result['message'] .= t('Unable to retrieve contact information.') . EOL;
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
@ -258,7 +259,7 @@ function new_contact($uid, $url, $interactive = false, $network = '') {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if (($contact['network'] == NETWORK_OSTATUS) && (strlen($contact['notify']))) {
|
if (($contact['network'] == NETWORK_OSTATUS) && (strlen($contact['notify']))) {
|
||||||
// create a follow slap
|
// create a follow slap
|
||||||
$item = array();
|
$item = array();
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
|
|
||||||
require_once 'include/socgraph.php';
|
require_once 'include/socgraph.php';
|
||||||
|
|
@ -18,7 +19,7 @@ function gprobe_run(&$argv, &$argc){
|
||||||
|
|
||||||
logger("gprobe start for ".normalise_link($url), LOGGER_DEBUG);
|
logger("gprobe start for ".normalise_link($url), LOGGER_DEBUG);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
|
|
||||||
// Is it a DDoS attempt?
|
// Is it a DDoS attempt?
|
||||||
$urlparts = parse_url($url);
|
$urlparts = parse_url($url);
|
||||||
|
|
@ -45,7 +46,7 @@ function gprobe_run(&$argv, &$argc){
|
||||||
dbesc(normalise_link($url))
|
dbesc(normalise_link($url))
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
// Check for accessibility and do a poco discovery
|
// Check for accessibility and do a poco discovery
|
||||||
if (poco_last_updated($r[0]['url'], true) && ($r[0]["network"] == NETWORK_DFRN))
|
if (poco_last_updated($r[0]['url'], true) && ($r[0]["network"] == NETWORK_DFRN))
|
||||||
poco_load(0,0,$r[0]['id'], str_replace('/profile/','/poco/',$r[0]['url']));
|
poco_load(0,0,$r[0]['id'], str_replace('/profile/','/poco/',$r[0]['url']));
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function group_add($uid,$name) {
|
function group_add($uid,$name) {
|
||||||
|
|
||||||
|
|
@ -41,7 +42,7 @@ function group_rmv($uid,$name) {
|
||||||
intval($uid),
|
intval($uid),
|
||||||
dbesc($name)
|
dbesc($name)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$group_id = $r[0]['id'];
|
$group_id = $r[0]['id'];
|
||||||
if (! $group_id)
|
if (! $group_id)
|
||||||
return false;
|
return false;
|
||||||
|
|
@ -103,7 +104,7 @@ function group_byname($uid,$name) {
|
||||||
intval($uid),
|
intval($uid),
|
||||||
dbesc($name)
|
dbesc($name)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0]['id'];
|
return $r[0]['id'];
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
@ -136,11 +137,11 @@ function group_add_member($uid,$name,$member,$gid = 0) {
|
||||||
intval($gid),
|
intval($gid),
|
||||||
intval($member)
|
intval($member)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return true; // You might question this, but
|
return true; // You might question this, but
|
||||||
// we indicate success because the group member was in fact created
|
// we indicate success because the group member was in fact created
|
||||||
// -- It was just created at another time
|
// -- It was just created at another time
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$r = dba::insert('group_member', array('uid' => $uid, 'gid' => $gid, 'contact-id' => $member));
|
$r = dba::insert('group_member', array('uid' => $uid, 'gid' => $gid, 'contact-id' => $member));
|
||||||
}
|
}
|
||||||
return $r;
|
return $r;
|
||||||
|
|
@ -157,7 +158,7 @@ function group_get_members($gid) {
|
||||||
intval($gid),
|
intval($gid),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$ret = $r;
|
$ret = $r;
|
||||||
}
|
}
|
||||||
return $ret;
|
return $ret;
|
||||||
|
|
@ -174,7 +175,7 @@ function group_public_members($gid) {
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
dbesc(NETWORK_OSTATUS)
|
dbesc(NETWORK_OSTATUS)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$ret = count($r);
|
$ret = count($r);
|
||||||
}
|
}
|
||||||
return $ret;
|
return $ret;
|
||||||
|
|
@ -190,7 +191,7 @@ function mini_group_select($uid,$gid = 0, $label = "") {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
$grps[] = array('name' => '', 'id' => '0', 'selected' => '');
|
$grps[] = array('name' => '', 'id' => '0', 'selected' => '');
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$grps[] = array('name' => $rr['name'], 'id' => $rr['id'], 'selected' => (($gid == $rr['id']) ? 'true' : ''));
|
$grps[] = array('name' => $rr['name'], 'id' => $rr['id'], 'selected' => (($gid == $rr['id']) ? 'true' : ''));
|
||||||
}
|
}
|
||||||
|
|
@ -248,7 +249,7 @@ function group_side($every="contacts",$each="group",$editmode = "standard", $gro
|
||||||
$member_of = groups_containing(local_user(),$cid);
|
$member_of = groups_containing(local_user(),$cid);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$selected = (($group_id == $rr['id']) ? ' group-selected' : '');
|
$selected = (($group_id == $rr['id']) ? ' group-selected' : '');
|
||||||
|
|
||||||
|
|
@ -309,7 +310,7 @@ function expand_groups($a,$check_dead = false, $use_gcontact = false) {
|
||||||
|
|
||||||
|
|
||||||
$ret = array();
|
$ret = array();
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
foreach ($r as $rr)
|
foreach ($r as $rr)
|
||||||
$ret[] = $rr['contact-id'];
|
$ret[] = $rr['contact-id'];
|
||||||
if ($check_dead && !$use_gcontact) {
|
if ($check_dead && !$use_gcontact) {
|
||||||
|
|
@ -338,7 +339,7 @@ function groups_containing($uid,$c) {
|
||||||
);
|
);
|
||||||
|
|
||||||
$ret = array();
|
$ret = array();
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$ret[] = $rr['gid'];
|
$ret[] = $rr['gid'];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -8,6 +8,7 @@ use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/ForumManager.php';
|
require_once 'include/ForumManager.php';
|
||||||
require_once 'include/bbcode.php';
|
require_once 'include/bbcode.php';
|
||||||
|
|
@ -143,7 +144,7 @@ function get_profiledata_by_nick($nickname, $uid = 0, $profile = 0) {
|
||||||
foreach ($_SESSION['remote'] as $visitor) {
|
foreach ($_SESSION['remote'] as $visitor) {
|
||||||
if ($visitor['uid'] == $uid) {
|
if ($visitor['uid'] == $uid) {
|
||||||
$r = dba::select('contact', array('profile-id'), array('id' => $visitor['cid']), array('limit' => 1));
|
$r = dba::select('contact', array('profile-id'), array('id' => $visitor['cid']), array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$profile = $r['profile-id'];
|
$profile = $r['profile-id'];
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
@ -167,7 +168,7 @@ function get_profiledata_by_nick($nickname, $uid = 0, $profile = 0) {
|
||||||
$profile_int
|
$profile_int
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
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`.*,
|
||||||
|
|
@ -303,7 +304,7 @@ function profile_sidebar($profile, $block = 0) {
|
||||||
'entries' => array(),
|
'entries' => array(),
|
||||||
);
|
);
|
||||||
|
|
||||||
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(
|
||||||
|
|
@ -382,7 +383,7 @@ function profile_sidebar($profile, $block = 0) {
|
||||||
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("SELECT `gcontact`.`updated` FROM `contact` INNER JOIN `gcontact` WHERE `gcontact`.`nurl` = `contact`.`nurl` AND `self` AND `uid` = %d LIMIT 1",
|
||||||
intval($a->profile['uid']));
|
intval($a->profile['uid']));
|
||||||
if (dbm::is_result($r))
|
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`
|
||||||
|
|
@ -395,7 +396,7 @@ 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']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -479,12 +480,12 @@ function get_birthdays() {
|
||||||
datetime_convert('UTC','UTC','now + 6 days'),
|
datetime_convert('UTC','UTC','now + 6 days'),
|
||||||
datetime_convert('UTC','UTC','now')
|
datetime_convert('UTC','UTC','now')
|
||||||
);
|
);
|
||||||
if (dbm::is_result($s)) {
|
if (DBM::is_result($s)) {
|
||||||
$r = dba::inArray($s);
|
$r = dba::inArray($s);
|
||||||
Cache::set($cachekey, $r, CACHE_HOUR);
|
Cache::set($cachekey, $r, CACHE_HOUR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$total = 0;
|
$total = 0;
|
||||||
$now = strtotime('now');
|
$now = strtotime('now');
|
||||||
$cids = array();
|
$cids = array();
|
||||||
|
|
@ -569,7 +570,7 @@ function get_events() {
|
||||||
|
|
||||||
$r = array();
|
$r = array();
|
||||||
|
|
||||||
if (dbm::is_result($s)) {
|
if (DBM::is_result($s)) {
|
||||||
$now = strtotime('now');
|
$now = strtotime('now');
|
||||||
$istoday = false;
|
$istoday = false;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,8 @@ use Friendica\Util\Lock;
|
||||||
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\Protocol\Dfrn;
|
use Friendica\Database\DBM;
|
||||||
|
use Friendica\Protocol\DFRN;
|
||||||
|
|
||||||
require_once 'include/bbcode.php';
|
require_once 'include/bbcode.php';
|
||||||
require_once 'include/oembed.php';
|
require_once 'include/oembed.php';
|
||||||
|
|
@ -429,7 +430,7 @@ function uri_to_guid($uri, $host = "") {
|
||||||
*/
|
*/
|
||||||
function store_conversation($arr) {
|
function store_conversation($arr) {
|
||||||
if (in_array($arr['network'], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS))) {
|
if (in_array($arr['network'], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS))) {
|
||||||
$conversation = array('item-uri' => $arr['uri'], 'received' => dbm::date());
|
$conversation = array('item-uri' => $arr['uri'], 'received' => DBM::date());
|
||||||
|
|
||||||
if (isset($arr['parent-uri']) && ($arr['parent-uri'] != $arr['uri'])) {
|
if (isset($arr['parent-uri']) && ($arr['parent-uri'] != $arr['uri'])) {
|
||||||
$conversation['reply-to-uri'] = $arr['parent-uri'];
|
$conversation['reply-to-uri'] = $arr['parent-uri'];
|
||||||
|
|
@ -456,7 +457,7 @@ function store_conversation($arr) {
|
||||||
|
|
||||||
$old_conv = dba::fetch_first("SELECT `item-uri`, `reply-to-uri`, `conversation-uri`, `conversation-href`, `protocol`, `source`
|
$old_conv = dba::fetch_first("SELECT `item-uri`, `reply-to-uri`, `conversation-uri`, `conversation-href`, `protocol`, `source`
|
||||||
FROM `conversation` WHERE `item-uri` = ?", $conversation['item-uri']);
|
FROM `conversation` WHERE `item-uri` = ?", $conversation['item-uri']);
|
||||||
if (dbm::is_result($old_conv)) {
|
if (DBM::is_result($old_conv)) {
|
||||||
// Don't update when only the source has changed.
|
// Don't update when only the source has changed.
|
||||||
// Only do this when there had been no source before.
|
// Only do this when there had been no source before.
|
||||||
if ($old_conv['source'] != '') {
|
if ($old_conv['source'] != '') {
|
||||||
|
|
@ -570,7 +571,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
$expire_interval = Config::get('system', 'dbclean-expire-days', 0);
|
$expire_interval = Config::get('system', 'dbclean-expire-days', 0);
|
||||||
|
|
||||||
$r = dba::select('user', array('expire'), array('uid' => $uid), array("limit" => 1));
|
$r = dba::select('user', array('expire'), array('uid' => $uid), array("limit" => 1));
|
||||||
if (dbm::is_result($r) && ($r['expire'] > 0) && (($r['expire'] < $expire_interval) || ($expire_interval == 0))) {
|
if (DBM::is_result($r) && ($r['expire'] > 0) && (($r['expire'] < $expire_interval) || ($expire_interval == 0))) {
|
||||||
$expire_interval = $r['expire'];
|
$expire_interval = $r['expire'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -596,7 +597,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
dbesc(NETWORK_DFRN),
|
dbesc(NETWORK_DFRN),
|
||||||
dbesc(NETWORK_OSTATUS)
|
dbesc(NETWORK_OSTATUS)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
// We only log the entries with a different user id than 0. Otherwise we would have too many false positives
|
// We only log the entries with a different user id than 0. Otherwise we would have too many false positives
|
||||||
if ($uid != 0) {
|
if ($uid != 0) {
|
||||||
logger("Item with uri ".$arr['uri']." already existed for user ".$uid." with id ".$r[0]["id"]." target network ".$r[0]["network"]." - new network: ".$arr['network']);
|
logger("Item with uri ".$arr['uri']." already existed for user ".$uid." with id ".$r[0]["id"]." target network ".$r[0]["network"]." - new network: ".$arr['network']);
|
||||||
|
|
@ -688,20 +689,20 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
$r = q("SELECT `network` FROM `gcontact` WHERE `network` IN ('%s', '%s', '%s') AND `nurl` = '%s' LIMIT 1",
|
$r = q("SELECT `network` FROM `gcontact` WHERE `network` IN ('%s', '%s', '%s') AND `nurl` = '%s' LIMIT 1",
|
||||||
dbesc(NETWORK_DFRN), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_OSTATUS),
|
dbesc(NETWORK_DFRN), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_OSTATUS),
|
||||||
dbesc(normalise_link($arr['author-link']))
|
dbesc(normalise_link($arr['author-link']))
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `network` FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1",
|
$r = q("SELECT `network` FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1",
|
||||||
intval($arr['contact-id']),
|
intval($arr['contact-id']),
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$arr['network'] = $r[0]["network"];
|
$arr['network'] = $r[0]["network"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -732,7 +733,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
if ($arr["contact-id"] == 0) {
|
if ($arr["contact-id"] == 0) {
|
||||||
$r = q("SELECT `id` FROM `contact` WHERE `self` AND `uid` = %d", intval($uid));
|
$r = q("SELECT `id` FROM `contact` WHERE `self` AND `uid` = %d", intval($uid));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$arr["contact-id"] = $r[0]["id"];
|
$arr["contact-id"] = $r[0]["id"];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -779,7 +780,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
$r = q("SELECT `guid` FROM `item` WHERE `guid` = '%s' AND `network` = '%s' AND `uid` = '%d' LIMIT 1",
|
$r = q("SELECT `guid` FROM `item` WHERE `guid` = '%s' AND `network` = '%s' AND `uid` = '%d' LIMIT 1",
|
||||||
dbesc($arr['guid']), dbesc($arr['network']), intval($arr['uid']));
|
dbesc($arr['guid']), dbesc($arr['network']), intval($arr['uid']));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger('found item with guid '.$arr['guid'].' for user '.$arr['uid'].' on network '.$arr['network'], LOGGER_DEBUG);
|
logger('found item with guid '.$arr['guid'].' for user '.$arr['uid'].' on network '.$arr['network'], LOGGER_DEBUG);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
@ -808,7 +809,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
// is the new message multi-level threaded?
|
// is the new message multi-level threaded?
|
||||||
// even though we don't support it now, preserve the info
|
// even though we don't support it now, preserve the info
|
||||||
|
|
@ -823,7 +824,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($z)) {
|
if (DBM::is_result($z)) {
|
||||||
$r = $z;
|
$r = $z;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -858,7 +859,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
// If its a post from myself then tag the thread as "mention"
|
// If its a post from myself then tag the thread as "mention"
|
||||||
logger("item_store: Checking if parent ".$parent_id." has to be tagged as mention for user ".$arr['uid'], LOGGER_DEBUG);
|
logger("item_store: Checking if parent ".$parent_id." has to be tagged as mention for user ".$arr['uid'], LOGGER_DEBUG);
|
||||||
$u = q("SELECT `nickname` FROM `user` WHERE `uid` = %d", intval($arr['uid']));
|
$u = q("SELECT `nickname` FROM `user` WHERE `uid` = %d", intval($arr['uid']));
|
||||||
if (dbm::is_result($u)) {
|
if (DBM::is_result($u)) {
|
||||||
$a = get_app();
|
$a = get_app();
|
||||||
$self = normalise_link(System::baseUrl() . '/profile/' . $u[0]['nickname']);
|
$self = normalise_link(System::baseUrl() . '/profile/' . $u[0]['nickname']);
|
||||||
logger("item_store: 'myself' is ".$self." for parent ".$parent_id." checking against ".$arr['author-link']." and ".$arr['owner-link'], LOGGER_DEBUG);
|
logger("item_store: 'myself' is ".$self." for parent ".$parent_id." checking against ".$arr['author-link']." and ".$arr['owner-link'], LOGGER_DEBUG);
|
||||||
|
|
@ -892,7 +893,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
dbesc(NETWORK_DFRN),
|
dbesc(NETWORK_DFRN),
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger('duplicated item with the same uri found. '.print_r($arr,true));
|
logger('duplicated item with the same uri found. '.print_r($arr,true));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
@ -903,7 +904,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
dbesc($arr['guid']),
|
dbesc($arr['guid']),
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger('duplicated item with the same guid found. '.print_r($arr,true));
|
logger('duplicated item with the same guid found. '.print_r($arr,true));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
@ -916,7 +917,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
intval($arr['contact-id']),
|
intval($arr['contact-id']),
|
||||||
intval($arr['uid'])
|
intval($arr['uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger('duplicated item with the same body found. '.print_r($arr,true));
|
logger('duplicated item with the same body found. '.print_r($arr,true));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
@ -931,7 +932,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
} else {
|
} else {
|
||||||
$isglobal = q("SELECT `global` FROM `item` WHERE `uid` = 0 AND `uri` = '%s'", dbesc($arr["uri"]));
|
$isglobal = q("SELECT `global` FROM `item` WHERE `uid` = 0 AND `uri` = '%s'", dbesc($arr["uri"]));
|
||||||
|
|
||||||
$arr["global"] = (dbm::is_result($isglobal) && count($isglobal) > 0);
|
$arr["global"] = (DBM::is_result($isglobal) && count($isglobal) > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ACL settings
|
// ACL settings
|
||||||
|
|
@ -973,7 +974,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
*/
|
*/
|
||||||
if ($arr["uid"] == 0) {
|
if ($arr["uid"] == 0) {
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' AND `uid` = 0 LIMIT 1", dbesc(trim($arr['uri'])));
|
$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' AND `uid` = 0 LIMIT 1", dbesc(trim($arr['uri'])));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger('Global item already stored. URI: '.$arr['uri'].' on network '.$arr['network'], LOGGER_DEBUG);
|
logger('Global item already stored. URI: '.$arr['uri'].' on network '.$arr['network'], LOGGER_DEBUG);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
@ -985,7 +986,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
$r = dba::insert('item', $arr);
|
$r = dba::insert('item', $arr);
|
||||||
|
|
||||||
// When the item was successfully stored we fetch the ID of the item.
|
// When the item was successfully stored we fetch the ID of the item.
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$current_post = dba::lastInsertId();
|
$current_post = dba::lastInsertId();
|
||||||
} else {
|
} else {
|
||||||
// This can happen - for example - if there are locking timeouts.
|
// This can happen - for example - if there are locking timeouts.
|
||||||
|
|
@ -1026,7 +1027,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
dbesc($arr['network'])
|
dbesc($arr['network'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
// This shouldn't happen, since COUNT always works when the database connection is there.
|
// This shouldn't happen, since COUNT always works when the database connection is there.
|
||||||
logger("We couldn't count the stored entries. Very strange ...");
|
logger("We couldn't count the stored entries. Very strange ...");
|
||||||
dba::rollback();
|
dba::rollback();
|
||||||
|
|
@ -1093,7 +1094,7 @@ function item_store($arr, $force_parent = false, $notify = false, $dontcache = f
|
||||||
if (!$deleted && !$dontcache) {
|
if (!$deleted && !$dontcache) {
|
||||||
|
|
||||||
$r = q('SELECT * FROM `item` WHERE `id` = %d', intval($current_post));
|
$r = q('SELECT * FROM `item` WHERE `id` = %d', intval($current_post));
|
||||||
if ((dbm::is_result($r)) && (count($r) == 1)) {
|
if ((DBM::is_result($r)) && (count($r) == 1)) {
|
||||||
if ($notify) {
|
if ($notify) {
|
||||||
call_hooks('post_local_end', $r[0]);
|
call_hooks('post_local_end', $r[0]);
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -1163,7 +1164,7 @@ function item_set_last_item($arr) {
|
||||||
if (!$update && ($arr["network"] == NETWORK_DFRN) && ($arr["parent-uri"] === $arr["uri"])) {
|
if (!$update && ($arr["network"] == NETWORK_DFRN) && ($arr["parent-uri"] === $arr["uri"])) {
|
||||||
$isforum = q("SELECT `forum` FROM `contact` WHERE `id` = %d AND `forum`",
|
$isforum = q("SELECT `forum` FROM `contact` WHERE `id` = %d AND `forum`",
|
||||||
intval($arr['contact-id']));
|
intval($arr['contact-id']));
|
||||||
if (dbm::is_result($isforum)) {
|
if (DBM::is_result($isforum)) {
|
||||||
$update = true;
|
$update = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -1255,7 +1256,7 @@ function item_body_set_hashtags(&$item) {
|
||||||
|
|
||||||
function get_item_guid($id) {
|
function get_item_guid($id) {
|
||||||
$r = q("SELECT `guid` FROM `item` WHERE `id` = %d LIMIT 1", intval($id));
|
$r = q("SELECT `guid` FROM `item` WHERE `id` = %d LIMIT 1", intval($id));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0]["guid"];
|
return $r[0]["guid"];
|
||||||
} else {
|
} else {
|
||||||
/// @TODO This else-block can be elimited again
|
/// @TODO This else-block can be elimited again
|
||||||
|
|
@ -1277,7 +1278,7 @@ function get_item_id($guid, $uid = 0) {
|
||||||
$r = q("SELECT `item`.`id`, `user`.`nickname` FROM `item` INNER JOIN `user` ON `user`.`uid` = `item`.`uid`
|
$r = q("SELECT `item`.`id`, `user`.`nickname` FROM `item` INNER JOIN `user` ON `user`.`uid` = `item`.`uid`
|
||||||
WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 AND `item`.`moderated` = 0
|
WHERE `item`.`visible` = 1 AND `item`.`deleted` = 0 AND `item`.`moderated` = 0
|
||||||
AND `item`.`guid` = '%s' AND `item`.`uid` = %d", dbesc($guid), intval($uid));
|
AND `item`.`guid` = '%s' AND `item`.`uid` = %d", dbesc($guid), intval($uid));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$id = $r[0]["id"];
|
$id = $r[0]["id"];
|
||||||
$nick = $r[0]["nickname"];
|
$nick = $r[0]["nickname"];
|
||||||
}
|
}
|
||||||
|
|
@ -1291,7 +1292,7 @@ function get_item_id($guid, $uid = 0) {
|
||||||
AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = ''
|
AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = ''
|
||||||
AND `item`.`private` = 0 AND `item`.`wall` = 1
|
AND `item`.`private` = 0 AND `item`.`wall` = 1
|
||||||
AND `item`.`guid` = '%s'", dbesc($guid));
|
AND `item`.`guid` = '%s'", dbesc($guid));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$id = $r[0]["id"];
|
$id = $r[0]["id"];
|
||||||
$nick = $r[0]["nickname"];
|
$nick = $r[0]["nickname"];
|
||||||
}
|
}
|
||||||
|
|
@ -1329,7 +1330,7 @@ function tag_deliver($uid, $item_id) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($u)) {
|
if (! DBM::is_result($u)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1341,7 +1342,7 @@ function tag_deliver($uid, $item_id) {
|
||||||
intval($item_id),
|
intval($item_id),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($i)) {
|
if (! DBM::is_result($i)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1398,7 +1399,7 @@ function tag_deliver($uid, $item_id) {
|
||||||
$c = q("SELECT `name`, `url`, `thumb` FROM `contact` WHERE `self` = 1 AND `uid` = %d LIMIT 1",
|
$c = q("SELECT `name`, `url`, `thumb` FROM `contact` WHERE `self` = 1 AND `uid` = %d LIMIT 1",
|
||||||
intval($u[0]['uid'])
|
intval($u[0]['uid'])
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($c)) {
|
if (! DBM::is_result($c)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1443,7 +1444,7 @@ function tgroup_check($uid, $item) {
|
||||||
$u = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1",
|
$u = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1",
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($u)) {
|
if (! DBM::is_result($u)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1562,9 +1563,9 @@ function consume_feed($xml, $importer, &$contact, &$hub, $datedir = 0, $pass = 0
|
||||||
WHERE `contact`.`id` = %d AND `user`.`uid` = %d",
|
WHERE `contact`.`id` = %d AND `user`.`uid` = %d",
|
||||||
dbesc($contact["id"]), dbesc($importer["uid"])
|
dbesc($contact["id"]), dbesc($importer["uid"])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger("Now import the DFRN feed");
|
logger("Now import the DFRN feed");
|
||||||
Dfrn::import($xml, $r[0], true);
|
DFRN::import($xml, $r[0], true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -1602,7 +1603,7 @@ function item_is_remote_self($contact, &$datarray) {
|
||||||
if ($contact['remote_self'] == 2) {
|
if ($contact['remote_self'] == 2) {
|
||||||
$r = q("SELECT `id`,`url`,`name`,`thumb` FROM `contact` WHERE `uid` = %d AND `self`",
|
$r = q("SELECT `id`,`url`,`name`,`thumb` FROM `contact` WHERE `uid` = %d AND `self`",
|
||||||
intval($contact['uid']));
|
intval($contact['uid']));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$datarray['contact-id'] = $r[0]["id"];
|
$datarray['contact-id'] = $r[0]["id"];
|
||||||
|
|
||||||
$datarray['owner-name'] = $r[0]["name"];
|
$datarray['owner-name'] = $r[0]["name"];
|
||||||
|
|
@ -1691,7 +1692,7 @@ function new_follower($importer, $contact, $datarray, $item, $sharing = false) {
|
||||||
intval($importer['uid']),
|
intval($importer['uid']),
|
||||||
dbesc($url)
|
dbesc($url)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact_record = $r[0];
|
$contact_record = $r[0];
|
||||||
update_contact_avatar($photo, $importer["uid"], $contact_record["id"], true);
|
update_contact_avatar($photo, $importer["uid"], $contact_record["id"], true);
|
||||||
}
|
}
|
||||||
|
|
@ -1701,7 +1702,7 @@ function new_follower($importer, $contact, $datarray, $item, $sharing = false) {
|
||||||
intval($importer['uid'])
|
intval($importer['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r) && !in_array($r[0]['page-flags'], array(PAGE_SOAPBOX, PAGE_FREELOVE, PAGE_COMMUNITY))) {
|
if (DBM::is_result($r) && !in_array($r[0]['page-flags'], array(PAGE_SOAPBOX, PAGE_FREELOVE, PAGE_COMMUNITY))) {
|
||||||
|
|
||||||
// create notification
|
// create notification
|
||||||
$hash = random_string();
|
$hash = random_string();
|
||||||
|
|
@ -1737,7 +1738,7 @@ function new_follower($importer, $contact, $datarray, $item, $sharing = false) {
|
||||||
));
|
));
|
||||||
|
|
||||||
}
|
}
|
||||||
} elseif (dbm::is_result($r) && in_array($r[0]['page-flags'], array(PAGE_SOAPBOX, PAGE_FREELOVE, PAGE_COMMUNITY))) {
|
} elseif (DBM::is_result($r) && in_array($r[0]['page-flags'], array(PAGE_SOAPBOX, PAGE_FREELOVE, PAGE_COMMUNITY))) {
|
||||||
$r = q("UPDATE `contact` SET `pending` = 0 WHERE `uid` = %d AND `url` = '%s' AND `pending` LIMIT 1",
|
$r = q("UPDATE `contact` SET `pending` = 0 WHERE `uid` = %d AND `url` = '%s' AND `pending` LIMIT 1",
|
||||||
intval($importer['uid']),
|
intval($importer['uid']),
|
||||||
dbesc($url)
|
dbesc($url)
|
||||||
|
|
@ -1780,7 +1781,7 @@ function subscribe_to_hub($url, $importer, $contact, $hubmode = 'subscribe') {
|
||||||
* through the direct Diaspora protocol. If we try and use
|
* through the direct Diaspora protocol. If we try and use
|
||||||
* the feed, we'll get duplicates. So don't.
|
* the feed, we'll get duplicates. So don't.
|
||||||
*/
|
*/
|
||||||
if ((! dbm::is_result($r)) || $contact['network'] === NETWORK_DIASPORA) {
|
if ((! DBM::is_result($r)) || $contact['network'] === NETWORK_DIASPORA) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1846,7 +1847,7 @@ function fix_private_photos($s, $uid, $item = null, $cid = 0) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
|
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
/*
|
/*
|
||||||
* Check to see if we should replace this photo link with an embedded image
|
* Check to see if we should replace this photo link with an embedded image
|
||||||
* 1. No need to do so if the photo is public
|
* 1. No need to do so if the photo is public
|
||||||
|
|
@ -2017,7 +2018,7 @@ function item_expire($uid, $days, $network = "", $force = false) {
|
||||||
intval($days)
|
intval($days)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -2094,7 +2095,7 @@ function drop_item($id, $interactive = true) {
|
||||||
intval($id)
|
intval($id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
if (! $interactive) {
|
if (! $interactive) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
@ -2261,7 +2262,7 @@ function drop_item($id, $interactive = true) {
|
||||||
dbesc($item['parent-uri']),
|
dbesc($item['parent-uri']),
|
||||||
intval($item['uid'])
|
intval($item['uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
dba::update('item', array('last-child' => true), array('id' => $r[0]['id']));
|
dba::update('item', array('last-child' => true), array('id' => $r[0]['id']));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -2298,7 +2299,7 @@ function first_post_date($uid, $wall = false) {
|
||||||
intval($uid),
|
intval($uid),
|
||||||
intval($wall ? 1 : 0)
|
intval($wall ? 1 : 0)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
// logger('first_post_date: ' . $r[0]['id'] . ' ' . $r[0]['created'], LOGGER_DATA);
|
// logger('first_post_date: ' . $r[0]['id'] . ' ' . $r[0]['created'], LOGGER_DATA);
|
||||||
return substr(datetime_convert('',date_default_timezone_get(), $r[0]['created']),0,10);
|
return substr(datetime_convert('',date_default_timezone_get(), $r[0]['created']),0,10);
|
||||||
}
|
}
|
||||||
|
|
@ -2391,7 +2392,7 @@ function posted_date_widget($url, $uid, $wall) {
|
||||||
|
|
||||||
$ret = list_post_dates($uid, $wall);
|
$ret = list_post_dates($uid, $wall);
|
||||||
|
|
||||||
if (! dbm::is_result($ret)) {
|
if (! DBM::is_result($ret)) {
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -71,7 +72,7 @@ function do_like($item_id, $verb) {
|
||||||
dbesc($item_id)
|
dbesc($item_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! $item_id || ! dbm::is_result($items)) {
|
if (! $item_id || ! DBM::is_result($items)) {
|
||||||
logger('like: unknown item ' . $item_id);
|
logger('like: unknown item ' . $item_id);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
@ -89,7 +90,7 @@ function do_like($item_id, $verb) {
|
||||||
AND `contact`.`uid` = %d",
|
AND `contact`.`uid` = %d",
|
||||||
intval($item['uid'])
|
intval($item['uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($owners)) {
|
if (DBM::is_result($owners)) {
|
||||||
$owner_self_contact = $owners[0];
|
$owner_self_contact = $owners[0];
|
||||||
} else {
|
} else {
|
||||||
logger('like: unknown owner ' . $item['uid']);
|
logger('like: unknown owner ' . $item['uid']);
|
||||||
|
|
@ -102,7 +103,7 @@ function do_like($item_id, $verb) {
|
||||||
$contacts = q("SELECT * FROM `contact` WHERE `id` = %d",
|
$contacts = q("SELECT * FROM `contact` WHERE `id` = %d",
|
||||||
intval($author_id)
|
intval($author_id)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($contacts)) {
|
if (DBM::is_result($contacts)) {
|
||||||
$author_contact = $contacts[0];
|
$author_contact = $contacts[0];
|
||||||
} else {
|
} else {
|
||||||
logger('like: unknown author ' . $author_id);
|
logger('like: unknown author ' . $author_id);
|
||||||
|
|
@ -119,7 +120,7 @@ function do_like($item_id, $verb) {
|
||||||
$contacts = q("SELECT * FROM `contact` WHERE `id` = %d",
|
$contacts = q("SELECT * FROM `contact` WHERE `id` = %d",
|
||||||
intval($item_contact_id)
|
intval($item_contact_id)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($contacts)) {
|
if (DBM::is_result($contacts)) {
|
||||||
$item_contact = $contacts[0];
|
$item_contact = $contacts[0];
|
||||||
} else {
|
} else {
|
||||||
logger('like: unknown item contact ' . $item_contact_id);
|
logger('like: unknown item contact ' . $item_contact_id);
|
||||||
|
|
@ -149,7 +150,7 @@ function do_like($item_id, $verb) {
|
||||||
);
|
);
|
||||||
|
|
||||||
// If it exists, mark it as deleted
|
// If it exists, mark it as deleted
|
||||||
if (dbm::is_result($existing_like)) {
|
if (DBM::is_result($existing_like)) {
|
||||||
$like_item = $existing_like[0];
|
$like_item = $existing_like[0];
|
||||||
|
|
||||||
// Already voted, undo it
|
// Already voted, undo it
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function send_message($recipient=0, $body='', $subject='', $replyto=''){
|
function send_message($recipient=0, $body='', $subject='', $replyto=''){
|
||||||
|
|
||||||
|
|
@ -42,7 +43,7 @@ function send_message($recipient=0, $body='', $subject='', $replyto=''){
|
||||||
dbesc($replyto),
|
dbesc($replyto),
|
||||||
dbesc($replyto)
|
dbesc($replyto)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$convid = $r[0]['convid'];
|
$convid = $r[0]['convid'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -67,7 +68,7 @@ function send_message($recipient=0, $body='', $subject='', $replyto=''){
|
||||||
$r = dba::insert('conv', $fields);
|
$r = dba::insert('conv', $fields);
|
||||||
|
|
||||||
$r = dba::select('conv', array('id'), array('guid' => $conv_guid, 'uid' => local_user()), array('limit' => 1));
|
$r = dba::select('conv', array('id'), array('guid' => $conv_guid, 'uid' => local_user()), array('limit' => 1));
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$convid = $r['id'];
|
$convid = $r['id'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -106,7 +107,7 @@ function send_message($recipient=0, $body='', $subject='', $replyto=''){
|
||||||
dbesc($uri),
|
dbesc($uri),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$post_id = $r[0]['id'];
|
$post_id = $r[0]['id'];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -191,7 +192,7 @@ function send_wallmessage($recipient='', $body='', $subject='', $replyto=''){
|
||||||
$r = dba::insert('conv', $fields);
|
$r = dba::insert('conv', $fields);
|
||||||
|
|
||||||
$r = dba::select('conv', array('id'), array('guid' => $conv_guid, 'uid' => $recipient['uid']), array('limit' => 1));
|
$r = dba::select('conv', array('id'), array('guid' => $conv_guid, 'uid' => $recipient['uid']), array('limit' => 1));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger('send message: conversation not found.');
|
logger('send message: conversation not found.');
|
||||||
return -4;
|
return -4;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function nav(App $a) {
|
function nav(App $a) {
|
||||||
|
|
||||||
|
|
@ -92,7 +93,7 @@ function nav_info(App $a)
|
||||||
// user info
|
// user info
|
||||||
$r = dba::select('contact', array('micro'), array('uid' => $a->user['uid'], 'self' => true), array('limit' => 1));
|
$r = dba::select('contact', array('micro'), array('uid' => $a->user['uid'], 'self' => true), array('limit' => 1));
|
||||||
$userinfo = array(
|
$userinfo = array(
|
||||||
'icon' => (dbm::is_result($r) ? $a->remove_baseurl($r['micro']) : 'images/person-48.jpg'),
|
'icon' => (DBM::is_result($r) ? $a->remove_baseurl($r['micro']) : 'images/person-48.jpg'),
|
||||||
'name' => $a->user['username'],
|
'name' => $a->user['username'],
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
|
|
||||||
|
|
@ -158,7 +159,7 @@ function notifier_run(&$argv, &$argc){
|
||||||
intval($item_id)
|
intval($item_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if ((! dbm::is_result($r)) || (! intval($r[0]['parent']))) {
|
if ((! DBM::is_result($r)) || (! intval($r[0]['parent']))) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -199,7 +200,7 @@ function notifier_run(&$argv, &$argc){
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -298,7 +299,7 @@ function notifier_run(&$argv, &$argc){
|
||||||
$fields = array('forum', 'prv');
|
$fields = array('forum', 'prv');
|
||||||
$condition = array('id' => $target_item['contact-id']);
|
$condition = array('id' => $target_item['contact-id']);
|
||||||
$contact = dba::select('contact', $fields, $condition, array('limit' => 1));
|
$contact = dba::select('contact', $fields, $condition, array('limit' => 1));
|
||||||
if (!dbm::is_result($contact)) {
|
if (!DBM::is_result($contact)) {
|
||||||
// Should never happen
|
// Should never happen
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
@ -335,7 +336,7 @@ function notifier_run(&$argv, &$argc){
|
||||||
intval($uid),
|
intval($uid),
|
||||||
dbesc(NETWORK_DFRN)
|
dbesc(NETWORK_DFRN)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$recipients_followup[] = $rr['id'];
|
$recipients_followup[] = $rr['id'];
|
||||||
}
|
}
|
||||||
|
|
@ -423,7 +424,7 @@ function notifier_run(&$argv, &$argc){
|
||||||
$r = q("SELECT `url`, `notify` FROM `contact` WHERE `nurl`='%s' AND `uid` IN (0, %d) AND `notify` != ''",
|
$r = q("SELECT `url`, `notify` FROM `contact` WHERE `nurl`='%s' AND `uid` IN (0, %d) AND `notify` != ''",
|
||||||
dbesc(normalise_link($thr_parent[0]['author-link'])),
|
dbesc(normalise_link($thr_parent[0]['author-link'])),
|
||||||
intval($uid));
|
intval($uid));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$probed_contact = $r[0];
|
$probed_contact = $r[0];
|
||||||
} else {
|
} else {
|
||||||
$probed_contact = Probe::uri($thr_parent[0]['author-link']);
|
$probed_contact = Probe::uri($thr_parent[0]['author-link']);
|
||||||
|
|
@ -438,7 +439,7 @@ function notifier_run(&$argv, &$argc){
|
||||||
$r = q("SELECT `url`, `notify` FROM `contact` WHERE `nurl`='%s' AND `uid` IN (0, %d) AND `notify` != ''",
|
$r = q("SELECT `url`, `notify` FROM `contact` WHERE `nurl`='%s' AND `uid` IN (0, %d) AND `notify` != ''",
|
||||||
dbesc(normalise_link($thr_parent[0]['owner-link'])),
|
dbesc(normalise_link($thr_parent[0]['owner-link'])),
|
||||||
intval($uid));
|
intval($uid));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$probed_contact = $r[0];
|
$probed_contact = $r[0];
|
||||||
} else {
|
} else {
|
||||||
$probed_contact = Probe::uri($thr_parent[0]['owner-link']);
|
$probed_contact = Probe::uri($thr_parent[0]['owner-link']);
|
||||||
|
|
@ -484,7 +485,7 @@ function notifier_run(&$argv, &$argc){
|
||||||
intval($uid),
|
intval($uid),
|
||||||
dbesc(NETWORK_MAIL)
|
dbesc(NETWORK_MAIL)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$recipients[] = $rr['id'];
|
$recipients[] = $rr['id'];
|
||||||
}
|
}
|
||||||
|
|
@ -508,7 +509,7 @@ function notifier_run(&$argv, &$argc){
|
||||||
|
|
||||||
// delivery loop
|
// delivery loop
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $contact) {
|
foreach ($r as $contact) {
|
||||||
if ($contact['self']) {
|
if ($contact['self']) {
|
||||||
continue;
|
continue;
|
||||||
|
|
@ -565,7 +566,7 @@ function notifier_run(&$argv, &$argc){
|
||||||
|
|
||||||
$r = array_merge($r2,$r1,$r0);
|
$r = array_merge($r2,$r1,$r0);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger('pubdeliver '.$target_item["guid"].': '.print_r($r,true), LOGGER_DEBUG);
|
logger('pubdeliver '.$target_item["guid"].': '.print_r($r,true), LOGGER_DEBUG);
|
||||||
|
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
|
|
|
||||||
|
|
@ -9,6 +9,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
define('REQUEST_TOKEN_DURATION', 300);
|
define('REQUEST_TOKEN_DURATION', 300);
|
||||||
define('ACCESS_TOKEN_DURATION', 31536000);
|
define('ACCESS_TOKEN_DURATION', 31536000);
|
||||||
|
|
@ -28,7 +29,7 @@ class FKOAuthDataStore extends OAuthDataStore {
|
||||||
$r = q("SELECT client_id, pw, redirect_uri FROM clients WHERE client_id='%s'",
|
$r = q("SELECT client_id, pw, redirect_uri FROM clients WHERE client_id='%s'",
|
||||||
dbesc($consumer_key)
|
dbesc($consumer_key)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return new OAuthConsumer($r[0]['client_id'],$r[0]['pw'],$r[0]['redirect_uri']);
|
return new OAuthConsumer($r[0]['client_id'],$r[0]['pw'],$r[0]['redirect_uri']);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
@ -40,7 +41,7 @@ class FKOAuthDataStore extends OAuthDataStore {
|
||||||
dbesc($token_type),
|
dbesc($token_type),
|
||||||
dbesc($token)
|
dbesc($token)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)){
|
if (DBM::is_result($r)){
|
||||||
$ot=new OAuthToken($r[0]['id'],$r[0]['secret']);
|
$ot=new OAuthToken($r[0]['id'],$r[0]['secret']);
|
||||||
$ot->scope=$r[0]['scope'];
|
$ot->scope=$r[0]['scope'];
|
||||||
$ot->expires = $r[0]['expires'];
|
$ot->expires = $r[0]['expires'];
|
||||||
|
|
@ -57,7 +58,7 @@ class FKOAuthDataStore extends OAuthDataStore {
|
||||||
dbesc($nonce),
|
dbesc($nonce),
|
||||||
intval($timestamp)
|
intval($timestamp)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return new OAuthToken($r[0]['id'],$r[0]['secret']);
|
return new OAuthToken($r[0]['id'],$r[0]['secret']);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
@ -141,7 +142,7 @@ class FKOAuth1 extends OAuthServer {
|
||||||
$r = q("SELECT * FROM `user` WHERE uid=%d AND `blocked` = 0 AND `account_expired` = 0 AND `account_removed` = 0 AND `verified` = 1 LIMIT 1",
|
$r = q("SELECT * FROM `user` WHERE uid=%d AND `blocked` = 0 AND `account_expired` = 0 AND `account_removed` = 0 AND `verified` = 1 LIMIT 1",
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)){
|
if (DBM::is_result($r)){
|
||||||
$record = $r[0];
|
$record = $r[0];
|
||||||
} else {
|
} else {
|
||||||
logger('FKOAuth1::loginUser failure: ' . print_r($_SERVER,true), LOGGER_DEBUG);
|
logger('FKOAuth1::loginUser failure: ' . print_r($_SERVER,true), LOGGER_DEBUG);
|
||||||
|
|
@ -167,7 +168,7 @@ class FKOAuth1 extends OAuthServer {
|
||||||
|
|
||||||
$r = q("SELECT * FROM `contact` WHERE `uid` = %s AND `self` = 1 LIMIT 1",
|
$r = q("SELECT * FROM `contact` WHERE `uid` = %s AND `self` = 1 LIMIT 1",
|
||||||
intval($_SESSION['uid']));
|
intval($_SESSION['uid']));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->contact = $r[0];
|
$a->contact = $r[0];
|
||||||
$a->cid = $r[0]['id'];
|
$a->cid = $r[0]['id'];
|
||||||
$_SESSION['cid'] = $a->cid;
|
$_SESSION['cid'] = $a->cid;
|
||||||
|
|
@ -224,7 +225,7 @@ class FKOAuth2 extends OAuth2 {
|
||||||
$r = q("SELECT client_id, expires, scope FROM tokens WHERE id = '%s'",
|
$r = q("SELECT client_id, expires, scope FROM tokens WHERE id = '%s'",
|
||||||
dbesc($oauth_token));
|
dbesc($oauth_token));
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0];
|
return $r[0];
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
@ -252,7 +253,7 @@ class FKOAuth2 extends OAuth2 {
|
||||||
$r = q("SELECT id, client_id, redirect_uri, expires, scope FROM auth_codes WHERE id = '%s'",
|
$r = q("SELECT id, client_id, redirect_uri, expires, scope FROM auth_codes WHERE id = '%s'",
|
||||||
dbesc($code));
|
dbesc($code));
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0];
|
return $r[0];
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -8,6 +8,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\ParseUrl;
|
use Friendica\ParseUrl;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function oembed_replacecb($matches){
|
function oembed_replacecb($matches){
|
||||||
$embedurl=$matches[1];
|
$embedurl=$matches[1];
|
||||||
|
|
@ -35,7 +36,7 @@ function oembed_fetch_url($embedurl, $no_rich_type = false){
|
||||||
$r = q("SELECT * FROM `oembed` WHERE `url` = '%s'",
|
$r = q("SELECT * FROM `oembed` WHERE `url` = '%s'",
|
||||||
dbesc(normalise_link($embedurl)));
|
dbesc(normalise_link($embedurl)));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$txt = $r[0]["content"];
|
$txt = $r[0]["content"];
|
||||||
} else {
|
} else {
|
||||||
$txt = Cache::get($a->videowidth . $embedurl);
|
$txt = Cache::get($a->videowidth . $embedurl);
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/follow.php';
|
require_once 'include/follow.php';
|
||||||
|
|
||||||
|
|
@ -78,7 +79,7 @@ function onepoll_run(&$argv, &$argc) {
|
||||||
WHERE `cid` = %d AND updated > UTC_TIMESTAMP() - INTERVAL 1 DAY",
|
WHERE `cid` = %d AND updated > UTC_TIMESTAMP() - INTERVAL 1 DAY",
|
||||||
intval($contact['id'])
|
intval($contact['id'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if (!$r[0]['total']) {
|
if (!$r[0]['total']) {
|
||||||
poco_load($contact['id'], $importer_uid, 0, $contact['poco']);
|
poco_load($contact['id'], $importer_uid, 0, $contact['poco']);
|
||||||
}
|
}
|
||||||
|
|
@ -147,7 +148,7 @@ function onepoll_run(&$argv, &$argc) {
|
||||||
intval($importer_uid)
|
intval($importer_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger('No self contact for user '.$importer_uid);
|
logger('No self contact for user '.$importer_uid);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -331,7 +332,7 @@ function onepoll_run(&$argv, &$argc) {
|
||||||
|
|
||||||
$condition = array("`server` != '' AND `uid` = ?", $importer_uid);
|
$condition = array("`server` != '' AND `uid` = ?", $importer_uid);
|
||||||
$mailconf = dba::select('mailacct', array(), $condition, array('limit' => 1));
|
$mailconf = dba::select('mailacct', array(), $condition, array('limit' => 1));
|
||||||
if (dbm::is_result($x) && dbm::is_result($mailconf)) {
|
if (DBM::is_result($x) && DBM::is_result($mailconf)) {
|
||||||
$mailbox = construct_mailbox_name($mailconf);
|
$mailbox = construct_mailbox_name($mailconf);
|
||||||
$password = '';
|
$password = '';
|
||||||
openssl_private_decrypt(hex2bin($mailconf['pass']), $password, $x['prvkey']);
|
openssl_private_decrypt(hex2bin($mailconf['pass']), $password, $x['prvkey']);
|
||||||
|
|
@ -375,7 +376,7 @@ function onepoll_run(&$argv, &$argc) {
|
||||||
$condition = array('uid' => $importer_uid, 'uri' => $datarray['uri']);
|
$condition = array('uid' => $importer_uid, 'uri' => $datarray['uri']);
|
||||||
$r = dba::select('item', $fields, $condition, array('limit' => 1));
|
$r = dba::select('item', $fields, $condition, array('limit' => 1));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger("Mail: Seen before ".$msg_uid." for ".$mailconf['user']." UID: ".$importer_uid." URI: ".$datarray['uri'],LOGGER_DEBUG);
|
logger("Mail: Seen before ".$msg_uid." for ".$mailconf['user']." UID: ".$importer_uid." URI: ".$datarray['uri'],LOGGER_DEBUG);
|
||||||
|
|
||||||
// Only delete when mails aren't automatically moved or deleted
|
// Only delete when mails aren't automatically moved or deleted
|
||||||
|
|
@ -427,7 +428,7 @@ function onepoll_run(&$argv, &$argc) {
|
||||||
$r = q("SELECT `parent-uri` FROM `item` USE INDEX (`uid_uri`) WHERE `uri` IN ($qstr) AND `uid` = %d LIMIT 1",
|
$r = q("SELECT `parent-uri` FROM `item` USE INDEX (`uid_uri`) WHERE `uri` IN ($qstr) AND `uid` = %d LIMIT 1",
|
||||||
intval($importer_uid)
|
intval($importer_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$datarray['parent-uri'] = $r[0]['parent-uri']; // Set the parent as the top-level item
|
$datarray['parent-uri'] = $r[0]['parent-uri']; // Set the parent as the top-level item
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -461,7 +462,7 @@ function onepoll_run(&$argv, &$argc) {
|
||||||
dbesc(protect_sprintf($datarray['title'])),
|
dbesc(protect_sprintf($datarray['title'])),
|
||||||
intval($importer_uid),
|
intval($importer_uid),
|
||||||
dbesc(NETWORK_MAIL));
|
dbesc(NETWORK_MAIL));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$datarray['parent-uri'] = $r[0]['parent-uri'];
|
$datarray['parent-uri'] = $r[0]['parent-uri'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
use Friendica\Util\Lock;
|
use Friendica\Util\Lock;
|
||||||
|
|
||||||
|
|
@ -70,7 +71,7 @@ class ostatus {
|
||||||
$importer["uid"], $aliaslink, NETWORK_STATUSNET);
|
$importer["uid"], $aliaslink, NETWORK_STATUSNET);
|
||||||
$r = dba::select('contact', array(), $condition, array('limit' => 1));
|
$r = dba::select('contact', array(), $condition, array('limit' => 1));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$found = true;
|
$found = true;
|
||||||
if ($r['blocked']) {
|
if ($r['blocked']) {
|
||||||
$r['id'] = -1;
|
$r['id'] = -1;
|
||||||
|
|
@ -89,7 +90,7 @@ class ostatus {
|
||||||
normalise_link($author["author-link"]), normalise_link($aliaslink), NETWORK_STATUSNET);
|
normalise_link($author["author-link"]), normalise_link($aliaslink), NETWORK_STATUSNET);
|
||||||
$r = dba::select('contact', array(), $condition, array('limit' => 1));
|
$r = dba::select('contact', array(), $condition, array('limit' => 1));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$found = true;
|
$found = true;
|
||||||
if ($r['blocked']) {
|
if ($r['blocked']) {
|
||||||
$r['id'] = -1;
|
$r['id'] = -1;
|
||||||
|
|
@ -104,7 +105,7 @@ class ostatus {
|
||||||
$importer["uid"], $addr, NETWORK_STATUSNET);
|
$importer["uid"], $addr, NETWORK_STATUSNET);
|
||||||
$r = dba::select('contact', array(), $condition, array('limit' => 1));
|
$r = dba::select('contact', array(), $condition, array('limit' => 1));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$found = true;
|
$found = true;
|
||||||
if ($r['blocked']) {
|
if ($r['blocked']) {
|
||||||
$r['id'] = -1;
|
$r['id'] = -1;
|
||||||
|
|
@ -529,7 +530,7 @@ class ostatus {
|
||||||
|
|
||||||
$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)) {
|
||||||
logger('Item from '.$item['author-link'].' with uri '.$item['uri'].' for user '.$item['uid']." wasn't found. We don't delete it. ");
|
logger('Item from '.$item['author-link'].' with uri '.$item['uri'].' for user '.$item['uid']." wasn't found. We don't delete it. ");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -868,7 +869,7 @@ class ostatus {
|
||||||
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)) {
|
||||||
$stored = true;
|
$stored = true;
|
||||||
$xml = $conversation['source'];
|
$xml = $conversation['source'];
|
||||||
if (self::process($xml, $importer, $contact, $hub, $stored, false)) {
|
if (self::process($xml, $importer, $contact, $hub, $stored, false)) {
|
||||||
|
|
@ -948,7 +949,7 @@ class ostatus {
|
||||||
if ($xml == '') {
|
if ($xml == '') {
|
||||||
$condition = array('item-uri' => $related_uri, 'protocol' => PROTOCOL_SPLITTED_CONV);
|
$condition = array('item-uri' => $related_uri, 'protocol' => PROTOCOL_SPLITTED_CONV);
|
||||||
$conversation = dba::select('conversation', array('source'), $condition, array('limit' => 1));
|
$conversation = dba::select('conversation', array('source'), $condition, array('limit' => 1));
|
||||||
if (dbm::is_result($conversation)) {
|
if (DBM::is_result($conversation)) {
|
||||||
$stored = true;
|
$stored = true;
|
||||||
logger('Got cached XML from conversation for URI '.$related_uri, LOGGER_DEBUG);
|
logger('Got cached XML from conversation for URI '.$related_uri, LOGGER_DEBUG);
|
||||||
$xml = $conversation['source'];
|
$xml = $conversation['source'];
|
||||||
|
|
@ -1336,7 +1337,7 @@ class ostatus {
|
||||||
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];
|
||||||
}
|
}
|
||||||
$author = $doc->createElement("author");
|
$author = $doc->createElement("author");
|
||||||
|
|
@ -1493,22 +1494,22 @@ class ostatus {
|
||||||
|
|
||||||
$r = q("SELECT * FROM `contact` WHERE `nurl` = '%s' AND `uid` IN (0, %d) ORDER BY `uid` DESC LIMIT 1",
|
$r = q("SELECT * FROM `contact` WHERE `nurl` = '%s' AND `uid` IN (0, %d) ORDER BY `uid` DESC LIMIT 1",
|
||||||
dbesc(normalise_link($url)), intval($owner["uid"]));
|
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("SELECT * FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
|
||||||
dbesc(normalise_link($url)));
|
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;
|
||||||
$contact["success_update"] = $contact["updated"];
|
$contact["success_update"] = $contact["updated"];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
$contact = owner;
|
$contact = owner;
|
||||||
|
|
||||||
if (!isset($contact["poll"])) {
|
if (!isset($contact["poll"])) {
|
||||||
|
|
@ -1547,7 +1548,7 @@ class ostatus {
|
||||||
$r = q("SELECT * FROM `item` WHERE `uid` = %d AND `guid` = '%s' AND NOT `private` AND `network` IN ('%s', '%s', '%s') LIMIT 1",
|
$r = q("SELECT * FROM `item` WHERE `uid` = %d AND `guid` = '%s' AND NOT `private` AND `network` IN ('%s', '%s', '%s') LIMIT 1",
|
||||||
intval($owner["uid"]), dbesc($repeated_guid),
|
intval($owner["uid"]), dbesc($repeated_guid),
|
||||||
dbesc(NETWORK_DFRN), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_OSTATUS));
|
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 {
|
||||||
return false;
|
return false;
|
||||||
|
|
@ -1702,7 +1703,7 @@ class ostatus {
|
||||||
$r = q("SELECT `id` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s'",
|
$r = q("SELECT `id` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s'",
|
||||||
intval($owner['uid']), dbesc(normalise_link($contact["url"])));
|
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'];
|
||||||
} else {
|
} else {
|
||||||
$connect_id = 0;
|
$connect_id = 0;
|
||||||
|
|
@ -1886,7 +1887,7 @@ class ostatus {
|
||||||
|
|
||||||
if (isset($parent_item)) {
|
if (isset($parent_item)) {
|
||||||
$r = dba::fetch_first("SELECT `conversation-uri`, `conversation-href` FROM `conversation` WHERE `item-uri` = ?", $parent_item);
|
$r = dba::fetch_first("SELECT `conversation-uri`, `conversation-href` FROM `conversation` WHERE `item-uri` = ?", $parent_item);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if ($r['conversation-uri'] != '') {
|
if ($r['conversation-uri'] != '') {
|
||||||
$conversation_uri = $r['conversation-uri'];
|
$conversation_uri = $r['conversation-uri'];
|
||||||
}
|
}
|
||||||
|
|
@ -1996,7 +1997,7 @@ class ostatus {
|
||||||
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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -8,6 +8,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief uninstalls an addon.
|
* @brief uninstalls an addon.
|
||||||
|
|
@ -77,7 +78,7 @@ function reload_plugins() {
|
||||||
if (strlen($plugins)) {
|
if (strlen($plugins)) {
|
||||||
|
|
||||||
$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;
|
||||||
else
|
else
|
||||||
$installed = array();
|
$installed = array();
|
||||||
|
|
@ -144,7 +145,7 @@ function register_hook($hook,$file,$function,$priority=0) {
|
||||||
dbesc($file),
|
dbesc($file),
|
||||||
dbesc($function)
|
dbesc($function)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
$r = dba::insert('hook', array('hook' => $hook, 'file' => $file, 'function' => $function, 'priority' => $priority));
|
$r = dba::insert('hook', array('hook' => $hook, 'file' => $file, 'function' => $function, 'priority' => $priority));
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Calls the post update functions
|
* @brief Calls the post update functions
|
||||||
|
|
@ -187,7 +188,7 @@ function post_update_1198() {
|
||||||
(`thread`.`uid` IN (SELECT `uid` from `user`) OR `thread`.`uid` = 0)");
|
(`thread`.`uid` IN (SELECT `uid` from `user`) OR `thread`.`uid` = 0)");
|
||||||
|
|
||||||
logger("Updated threads", LOGGER_DEBUG);
|
logger("Updated threads", LOGGER_DEBUG);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
Config::set("system", "post_update_version", 1198);
|
Config::set("system", "post_update_version", 1198);
|
||||||
logger("Done", LOGGER_DEBUG);
|
logger("Done", LOGGER_DEBUG);
|
||||||
return true;
|
return true;
|
||||||
|
|
@ -245,7 +246,7 @@ function post_update_1206() {
|
||||||
FROM `user`
|
FROM `user`
|
||||||
INNER JOIN `contact` ON `contact`.`uid` = `user`.`uid` AND `contact`.`self`");
|
INNER JOIN `contact` ON `contact`.`uid` = `user`.`uid` AND `contact`.`self`");
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
foreach ($r AS $user) {
|
foreach ($r AS $user) {
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/items.php');
|
require_once('include/items.php');
|
||||||
require_once('include/ostatus.php');
|
require_once('include/ostatus.php');
|
||||||
|
|
@ -34,7 +35,7 @@ function handle_pubsubhubbub($id) {
|
||||||
global $a;
|
global $a;
|
||||||
|
|
||||||
$r = q("SELECT * FROM `push_subscriber` WHERE `id` = %d", intval($id));
|
$r = q("SELECT * FROM `push_subscriber` WHERE `id` = %d", intval($id));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,8 +2,9 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
use Friendica\Protocol\Dfrn;
|
use Friendica\Protocol\DFRN;
|
||||||
|
|
||||||
require_once 'include/queue_fn.php';
|
require_once 'include/queue_fn.php';
|
||||||
require_once 'include/datetime.php';
|
require_once 'include/datetime.php';
|
||||||
|
|
@ -35,7 +36,7 @@ function queue_run(&$argv, &$argc) {
|
||||||
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) {
|
||||||
logger('Removing expired queue item for ' . $rr['name'] . ', uid=' . $rr['uid']);
|
logger('Removing expired queue item for ' . $rr['name'] . ', uid=' . $rr['uid']);
|
||||||
logger('Expired queue data: ' . $rr['content'], LOGGER_DATA);
|
logger('Expired queue data: ' . $rr['content'], LOGGER_DATA);
|
||||||
|
|
@ -51,7 +52,7 @@ function queue_run(&$argv, &$argc) {
|
||||||
|
|
||||||
call_hooks('queue_predeliver', $a, $r);
|
call_hooks('queue_predeliver', $a, $r);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $q_item) {
|
foreach ($r as $q_item) {
|
||||||
logger('Call queue for id '.$q_item['id']);
|
logger('Call queue for id '.$q_item['id']);
|
||||||
Worker::add(array('priority' => PRIORITY_LOW, 'dont_fork' => true), "queue", (int)$q_item['id']);
|
Worker::add(array('priority' => PRIORITY_LOW, 'dont_fork' => true), "queue", (int)$q_item['id']);
|
||||||
|
|
@ -68,7 +69,7 @@ function queue_run(&$argv, &$argc) {
|
||||||
$r = q("SELECT * FROM `queue` WHERE `id` = %d LIMIT 1",
|
$r = q("SELECT * FROM `queue` WHERE `id` = %d LIMIT 1",
|
||||||
intval($queue_id));
|
intval($queue_id));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -78,7 +79,7 @@ function queue_run(&$argv, &$argc) {
|
||||||
intval($q_item['cid'])
|
intval($q_item['cid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($c)) {
|
if (!DBM::is_result($c)) {
|
||||||
remove_queue_item($q_item['id']);
|
remove_queue_item($q_item['id']);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -114,7 +115,7 @@ function queue_run(&$argv, &$argc) {
|
||||||
FROM `user` WHERE `uid` = %d LIMIT 1",
|
FROM `user` WHERE `uid` = %d LIMIT 1",
|
||||||
intval($c[0]['uid'])
|
intval($c[0]['uid'])
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($u)) {
|
if (!DBM::is_result($u)) {
|
||||||
remove_queue_item($q_item['id']);
|
remove_queue_item($q_item['id']);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -129,7 +130,7 @@ function queue_run(&$argv, &$argc) {
|
||||||
switch ($contact['network']) {
|
switch ($contact['network']) {
|
||||||
case NETWORK_DFRN:
|
case NETWORK_DFRN:
|
||||||
logger('queue: dfrndelivery: item '.$q_item['id'].' for '.$contact['name'].' <'.$contact['url'].'>');
|
logger('queue: dfrndelivery: item '.$q_item['id'].' for '.$contact['name'].' <'.$contact['url'].'>');
|
||||||
$deliver_status = Dfrn::deliver($owner, $contact, $data);
|
$deliver_status = DFRN::deliver($owner, $contact, $data);
|
||||||
|
|
||||||
if ($deliver_status == (-1)) {
|
if ($deliver_status == (-1)) {
|
||||||
update_queue_time($q_item['id']);
|
update_queue_time($q_item['id']);
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function update_queue_time($id) {
|
function update_queue_time($id) {
|
||||||
logger('queue: requeue item ' . $id);
|
logger('queue: requeue item ' . $id);
|
||||||
|
|
@ -33,7 +34,7 @@ function was_recently_delayed($cid) {
|
||||||
intval($cid)
|
intval($cid)
|
||||||
);
|
);
|
||||||
|
|
||||||
$was_delayed = dbm::is_result($r);
|
$was_delayed = DBM::is_result($r);
|
||||||
|
|
||||||
// We set "term-date" to a current date if the communication has problems.
|
// We set "term-date" to a current date if the communication has problems.
|
||||||
// If the communication works again we reset this value.
|
// If the communication works again we reset this value.
|
||||||
|
|
@ -41,7 +42,7 @@ function was_recently_delayed($cid) {
|
||||||
$r = q("SELECT `term-date` FROM `contact` WHERE `id` = %d AND `term-date` <= '1000-01-01' LIMIT 1",
|
$r = q("SELECT `term-date` FROM `contact` WHERE `id` = %d AND `term-date` <= '1000-01-01' LIMIT 1",
|
||||||
intval($cid)
|
intval($cid)
|
||||||
);
|
);
|
||||||
$was_delayed = !dbm::is_result($r);
|
$was_delayed = !DBM::is_result($r);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $was_delayed;
|
return $was_delayed;
|
||||||
|
|
@ -64,7 +65,7 @@ function add_to_queue($cid,$network,$msg,$batch = false) {
|
||||||
WHERE `queue`.`cid` = %d AND `contact`.`self` = 0 ",
|
WHERE `queue`.`cid` = %d AND `contact`.`self` = 0 ",
|
||||||
intval($cid)
|
intval($cid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if ($batch && ($r[0]['total'] > $batch_queue)) {
|
if ($batch && ($r[0]['total'] > $batch_queue)) {
|
||||||
logger('add_to_queue: too many queued items for batch server ' . $cid . ' - discarding message');
|
logger('add_to_queue: too many queued items for batch server ' . $cid . ' - discarding message');
|
||||||
return;
|
return;
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function auto_redir(App $a, $contact_nick) {
|
function auto_redir(App $a, $contact_nick) {
|
||||||
|
|
||||||
|
|
@ -39,7 +40,7 @@ function auto_redir(App $a, $contact_nick) {
|
||||||
dbesc($nurl)
|
dbesc($nurl)
|
||||||
);
|
);
|
||||||
|
|
||||||
if ((! dbm::is_result($r)) || $r[0]['id'] == remote_user()) {
|
if ((! DBM::is_result($r)) || $r[0]['id'] == remote_user()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -51,7 +52,7 @@ function auto_redir(App $a, $contact_nick) {
|
||||||
dbesc($baseurl)
|
dbesc($baseurl)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Calculate the hash that is needed for the "Friendica" cookie
|
* @brief Calculate the hash that is needed for the "Friendica" cookie
|
||||||
|
|
@ -87,14 +88,14 @@ function authenticate_success($user_record, $login_initial = false, $interactive
|
||||||
$r = dba::fetch_first("SELECT * FROM `user` WHERE `uid` = ? LIMIT 1",
|
$r = dba::fetch_first("SELECT * FROM `user` WHERE `uid` = ? LIMIT 1",
|
||||||
intval($_SESSION['submanage'])
|
intval($_SESSION['submanage'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$master_record = $r;
|
$master_record = $r;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = dba::select('user', array('uid', 'username', 'nickname'),
|
$r = dba::select('user', array('uid', 'username', 'nickname'),
|
||||||
array('password' => $master_record['password'], 'email' => $master_record['email'], 'account_removed' => false));
|
array('password' => $master_record['password'], 'email' => $master_record['email'], 'account_removed' => false));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->identities = dba::inArray($r);
|
$a->identities = dba::inArray($r);
|
||||||
} else {
|
} else {
|
||||||
$a->identities = array();
|
$a->identities = array();
|
||||||
|
|
@ -106,7 +107,7 @@ function authenticate_success($user_record, $login_initial = false, $interactive
|
||||||
WHERE `user`.`account_removed` = 0 AND `manage`.`uid` = ?",
|
WHERE `user`.`account_removed` = 0 AND `manage`.`uid` = ?",
|
||||||
$master_record['uid']
|
$master_record['uid']
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->identities = array_merge($a->identities, dba::inArray($r));
|
$a->identities = array_merge($a->identities, dba::inArray($r));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -118,7 +119,7 @@ function authenticate_success($user_record, $login_initial = false, $interactive
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = dba::fetch_first("SELECT * FROM `contact` WHERE `uid` = ? AND `self` LIMIT 1", $_SESSION['uid']);
|
$r = dba::fetch_first("SELECT * FROM `contact` WHERE `uid` = ? AND `self` LIMIT 1", $_SESSION['uid']);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->contact = $r;
|
$a->contact = $r;
|
||||||
$a->cid = $r['id'];
|
$a->cid = $r['id'];
|
||||||
$_SESSION['cid'] = $a->cid;
|
$_SESSION['cid'] = $a->cid;
|
||||||
|
|
@ -209,7 +210,7 @@ function can_write_wall(App $a, $owner) {
|
||||||
intval(PAGE_COMMUNITY)
|
intval(PAGE_COMMUNITY)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$verified = 2;
|
$verified = 2;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
@ -259,7 +260,7 @@ function permissions_sql($owner_id, $remote_verified = false, $groups = null) {
|
||||||
intval($remote_user),
|
intval($remote_user),
|
||||||
intval($owner_id)
|
intval($owner_id)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$remote_verified = true;
|
$remote_verified = true;
|
||||||
$groups = init_groups_visitor($remote_user);
|
$groups = init_groups_visitor($remote_user);
|
||||||
}
|
}
|
||||||
|
|
@ -338,7 +339,7 @@ function item_permissions_sql($owner_id, $remote_verified = false, $groups = nul
|
||||||
intval($remote_user),
|
intval($remote_user),
|
||||||
intval($owner_id)
|
intval($owner_id)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$remote_verified = true;
|
$remote_verified = true;
|
||||||
$groups = init_groups_visitor($remote_user);
|
$groups = init_groups_visitor($remote_user);
|
||||||
}
|
}
|
||||||
|
|
@ -456,7 +457,7 @@ function init_groups_visitor($contact_id) {
|
||||||
WHERE `contact-id` = %d ",
|
WHERE `contact-id` = %d ",
|
||||||
intval($contact_id)
|
intval($contact_id)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr)
|
foreach ($r as $rr)
|
||||||
$groups[] = $rr['gid'];
|
$groups[] = $rr['gid'];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
// session info.
|
// session info.
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/cache.php');
|
require_once('include/cache.php');
|
||||||
|
|
||||||
|
|
@ -32,7 +33,7 @@ function ref_session_read($id) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = dba::select('session', array('data'), array('sid' => $id), array('limit' => 1));
|
$r = dba::select('session', array('data'), array('sid' => $id), array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$session_exists = true;
|
$session_exists = true;
|
||||||
return $r['data'];
|
return $r['data'];
|
||||||
} else {
|
} else {
|
||||||
|
|
|
||||||
|
|
@ -11,6 +11,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
|
|
||||||
require_once 'include/datetime.php';
|
require_once 'include/datetime.php';
|
||||||
|
|
@ -59,7 +60,7 @@ function poco_load_worker($cid, $uid, $zcid, $url) {
|
||||||
$r = q("select `poco`, `uid` from `contact` where `id` = %d limit 1",
|
$r = q("select `poco`, `uid` from `contact` where `id` = %d limit 1",
|
||||||
intval($cid)
|
intval($cid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$url = $r[0]['poco'];
|
$url = $r[0]['poco'];
|
||||||
$uid = $r[0]['uid'];
|
$uid = $r[0]['uid'];
|
||||||
}
|
}
|
||||||
|
|
@ -252,7 +253,7 @@ function sanitize_gcontact($gcontact) {
|
||||||
$r = q("SELECT `network` FROM `contact` WHERE `uid` = 0 AND `nurl` = '%s' AND `network` != '' AND `network` != '%s' LIMIT 1",
|
$r = q("SELECT `network` FROM `contact` WHERE `uid` = 0 AND `nurl` = '%s' AND `network` != '' AND `network` != '%s' LIMIT 1",
|
||||||
dbesc(normalise_link($gcontact['url'])), dbesc(NETWORK_STATUSNET)
|
dbesc(normalise_link($gcontact['url'])), dbesc(NETWORK_STATUSNET)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$gcontact['network'] = $r[0]["network"];
|
$gcontact['network'] = $r[0]["network"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -260,7 +261,7 @@ function sanitize_gcontact($gcontact) {
|
||||||
$r = q("SELECT `network`, `url` FROM `contact` WHERE `uid` = 0 AND `alias` IN ('%s', '%s') AND `network` != '' AND `network` != '%s' LIMIT 1",
|
$r = q("SELECT `network`, `url` FROM `contact` WHERE `uid` = 0 AND `alias` IN ('%s', '%s') AND `network` != '' AND `network` != '%s' LIMIT 1",
|
||||||
dbesc($gcontact['url']), dbesc(normalise_link($gcontact['url'])), dbesc(NETWORK_STATUSNET)
|
dbesc($gcontact['url']), dbesc(normalise_link($gcontact['url'])), dbesc(NETWORK_STATUSNET)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$gcontact['network'] = $r[0]["network"];
|
$gcontact['network'] = $r[0]["network"];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -273,7 +274,7 @@ function sanitize_gcontact($gcontact) {
|
||||||
dbesc(normalise_link($gcontact['url']))
|
dbesc(normalise_link($gcontact['url']))
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($x)) {
|
if (DBM::is_result($x)) {
|
||||||
if (!isset($gcontact['network']) && ($x[0]["network"] != NETWORK_STATUSNET)) {
|
if (!isset($gcontact['network']) && ($x[0]["network"] != NETWORK_STATUSNET)) {
|
||||||
$gcontact['network'] = $x[0]["network"];
|
$gcontact['network'] = $x[0]["network"];
|
||||||
}
|
}
|
||||||
|
|
@ -305,7 +306,7 @@ function sanitize_gcontact($gcontact) {
|
||||||
if ($alternate && ($gcontact['network'] == NETWORK_OSTATUS)) {
|
if ($alternate && ($gcontact['network'] == NETWORK_OSTATUS)) {
|
||||||
// Delete the old entry - if it exists
|
// Delete the old entry - if it exists
|
||||||
$r = q("SELECT `id` FROM `gcontact` WHERE `nurl` = '%s'", dbesc(normalise_link($orig_profile)));
|
$r = q("SELECT `id` FROM `gcontact` WHERE `nurl` = '%s'", dbesc(normalise_link($orig_profile)));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
q("DELETE FROM `gcontact` WHERE `nurl` = '%s'", dbesc(normalise_link($orig_profile)));
|
q("DELETE FROM `gcontact` WHERE `nurl` = '%s'", dbesc(normalise_link($orig_profile)));
|
||||||
q("DELETE FROM `glink` WHERE `gcid` = %d", intval($r[0]["id"]));
|
q("DELETE FROM `glink` WHERE `gcid` = %d", intval($r[0]["id"]));
|
||||||
}
|
}
|
||||||
|
|
@ -360,7 +361,7 @@ function link_gcontact($gcid, $uid = 0, $cid = 0, $zcid = 0) {
|
||||||
intval($zcid)
|
intval($zcid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
q("INSERT INTO `glink` (`cid`, `uid`, `gcid`, `zcid`, `updated`) VALUES (%d, %d, %d, %d, '%s') ",
|
q("INSERT INTO `glink` (`cid`, `uid`, `gcid`, `zcid`, `updated`) VALUES (%d, %d, %d, %d, '%s') ",
|
||||||
intval($cid),
|
intval($cid),
|
||||||
intval($uid),
|
intval($uid),
|
||||||
|
|
@ -454,7 +455,7 @@ function poco_detect_server($profile) {
|
||||||
|
|
||||||
$r = q("SELECT `id` FROM `gserver` WHERE `nurl` = '%s' AND `last_contact` > `last_failure`",
|
$r = q("SELECT `id` FROM `gserver` WHERE `nurl` = '%s' AND `last_contact` > `last_failure`",
|
||||||
dbesc(normalise_link($server_url)));
|
dbesc(normalise_link($server_url)));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $server_url;
|
return $server_url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -476,7 +477,7 @@ function poco_last_updated($profile, $force = false) {
|
||||||
$gcontacts = q("SELECT * FROM `gcontact` WHERE `nurl` = '%s'",
|
$gcontacts = q("SELECT * FROM `gcontact` WHERE `nurl` = '%s'",
|
||||||
dbesc(normalise_link($profile)));
|
dbesc(normalise_link($profile)));
|
||||||
|
|
||||||
if (!dbm::is_result($gcontacts)) {
|
if (!DBM::is_result($gcontacts)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -688,7 +689,7 @@ function poco_last_updated($profile, $force = false) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
q("UPDATE `gcontact` SET `updated` = '%s', `last_contact` = '%s' WHERE `nurl` = '%s'",
|
q("UPDATE `gcontact` SET `updated` = '%s', `last_contact` = '%s' WHERE `nurl` = '%s'",
|
||||||
dbesc(dbm::date($last_updated)), dbesc(dbm::date()), dbesc(normalise_link($profile)));
|
dbesc(DBM::date($last_updated)), dbesc(DBM::date()), dbesc(normalise_link($profile)));
|
||||||
|
|
||||||
if (($gcontacts[0]["generation"] == 0)) {
|
if (($gcontacts[0]["generation"] == 0)) {
|
||||||
q("UPDATE `gcontact` SET `generation` = 9 WHERE `nurl` = '%s'",
|
q("UPDATE `gcontact` SET `generation` = 9 WHERE `nurl` = '%s'",
|
||||||
|
|
@ -970,7 +971,7 @@ function poco_check_server($server_url, $network = "", $force = false) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$servers = q("SELECT * FROM `gserver` WHERE `nurl` = '%s'", dbesc(normalise_link($server_url)));
|
$servers = q("SELECT * FROM `gserver` WHERE `nurl` = '%s'", dbesc(normalise_link($server_url)));
|
||||||
if (dbm::is_result($servers)) {
|
if (DBM::is_result($servers)) {
|
||||||
|
|
||||||
if ($servers[0]["created"] <= NULL_DATE) {
|
if ($servers[0]["created"] <= NULL_DATE) {
|
||||||
q("UPDATE `gserver` SET `created` = '%s' WHERE `nurl` = '%s'",
|
q("UPDATE `gserver` SET `created` = '%s' WHERE `nurl` = '%s'",
|
||||||
|
|
@ -1023,7 +1024,7 @@ function poco_check_server($server_url, $network = "", $force = false) {
|
||||||
|
|
||||||
// Quit if there is a timeout.
|
// Quit if there is a timeout.
|
||||||
// But we want to make sure to only quit if we are mostly sure that this server url fits.
|
// But we want to make sure to only quit if we are mostly sure that this server url fits.
|
||||||
if (dbm::is_result($servers) && ($orig_server_url == $server_url) &&
|
if (DBM::is_result($servers) && ($orig_server_url == $server_url) &&
|
||||||
($serverret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
($serverret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
||||||
logger("Connection to server ".$server_url." timed out.", LOGGER_DEBUG);
|
logger("Connection to server ".$server_url." timed out.", LOGGER_DEBUG);
|
||||||
dba::update('gserver', array('last_failure' => datetime_convert()), array('nurl' => normalise_link($server_url)));
|
dba::update('gserver', array('last_failure' => datetime_convert()), array('nurl' => normalise_link($server_url)));
|
||||||
|
|
@ -1417,7 +1418,7 @@ function count_common_friends($uid, $cid) {
|
||||||
);
|
);
|
||||||
|
|
||||||
// logger("count_common_friends: $uid $cid {$r[0]['total']}");
|
// logger("count_common_friends: $uid $cid {$r[0]['total']}");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0]['total'];
|
return $r[0]['total'];
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -1450,7 +1451,7 @@ function common_friends($uid, $cid, $start = 0, $limit = 9999, $shuffle = false)
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
/// @TODO Check all calling-findings of this function if they properly use dbm::is_result()
|
/// @TODO Check all calling-findings of this function if they properly use DBM::is_result()
|
||||||
return $r;
|
return $r;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
@ -1466,7 +1467,7 @@ function count_common_friends_zcid($uid, $zcid) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0]['total'];
|
return $r[0]['total'];
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -1492,7 +1493,7 @@ function common_friends_zcid($uid, $zcid, $start = 0, $limit = 9999, $shuffle =
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
/// @TODO Check all calling-findings of this function if they properly use dbm::is_result()
|
/// @TODO Check all calling-findings of this function if they properly use DBM::is_result()
|
||||||
return $r;
|
return $r;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
@ -1508,7 +1509,7 @@ function count_all_friends($uid, $cid) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0]['total'];
|
return $r[0]['total'];
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -1532,7 +1533,7 @@ function all_friends($uid, $cid, $start = 0, $limit = 80) {
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
/// @TODO Check all calling-findings of this function if they properly use dbm::is_result()
|
/// @TODO Check all calling-findings of this function if they properly use DBM::is_result()
|
||||||
return $r;
|
return $r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1587,7 +1588,7 @@ function suggestion_query($uid, $start = 0, $limit = 80) {
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r) && count($r) >= ($limit -1)) {
|
if (DBM::is_result($r) && count($r) >= ($limit -1)) {
|
||||||
/*
|
/*
|
||||||
* Uncommented because the result of the queries are to big to store it in the cache.
|
* Uncommented because the result of the queries are to big to store it in the cache.
|
||||||
* We need to decide if we want to change the db column type or if we want to delete it.
|
* We need to decide if we want to change the db column type or if we want to delete it.
|
||||||
|
|
@ -1670,7 +1671,7 @@ function update_suggestions() {
|
||||||
dbesc(NETWORK_DFRN), dbesc(NETWORK_DIASPORA)
|
dbesc(NETWORK_DFRN), dbesc(NETWORK_DIASPORA)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$base = substr($rr['poco'],0,strrpos($rr['poco'],'/'));
|
$base = substr($rr['poco'],0,strrpos($rr['poco'],'/'));
|
||||||
if (! in_array($base,$done)) {
|
if (! in_array($base,$done)) {
|
||||||
|
|
@ -1700,7 +1701,7 @@ function poco_fetch_serverlist($poco) {
|
||||||
$server_url = str_replace("/index.php", "", $server->url);
|
$server_url = str_replace("/index.php", "", $server->url);
|
||||||
|
|
||||||
$r = q("SELECT `nurl` FROM `gserver` WHERE `nurl` = '%s'", dbesc(normalise_link($server_url)));
|
$r = q("SELECT `nurl` FROM `gserver` WHERE `nurl` = '%s'", dbesc(normalise_link($server_url)));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger("Call server check for server ".$server_url, LOGGER_DEBUG);
|
logger("Call server check for server ".$server_url, LOGGER_DEBUG);
|
||||||
Worker::add(PRIORITY_LOW, "discover_poco", "server", $server_url);
|
Worker::add(PRIORITY_LOW, "discover_poco", "server", $server_url);
|
||||||
}
|
}
|
||||||
|
|
@ -1762,7 +1763,7 @@ function poco_discover_federation() {
|
||||||
|
|
||||||
function poco_discover_single_server($id) {
|
function poco_discover_single_server($id) {
|
||||||
$r = q("SELECT `poco`, `nurl`, `url`, `network` FROM `gserver` WHERE `id` = %d", intval($id));
|
$r = q("SELECT `poco`, `nurl`, `url`, `network` FROM `gserver` WHERE `id` = %d", intval($id));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1837,7 +1838,7 @@ function poco_discover($complete = false) {
|
||||||
$last_update = date("c", time() - (60 * 60 * 24 * $requery_days));
|
$last_update = date("c", time() - (60 * 60 * 24 * $requery_days));
|
||||||
|
|
||||||
$r = q("SELECT `id`, `url`, `network` FROM `gserver` WHERE `last_contact` >= `last_failure` AND `poco` != '' AND `last_poco_query` < '%s' ORDER BY RAND()", dbesc($last_update));
|
$r = q("SELECT `id`, `url`, `network` FROM `gserver` WHERE `last_contact` >= `last_failure` AND `poco` != '' AND `last_poco_query` < '%s' ORDER BY RAND()", dbesc($last_update));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $server) {
|
foreach ($r as $server) {
|
||||||
|
|
||||||
if (!poco_check_server($server["url"], $server["network"])) {
|
if (!poco_check_server($server["url"], $server["network"])) {
|
||||||
|
|
@ -2083,7 +2084,7 @@ function get_gcontact_id($contact) {
|
||||||
$r = q("SELECT `id`, `last_contact`, `last_failure`, `network` FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
|
$r = q("SELECT `id`, `last_contact`, `last_failure`, `network` FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
|
||||||
dbesc(normalise_link($contact["url"])));
|
dbesc(normalise_link($contact["url"])));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$gcontact_id = $r[0]["id"];
|
$gcontact_id = $r[0]["id"];
|
||||||
|
|
||||||
// Update every 90 days
|
// Update every 90 days
|
||||||
|
|
@ -2115,7 +2116,7 @@ function get_gcontact_id($contact) {
|
||||||
$r = q("SELECT `id`, `network` FROM `gcontact` WHERE `nurl` = '%s' ORDER BY `id` LIMIT 2",
|
$r = q("SELECT `id`, `network` FROM `gcontact` WHERE `nurl` = '%s' ORDER BY `id` LIMIT 2",
|
||||||
dbesc(normalise_link($contact["url"])));
|
dbesc(normalise_link($contact["url"])));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$gcontact_id = $r[0]["id"];
|
$gcontact_id = $r[0]["id"];
|
||||||
|
|
||||||
$doprobing = in_array($r[0]["network"], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS, ""));
|
$doprobing = in_array($r[0]["network"], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS, ""));
|
||||||
|
|
@ -2198,7 +2199,7 @@ function update_gcontact($contact) {
|
||||||
fix_alternate_contact_address($contact);
|
fix_alternate_contact_address($contact);
|
||||||
|
|
||||||
if (!isset($contact["updated"])) {
|
if (!isset($contact["updated"])) {
|
||||||
$contact["updated"] = dbm::date();
|
$contact["updated"] = DBM::date();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($contact["network"] == NETWORK_TWITTER) {
|
if ($contact["network"] == NETWORK_TWITTER) {
|
||||||
|
|
@ -2241,7 +2242,7 @@ function update_gcontact($contact) {
|
||||||
logger("Update gcontact for ".$contact["url"], LOGGER_DEBUG);
|
logger("Update gcontact for ".$contact["url"], LOGGER_DEBUG);
|
||||||
$condition = array('`nurl` = ? AND (`generation` = 0 OR `generation` >= ?)',
|
$condition = array('`nurl` = ? AND (`generation` = 0 OR `generation` >= ?)',
|
||||||
normalise_link($contact["url"]), $contact["generation"]);
|
normalise_link($contact["url"]), $contact["generation"]);
|
||||||
$contact["updated"] = dbm::date($contact["updated"]);
|
$contact["updated"] = DBM::date($contact["updated"]);
|
||||||
|
|
||||||
$updated = array('photo' => $contact['photo'], 'name' => $contact['name'],
|
$updated = array('photo' => $contact['photo'], 'name' => $contact['name'],
|
||||||
'nick' => $contact['nick'], 'addr' => $contact['addr'],
|
'nick' => $contact['nick'], 'addr' => $contact['addr'],
|
||||||
|
|
@ -2261,7 +2262,7 @@ function update_gcontact($contact) {
|
||||||
$r = q("SELECT `id` FROM `contact` WHERE `nurl` = '%s' AND `uid` = 0 ORDER BY `id` LIMIT 1",
|
$r = q("SELECT `id` FROM `contact` WHERE `nurl` = '%s' AND `uid` = 0 ORDER BY `id` LIMIT 1",
|
||||||
dbesc(normalise_link($contact["url"])));
|
dbesc(normalise_link($contact["url"])));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger("Update public contact ".$r[0]["id"], LOGGER_DEBUG);
|
logger("Update public contact ".$r[0]["id"], LOGGER_DEBUG);
|
||||||
|
|
||||||
update_contact_avatar($contact["photo"], 0, $r[0]["id"]);
|
update_contact_avatar($contact["photo"], 0, $r[0]["id"]);
|
||||||
|
|
@ -2416,7 +2417,7 @@ function gs_discover() {
|
||||||
$r = q("SELECT `nurl`, `url` FROM `gserver` WHERE `last_contact` >= `last_failure` AND `network` = '%s' AND `last_poco_query` < '%s' ORDER BY RAND() LIMIT 5",
|
$r = q("SELECT `nurl`, `url` FROM `gserver` WHERE `last_contact` >= `last_failure` AND `network` = '%s' AND `last_poco_query` < '%s' ORDER BY RAND() LIMIT 5",
|
||||||
dbesc(NETWORK_OSTATUS), dbesc($last_update));
|
dbesc(NETWORK_OSTATUS), dbesc($last_update));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -2436,7 +2437,7 @@ function poco_serverlist() {
|
||||||
ORDER BY `last_contact`
|
ORDER BY `last_contact`
|
||||||
LIMIT 1000",
|
LIMIT 1000",
|
||||||
dbesc(NETWORK_DFRN), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_OSTATUS));
|
dbesc(NETWORK_DFRN), dbesc(NETWORK_DIASPORA), dbesc(NETWORK_OSTATUS));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once "include/template_processor.php";
|
require_once "include/template_processor.php";
|
||||||
require_once "include/friendica_smarty.php";
|
require_once "include/friendica_smarty.php";
|
||||||
|
|
@ -525,7 +526,7 @@ function photo_new_resource() {
|
||||||
dbesc($resource)
|
dbesc($resource)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$found = true;
|
$found = true;
|
||||||
}
|
}
|
||||||
} while ($found == true);
|
} while ($found == true);
|
||||||
|
|
@ -956,7 +957,7 @@ function contact_block() {
|
||||||
dbesc(NETWORK_OSTATUS),
|
dbesc(NETWORK_OSTATUS),
|
||||||
dbesc(NETWORK_DIASPORA)
|
dbesc(NETWORK_DIASPORA)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$total = intval($r[0]['total']);
|
$total = intval($r[0]['total']);
|
||||||
}
|
}
|
||||||
if (! $total) {
|
if (! $total) {
|
||||||
|
|
@ -975,7 +976,7 @@ function contact_block() {
|
||||||
dbesc(NETWORK_DIASPORA),
|
dbesc(NETWORK_DIASPORA),
|
||||||
intval($shown)
|
intval($shown)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contacts = array();
|
$contacts = array();
|
||||||
foreach ($r AS $contact) {
|
foreach ($r AS $contact) {
|
||||||
$contacts[] = $contact["id"];
|
$contacts[] = $contact["id"];
|
||||||
|
|
@ -983,7 +984,7 @@ function contact_block() {
|
||||||
$r = q("SELECT `id`, `uid`, `addr`, `url`, `name`, `thumb`, `network` FROM `contact` WHERE `id` IN (%s)",
|
$r = q("SELECT `id`, `uid`, `addr`, `url`, `name`, `thumb`, `network` FROM `contact` WHERE `id` IN (%s)",
|
||||||
dbesc(implode(",", $contacts)));
|
dbesc(implode(",", $contacts)));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contacts = sprintf( tt('%d Contact','%d Contacts', $total),$total);
|
$contacts = sprintf( tt('%d Contact','%d Contacts', $total),$total);
|
||||||
$micropro = Array();
|
$micropro = Array();
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
|
|
@ -1669,7 +1670,7 @@ function generate_user_guid() {
|
||||||
$x = q("SELECT `uid` FROM `user` WHERE `guid` = '%s' LIMIT 1",
|
$x = q("SELECT `uid` FROM `user` WHERE `guid` = '%s' LIMIT 1",
|
||||||
dbesc($guid)
|
dbesc($guid)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($x)) {
|
if (! DBM::is_result($x)) {
|
||||||
$found = false;
|
$found = false;
|
||||||
}
|
}
|
||||||
} while ($found == true);
|
} while ($found == true);
|
||||||
|
|
@ -2023,7 +2024,7 @@ function file_tag_update_pconfig($uid, $file_old, $file_new, $type = 'file') {
|
||||||
intval($termtype),
|
intval($termtype),
|
||||||
intval($uid));
|
intval($uid));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
unset($deleted_tags[$key]);
|
unset($deleted_tags[$key]);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
@ -2053,7 +2054,7 @@ function file_tag_save_file($uid, $item, $file) {
|
||||||
intval($item),
|
intval($item),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if (! stristr($r[0]['file'],'[' . file_tag_encode($file) . ']')) {
|
if (! stristr($r[0]['file'],'[' . file_tag_encode($file) . ']')) {
|
||||||
q("UPDATE `item` SET `file` = '%s' WHERE `id` = %d AND `uid` = %d",
|
q("UPDATE `item` SET `file` = '%s' WHERE `id` = %d AND `uid` = %d",
|
||||||
dbesc($r[0]['file'] . '[' . file_tag_encode($file) . ']'),
|
dbesc($r[0]['file'] . '[' . file_tag_encode($file) . ']'),
|
||||||
|
|
@ -2093,7 +2094,7 @@ function file_tag_unsave_file($uid, $item, $file, $cat = false) {
|
||||||
intval($item),
|
intval($item),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -2111,7 +2112,7 @@ function file_tag_unsave_file($uid, $item, $file, $cat = false) {
|
||||||
intval($termtype),
|
intval($termtype),
|
||||||
intval($uid));
|
intval($uid));
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$saved = PConfig::get($uid,'system','filetags');
|
$saved = PConfig::get($uid,'system','filetags');
|
||||||
PConfig::set($uid, 'system', 'filetags', str_replace($pattern, '', $saved));
|
PConfig::set($uid, 'system', 'filetags', str_replace($pattern, '', $saved));
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function add_thread($itemid, $onlyshadow = false) {
|
function add_thread($itemid, $onlyshadow = false) {
|
||||||
$items = q("SELECT `uid`, `created`, `edited`, `commented`, `received`, `changed`, `wall`, `private`, `pubmail`,
|
$items = q("SELECT `uid`, `created`, `edited`, `commented`, `received`, `changed`, `wall`, `private`, `pubmail`,
|
||||||
|
|
@ -35,7 +36,7 @@ function add_shadow_thread($itemid) {
|
||||||
$items = q("SELECT `uid`, `wall`, `private`, `moderated`, `visible`, `contact-id`, `deleted`, `network`, `author-id`, `owner-id`
|
$items = q("SELECT `uid`, `wall`, `private`, `moderated`, `visible`, `contact-id`, `deleted`, `network`, `author-id`, `owner-id`
|
||||||
FROM `item` WHERE `id` = %d AND (`parent` = %d OR `parent` = 0) LIMIT 1", intval($itemid), intval($itemid));
|
FROM `item` WHERE `id` = %d AND (`parent` = %d OR `parent` = 0) LIMIT 1", intval($itemid), intval($itemid));
|
||||||
|
|
||||||
if (!dbm::is_result($items)) {
|
if (!DBM::is_result($items)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -67,7 +68,7 @@ function add_shadow_thread($itemid) {
|
||||||
$r = q("SELECT `hide-friends` FROM `profile` WHERE `is-default` AND `uid` = %d AND NOT `hide-friends`",
|
$r = q("SELECT `hide-friends` FROM `profile` WHERE `is-default` AND `uid` = %d AND NOT `hide-friends`",
|
||||||
$item['uid']);
|
$item['uid']);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -75,14 +76,14 @@ function add_shadow_thread($itemid) {
|
||||||
$r = q("SELECT `id` FROM `contact` WHERE NOT `hidden` AND NOT `blocked` AND `id` = %d",
|
$r = q("SELECT `id` FROM `contact` WHERE NOT `hidden` AND NOT `blocked` AND `id` = %d",
|
||||||
$item['contact-id']);
|
$item['contact-id']);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Only add a shadow, if the profile isn't hidden
|
// Only add a shadow, if the profile isn't hidden
|
||||||
$r = q("SELECT `uid` FROM `user` where `uid` = %d AND NOT `hidewall`", $item['uid']);
|
$r = q("SELECT `uid` FROM `user` where `uid` = %d AND NOT `hidewall`", $item['uid']);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -94,7 +95,7 @@ function add_shadow_thread($itemid) {
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' AND `uid` = 0 LIMIT 1",
|
$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' AND `uid` = 0 LIMIT 1",
|
||||||
dbesc($item['uri']));
|
dbesc($item['uri']));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
// Preparing public shadow (removing user specific data)
|
// Preparing public shadow (removing user specific data)
|
||||||
require_once("include/items.php");
|
require_once("include/items.php");
|
||||||
require_once("include/Contact.php");
|
require_once("include/Contact.php");
|
||||||
|
|
@ -129,7 +130,7 @@ function add_shadow_entry($itemid) {
|
||||||
|
|
||||||
$items = q("SELECT * FROM `item` WHERE `id` = %d", intval($itemid));
|
$items = q("SELECT * FROM `item` WHERE `id` = %d", intval($itemid));
|
||||||
|
|
||||||
if (!dbm::is_result($items)) {
|
if (!DBM::is_result($items)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -147,12 +148,12 @@ function add_shadow_entry($itemid) {
|
||||||
|
|
||||||
// Is there a shadow parent?
|
// Is there a shadow parent?
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' AND `uid` = 0 LIMIT 1", dbesc($item['parent-uri']));
|
$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' AND `uid` = 0 LIMIT 1", dbesc($item['parent-uri']));
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Is there already a shadow entry?
|
// Is there already a shadow entry?
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' AND `uid` = 0 LIMIT 1", dbesc($item['uri']));
|
$r = q("SELECT `id` FROM `item` WHERE `uri` = '%s' AND `uid` = 0 LIMIT 1", dbesc($item['uri']));
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Preparing public shadow (removing user specific data)
|
// Preparing public shadow (removing user specific data)
|
||||||
|
|
@ -179,7 +180,7 @@ function add_shadow_entry($itemid) {
|
||||||
function update_thread_uri($itemuri, $uid) {
|
function update_thread_uri($itemuri, $uid) {
|
||||||
$messages = q("SELECT `id` FROM `item` WHERE uri ='%s' AND uid=%d", dbesc($itemuri), intval($uid));
|
$messages = q("SELECT `id` FROM `item` WHERE uri ='%s' AND uid=%d", dbesc($itemuri), intval($uid));
|
||||||
|
|
||||||
if (dbm::is_result($messages)) {
|
if (DBM::is_result($messages)) {
|
||||||
foreach ($messages as $message) {
|
foreach ($messages as $message) {
|
||||||
update_thread($message["id"]);
|
update_thread($message["id"]);
|
||||||
}
|
}
|
||||||
|
|
@ -190,7 +191,7 @@ function update_thread($itemid, $setmention = false) {
|
||||||
$items = q("SELECT `uid`, `guid`, `title`, `body`, `created`, `edited`, `commented`, `received`, `changed`, `wall`, `private`, `pubmail`, `moderated`, `visible`, `spam`, `starred`, `bookmark`, `contact-id`, `gcontact-id`,
|
$items = q("SELECT `uid`, `guid`, `title`, `body`, `created`, `edited`, `commented`, `received`, `changed`, `wall`, `private`, `pubmail`, `moderated`, `visible`, `spam`, `starred`, `bookmark`, `contact-id`, `gcontact-id`,
|
||||||
`deleted`, `origin`, `forum_mode`, `network`, `rendered-html`, `rendered-hash` FROM `item` WHERE `id` = %d AND (`parent` = %d OR `parent` = 0) LIMIT 1", intval($itemid), intval($itemid));
|
`deleted`, `origin`, `forum_mode`, `network`, `rendered-html`, `rendered-hash` FROM `item` WHERE `id` = %d AND (`parent` = %d OR `parent` = 0) LIMIT 1", intval($itemid), intval($itemid));
|
||||||
|
|
||||||
if (!dbm::is_result($items)) {
|
if (!DBM::is_result($items)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -218,7 +219,7 @@ function update_thread($itemid, $setmention = false) {
|
||||||
// Updating a shadow item entry
|
// Updating a shadow item entry
|
||||||
$items = q("SELECT `id` FROM `item` WHERE `guid` = '%s' AND `uid` = 0 LIMIT 1", dbesc($item["guid"]));
|
$items = q("SELECT `id` FROM `item` WHERE `guid` = '%s' AND `uid` = 0 LIMIT 1", dbesc($item["guid"]));
|
||||||
|
|
||||||
if (!dbm::is_result($items)) {
|
if (!DBM::is_result($items)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -235,7 +236,7 @@ function update_thread($itemid, $setmention = false) {
|
||||||
function delete_thread_uri($itemuri, $uid) {
|
function delete_thread_uri($itemuri, $uid) {
|
||||||
$messages = q("SELECT `id` FROM `item` WHERE uri ='%s' AND uid=%d", dbesc($itemuri), intval($uid));
|
$messages = q("SELECT `id` FROM `item` WHERE uri ='%s' AND uid=%d", dbesc($itemuri), intval($uid));
|
||||||
|
|
||||||
if (dbm::is_result($messages)) {
|
if (DBM::is_result($messages)) {
|
||||||
foreach ($messages as $message) {
|
foreach ($messages as $message) {
|
||||||
delete_thread($message["id"], $itemuri);
|
delete_thread($message["id"], $itemuri);
|
||||||
}
|
}
|
||||||
|
|
@ -245,7 +246,7 @@ function delete_thread_uri($itemuri, $uid) {
|
||||||
function delete_thread($itemid, $itemuri = "") {
|
function delete_thread($itemid, $itemuri = "") {
|
||||||
$item = q("SELECT `uid` FROM `thread` WHERE `iid` = %d", intval($itemid));
|
$item = q("SELECT `uid` FROM `thread` WHERE `iid` = %d", intval($itemid));
|
||||||
|
|
||||||
if (!dbm::is_result($item)) {
|
if (!DBM::is_result($item)) {
|
||||||
logger('No thread found for id '.$itemid, LOGGER_DEBUG);
|
logger('No thread found for id '.$itemid, LOGGER_DEBUG);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -260,7 +261,7 @@ function delete_thread($itemid, $itemuri = "") {
|
||||||
dbesc($itemuri),
|
dbesc($itemuri),
|
||||||
intval($item["uid"])
|
intval($item["uid"])
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
dba::delete('item', array('uri' => $itemuri, 'uid' => 0));
|
dba::delete('item', array('uri' => $itemuri, 'uid' => 0));
|
||||||
logger("delete_thread: Deleted shadow for item ".$itemuri, LOGGER_DEBUG);
|
logger("delete_thread: Deleted shadow for item ".$itemuri, LOGGER_DEBUG);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once("include/Photo.php");
|
require_once("include/Photo.php");
|
||||||
define("IMPORT_DEBUG", False);
|
define("IMPORT_DEBUG", False);
|
||||||
|
|
@ -104,7 +105,7 @@ function import_account(App $a, $file) {
|
||||||
notice(t('Error! Cannot check nickname'));
|
notice(t('Error! Cannot check nickname'));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (dbm::is_result($r) > 0) {
|
if (DBM::is_result($r) > 0) {
|
||||||
notice(sprintf(t("User '%s' already exists on this server!"), $account['user']['nickname']));
|
notice(sprintf(t("User '%s' already exists on this server!"), $account['user']['nickname']));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -115,7 +116,7 @@ function import_account(App $a, $file) {
|
||||||
notice(t('Error! Cannot check nickname'));
|
notice(t('Error! Cannot check nickname'));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (dbm::is_result($r) > 0) {
|
if (DBM::is_result($r) > 0) {
|
||||||
notice(sprintf(t("User '%s' already exists on this server!"), $account['user']['nickname']));
|
notice(sprintf(t("User '%s' already exists on this server!"), $account['user']['nickname']));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function update_gcontact_run(&$argv, &$argc) {
|
function update_gcontact_run(&$argv, &$argc) {
|
||||||
global $a;
|
global $a;
|
||||||
|
|
@ -21,7 +22,7 @@ function update_gcontact_run(&$argv, &$argc) {
|
||||||
|
|
||||||
$r = q("SELECT * FROM `gcontact` WHERE `id` = %d", intval($contact_id));
|
$r = q("SELECT * FROM `gcontact` WHERE `id` = %d", intval($contact_id));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/network.php');
|
require_once('include/network.php');
|
||||||
require_once('include/plugin.php');
|
require_once('include/plugin.php');
|
||||||
|
|
@ -125,7 +126,7 @@ function create_user($arr) {
|
||||||
$r = q("SELECT * FROM `user` WHERE `email` = '%s' LIMIT 1",
|
$r = q("SELECT * FROM `user` WHERE `email` = '%s' LIMIT 1",
|
||||||
dbesc($email)
|
dbesc($email)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$result['message'] .= t('Cannot use that email.') . EOL;
|
$result['message'] .= t('Cannot use that email.') . EOL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -138,7 +139,7 @@ function create_user($arr) {
|
||||||
WHERE `nickname` = '%s' LIMIT 1",
|
WHERE `nickname` = '%s' LIMIT 1",
|
||||||
dbesc($nickname)
|
dbesc($nickname)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$result['message'] .= t('Nickname is already registered. Please choose another.') . EOL;
|
$result['message'] .= t('Nickname is already registered. Please choose another.') . EOL;
|
||||||
|
|
||||||
// Check deleted accounts that had this nickname. Doesn't matter to us,
|
// Check deleted accounts that had this nickname. Doesn't matter to us,
|
||||||
|
|
@ -148,7 +149,7 @@ function create_user($arr) {
|
||||||
WHERE `username` = '%s' LIMIT 1",
|
WHERE `username` = '%s' LIMIT 1",
|
||||||
dbesc($nickname)
|
dbesc($nickname)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$result['message'] .= t('Nickname was once registered here and may not be re-used. Please choose another.') . EOL;
|
$result['message'] .= t('Nickname was once registered here and may not be re-used. Please choose another.') . EOL;
|
||||||
|
|
||||||
if(strlen($result['message'])) {
|
if(strlen($result['message'])) {
|
||||||
|
|
@ -201,7 +202,7 @@ function create_user($arr) {
|
||||||
dbesc($username),
|
dbesc($username),
|
||||||
dbesc($new_password_encoded)
|
dbesc($new_password_encoded)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$u = $r[0];
|
$u = $r[0];
|
||||||
$newuid = intval($r[0]['uid']);
|
$newuid = intval($r[0]['uid']);
|
||||||
}
|
}
|
||||||
|
|
@ -220,7 +221,7 @@ function create_user($arr) {
|
||||||
WHERE `nickname` = '%s' ",
|
WHERE `nickname` = '%s' ",
|
||||||
dbesc($nickname)
|
dbesc($nickname)
|
||||||
);
|
);
|
||||||
if ((dbm::is_result($r)) && (count($r) > 1) && $newuid) {
|
if ((DBM::is_result($r)) && (count($r) > 1) && $newuid) {
|
||||||
$result['message'] .= t('Nickname is already registered. Please choose another.') . EOL;
|
$result['message'] .= t('Nickname is already registered. Please choose another.') . EOL;
|
||||||
dba::delete('user', array('uid' => $newuid));
|
dba::delete('user', array('uid' => $newuid));
|
||||||
return $result;
|
return $result;
|
||||||
|
|
@ -259,7 +260,7 @@ function create_user($arr) {
|
||||||
intval($newuid),
|
intval($newuid),
|
||||||
dbesc(t('Friends'))
|
dbesc(t('Friends'))
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$def_gid = $r[0]['id'];
|
$def_gid = $r[0]['id'];
|
||||||
|
|
||||||
q("UPDATE `user` SET `def_gid` = %d WHERE `uid` = %d",
|
q("UPDATE `user` SET `def_gid` = %d WHERE `uid` = %d",
|
||||||
|
|
@ -346,12 +347,12 @@ function user_create_self_contact($uid) {
|
||||||
|
|
||||||
// Only create the entry if it doesn't exist yet
|
// Only create the entry if it doesn't exist yet
|
||||||
$r = q("SELECT `id` FROM `contact` WHERE `uid` = %d AND `self`", intval($uid));
|
$r = q("SELECT `id` FROM `contact` WHERE `uid` = %d AND `self`", intval($uid));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = q("SELECT `uid`, `username`, `nickname` FROM `user` WHERE `uid` = %d", intval($uid));
|
$r = q("SELECT `uid`, `username`, `nickname` FROM `user` WHERE `uid` = %d", intval($uid));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -17,6 +17,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'boot.php';
|
require_once 'boot.php';
|
||||||
require_once 'object/BaseObject.php';
|
require_once 'object/BaseObject.php';
|
||||||
|
|
@ -117,7 +118,7 @@ if (x($_SESSION,'authenticated') && !x($_SESSION,'language')) {
|
||||||
// we didn't loaded user data yet, but we need user language
|
// we didn't loaded user data yet, but we need user language
|
||||||
$r = dba::select('user', array('language'), array('uid' => $_SESSION['uid']), array('limit' => 1));
|
$r = dba::select('user', array('language'), array('uid' => $_SESSION['uid']), array('limit' => 1));
|
||||||
$_SESSION['language'] = $lang;
|
$_SESSION['language'] = $lang;
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$_SESSION['language'] = $r['language'];
|
$_SESSION['language'] = $r['language'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -10,6 +10,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once("include/enotify.php");
|
require_once("include/enotify.php");
|
||||||
require_once("include/text.php");
|
require_once("include/text.php");
|
||||||
|
|
@ -612,7 +613,7 @@ function admin_page_summary(App $a) {
|
||||||
dbesc(dba::database_name()));
|
dbesc(dba::database_name()));
|
||||||
$showwarning = false;
|
$showwarning = false;
|
||||||
$warningtext = array();
|
$warningtext = array();
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$showwarning = true;
|
$showwarning = true;
|
||||||
$warningtext[] = sprintf(t('Your DB still runs with MyISAM tables. You should change the engine type to InnoDB. As Friendica will use InnoDB only features in the future, you should change this! See <a href="%s">here</a> for a guide that may be helpful converting the table engines. You may also use the command <tt>php include/dbstructure.php toinnodb</tt> of your Friendica installation for an automatic conversion.<br />'), 'https://dev.mysql.com/doc/refman/5.7/en/converting-tables-to-innodb.html');
|
$warningtext[] = sprintf(t('Your DB still runs with MyISAM tables. You should change the engine type to InnoDB. As Friendica will use InnoDB only features in the future, you should change this! See <a href="%s">here</a> for a guide that may be helpful converting the table engines. You may also use the command <tt>php include/dbstructure.php toinnodb</tt> of your Friendica installation for an automatic conversion.<br />'), 'https://dev.mysql.com/doc/refman/5.7/en/converting-tables-to-innodb.html');
|
||||||
}
|
}
|
||||||
|
|
@ -1337,7 +1338,7 @@ function admin_page_dbsync(App $a) {
|
||||||
|
|
||||||
$failed = array();
|
$failed = array();
|
||||||
$r = q("SELECT `k`, `v` FROM `config` WHERE `cat` = 'database' ");
|
$r = q("SELECT `k`, `v` FROM `config` WHERE `cat` = 'database' ");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$upd = intval(substr($rr['k'],7));
|
$upd = intval(substr($rr['k'],7));
|
||||||
if ($upd < 1139 || $rr['v'] === 'success') {
|
if ($upd < 1139 || $rr['v'] === 'success') {
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/socgraph.php');
|
require_once('include/socgraph.php');
|
||||||
require_once('include/Contact.php');
|
require_once('include/Contact.php');
|
||||||
|
|
@ -31,7 +32,7 @@ function allfriends_content(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($c)) {
|
if (! DBM::is_result($c)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -45,7 +46,7 @@ function allfriends_content(App $a) {
|
||||||
|
|
||||||
$r = all_friends(local_user(), $cid, $a->pager['start'], $a->pager['itemspage']);
|
$r = all_friends(local_user(), $cid, $a->pager['start'], $a->pager['itemspage']);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$o .= t('No friends to display.');
|
$o .= t('No friends to display.');
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/api.php');
|
require_once('include/api.php');
|
||||||
|
|
||||||
|
|
@ -17,7 +18,7 @@ function oauth_get_client($request){
|
||||||
AND `tokens`.`id`='%s' AND `tokens`.`scope`='request'",
|
AND `tokens`.`id`='%s' AND `tokens`.`scope`='request'",
|
||||||
dbesc($token));
|
dbesc($token));
|
||||||
|
|
||||||
if (!dbm::is_result($r))
|
if (!DBM::is_result($r))
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
return $r[0];
|
return $r[0];
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/security.php');
|
require_once('include/security.php');
|
||||||
|
|
||||||
|
|
@ -18,7 +19,7 @@ function attach_init(App $a) {
|
||||||
$r = q("SELECT * FROM `attach` WHERE `id` = %d LIMIT 1",
|
$r = q("SELECT * FROM `attach` WHERE `id` = %d LIMIT 1",
|
||||||
intval($item_id)
|
intval($item_id)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Item was not found.'). EOL);
|
notice( t('Item was not found.'). EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -31,7 +32,7 @@ function attach_init(App $a) {
|
||||||
dbesc($item_id)
|
dbesc($item_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Permission denied.') . EOL);
|
notice( t('Permission denied.') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -10,6 +10,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/event.php');
|
require_once('include/event.php');
|
||||||
require_once('include/redir.php');
|
require_once('include/redir.php');
|
||||||
|
|
@ -130,7 +131,7 @@ function cal_content(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($a->profile['profile_uid'])
|
intval($a->profile['profile_uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
$remote_contact = true;
|
$remote_contact = true;
|
||||||
}
|
}
|
||||||
|
|
@ -225,7 +226,7 @@ function cal_content(App $a) {
|
||||||
|
|
||||||
$links = array();
|
$links = array();
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$r = sort_by_date($r);
|
$r = sort_by_date($r);
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$j = (($rr['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$rr['start'], 'j') : datetime_convert('UTC','UTC',$rr['start'],'j'));
|
$j = (($rr['adjust']) ? datetime_convert('UTC',date_default_timezone_get(),$rr['start'], 'j') : datetime_convert('UTC','UTC',$rr['start'],'j'));
|
||||||
|
|
@ -239,7 +240,7 @@ function cal_content(App $a) {
|
||||||
$events=array();
|
$events=array();
|
||||||
|
|
||||||
// transform the event in a usable array
|
// transform the event in a usable array
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$r = sort_by_date($r);
|
$r = sort_by_date($r);
|
||||||
$events = process_events($r);
|
$events = process_events($r);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/socgraph.php');
|
require_once('include/socgraph.php');
|
||||||
require_once('include/Contact.php');
|
require_once('include/Contact.php');
|
||||||
|
|
@ -34,14 +35,14 @@ function common_content(App $a) {
|
||||||
intval($cid),
|
intval($cid),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
/// @TODO Handle $c with dbm::is_result()
|
/// @TODO Handle $c with DBM::is_result()
|
||||||
$a->page['aside'] = "";
|
$a->page['aside'] = "";
|
||||||
profile_load($a, "", 0, get_contact_details_by_url($c[0]["url"]));
|
profile_load($a, "", 0, get_contact_details_by_url($c[0]["url"]));
|
||||||
} else {
|
} else {
|
||||||
$c = q("SELECT `name`, `url`, `photo` FROM `contact` WHERE `self` = 1 AND `uid` = %d LIMIT 1",
|
$c = q("SELECT `name`, `url`, `photo` FROM `contact` WHERE `self` = 1 AND `uid` = %d LIMIT 1",
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
/// @TODO Handle $c with dbm::is_result()
|
/// @TODO Handle $c with DBM::is_result()
|
||||||
|
|
||||||
$vcard_widget .= replace_macros(get_markup_template("vcard-widget.tpl"),array(
|
$vcard_widget .= replace_macros(get_markup_template("vcard-widget.tpl"),array(
|
||||||
'$name' => htmlentities($c[0]['name']),
|
'$name' => htmlentities($c[0]['name']),
|
||||||
|
|
@ -55,7 +56,7 @@ function common_content(App $a) {
|
||||||
$a->page['aside'] .= $vcard_widget;
|
$a->page['aside'] .= $vcard_widget;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! dbm::is_result($c)) {
|
if (! DBM::is_result($c)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -65,13 +66,13 @@ function common_content(App $a) {
|
||||||
dbesc(normalise_link(get_my_url())),
|
dbesc(normalise_link(get_my_url())),
|
||||||
intval($profile_uid)
|
intval($profile_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$cid = $r[0]['id'];
|
$cid = $r[0]['id'];
|
||||||
else {
|
else {
|
||||||
$r = q("SELECT `id` FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
|
$r = q("SELECT `id` FROM `gcontact` WHERE `nurl` = '%s' LIMIT 1",
|
||||||
dbesc(normalise_link(get_my_url()))
|
dbesc(normalise_link(get_my_url()))
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$zcid = $r[0]['id'];
|
$zcid = $r[0]['id'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -102,7 +103,7 @@ function common_content(App $a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function community_init(App $a) {
|
function community_init(App $a) {
|
||||||
if (! local_user()) {
|
if (! local_user()) {
|
||||||
|
|
@ -45,7 +46,7 @@ function community_content(App $a, $update = 0) {
|
||||||
|
|
||||||
$r = community_getitems($a->pager['start'], $a->pager['itemspage']);
|
$r = community_getitems($a->pager['start'], $a->pager['itemspage']);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
info( t('No results.') . EOL);
|
info( t('No results.') . EOL);
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/group.php');
|
require_once('include/group.php');
|
||||||
|
|
||||||
|
|
@ -14,7 +15,7 @@ function contactgroup_content(App $a) {
|
||||||
intval($a->argv[2]),
|
intval($a->argv[2]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$change = intval($a->argv[2]);
|
$change = intval($a->argv[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -24,7 +25,7 @@ function contactgroup_content(App $a) {
|
||||||
intval($a->argv[1]),
|
intval($a->argv[1]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
|
|
||||||
require_once 'include/Contact.php';
|
require_once 'include/Contact.php';
|
||||||
|
|
@ -24,7 +25,7 @@ function contacts_init(App $a) {
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
intval($contact_id)
|
intval($contact_id)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$contact_id = 0;
|
$contact_id = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -183,7 +184,7 @@ function contacts_post(App $a) {
|
||||||
intval($profile_id),
|
intval($profile_id),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Could not locate selected profile.') . EOL);
|
notice( t('Could not locate selected profile.') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -225,7 +226,7 @@ function contacts_post(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if($r && dbm::is_result($r))
|
if($r && DBM::is_result($r))
|
||||||
$a->data['contact'] = $r[0];
|
$a->data['contact'] = $r[0];
|
||||||
|
|
||||||
return;
|
return;
|
||||||
|
|
@ -352,7 +353,7 @@ function _contact_drop($contact_id, $orig_record) {
|
||||||
WHERE `user`.`uid` = %d AND `contact`.`self` LIMIT 1",
|
WHERE `user`.`uid` = %d AND `contact`.`self` LIMIT 1",
|
||||||
intval($a->user['uid'])
|
intval($a->user['uid'])
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -794,7 +795,7 @@ function contacts_content(App $a) {
|
||||||
$r = q("SELECT COUNT(*) AS `total` FROM `contact`
|
$r = q("SELECT COUNT(*) AS `total` FROM `contact`
|
||||||
WHERE `uid` = %d AND `self` = 0 AND `pending` = 0 $sql_extra $sql_extra2 ",
|
WHERE `uid` = %d AND `self` = 0 AND `pending` = 0 $sql_extra $sql_extra2 ",
|
||||||
intval($_SESSION['uid']));
|
intval($_SESSION['uid']));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->set_pager_total($r[0]['total']);
|
$a->set_pager_total($r[0]['total']);
|
||||||
$total = $r[0]['total'];
|
$total = $r[0]['total'];
|
||||||
}
|
}
|
||||||
|
|
@ -809,7 +810,7 @@ function contacts_content(App $a) {
|
||||||
|
|
||||||
$contacts = array();
|
$contacts = array();
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$contacts[] = _contact_detail_for_template($rr);
|
$contacts[] = _contact_detail_for_template($rr);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once("include/contact_selectors.php");
|
require_once("include/contact_selectors.php");
|
||||||
require_once("mod/contacts.php");
|
require_once("mod/contacts.php");
|
||||||
|
|
@ -19,7 +20,7 @@ function crepair_init(App $a) {
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
intval($contact_id)
|
intval($contact_id)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$contact_id = 0;
|
$contact_id = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -48,7 +49,7 @@ function crepair_post(App $a) {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -116,7 +117,7 @@ function crepair_content(App $a) {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Contact not found.') . EOL);
|
notice( t('Contact not found.') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('mod/settings.php');
|
require_once('mod/settings.php');
|
||||||
|
|
||||||
|
|
@ -29,12 +30,12 @@ function delegate_content(App $a) {
|
||||||
$r = q("select `nickname` from user where uid = %d limit 1",
|
$r = q("select `nickname` from user where uid = %d limit 1",
|
||||||
intval($id)
|
intval($id)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$r = q("select id from contact where uid = %d and nurl = '%s' limit 1",
|
$r = q("select id from contact where uid = %d and nurl = '%s' limit 1",
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
dbesc(normalise_link(System::baseUrl() . '/profile/' . $r[0]['nickname']))
|
dbesc(normalise_link(System::baseUrl() . '/profile/' . $r[0]['nickname']))
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
dba::insert('manage', array('uid' => $a->argv[2], 'mid' => local_user()));
|
dba::insert('manage', array('uid' => $a->argv[2], 'mid' => local_user()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -64,7 +65,7 @@ function delegate_content(App $a) {
|
||||||
dbesc($a->user['email']),
|
dbesc($a->user['email']),
|
||||||
dbesc($a->user['password'])
|
dbesc($a->user['password'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$full_managers = $r;
|
$full_managers = $r;
|
||||||
|
|
||||||
$delegates = array();
|
$delegates = array();
|
||||||
|
|
@ -75,7 +76,7 @@ function delegate_content(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$delegates = $r;
|
$delegates = $r;
|
||||||
|
|
||||||
$uids = array();
|
$uids = array();
|
||||||
|
|
@ -97,14 +98,14 @@ function delegate_content(App $a) {
|
||||||
dbesc(NETWORK_DFRN)
|
dbesc(NETWORK_DFRN)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('No potential page delegates located.') . EOL);
|
notice( t('No potential page delegates located.') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$nicknames = array();
|
$nicknames = array();
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$nicknames[] = "'" . dbesc(basename($rr['nurl'])) . "'";
|
$nicknames[] = "'" . dbesc(basename($rr['nurl'])) . "'";
|
||||||
}
|
}
|
||||||
|
|
@ -118,7 +119,7 @@ function delegate_content(App $a) {
|
||||||
|
|
||||||
$r = q("select `uid`, `username`, `nickname` from user where nickname in ( $nicks )");
|
$r = q("select `uid`, `username`, `nickname` from user where nickname in ( $nicks )");
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
if(! in_array($rr['uid'],$uids))
|
if(! in_array($rr['uid'],$uids))
|
||||||
$potentials[] = $rr;
|
$potentials[] = $rr;
|
||||||
|
|
|
||||||
|
|
@ -23,6 +23,7 @@ use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
|
|
||||||
|
|
@ -128,7 +129,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
logger('Contact not found in DB.');
|
logger('Contact not found in DB.');
|
||||||
notice( t('Contact not found.') . EOL );
|
notice( t('Contact not found.') . EOL );
|
||||||
notice( t('This may occasionally happen if contact was requested by both persons and it has already been approved.') . EOL );
|
notice( t('This may occasionally happen if contact was requested by both persons and it has already been approved.') . EOL );
|
||||||
|
|
@ -419,7 +420,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @TODO is dbm::is_result() working here?
|
/// @TODO is DBM::is_result() working here?
|
||||||
if ($r === false) {
|
if ($r === false) {
|
||||||
notice( t('Unable to set contact photo.') . EOL);
|
notice( t('Unable to set contact photo.') . EOL);
|
||||||
}
|
}
|
||||||
|
|
@ -429,7 +430,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
$r = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1",
|
$r = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1",
|
||||||
intval($contact_id)
|
intval($contact_id)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
} else {
|
} else {
|
||||||
$contact = null;
|
$contact = null;
|
||||||
|
|
@ -449,7 +450,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if((dbm::is_result($r)) && ($r[0]['hide-friends'] == 0) && ($activity) && (! $hidden)) {
|
if((DBM::is_result($r)) && ($r[0]['hide-friends'] == 0) && ($activity) && (! $hidden)) {
|
||||||
|
|
||||||
require_once 'include/items.php';
|
require_once 'include/items.php';
|
||||||
|
|
||||||
|
|
@ -560,7 +561,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
$r = q("SELECT * FROM `user` WHERE `nickname` = '%s' LIMIT 1",
|
$r = q("SELECT * FROM `user` WHERE `nickname` = '%s' LIMIT 1",
|
||||||
dbesc($node));
|
dbesc($node));
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$message = sprintf(t('No user record found for \'%s\' '), $node);
|
$message = sprintf(t('No user record found for \'%s\' '), $node);
|
||||||
xml_status(3,$message); // failure
|
xml_status(3,$message); // failure
|
||||||
// NOTREACHED
|
// NOTREACHED
|
||||||
|
|
@ -591,7 +592,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
dbesc($decrypted_source_url),
|
dbesc($decrypted_source_url),
|
||||||
intval($local_uid)
|
intval($local_uid)
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($ret)) {
|
if (!DBM::is_result($ret)) {
|
||||||
if (strstr($decrypted_source_url,'http:')) {
|
if (strstr($decrypted_source_url,'http:')) {
|
||||||
$newurl = str_replace('http:','https:',$decrypted_source_url);
|
$newurl = str_replace('http:','https:',$decrypted_source_url);
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -602,7 +603,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
dbesc($newurl),
|
dbesc($newurl),
|
||||||
intval($local_uid)
|
intval($local_uid)
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($ret)) {
|
if (!DBM::is_result($ret)) {
|
||||||
// this is either a bogus confirmation (?) or we deleted the original introduction.
|
// this is either a bogus confirmation (?) or we deleted the original introduction.
|
||||||
$message = t('Contact record was not found for you on our site.');
|
$message = t('Contact record was not found for you on our site.');
|
||||||
xml_status(3,$message);
|
xml_status(3,$message);
|
||||||
|
|
@ -637,7 +638,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
$r = q("SELECT * FROM `contact` WHERE `dfrn-id` = '%s' LIMIT 1",
|
$r = q("SELECT * FROM `contact` WHERE `dfrn-id` = '%s' LIMIT 1",
|
||||||
dbesc($decrypted_dfrn_id)
|
dbesc($decrypted_dfrn_id)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$message = t('The ID provided by your system is a duplicate on our system. It should work if you try again.');
|
$message = t('The ID provided by your system is a duplicate on our system. It should work if you try again.');
|
||||||
xml_status(1,$message); // Birthday paradox - duplicate dfrn-id
|
xml_status(1,$message); // Birthday paradox - duplicate dfrn-id
|
||||||
// NOTREACHED
|
// NOTREACHED
|
||||||
|
|
@ -648,7 +649,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
dbesc($dfrn_pubkey),
|
dbesc($dfrn_pubkey),
|
||||||
intval($dfrn_record)
|
intval($dfrn_record)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$message = t('Unable to set your contact credentials on our system.');
|
$message = t('Unable to set your contact credentials on our system.');
|
||||||
xml_status(3,$message);
|
xml_status(3,$message);
|
||||||
}
|
}
|
||||||
|
|
@ -669,7 +670,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
$r = q("SELECT `photo` FROM `contact` WHERE `id` = %d LIMIT 1",
|
$r = q("SELECT `photo` FROM `contact` WHERE `id` = %d LIMIT 1",
|
||||||
intval($dfrn_record));
|
intval($dfrn_record));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$photo = $r[0]['photo'];
|
$photo = $r[0]['photo'];
|
||||||
} else {
|
} else {
|
||||||
$photo = System::baseUrl() . '/images/person-175.jpg';
|
$photo = System::baseUrl() . '/images/person-175.jpg';
|
||||||
|
|
@ -725,10 +726,10 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
intval($dfrn_record)
|
intval($dfrn_record)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$combined = $r[0];
|
$combined = $r[0];
|
||||||
|
|
||||||
if((dbm::is_result($r)) && ($r[0]['notify-flags'] & NOTIFY_CONFIRM)) {
|
if((DBM::is_result($r)) && ($r[0]['notify-flags'] & NOTIFY_CONFIRM)) {
|
||||||
$mutual = ($new_relation == CONTACT_IS_FRIEND);
|
$mutual = ($new_relation == CONTACT_IS_FRIEND);
|
||||||
notification(array(
|
notification(array(
|
||||||
'type' => NOTIFY_CONFIRM,
|
'type' => NOTIFY_CONFIRM,
|
||||||
|
|
@ -753,7 +754,7 @@ function dfrn_confirm_post(App $a, $handsfree = null) {
|
||||||
intval($local_uid)
|
intval($local_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if((dbm::is_result($r)) && ($r[0]['hide-friends'] == 0)) {
|
if((DBM::is_result($r)) && ($r[0]['hide-friends'] == 0)) {
|
||||||
|
|
||||||
require_once 'include/items.php';
|
require_once 'include/items.php';
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,8 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Protocol\Dfrn;
|
use Friendica\Database\DBM;
|
||||||
|
use Friendica\Protocol\DFRN;
|
||||||
|
|
||||||
require_once('include/items.php');
|
require_once('include/items.php');
|
||||||
require_once('include/event.php');
|
require_once('include/event.php');
|
||||||
|
|
@ -46,7 +47,7 @@ function dfrn_notify_post(App $a) {
|
||||||
dbesc($dfrn_id),
|
dbesc($dfrn_id),
|
||||||
dbesc($challenge)
|
dbesc($challenge)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
logger('dfrn_notify: could not match challenge to dfrn_id ' . $dfrn_id . ' challenge=' . $challenge);
|
logger('dfrn_notify: could not match challenge to dfrn_id ' . $dfrn_id . ' challenge=' . $challenge);
|
||||||
xml_status(3, 'Could not match challenge');
|
xml_status(3, 'Could not match challenge');
|
||||||
}
|
}
|
||||||
|
|
@ -94,7 +95,7 @@ function dfrn_notify_post(App $a) {
|
||||||
dbesc($a->argv[1])
|
dbesc($a->argv[1])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
logger('dfrn_notify: contact not found for dfrn_id ' . $dfrn_id);
|
logger('dfrn_notify: contact not found for dfrn_id ' . $dfrn_id);
|
||||||
xml_status(3, 'Contact not found');
|
xml_status(3, 'Contact not found');
|
||||||
//NOTREACHED
|
//NOTREACHED
|
||||||
|
|
@ -180,7 +181,7 @@ function dfrn_notify_post(App $a) {
|
||||||
*we got a key. old code send only the key, without RINO version.
|
*we got a key. old code send only the key, without RINO version.
|
||||||
* we assume RINO 1 if key and no RINO version
|
* we assume RINO 1 if key and no RINO version
|
||||||
*/
|
*/
|
||||||
$data = Dfrn::aes_decrypt(hex2bin($data), $final_key);
|
$data = DFRN::aes_decrypt(hex2bin($data), $final_key);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
try {
|
try {
|
||||||
|
|
@ -212,7 +213,7 @@ function dfrn_notify_post(App $a) {
|
||||||
logger('rino: decrypted data: ' . $data, LOGGER_DATA);
|
logger('rino: decrypted data: ' . $data, LOGGER_DATA);
|
||||||
}
|
}
|
||||||
|
|
||||||
$ret = Dfrn::import($data, $importer);
|
$ret = DFRN::import($data, $importer);
|
||||||
xml_status($ret, 'Processed');
|
xml_status($ret, 'Processed');
|
||||||
|
|
||||||
// NOTREACHED
|
// NOTREACHED
|
||||||
|
|
@ -284,7 +285,7 @@ function dfrn_notify_content(App $a) {
|
||||||
dbesc($a->argv[1])
|
dbesc($a->argv[1])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$status = 1;
|
$status = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,8 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Protocol\Dfrn;
|
use Friendica\Database\DBM;
|
||||||
|
use Friendica\Protocol\DFRN;
|
||||||
|
|
||||||
require_once('include/items.php');
|
require_once('include/items.php');
|
||||||
require_once('include/auth.php');
|
require_once('include/auth.php');
|
||||||
|
|
@ -58,7 +59,7 @@ function dfrn_poll_init(App $a) {
|
||||||
|
|
||||||
logger('dfrn_poll: public feed request from ' . $_SERVER['REMOTE_ADDR'] . ' for ' . $user);
|
logger('dfrn_poll: public feed request from ' . $_SERVER['REMOTE_ADDR'] . ' for ' . $user);
|
||||||
header("Content-type: application/atom+xml");
|
header("Content-type: application/atom+xml");
|
||||||
echo Dfrn::feed('', $user,$last_update, 0, $hidewall);
|
echo DFRN::feed('', $user,$last_update, 0, $hidewall);
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -90,7 +91,7 @@ function dfrn_poll_init(App $a) {
|
||||||
dbesc($a->argv[1])
|
dbesc($a->argv[1])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
$s = fetch_url($r[0]['poll'] . '?dfrn_id=' . $my_id . '&type=profile-check');
|
$s = fetch_url($r[0]['poll'] . '?dfrn_id=' . $my_id . '&type=profile-check');
|
||||||
|
|
||||||
|
|
@ -137,7 +138,7 @@ function dfrn_poll_init(App $a) {
|
||||||
$r = q("SELECT * FROM `profile_check` WHERE `sec` = '%s' ORDER BY `expire` DESC LIMIT 1",
|
$r = q("SELECT * FROM `profile_check` WHERE `sec` = '%s' ORDER BY `expire` DESC LIMIT 1",
|
||||||
dbesc($sec)
|
dbesc($sec)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
xml_status(3, 'No ticket');
|
xml_status(3, 'No ticket');
|
||||||
// NOTREACHED
|
// NOTREACHED
|
||||||
}
|
}
|
||||||
|
|
@ -148,7 +149,7 @@ function dfrn_poll_init(App $a) {
|
||||||
$c = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1",
|
$c = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1",
|
||||||
intval($r[0]['cid'])
|
intval($r[0]['cid'])
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($c)) {
|
if (! DBM::is_result($c)) {
|
||||||
xml_status(3, 'No profile');
|
xml_status(3, 'No profile');
|
||||||
}
|
}
|
||||||
$contact = $c[0];
|
$contact = $c[0];
|
||||||
|
|
@ -201,7 +202,7 @@ function dfrn_poll_init(App $a) {
|
||||||
q("DELETE FROM `profile_check` WHERE `expire` < " . intval(time()));
|
q("DELETE FROM `profile_check` WHERE `expire` < " . intval(time()));
|
||||||
$r = q("SELECT * FROM `profile_check` WHERE `dfrn_id` = '%s' ORDER BY `expire` DESC",
|
$r = q("SELECT * FROM `profile_check` WHERE `dfrn_id` = '%s' ORDER BY `expire` DESC",
|
||||||
dbesc($dfrn_id));
|
dbesc($dfrn_id));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
xml_status(1);
|
xml_status(1);
|
||||||
return; // NOTREACHED
|
return; // NOTREACHED
|
||||||
}
|
}
|
||||||
|
|
@ -234,7 +235,7 @@ function dfrn_poll_post(App $a) {
|
||||||
$r = q("SELECT * FROM `profile_check` WHERE `sec` = '%s' ORDER BY `expire` DESC LIMIT 1",
|
$r = q("SELECT * FROM `profile_check` WHERE `sec` = '%s' ORDER BY `expire` DESC LIMIT 1",
|
||||||
dbesc($sec)
|
dbesc($sec)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
xml_status(3, 'No ticket');
|
xml_status(3, 'No ticket');
|
||||||
// NOTREACHED
|
// NOTREACHED
|
||||||
}
|
}
|
||||||
|
|
@ -245,7 +246,7 @@ function dfrn_poll_post(App $a) {
|
||||||
$c = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1",
|
$c = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1",
|
||||||
intval($r[0]['cid'])
|
intval($r[0]['cid'])
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($c)) {
|
if (! DBM::is_result($c)) {
|
||||||
xml_status(3, 'No profile');
|
xml_status(3, 'No profile');
|
||||||
}
|
}
|
||||||
$contact = $c[0];
|
$contact = $c[0];
|
||||||
|
|
@ -295,7 +296,7 @@ function dfrn_poll_post(App $a) {
|
||||||
dbesc($challenge)
|
dbesc($challenge)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -331,7 +332,7 @@ function dfrn_poll_post(App $a) {
|
||||||
$r = q("SELECT * FROM `contact` WHERE `blocked` = 0 AND `pending` = 0 $sql_extra LIMIT 1");
|
$r = q("SELECT * FROM `contact` WHERE `blocked` = 0 AND `pending` = 0 $sql_extra LIMIT 1");
|
||||||
|
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -348,7 +349,7 @@ function dfrn_poll_post(App $a) {
|
||||||
$reputation = 0;
|
$reputation = 0;
|
||||||
$text = '';
|
$text = '';
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$reputation = $r[0]['rating'];
|
$reputation = $r[0]['rating'];
|
||||||
$text = $r[0]['reason'];
|
$text = $r[0]['reason'];
|
||||||
|
|
||||||
|
|
@ -387,7 +388,7 @@ function dfrn_poll_post(App $a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
header("Content-type: application/atom+xml");
|
header("Content-type: application/atom+xml");
|
||||||
$o = Dfrn::feed($dfrn_id, $a->argv[1], $last_update, $direction);
|
$o = DFRN::feed($dfrn_id, $a->argv[1], $last_update, $direction);
|
||||||
echo $o;
|
echo $o;
|
||||||
killme();
|
killme();
|
||||||
|
|
||||||
|
|
@ -461,7 +462,7 @@ function dfrn_poll_content(App $a) {
|
||||||
dbesc($nickname)
|
dbesc($nickname)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
$challenge = '';
|
$challenge = '';
|
||||||
$encrypted_id = '';
|
$encrypted_id = '';
|
||||||
|
|
@ -508,7 +509,7 @@ function dfrn_poll_content(App $a) {
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
$profile = ((dbm::is_result($r) && $r[0]['nickname']) ? $r[0]['nickname'] : $nickname);
|
$profile = ((DBM::is_result($r) && $r[0]['nickname']) ? $r[0]['nickname'] : $nickname);
|
||||||
|
|
||||||
switch($destination_url) {
|
switch($destination_url) {
|
||||||
case 'profile':
|
case 'profile':
|
||||||
|
|
|
||||||
|
|
@ -16,6 +16,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
|
|
||||||
require_once 'include/enotify.php';
|
require_once 'include/enotify.php';
|
||||||
|
|
@ -95,7 +96,7 @@ function dfrn_request_post(App $a) {
|
||||||
dbesc(normalise_link($dfrn_url))
|
dbesc(normalise_link($dfrn_url))
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if(strlen($r[0]['dfrn-id'])) {
|
if(strlen($r[0]['dfrn-id'])) {
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
@ -149,7 +150,7 @@ function dfrn_request_post(App $a) {
|
||||||
$photo = $parms["photo"];
|
$photo = $parms["photo"];
|
||||||
|
|
||||||
// Escape the entire array
|
// Escape the entire array
|
||||||
dbm::esc_array($parms);
|
DBM::esc_array($parms);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a contact record on our site for the other person
|
* Create a contact record on our site for the other person
|
||||||
|
|
@ -189,7 +190,7 @@ function dfrn_request_post(App $a) {
|
||||||
dbesc($dfrn_url),
|
dbesc($dfrn_url),
|
||||||
$parms['key'] // this was already escaped
|
$parms['key'] // this was already escaped
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$def_gid = get_default_group(local_user(), $r[0]["network"]);
|
$def_gid = get_default_group(local_user(), $r[0]["network"]);
|
||||||
if(intval($def_gid))
|
if(intval($def_gid))
|
||||||
group_add_member(local_user(), '', $r[0]['id'], $def_gid);
|
group_add_member(local_user(), '', $r[0]['id'], $def_gid);
|
||||||
|
|
@ -280,7 +281,7 @@ function dfrn_request_post(App $a) {
|
||||||
dbesc(datetime_convert('UTC','UTC','now - 24 hours')),
|
dbesc(datetime_convert('UTC','UTC','now - 24 hours')),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r) && count($r) > $maxreq) {
|
if (DBM::is_result($r) && count($r) > $maxreq) {
|
||||||
notice( sprintf( t('%s has received too many connection requests today.'), $a->profile['name']) . EOL);
|
notice( sprintf( t('%s has received too many connection requests today.'), $a->profile['name']) . EOL);
|
||||||
notice( t('Spam protection measures have been invoked.') . EOL);
|
notice( t('Spam protection measures have been invoked.') . EOL);
|
||||||
notice( t('Friends are advised to please try again in 24 hours.') . EOL);
|
notice( t('Friends are advised to please try again in 24 hours.') . EOL);
|
||||||
|
|
@ -302,7 +303,7 @@ function dfrn_request_post(App $a) {
|
||||||
AND `intro`.`datetime` < UTC_TIMESTAMP() - INTERVAL 30 MINUTE ",
|
AND `intro`.`datetime` < UTC_TIMESTAMP() - INTERVAL 30 MINUTE ",
|
||||||
dbesc(NETWORK_MAIL2)
|
dbesc(NETWORK_MAIL2)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if(! $rr['rel']) {
|
if(! $rr['rel']) {
|
||||||
q("DELETE FROM `contact` WHERE `id` = %d AND NOT `self`",
|
q("DELETE FROM `contact` WHERE `id` = %d AND NOT `self`",
|
||||||
|
|
@ -327,7 +328,7 @@ function dfrn_request_post(App $a) {
|
||||||
AND `intro`.`datetime` < UTC_TIMESTAMP() - INTERVAL 3 DAY ",
|
AND `intro`.`datetime` < UTC_TIMESTAMP() - INTERVAL 3 DAY ",
|
||||||
dbesc(NETWORK_MAIL2)
|
dbesc(NETWORK_MAIL2)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if(! $rr['rel']) {
|
if(! $rr['rel']) {
|
||||||
q("DELETE FROM `contact` WHERE `id` = %d AND NOT `self`",
|
q("DELETE FROM `contact` WHERE `id` = %d AND NOT `self`",
|
||||||
|
|
@ -378,7 +379,7 @@ function dfrn_request_post(App $a) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('This account has not been configured for email. Request failed.') . EOL);
|
notice( t('This account has not been configured for email. Request failed.') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -405,7 +406,7 @@ function dfrn_request_post(App $a) {
|
||||||
dbesc($poll),
|
dbesc($poll),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact_id = $r[0]['id'];
|
$contact_id = $r[0]['id'];
|
||||||
|
|
||||||
$def_gid = get_default_group($uid, $r[0]["network"]);
|
$def_gid = get_default_group($uid, $r[0]["network"]);
|
||||||
|
|
@ -480,7 +481,7 @@ function dfrn_request_post(App $a) {
|
||||||
dbesc($url)
|
dbesc($url)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($ret)) {
|
if (DBM::is_result($ret)) {
|
||||||
if(strlen($ret[0]['issued-id'])) {
|
if(strlen($ret[0]['issued-id'])) {
|
||||||
notice( t('You have already introduced yourself here.') . EOL );
|
notice( t('You have already introduced yourself here.') . EOL );
|
||||||
return;
|
return;
|
||||||
|
|
@ -552,7 +553,7 @@ function dfrn_request_post(App $a) {
|
||||||
$parms['issued-id'] = $issued_id;
|
$parms['issued-id'] = $issued_id;
|
||||||
$photo = $parms["photo"];
|
$photo = $parms["photo"];
|
||||||
|
|
||||||
dbm::esc_array($parms);
|
DBM::esc_array($parms);
|
||||||
$r = q("INSERT INTO `contact` ( `uid`, `created`, `url`, `nurl`, `addr`, `name`, `nick`, `issued-id`, `photo`, `site-pubkey`,
|
$r = q("INSERT INTO `contact` ( `uid`, `created`, `url`, `nurl`, `addr`, `name`, `nick`, `issued-id`, `photo`, `site-pubkey`,
|
||||||
`request`, `confirm`, `notify`, `poll`, `poco`, `network`, `blocked`, `pending` )
|
`request`, `confirm`, `notify`, `poll`, `poco`, `network`, `blocked`, `pending` )
|
||||||
VALUES ( %d, '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', %d, %d )",
|
VALUES ( %d, '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', %d, %d )",
|
||||||
|
|
@ -584,7 +585,7 @@ function dfrn_request_post(App $a) {
|
||||||
$parms['url'],
|
$parms['url'],
|
||||||
$parms['issued-id']
|
$parms['issued-id']
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact_record = $r[0];
|
$contact_record = $r[0];
|
||||||
update_contact_avatar($photo, $uid, $contact_record["id"], true);
|
update_contact_avatar($photo, $uid, $contact_record["id"], true);
|
||||||
}
|
}
|
||||||
|
|
@ -735,7 +736,7 @@ function dfrn_request_content(App $a) {
|
||||||
dbesc($_GET['confirm_key'])
|
dbesc($_GET['confirm_key'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($intro)) {
|
if (DBM::is_result($intro)) {
|
||||||
|
|
||||||
$r = q("SELECT `contact`.*, `user`.* FROM `contact` LEFT JOIN `user` ON `contact`.`uid` = `user`.`uid`
|
$r = q("SELECT `contact`.*, `user`.* FROM `contact` LEFT JOIN `user` ON `contact`.`uid` = `user`.`uid`
|
||||||
WHERE `contact`.`id` = %d LIMIT 1",
|
WHERE `contact`.`id` = %d LIMIT 1",
|
||||||
|
|
@ -744,7 +745,7 @@ function dfrn_request_content(App $a) {
|
||||||
|
|
||||||
$auto_confirm = false;
|
$auto_confirm = false;
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if(($r[0]['page-flags'] != PAGE_NORMAL) && ($r[0]['page-flags'] != PAGE_PRVGROUP))
|
if(($r[0]['page-flags'] != PAGE_NORMAL) && ($r[0]['page-flags'] != PAGE_PRVGROUP))
|
||||||
$auto_confirm = true;
|
$auto_confirm = true;
|
||||||
|
|
||||||
|
|
@ -861,7 +862,7 @@ function dfrn_request_content(App $a) {
|
||||||
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d LIMIT 1",
|
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d LIMIT 1",
|
||||||
intval($a->profile['uid'])
|
intval($a->profile['uid'])
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$mail_disabled = 1;
|
$mail_disabled = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function directory_init(App $a) {
|
function directory_init(App $a) {
|
||||||
$a->set_pager_itemspage(60);
|
$a->set_pager_itemspage(60);
|
||||||
|
|
@ -73,7 +74,7 @@ function directory_content(App $a) {
|
||||||
$r = q("SELECT COUNT(*) AS `total` FROM `profile`
|
$r = q("SELECT COUNT(*) AS `total` FROM `profile`
|
||||||
LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
||||||
WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 $sql_extra ");
|
WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 $sql_extra ");
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$a->set_pager_total($r[0]['total']);
|
$a->set_pager_total($r[0]['total']);
|
||||||
|
|
||||||
$order = " ORDER BY `name` ASC ";
|
$order = " ORDER BY `name` ASC ";
|
||||||
|
|
@ -85,7 +86,7 @@ function directory_content(App $a) {
|
||||||
LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
LEFT JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
||||||
LEFT JOIN `contact` ON `contact`.`uid` = `user`.`uid`
|
LEFT JOIN `contact` ON `contact`.`uid` = `user`.`uid`
|
||||||
WHERE `is-default` $publish AND `user`.`blocked` = 0 AND `contact`.`self` $sql_extra $order LIMIT ".$limit);
|
WHERE `is-default` $publish AND `user`.`blocked` = 0 AND `contact`.`self` $sql_extra $order LIMIT ".$limit);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
if (in_array('small', $a->argv)) {
|
if (in_array('small', $a->argv)) {
|
||||||
$photo = 'thumb';
|
$photo = 'thumb';
|
||||||
|
|
|
||||||
|
|
@ -105,7 +105,7 @@ function dirfind_content(App $a, $prefix = "") {
|
||||||
|
|
||||||
$search2 = "%".$search."%";
|
$search2 = "%".$search."%";
|
||||||
|
|
||||||
/// @TODO These 2 SELECTs are not checked on validity with dbm::is_result()
|
/// @TODO These 2 SELECTs are not checked on validity with DBM::is_result()
|
||||||
$count = q("SELECT count(*) AS `total` FROM `gcontact`
|
$count = q("SELECT count(*) AS `total` FROM `gcontact`
|
||||||
LEFT JOIN `contact` ON `contact`.`nurl` = `gcontact`.`nurl`
|
LEFT JOIN `contact` ON `contact`.`nurl` = `gcontact`.`nurl`
|
||||||
AND `contact`.`network` = `gcontact`.`network`
|
AND `contact`.`network` = `gcontact`.`network`
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,8 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Protocol\Dfrn;
|
use Friendica\Database\DBM;
|
||||||
|
use Friendica\Protocol\DFRN;
|
||||||
|
|
||||||
function display_init(App $a) {
|
function display_init(App $a) {
|
||||||
|
|
||||||
|
|
@ -40,14 +41,14 @@ function display_init(App $a) {
|
||||||
`author-avatar`, `network`, `body`, `uid`, `owner-link`
|
`author-avatar`, `network`, `body`, `uid`, `owner-link`
|
||||||
FROM `item` WHERE `visible` AND NOT `deleted` AND NOT `moderated`
|
FROM `item` WHERE `visible` AND NOT `deleted` AND NOT `moderated`
|
||||||
AND `guid` = ? AND `uid` = ? LIMIT 1", $a->argv[1], local_user());
|
AND `guid` = ? AND `uid` = ? LIMIT 1", $a->argv[1], local_user());
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$nick = $a->user["nickname"];
|
$nick = $a->user["nickname"];
|
||||||
$itemuid = local_user();
|
$itemuid = local_user();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is it an item with uid=0?
|
// Is it an item with uid=0?
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = dba::fetch_first("SELECT `id`, `parent`, `author-name`, `author-link`,
|
$r = dba::fetch_first("SELECT `id`, `parent`, `author-name`, `author-link`,
|
||||||
`author-avatar`, `network`, `body`, `uid`, `owner-link`
|
`author-avatar`, `network`, `body`, `uid`, `owner-link`
|
||||||
FROM `item` WHERE `visible` AND NOT `deleted` AND NOT `moderated`
|
FROM `item` WHERE `visible` AND NOT `deleted` AND NOT `moderated`
|
||||||
|
|
@ -58,7 +59,7 @@ function display_init(App $a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Or is it anywhere on the server?
|
// Or is it anywhere on the server?
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = dba::fetch_first("SELECT `item`.`id`, `item`.`parent`, `item`.`author-name`, `item`.`author-link`,
|
$r = dba::fetch_first("SELECT `item`.`id`, `item`.`parent`, `item`.`author-name`, `item`.`author-link`,
|
||||||
`item`.`author-avatar`, `item`.`network`, `item`.`body`, `item`.`uid`, `item`.`owner-link`
|
`item`.`author-avatar`, `item`.`network`, `item`.`body`, `item`.`uid`, `item`.`owner-link`
|
||||||
FROM `item` STRAIGHT_JOIN `user` ON `user`.`uid` = `item`.`uid`
|
FROM `item` STRAIGHT_JOIN `user` ON `user`.`uid` = `item`.`uid`
|
||||||
|
|
@ -69,7 +70,7 @@ function display_init(App $a) {
|
||||||
AND `item`.`guid` = ? LIMIT 1", $a->argv[1]);
|
AND `item`.`guid` = ? LIMIT 1", $a->argv[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
if (strstr($_SERVER['HTTP_ACCEPT'], 'application/atom+xml')) {
|
if (strstr($_SERVER['HTTP_ACCEPT'], 'application/atom+xml')) {
|
||||||
logger('Directly serving XML for id '.$r["id"], LOGGER_DEBUG);
|
logger('Directly serving XML for id '.$r["id"], LOGGER_DEBUG);
|
||||||
|
|
@ -93,7 +94,7 @@ function display_init(App $a) {
|
||||||
WHERE `user`.`nickname` = ? AND `profile`.`is-default` AND `contact`.`self` LIMIT 1",
|
WHERE `user`.`nickname` = ? AND `profile`.`is-default` AND `contact`.`self` LIMIT 1",
|
||||||
$nickname
|
$nickname
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$profiledata = $r;
|
$profiledata = $r;
|
||||||
}
|
}
|
||||||
$profiledata["network"] = NETWORK_DFRN;
|
$profiledata["network"] = NETWORK_DFRN;
|
||||||
|
|
@ -229,7 +230,7 @@ function display_content(App $a, $update = 0) {
|
||||||
$r = dba::fetch_first("SELECT `id`, `parent` FROM `item`
|
$r = dba::fetch_first("SELECT `id`, `parent` FROM `item`
|
||||||
WHERE `item`.`visible` AND NOT `item`.`deleted` AND NOT `item`.`moderated`
|
WHERE `item`.`visible` AND NOT `item`.`deleted` AND NOT `item`.`moderated`
|
||||||
AND `guid` = ? AND `uid` = ?", $a->argv[1], local_user());
|
AND `guid` = ? AND `uid` = ?", $a->argv[1], local_user());
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$item_id = $r["id"];
|
$item_id = $r["id"];
|
||||||
$item_parent = $r["parent"];
|
$item_parent = $r["parent"];
|
||||||
$nick = $a->user["nickname"];
|
$nick = $a->user["nickname"];
|
||||||
|
|
@ -243,7 +244,7 @@ function display_content(App $a, $update = 0) {
|
||||||
AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = ''
|
AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = ''
|
||||||
AND NOT `item`.`private` AND NOT `user`.`hidewall`
|
AND NOT `item`.`private` AND NOT `user`.`hidewall`
|
||||||
AND `item`.`guid` = ?", $a->argv[1]);
|
AND `item`.`guid` = ?", $a->argv[1]);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$item_id = $r["id"];
|
$item_id = $r["id"];
|
||||||
$item_parent = $r["parent"];
|
$item_parent = $r["parent"];
|
||||||
$nick = $r["nickname"];
|
$nick = $r["nickname"];
|
||||||
|
|
@ -256,7 +257,7 @@ function display_content(App $a, $update = 0) {
|
||||||
AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = ''
|
AND `item`.`deny_cid` = '' AND `item`.`deny_gid` = ''
|
||||||
AND NOT `item`.`private` AND `item`.`uid` = 0
|
AND NOT `item`.`private` AND `item`.`uid` = 0
|
||||||
AND `item`.`guid` = ?", $a->argv[1]);
|
AND `item`.`guid` = ?", $a->argv[1]);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$item_id = $r["id"];
|
$item_id = $r["id"];
|
||||||
$item_parent = $r["parent"];
|
$item_parent = $r["parent"];
|
||||||
}
|
}
|
||||||
|
|
@ -266,7 +267,7 @@ function display_content(App $a, $update = 0) {
|
||||||
|
|
||||||
if ($item_id && !is_numeric($item_id)) {
|
if ($item_id && !is_numeric($item_id)) {
|
||||||
$r = dba::select('item', array('id', 'parent'), array('uri' => $item_id, 'uid' => $a->profile['uid']), array('limit' => 1));
|
$r = dba::select('item', array('id', 'parent'), array('uri' => $item_id, 'uid' => $a->profile['uid']), array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$item_id = $r["id"];
|
$item_id = $r["id"];
|
||||||
$item_parent = $r["parent"];
|
$item_parent = $r["parent"];
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -316,7 +317,7 @@ function display_content(App $a, $update = 0) {
|
||||||
$contact_id,
|
$contact_id,
|
||||||
$a->profile['uid']
|
$a->profile['uid']
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact = $r;
|
$contact = $r;
|
||||||
$remote_contact = true;
|
$remote_contact = true;
|
||||||
}
|
}
|
||||||
|
|
@ -330,7 +331,7 @@ function display_content(App $a, $update = 0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = dba::fetch_first("SELECT * FROM `contact` WHERE `uid` = ? AND `self` LIMIT 1", $a->profile['uid']);
|
$r = dba::fetch_first("SELECT * FROM `contact` WHERE `uid` = ? AND `self` LIMIT 1", $a->profile['uid']);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->page_contact = $r;
|
$a->page_contact = $r;
|
||||||
}
|
}
|
||||||
$is_owner = ((local_user()) && (local_user() == $a->profile['profile_uid']) ? true : false);
|
$is_owner = ((local_user()) && (local_user() == $a->profile['profile_uid']) ? true : false);
|
||||||
|
|
@ -379,7 +380,7 @@ function display_content(App $a, $update = 0) {
|
||||||
$item_id
|
$item_id
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r) && local_user()) {
|
if (!DBM::is_result($r) && local_user()) {
|
||||||
// Check if this is another person's link to a post that we have
|
// Check if this is another person's link to a post that we have
|
||||||
$r = dba::fetch_first("SELECT `item`.uri FROM `item`
|
$r = dba::fetch_first("SELECT `item`.uri FROM `item`
|
||||||
WHERE (`item`.`id` = ? OR `item`.`uri` = ?)
|
WHERE (`item`.`id` = ? OR `item`.`uri` = ?)
|
||||||
|
|
@ -387,7 +388,7 @@ function display_content(App $a, $update = 0) {
|
||||||
$item_id,
|
$item_id,
|
||||||
$item_id
|
$item_id
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$item_uri = $r['uri'];
|
$item_uri = $r['uri'];
|
||||||
|
|
||||||
$r = dba::p(item_query()." AND `item`.`uid` = ?
|
$r = dba::p(item_query()." AND `item`.`uid` = ?
|
||||||
|
|
@ -400,12 +401,12 @@ function display_content(App $a, $update = 0) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$s = dba::inArray($r);
|
$s = dba::inArray($r);
|
||||||
|
|
||||||
if ((local_user()) && (local_user() == $a->profile['uid'])) {
|
if ((local_user()) && (local_user() == $a->profile['uid'])) {
|
||||||
$unseen = dba::select('item', array('id'), array('parent' => $s[0]['parent'], 'unseen' => true), array('limit' => 1));
|
$unseen = dba::select('item', array('id'), array('parent' => $s[0]['parent'], 'unseen' => true), array('limit' => 1));
|
||||||
if (dbm::is_result($unseen)) {
|
if (DBM::is_result($unseen)) {
|
||||||
dba::update('item', array('unseen' => false), array('parent' => $s[0]['parent'], 'unseen' => true));
|
dba::update('item', array('unseen' => false), array('parent' => $s[0]['parent'], 'unseen' => true));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -477,7 +478,7 @@ function display_content(App $a, $update = 0) {
|
||||||
$item_id,
|
$item_id,
|
||||||
$item_id
|
$item_id
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if ($r['deleted']) {
|
if ($r['deleted']) {
|
||||||
notice(t('Item has been removed.') . EOL);
|
notice(t('Item has been removed.') . EOL);
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -491,7 +492,7 @@ function display_content(App $a, $update = 0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function displayShowFeed($item_id, $conversation) {
|
function displayShowFeed($item_id, $conversation) {
|
||||||
$xml = Dfrn::itemFeed($item_id, $conversation);
|
$xml = DFRN::itemFeed($item_id, $conversation);
|
||||||
if ($xml == '') {
|
if ($xml == '') {
|
||||||
http_status_exit(500);
|
http_status_exit(500);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/acl_selectors.php');
|
require_once('include/acl_selectors.php');
|
||||||
|
|
||||||
|
|
@ -27,7 +28,7 @@ function editpost_content(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($itm)) {
|
if (! DBM::is_result($itm)) {
|
||||||
notice( t('Item not found') . EOL);
|
notice( t('Item not found') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -72,7 +73,7 @@ function editpost_content(App $a) {
|
||||||
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d AND `server` != '' LIMIT 1",
|
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d AND `server` != '' LIMIT 1",
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$mail_enabled = true;
|
$mail_enabled = true;
|
||||||
if(intval($r[0]['pubmail']))
|
if(intval($r[0]['pubmail']))
|
||||||
$pubmail_enabled = true;
|
$pubmail_enabled = true;
|
||||||
|
|
|
||||||
|
|
@ -8,6 +8,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/bbcode.php';
|
require_once 'include/bbcode.php';
|
||||||
require_once 'include/datetime.php';
|
require_once 'include/datetime.php';
|
||||||
|
|
@ -339,7 +340,7 @@ function events_content(App $a) {
|
||||||
|
|
||||||
$links = array();
|
$links = array();
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$r = sort_by_date($r);
|
$r = sort_by_date($r);
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$j = (($rr['adjust']) ? datetime_convert('UTC', date_default_timezone_get(), $rr['start'], 'j') : datetime_convert('UTC', 'UTC', $rr['start'], 'j'));
|
$j = (($rr['adjust']) ? datetime_convert('UTC', date_default_timezone_get(), $rr['start'], 'j') : datetime_convert('UTC', 'UTC', $rr['start'], 'j'));
|
||||||
|
|
@ -352,7 +353,7 @@ function events_content(App $a) {
|
||||||
$events = array();
|
$events = array();
|
||||||
|
|
||||||
// transform the event in a usable array
|
// transform the event in a usable array
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$r = sort_by_date($r);
|
$r = sort_by_date($r);
|
||||||
$events = process_events($r);
|
$events = process_events($r);
|
||||||
}
|
}
|
||||||
|
|
@ -410,7 +411,7 @@ function events_content(App $a) {
|
||||||
intval($event_id),
|
intval($event_id),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$orig_event = $r[0];
|
$orig_event = $r[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -545,7 +546,7 @@ function events_content(App $a) {
|
||||||
$ev = event_by_id(local_user(), $params);
|
$ev = event_by_id(local_user(), $params);
|
||||||
|
|
||||||
// Delete only real events (no birthdays)
|
// Delete only real events (no birthdays)
|
||||||
if (dbm::is_result($ev) && $ev[0]['type'] == 'event') {
|
if (DBM::is_result($ev) && $ev[0]['type'] == 'event') {
|
||||||
$del = drop_item($ev[0]['itemid'], false);
|
$del = drop_item($ev[0]['itemid'], false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function friendica_init(App $a) {
|
function friendica_init(App $a) {
|
||||||
if ($a->argv[1] == "json"){
|
if ($a->argv[1] == "json"){
|
||||||
|
|
@ -27,7 +28,7 @@ function friendica_init(App $a) {
|
||||||
$visible_plugins = array();
|
$visible_plugins = array();
|
||||||
if (is_array($a->plugins) && count($a->plugins)) {
|
if (is_array($a->plugins) && count($a->plugins)) {
|
||||||
$r = q("SELECT * FROM `addon` WHERE `hidden` = 0");
|
$r = q("SELECT * FROM `addon` WHERE `hidden` = 0");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach($r as $rr) {
|
foreach($r as $rr) {
|
||||||
$visible_plugins[] = $rr['name'];
|
$visible_plugins[] = $rr['name'];
|
||||||
}
|
}
|
||||||
|
|
@ -85,7 +86,7 @@ function friendica_content(App $a) {
|
||||||
$visible_plugins = array();
|
$visible_plugins = array();
|
||||||
if (is_array($a->plugins) && count($a->plugins)) {
|
if (is_array($a->plugins) && count($a->plugins)) {
|
||||||
$r = q("SELECT * FROM `addon` WHERE `hidden` = 0");
|
$r = q("SELECT * FROM `addon` WHERE `hidden` = 0");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach($r as $rr) {
|
foreach($r as $rr) {
|
||||||
$visible_plugins[] = $rr['name'];
|
$visible_plugins[] = $rr['name'];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function fsuggest_post(App $a) {
|
function fsuggest_post(App $a) {
|
||||||
|
|
||||||
|
|
@ -19,7 +20,7 @@ function fsuggest_post(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Contact not found.') . EOL);
|
notice( t('Contact not found.') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -36,7 +37,7 @@ function fsuggest_post(App $a) {
|
||||||
intval($new_contact),
|
intval($new_contact),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
$x = q("INSERT INTO `fsuggest` ( `uid`,`cid`,`name`,`url`,`request`,`photo`,`note`,`created`)
|
$x = q("INSERT INTO `fsuggest` ( `uid`,`cid`,`name`,`url`,`request`,`photo`,`note`,`created`)
|
||||||
VALUES ( %d, %d, '%s','%s','%s','%s','%s','%s')",
|
VALUES ( %d, %d, '%s','%s','%s','%s','%s','%s')",
|
||||||
|
|
@ -53,7 +54,7 @@ function fsuggest_post(App $a) {
|
||||||
dbesc($hash),
|
dbesc($hash),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$fsuggest_id = $r[0]['id'];
|
$fsuggest_id = $r[0]['id'];
|
||||||
q("UPDATE `fsuggest` SET `note` = '%s' WHERE `id` = %d AND `uid` = %d",
|
q("UPDATE `fsuggest` SET `note` = '%s' WHERE `id` = %d AND `uid` = %d",
|
||||||
dbesc($note),
|
dbesc($note),
|
||||||
|
|
@ -91,7 +92,7 @@ function fsuggest_content(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Contact not found.') . EOL);
|
notice( t('Contact not found.') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -9,6 +9,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function group_init(App $a) {
|
function group_init(App $a) {
|
||||||
if (local_user()) {
|
if (local_user()) {
|
||||||
|
|
@ -49,7 +50,7 @@ function group_post(App $a) {
|
||||||
intval($a->argv[1]),
|
intval($a->argv[1]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice(t('Group not found.') . EOL);
|
notice(t('Group not found.') . EOL);
|
||||||
goaway(System::baseUrl() . '/contacts');
|
goaway(System::baseUrl() . '/contacts');
|
||||||
return; // NOTREACHED
|
return; // NOTREACHED
|
||||||
|
|
@ -116,7 +117,7 @@ function group_content(App $a) {
|
||||||
|
|
||||||
$result = null;
|
$result = null;
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$result = group_rmv(local_user(), $r[0]['name']);
|
$result = group_rmv(local_user(), $r[0]['name']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -137,7 +138,7 @@ function group_content(App $a) {
|
||||||
intval($a->argv[2]),
|
intval($a->argv[2]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$change = intval($a->argv[2]);
|
$change = intval($a->argv[2]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -151,7 +152,7 @@ function group_content(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice(t('Group not found.') . EOL);
|
notice(t('Group not found.') . EOL);
|
||||||
goaway(System::baseUrl() . '/contacts');
|
goaway(System::baseUrl() . '/contacts');
|
||||||
}
|
}
|
||||||
|
|
@ -240,7 +241,7 @@ function group_content(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
// Format the data of the contacts who aren't in the contact group
|
// Format the data of the contacts who aren't in the contact group
|
||||||
foreach ($r as $member) {
|
foreach ($r as $member) {
|
||||||
if (! in_array($member['id'], $preselected)) {
|
if (! in_array($member['id'], $preselected)) {
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function ignored_init(App $a) {
|
function ignored_init(App $a) {
|
||||||
|
|
||||||
|
|
@ -21,7 +22,7 @@ function ignored_init(App $a) {
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
intval($message_id)
|
intval($message_id)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once "include/Photo.php";
|
require_once "include/Photo.php";
|
||||||
|
|
||||||
|
|
@ -133,7 +134,7 @@ function install_content(App $a) {
|
||||||
|
|
||||||
if (dba::$connected) {
|
if (dba::$connected) {
|
||||||
$r = q("SELECT COUNT(*) as `total` FROM `user`");
|
$r = q("SELECT COUNT(*) as `total` FROM `user`");
|
||||||
if (dbm::is_result($r) && $r[0]['total']) {
|
if (DBM::is_result($r) && $r[0]['total']) {
|
||||||
$tpl = get_markup_template('install.tpl');
|
$tpl = get_markup_template('install.tpl');
|
||||||
return replace_macros($tpl, array(
|
return replace_macros($tpl, array(
|
||||||
'$title' => $install_title,
|
'$title' => $install_title,
|
||||||
|
|
|
||||||
55
mod/item.php
55
mod/item.php
|
|
@ -19,6 +19,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
|
|
||||||
|
|
@ -107,7 +108,7 @@ function item_post(App $a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// if this isn't the real parent of the conversation, find it
|
// if this isn't the real parent of the conversation, find it
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$parid = $r[0]['parent'];
|
$parid = $r[0]['parent'];
|
||||||
$parent_uri = $r[0]['uri'];
|
$parent_uri = $r[0]['uri'];
|
||||||
if ($r[0]['id'] != $r[0]['parent']) {
|
if ($r[0]['id'] != $r[0]['parent']) {
|
||||||
|
|
@ -117,7 +118,7 @@ function item_post(App $a) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Unable to locate original post.') . EOL);
|
notice( t('Unable to locate original post.') . EOL);
|
||||||
if (x($_REQUEST, 'return')) {
|
if (x($_REQUEST, 'return')) {
|
||||||
goaway($return_path);
|
goaway($return_path);
|
||||||
|
|
@ -136,13 +137,13 @@ function item_post(App $a) {
|
||||||
intval($parent_item['contact-id']),
|
intval($parent_item['contact-id']),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$parent_contact = $r[0];
|
$parent_contact = $r[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
// If the contact id doesn't fit with the contact, then set the contact to null
|
// If the contact id doesn't fit with the contact, then set the contact to null
|
||||||
$thrparent = q("SELECT `author-link`, `network` FROM `item` WHERE `uri` = '%s' LIMIT 1", dbesc($thr_parent));
|
$thrparent = q("SELECT `author-link`, `network` FROM `item` WHERE `uri` = '%s' LIMIT 1", dbesc($thr_parent));
|
||||||
if (dbm::is_result($thrparent) && ($thrparent[0]["network"] === NETWORK_OSTATUS)
|
if (DBM::is_result($thrparent) && ($thrparent[0]["network"] === NETWORK_OSTATUS)
|
||||||
&& (normalise_link($parent_contact["url"]) != normalise_link($thrparent[0]["author-link"]))) {
|
&& (normalise_link($parent_contact["url"]) != normalise_link($thrparent[0]["author-link"]))) {
|
||||||
$parent_contact = get_contact_details_by_url($thrparent[0]["author-link"]);
|
$parent_contact = get_contact_details_by_url($thrparent[0]["author-link"]);
|
||||||
|
|
||||||
|
|
@ -184,7 +185,7 @@ function item_post(App $a) {
|
||||||
intval($profile_uid)
|
intval($profile_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger("Message with URI ".$message_id." already exists for user ".$profile_uid, LOGGER_DEBUG);
|
logger("Message with URI ".$message_id." already exists for user ".$profile_uid, LOGGER_DEBUG);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -226,7 +227,7 @@ function item_post(App $a) {
|
||||||
intval($profile_uid),
|
intval($profile_uid),
|
||||||
intval($post_id)
|
intval($post_id)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($i)) {
|
if (! DBM::is_result($i)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
$orig_post = $i[0];
|
$orig_post = $i[0];
|
||||||
|
|
@ -237,7 +238,7 @@ function item_post(App $a) {
|
||||||
$r = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1",
|
$r = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1",
|
||||||
intval($profile_uid)
|
intval($profile_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$user = $r[0];
|
$user = $r[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -335,7 +336,7 @@ function item_post(App $a) {
|
||||||
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d AND `server` != '' LIMIT 1",
|
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d AND `server` != '' LIMIT 1",
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r) && intval($r[0]['pubmail'])) {
|
if (DBM::is_result($r) && intval($r[0]['pubmail'])) {
|
||||||
$pubmail_enabled = true;
|
$pubmail_enabled = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -392,7 +393,7 @@ function item_post(App $a) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$author = $r[0];
|
$author = $r[0];
|
||||||
$contact_id = $author['id'];
|
$contact_id = $author['id'];
|
||||||
}
|
}
|
||||||
|
|
@ -405,7 +406,7 @@ function item_post(App $a) {
|
||||||
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND `self` = 1 LIMIT 1",
|
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND `self` = 1 LIMIT 1",
|
||||||
intval($profile_uid)
|
intval($profile_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact_record = $r[0];
|
$contact_record = $r[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -456,7 +457,7 @@ function item_post(App $a) {
|
||||||
intval($profile_uid)
|
intval($profile_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -488,7 +489,7 @@ function item_post(App $a) {
|
||||||
intval($profile_uid),
|
intval($profile_uid),
|
||||||
intval($attach)
|
intval($attach)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$r = q("UPDATE `attach` SET `allow_cid` = '%s', `allow_gid` = '%s', `deny_cid` = '%s', `deny_gid` = '%s'
|
$r = q("UPDATE `attach` SET `allow_cid` = '%s', `allow_gid` = '%s', `deny_cid` = '%s', `deny_gid` = '%s'
|
||||||
WHERE `uid` = %d AND `id` = %d",
|
WHERE `uid` = %d AND `id` = %d",
|
||||||
dbesc($str_contact_allow),
|
dbesc($str_contact_allow),
|
||||||
|
|
@ -558,7 +559,7 @@ function item_post(App $a) {
|
||||||
$toplevel_parent = q("SELECT `contact`.* FROM `contact`
|
$toplevel_parent = q("SELECT `contact`.* FROM `contact`
|
||||||
INNER JOIN `item` ON `item`.`contact-id` = `contact`.`id` AND `contact`.`url` = `item`.`author-link`
|
INNER JOIN `item` ON `item`.`contact-id` = `contact`.`id` AND `contact`.`url` = `item`.`author-link`
|
||||||
WHERE `item`.`id` = `item`.`parent` AND `item`.`parent` = %d", intval($parent));
|
WHERE `item`.`id` = `item`.`parent` AND `item`.`parent` = %d", intval($parent));
|
||||||
if (dbm::is_result($toplevel_parent)) {
|
if (DBM::is_result($toplevel_parent)) {
|
||||||
if (!empty($toplevel_parent[0]['addr'])) {
|
if (!empty($toplevel_parent[0]['addr'])) {
|
||||||
$toplevel_contact = '@' . $toplevel_parent[0]['addr'];
|
$toplevel_contact = '@' . $toplevel_parent[0]['addr'];
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -651,7 +652,7 @@ function item_post(App $a) {
|
||||||
intval($profile_uid),
|
intval($profile_uid),
|
||||||
intval($mtch)
|
intval($mtch)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if (strlen($attachments)) {
|
if (strlen($attachments)) {
|
||||||
$attachments .= ',';
|
$attachments .= ',';
|
||||||
}
|
}
|
||||||
|
|
@ -760,7 +761,7 @@ function item_post(App $a) {
|
||||||
$datarray['protocol'] = PROTOCOL_DFRN;
|
$datarray['protocol'] = PROTOCOL_DFRN;
|
||||||
|
|
||||||
$r = dba::fetch_first("SELECT `conversation-uri`, `conversation-href` FROM `conversation` WHERE `item-uri` = ?", $datarray['parent-uri']);
|
$r = dba::fetch_first("SELECT `conversation-uri`, `conversation-href` FROM `conversation` WHERE `item-uri` = ?", $datarray['parent-uri']);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if ($r['conversation-uri'] != '') {
|
if ($r['conversation-uri'] != '') {
|
||||||
$datarray['conversation-uri'] = $r['conversation-uri'];
|
$datarray['conversation-uri'] = $r['conversation-uri'];
|
||||||
}
|
}
|
||||||
|
|
@ -919,7 +920,7 @@ function item_post(App $a) {
|
||||||
intval($datarray['visible'])
|
intval($datarray['visible'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$post_id = dba::lastInsertId();
|
$post_id = dba::lastInsertId();
|
||||||
} else {
|
} else {
|
||||||
logger('mod_item: unable to create post.');
|
logger('mod_item: unable to create post.');
|
||||||
|
|
@ -1157,11 +1158,11 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
|
|
||||||
$r = q("SELECT `alias`, `name` FROM `contact` WHERE `nurl` = '%s' AND `alias` != '' AND `uid` = 0",
|
$r = q("SELECT `alias`, `name` FROM `contact` WHERE `nurl` = '%s' AND `alias` != '' AND `uid` = 0",
|
||||||
normalise_link($matches[1]));
|
normalise_link($matches[1]));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `alias`, `name` FROM `gcontact` WHERE `nurl` = '%s' AND `alias` != ''",
|
$r = q("SELECT `alias`, `name` FROM `gcontact` WHERE `nurl` = '%s' AND `alias` != ''",
|
||||||
normalise_link($matches[1]));
|
normalise_link($matches[1]));
|
||||||
}
|
}
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$data = $r[0];
|
$data = $r[0];
|
||||||
} else {
|
} else {
|
||||||
$data = Probe::uri($matches[1]);
|
$data = Probe::uri($matches[1]);
|
||||||
|
|
@ -1204,7 +1205,7 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
);
|
);
|
||||||
|
|
||||||
// Then check in the contact table for the url
|
// Then check in the contact table for the url
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network`, `notify`, `forum`, `prv` FROM `contact`
|
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network`, `notify`, `forum`, `prv` FROM `contact`
|
||||||
WHERE `nurl` = '%s' AND `uid` = %d AND
|
WHERE `nurl` = '%s' AND `uid` = %d AND
|
||||||
(`network` != '%s' OR (`notify` != '' AND `alias` != ''))
|
(`network` != '%s' OR (`notify` != '' AND `alias` != ''))
|
||||||
|
|
@ -1216,7 +1217,7 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
}
|
}
|
||||||
|
|
||||||
// Then check in the global contacts for the address
|
// Then check in the global contacts for the address
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `url`, `nick`, `name`, `alias`, `network`, `notify` FROM `gcontact`
|
$r = q("SELECT `url`, `nick`, `name`, `alias`, `network`, `notify` FROM `gcontact`
|
||||||
WHERE `addr` = '%s' AND (`network` != '%s' OR (`notify` != '' AND `alias` != ''))
|
WHERE `addr` = '%s' AND (`network` != '%s' OR (`notify` != '' AND `alias` != ''))
|
||||||
LIMIT 1",
|
LIMIT 1",
|
||||||
|
|
@ -1226,7 +1227,7 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
}
|
}
|
||||||
|
|
||||||
// Then check in the global contacts for the url
|
// Then check in the global contacts for the url
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `url`, `nick`, `name`, `alias`, `network`, `notify` FROM `gcontact`
|
$r = q("SELECT `url`, `nick`, `name`, `alias`, `network`, `notify` FROM `gcontact`
|
||||||
WHERE `nurl` = '%s' AND (`network` != '%s' OR (`notify` != '' AND `alias` != ''))
|
WHERE `nurl` = '%s' AND (`network` != '%s' OR (`notify` != '' AND `alias` != ''))
|
||||||
LIMIT 1",
|
LIMIT 1",
|
||||||
|
|
@ -1235,7 +1236,7 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$probed = Probe::uri($name);
|
$probed = Probe::uri($name);
|
||||||
if ($result['network'] != NETWORK_PHANTOM) {
|
if ($result['network'] != NETWORK_PHANTOM) {
|
||||||
update_gcontact($probed);
|
update_gcontact($probed);
|
||||||
|
|
@ -1256,7 +1257,7 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
}
|
}
|
||||||
|
|
||||||
// select someone by attag or nick and the name passed in the current network
|
// select someone by attag or nick and the name passed in the current network
|
||||||
if(!dbm::is_result($r) && ($network != ""))
|
if(!DBM::is_result($r) && ($network != ""))
|
||||||
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network` FROM `contact` WHERE `attag` = '%s' OR `nick` = '%s' AND `network` = '%s' AND `uid` = %d ORDER BY `attag` DESC LIMIT 1",
|
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network` FROM `contact` WHERE `attag` = '%s' OR `nick` = '%s' AND `network` = '%s' AND `uid` = %d ORDER BY `attag` DESC LIMIT 1",
|
||||||
dbesc($name),
|
dbesc($name),
|
||||||
dbesc($name),
|
dbesc($name),
|
||||||
|
|
@ -1265,7 +1266,7 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
);
|
);
|
||||||
|
|
||||||
//select someone from this user's contacts by name in the current network
|
//select someone from this user's contacts by name in the current network
|
||||||
if (!dbm::is_result($r) && ($network != "")) {
|
if (!DBM::is_result($r) && ($network != "")) {
|
||||||
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network` FROM `contact` WHERE `name` = '%s' AND `network` = '%s' AND `uid` = %d LIMIT 1",
|
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network` FROM `contact` WHERE `name` = '%s' AND `network` = '%s' AND `uid` = %d LIMIT 1",
|
||||||
dbesc($name),
|
dbesc($name),
|
||||||
dbesc($network),
|
dbesc($network),
|
||||||
|
|
@ -1274,7 +1275,7 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
}
|
}
|
||||||
|
|
||||||
// select someone by attag or nick and the name passed in
|
// select someone by attag or nick and the name passed in
|
||||||
if(!dbm::is_result($r)) {
|
if(!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network` FROM `contact` WHERE `attag` = '%s' OR `nick` = '%s' AND `uid` = %d ORDER BY `attag` DESC LIMIT 1",
|
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network` FROM `contact` WHERE `attag` = '%s' OR `nick` = '%s' AND `uid` = %d ORDER BY `attag` DESC LIMIT 1",
|
||||||
dbesc($name),
|
dbesc($name),
|
||||||
dbesc($name),
|
dbesc($name),
|
||||||
|
|
@ -1283,7 +1284,7 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
}
|
}
|
||||||
|
|
||||||
// select someone from this user's contacts by name
|
// select someone from this user's contacts by name
|
||||||
if(!dbm::is_result($r)) {
|
if(!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network` FROM `contact` WHERE `name` = '%s' AND `uid` = %d LIMIT 1",
|
$r = q("SELECT `id`, `url`, `nick`, `name`, `alias`, `network` FROM `contact` WHERE `name` = '%s' AND `uid` = %d LIMIT 1",
|
||||||
dbesc($name),
|
dbesc($name),
|
||||||
intval($profile_uid)
|
intval($profile_uid)
|
||||||
|
|
@ -1291,7 +1292,7 @@ function handle_tag(App $a, &$body, &$inform, &$str_tags, $profile_uid, $tag, $n
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if (strlen($inform) && (isset($r[0]["notify"]) || isset($r[0]["id"]))) {
|
if (strlen($inform) && (isset($r[0]["notify"]) || isset($r[0]["id"]))) {
|
||||||
$inform .= ',';
|
$inform .= ',';
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function lockview_content(App $a) {
|
function lockview_content(App $a) {
|
||||||
|
|
||||||
|
|
@ -22,7 +23,7 @@ function lockview_content(App $a) {
|
||||||
dbesc($type),
|
dbesc($type),
|
||||||
intval($item_id)
|
intval($item_id)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
$item = $r[0];
|
$item = $r[0];
|
||||||
|
|
@ -54,7 +55,7 @@ function lockview_content(App $a) {
|
||||||
$r = q("SELECT `name` FROM `group` WHERE `id` IN ( %s )",
|
$r = q("SELECT `name` FROM `group` WHERE `id` IN ( %s )",
|
||||||
dbesc(implode(', ', $allowed_groups))
|
dbesc(implode(', ', $allowed_groups))
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
$l[] = '<b>' . $rr['name'] . '</b>';
|
$l[] = '<b>' . $rr['name'] . '</b>';
|
||||||
}
|
}
|
||||||
|
|
@ -62,7 +63,7 @@ function lockview_content(App $a) {
|
||||||
$r = q("SELECT `name` FROM `contact` WHERE `id` IN ( %s )",
|
$r = q("SELECT `name` FROM `contact` WHERE `id` IN ( %s )",
|
||||||
dbesc(implode(', ',$allowed_users))
|
dbesc(implode(', ',$allowed_users))
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
$l[] = $rr['name'];
|
$l[] = $rr['name'];
|
||||||
|
|
||||||
|
|
@ -72,7 +73,7 @@ function lockview_content(App $a) {
|
||||||
$r = q("SELECT `name` FROM `group` WHERE `id` IN ( %s )",
|
$r = q("SELECT `name` FROM `group` WHERE `id` IN ( %s )",
|
||||||
dbesc(implode(', ', $deny_groups))
|
dbesc(implode(', ', $deny_groups))
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
$l[] = '<b><strike>' . $rr['name'] . '</strike></b>';
|
$l[] = '<b><strike>' . $rr['name'] . '</strike></b>';
|
||||||
}
|
}
|
||||||
|
|
@ -80,7 +81,7 @@ function lockview_content(App $a) {
|
||||||
$r = q("SELECT `name` FROM `contact` WHERE `id` IN ( %s )",
|
$r = q("SELECT `name` FROM `contact` WHERE `id` IN ( %s )",
|
||||||
dbesc(implode(', ',$deny_users))
|
dbesc(implode(', ',$deny_users))
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
$l[] = '<strike>' . $rr['name'] . '</strike>';
|
$l[] = '<strike>' . $rr['name'] . '</strike>';
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/email.php');
|
require_once('include/email.php');
|
||||||
require_once('include/enotify.php');
|
require_once('include/enotify.php');
|
||||||
|
|
@ -18,7 +19,7 @@ function lostpass_post(App $a) {
|
||||||
dbesc($loginame)
|
dbesc($loginame)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('No valid account found.') . EOL);
|
notice( t('No valid account found.') . EOL);
|
||||||
goaway(System::baseUrl());
|
goaway(System::baseUrl());
|
||||||
}
|
}
|
||||||
|
|
@ -90,7 +91,7 @@ function lostpass_content(App $a) {
|
||||||
$r = q("SELECT * FROM `user` WHERE `pwdreset` = '%s' LIMIT 1",
|
$r = q("SELECT * FROM `user` WHERE `pwdreset` = '%s' LIMIT 1",
|
||||||
dbesc($hash)
|
dbesc($hash)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$o = t("Request could not be verified. \x28You may have previously submitted it.\x29 Password reset failed.");
|
$o = t("Request could not be verified. \x28You may have previously submitted it.\x29 Password reset failed.");
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
@ -106,7 +107,7 @@ function lostpass_content(App $a) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
/// @TODO Is dbm::is_result() okay here?
|
/// @TODO Is DBM::is_result() okay here?
|
||||||
if ($r) {
|
if ($r) {
|
||||||
$tpl = get_markup_template('pwdreset.tpl');
|
$tpl = get_markup_template('pwdreset.tpl');
|
||||||
$o .= replace_macros($tpl,array(
|
$o .= replace_macros($tpl,array(
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once("include/text.php");
|
require_once("include/text.php");
|
||||||
|
|
||||||
|
|
@ -18,7 +19,7 @@ function manage_post(App $a) {
|
||||||
$r = q("select * from user where uid = %d limit 1",
|
$r = q("select * from user where uid = %d limit 1",
|
||||||
intval($_SESSION['submanage'])
|
intval($_SESSION['submanage'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$uid = intval($r[0]['uid']);
|
$uid = intval($r[0]['uid']);
|
||||||
$orig_record = $r[0];
|
$orig_record = $r[0];
|
||||||
}
|
}
|
||||||
|
|
@ -38,7 +39,7 @@ function manage_post(App $a) {
|
||||||
$limited_id = 0;
|
$limited_id = 0;
|
||||||
$original_id = $uid;
|
$original_id = $uid;
|
||||||
|
|
||||||
if (dbm::is_result($submanage)) {
|
if (DBM::is_result($submanage)) {
|
||||||
foreach ($submanage as $m) {
|
foreach ($submanage as $m) {
|
||||||
if ($identity == $m['mid']) {
|
if ($identity == $m['mid']) {
|
||||||
$limited_id = $m['mid'];
|
$limited_id = $m['mid'];
|
||||||
|
|
@ -59,7 +60,7 @@ function manage_post(App $a) {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -128,21 +129,21 @@ function manage_content(App $a) {
|
||||||
$r = q("SELECT DISTINCT(`parent`) FROM `notify` WHERE `uid` = %d AND NOT `seen` AND NOT (`type` IN (%d, %d))",
|
$r = q("SELECT DISTINCT(`parent`) FROM `notify` WHERE `uid` = %d AND NOT `seen` AND NOT (`type` IN (%d, %d))",
|
||||||
intval($id['uid']), intval(NOTIFY_INTRO), intval(NOTIFY_MAIL));
|
intval($id['uid']), intval(NOTIFY_INTRO), intval(NOTIFY_MAIL));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$notifications = sizeof($r);
|
$notifications = sizeof($r);
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = q("SELECT DISTINCT(`convid`) FROM `mail` WHERE `uid` = %d AND NOT `seen`",
|
$r = q("SELECT DISTINCT(`convid`) FROM `mail` WHERE `uid` = %d AND NOT `seen`",
|
||||||
intval($id['uid']));
|
intval($id['uid']));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$notifications = $notifications + sizeof($r);
|
$notifications = $notifications + sizeof($r);
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = q("SELECT COUNT(*) AS `introductions` FROM `intro` WHERE NOT `blocked` AND NOT `ignore` AND `uid` = %d",
|
$r = q("SELECT COUNT(*) AS `introductions` FROM `intro` WHERE NOT `blocked` AND NOT `ignore` AND `uid` = %d",
|
||||||
intval($id['uid']));
|
intval($id['uid']));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$notifications = $notifications + $r[0]["introductions"];
|
$notifications = $notifications + $r[0]["introductions"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/text.php');
|
require_once('include/text.php');
|
||||||
require_once('include/socgraph.php');
|
require_once('include/socgraph.php');
|
||||||
|
|
@ -33,7 +34,7 @@ function match_content(App $a) {
|
||||||
$r = q("SELECT `pub_keywords`, `prv_keywords` FROM `profile` WHERE `is-default` = 1 AND `uid` = %d LIMIT 1",
|
$r = q("SELECT `pub_keywords`, `prv_keywords` FROM `profile` WHERE `is-default` = 1 AND `uid` = %d LIMIT 1",
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if(! $r[0]['pub_keywords'] && (! $r[0]['prv_keywords'])) {
|
if(! $r[0]['pub_keywords'] && (! $r[0]['prv_keywords'])) {
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/acl_selectors.php');
|
require_once('include/acl_selectors.php');
|
||||||
require_once('include/message.php');
|
require_once('include/message.php');
|
||||||
|
|
@ -231,7 +232,7 @@ function message_content(App $a) {
|
||||||
intval($a->argv[2]),
|
intval($a->argv[2]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$parent = $r[0]['parent-uri'];
|
$parent = $r[0]['parent-uri'];
|
||||||
$convid = $r[0]['convid'];
|
$convid = $r[0]['convid'];
|
||||||
|
|
||||||
|
|
@ -288,21 +289,21 @@ function message_content(App $a) {
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
intval($a->argv[2])
|
intval($a->argv[2])
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `name`, `url`, `id` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s' LIMIT 1",
|
$r = q("SELECT `name`, `url`, `id` FROM `contact` WHERE `uid` = %d AND `nurl` = '%s' LIMIT 1",
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
dbesc(normalise_link(base64_decode($a->argv[2])))
|
dbesc(normalise_link(base64_decode($a->argv[2])))
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$r = q("SELECT `name`, `url`, `id` FROM `contact` WHERE `uid` = %d AND `addr` = '%s' LIMIT 1",
|
$r = q("SELECT `name`, `url`, `id` FROM `contact` WHERE `uid` = %d AND `addr` = '%s' LIMIT 1",
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
dbesc(base64_decode($a->argv[2]))
|
dbesc(base64_decode($a->argv[2]))
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$prename = $r[0]['name'];
|
$prename = $r[0]['name'];
|
||||||
$preurl = $r[0]['url'];
|
$preurl = $r[0]['url'];
|
||||||
$preid = $r[0]['id'];
|
$preid = $r[0]['id'];
|
||||||
|
|
@ -354,13 +355,13 @@ function message_content(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->set_pager_total($r[0]['total']);
|
$a->set_pager_total($r[0]['total']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = get_messages(local_user(), $a->pager['start'], $a->pager['itemspage']);
|
$r = get_messages(local_user(), $a->pager['start'], $a->pager['itemspage']);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
info( t('No messages.') . EOL);
|
info( t('No messages.') . EOL);
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
@ -382,7 +383,7 @@ function message_content(App $a) {
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
intval($a->argv[1])
|
intval($a->argv[1])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact_id = $r[0]['contact-id'];
|
$contact_id = $r[0]['contact-id'];
|
||||||
$convid = $r[0]['convid'];
|
$convid = $r[0]['convid'];
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('library/asn1.php');
|
require_once('library/asn1.php');
|
||||||
|
|
||||||
|
|
@ -14,7 +15,7 @@ function modexp_init(App $a) {
|
||||||
dbesc($nick)
|
dbesc($nick)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/security.php');
|
require_once('include/security.php');
|
||||||
require_once('include/bbcode.php');
|
require_once('include/bbcode.php');
|
||||||
|
|
@ -40,7 +41,7 @@ function mood_init(App $a) {
|
||||||
intval($parent),
|
intval($parent),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$parent_uri = $r[0]['uri'];
|
$parent_uri = $r[0]['uri'];
|
||||||
$private = $r[0]['private'];
|
$private = $r[0]['private'];
|
||||||
$allow_cid = $r[0]['allow_cid'];
|
$allow_cid = $r[0]['allow_cid'];
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function msearch_post(App $a) {
|
function msearch_post(App $a) {
|
||||||
|
|
||||||
|
|
@ -17,7 +18,7 @@ function msearch_post(App $a) {
|
||||||
dbesc($search)
|
dbesc($search)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$total = $r[0]['total'];
|
$total = $r[0]['total'];
|
||||||
|
|
||||||
$results = array();
|
$results = array();
|
||||||
|
|
@ -28,7 +29,7 @@ function msearch_post(App $a) {
|
||||||
intval($perpage)
|
intval($perpage)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
$results[] = array(
|
$results[] = array(
|
||||||
'name' => $rr['name'],
|
'name' => $rr['name'],
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/conversation.php';
|
require_once 'include/conversation.php';
|
||||||
require_once 'include/group.php';
|
require_once 'include/group.php';
|
||||||
|
|
@ -497,9 +498,9 @@ function networkThreadedView(App $a, $update = 0) {
|
||||||
$rawmode = (isset($_GET["mode"]) AND ($_GET["mode"] == "raw"));
|
$rawmode = (isset($_GET["mode"]) AND ($_GET["mode"] == "raw"));
|
||||||
|
|
||||||
if (isset($_GET["last_received"]) && isset($_GET["last_commented"]) && isset($_GET["last_created"]) && isset($_GET["last_id"])) {
|
if (isset($_GET["last_received"]) && isset($_GET["last_commented"]) && isset($_GET["last_created"]) && isset($_GET["last_id"])) {
|
||||||
$last_received = dbm::date($_GET["last_received"]);
|
$last_received = DBM::date($_GET["last_received"]);
|
||||||
$last_commented = dbm::date($_GET["last_commented"]);
|
$last_commented = DBM::date($_GET["last_commented"]);
|
||||||
$last_created = dbm::date($_GET["last_created"]);
|
$last_created = DBM::date($_GET["last_created"]);
|
||||||
$last_id = intval($_GET["last_id"]);
|
$last_id = intval($_GET["last_id"]);
|
||||||
} else {
|
} else {
|
||||||
$last_received = '';
|
$last_received = '';
|
||||||
|
|
@ -575,7 +576,7 @@ function networkThreadedView(App $a, $update = 0) {
|
||||||
// If $cid belongs to a communitity forum or a privat goup,.add a mention to the status editor
|
// If $cid belongs to a communitity forum or a privat goup,.add a mention to the status editor
|
||||||
$condition = array("`id` = ? AND (`forum` OR `prv`)", $cid);
|
$condition = array("`id` = ? AND (`forum` OR `prv`)", $cid);
|
||||||
$contact = dba::select('contact', array('addr', 'nick'), $condition, array('limit' => 1));
|
$contact = dba::select('contact', array('addr', 'nick'), $condition, array('limit' => 1));
|
||||||
if (dbm::is_result($contact)) {
|
if (DBM::is_result($contact)) {
|
||||||
if ($contact["addr"] != '') {
|
if ($contact["addr"] != '') {
|
||||||
$content = "!".$contact["addr"];
|
$content = "!".$contact["addr"];
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -628,7 +629,7 @@ function networkThreadedView(App $a, $update = 0) {
|
||||||
|
|
||||||
if ($group) {
|
if ($group) {
|
||||||
$r = dba::select('group', array('name'), array('id' => $group, 'uid' => $_SESSION['uid']), array('limit' => 1));
|
$r = dba::select('group', array('name'), array('id' => $group, 'uid' => $_SESSION['uid']), array('limit' => 1));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
if ($update)
|
if ($update)
|
||||||
killme();
|
killme();
|
||||||
notice(t('No such group') . EOL);
|
notice(t('No such group') . EOL);
|
||||||
|
|
@ -643,7 +644,7 @@ function networkThreadedView(App $a, $update = 0) {
|
||||||
|
|
||||||
$contact_str = implode(',',$contacts);
|
$contact_str = implode(',',$contacts);
|
||||||
$self = dba::select('contact', array('id'), array('uid' => $_SESSION['uid'], 'self' => true), array('limit' => 1));
|
$self = dba::select('contact', array('id'), array('uid' => $_SESSION['uid'], 'self' => true), array('limit' => 1));
|
||||||
if (dbm::is_result($self)) {
|
if (DBM::is_result($self)) {
|
||||||
$contact_str_self = $self["id"];
|
$contact_str_self = $self["id"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -664,7 +665,7 @@ function networkThreadedView(App $a, $update = 0) {
|
||||||
'forum', 'prv', 'contact-type', 'addr', 'thumb', 'location');
|
'forum', 'prv', 'contact-type', 'addr', 'thumb', 'location');
|
||||||
$condition = array("`id` = ? AND (NOT `blocked` OR `pending`)", $cid);
|
$condition = array("`id` = ? AND (NOT `blocked` OR `pending`)", $cid);
|
||||||
$r = dba::select('contact', $fields, $condition, array('limit' => 1));
|
$r = dba::select('contact', $fields, $condition, array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$sql_extra = " AND ".$sql_table.".`contact-id` = ".intval($cid);
|
$sql_extra = " AND ".$sql_table.".`contact-id` = ".intval($cid);
|
||||||
|
|
||||||
$entries[0] = array(
|
$entries[0] = array(
|
||||||
|
|
@ -808,7 +809,7 @@ function networkThreadedView(App $a, $update = 0) {
|
||||||
$parents_str = '';
|
$parents_str = '';
|
||||||
$date_offset = "";
|
$date_offset = "";
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if (!in_array($rr['item_id'],$parents_arr)) {
|
if (!in_array($rr['item_id'],$parents_arr)) {
|
||||||
$parents_arr[] = $rr['item_id'];
|
$parents_arr[] = $rr['item_id'];
|
||||||
|
|
@ -835,7 +836,7 @@ function networkThreadedView(App $a, $update = 0) {
|
||||||
$parents
|
$parents
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($thread_items)) {
|
if (DBM::is_result($thread_items)) {
|
||||||
$items = array_merge($items, dba::inArray($thread_items));
|
$items = array_merge($items, dba::inArray($thread_items));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/Contact.php');
|
require_once('include/Contact.php');
|
||||||
require_once('include/socgraph.php');
|
require_once('include/socgraph.php');
|
||||||
|
|
@ -32,11 +33,11 @@ function nogroup_content(App $a) {
|
||||||
|
|
||||||
require_once('include/Contact.php');
|
require_once('include/Contact.php');
|
||||||
$r = contacts_not_grouped(local_user());
|
$r = contacts_not_grouped(local_user());
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->set_pager_total($r[0]['total']);
|
$a->set_pager_total($r[0]['total']);
|
||||||
}
|
}
|
||||||
$r = contacts_not_grouped(local_user(),$a->pager['start'],$a->pager['itemspage']);
|
$r = contacts_not_grouped(local_user(),$a->pager['start'],$a->pager['itemspage']);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
|
|
||||||
$contact_details = get_contact_details_by_url($rr['url'], local_user(), $rr);
|
$contact_details = get_contact_details_by_url($rr['url'], local_user(), $rr);
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function noscrape_init(App $a) {
|
function noscrape_init(App $a) {
|
||||||
|
|
||||||
|
|
@ -48,7 +49,7 @@ function noscrape_init(App $a) {
|
||||||
/// @todo What should this value tell us?
|
/// @todo What should this value tell us?
|
||||||
$r = q("SELECT `gcontact`.`updated` FROM `contact` INNER JOIN `gcontact` WHERE `gcontact`.`nurl` = `contact`.`nurl` AND `self` AND `uid` = %d LIMIT 1",
|
$r = q("SELECT `gcontact`.`updated` FROM `contact` INNER JOIN `gcontact` WHERE `gcontact`.`nurl` = `contact`.`nurl` AND `self` AND `uid` = %d LIMIT 1",
|
||||||
intval($a->profile['uid']));
|
intval($a->profile['uid']));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$json_info["updated"] = date("c", strtotime($r[0]['updated']));
|
$json_info["updated"] = date("c", strtotime($r[0]['updated']));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -59,7 +60,7 @@ function noscrape_init(App $a) {
|
||||||
dbesc(NETWORK_DIASPORA),
|
dbesc(NETWORK_DIASPORA),
|
||||||
dbesc(NETWORK_OSTATUS)
|
dbesc(NETWORK_OSTATUS)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$json_info["contacts"] = intval($r[0]['total']);
|
$json_info["contacts"] = intval($r[0]['total']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -68,13 +69,13 @@ function noscrape_init(App $a) {
|
||||||
$last_active = 0;
|
$last_active = 0;
|
||||||
$condition = array('uid' => $a->profile['uid'], 'self' => true);
|
$condition = array('uid' => $a->profile['uid'], 'self' => true);
|
||||||
$contact = dba::select('contact', array('last-item'), $condition, array('limit' => 1));
|
$contact = dba::select('contact', array('last-item'), $condition, array('limit' => 1));
|
||||||
if (dbm::is_result($contact)) {
|
if (DBM::is_result($contact)) {
|
||||||
$last_active = strtotime($contact['last-item']);
|
$last_active = strtotime($contact['last-item']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$condition = array('uid' => $a->profile['uid']);
|
$condition = array('uid' => $a->profile['uid']);
|
||||||
$user = dba::select('user', array('login_date'), $condition, array('limit' => 1));
|
$user = dba::select('user', array('login_date'), $condition, array('limit' => 1));
|
||||||
if (dbm::is_result($user)) {
|
if (DBM::is_result($user)) {
|
||||||
if ($last_active < strtotime($user['login_date'])) {
|
if ($last_active < strtotime($user['login_date'])) {
|
||||||
$last_active = strtotime($user['login_date']);
|
$last_active = strtotime($user['login_date']);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function notes_init(App $a) {
|
function notes_init(App $a) {
|
||||||
|
|
||||||
|
|
@ -85,7 +86,7 @@ function notes_content(App $a, $update = false) {
|
||||||
|
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->set_pager_total($r[0]['total']);
|
$a->set_pager_total($r[0]['total']);
|
||||||
$a->set_pager_itemspage(40);
|
$a->set_pager_itemspage(40);
|
||||||
}
|
}
|
||||||
|
|
@ -105,7 +106,7 @@ function notes_content(App $a, $update = false) {
|
||||||
$parents_arr = array();
|
$parents_arr = array();
|
||||||
$parents_str = '';
|
$parents_str = '';
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
$parents_arr[] = $rr['item_id'];
|
$parents_arr[] = $rr['item_id'];
|
||||||
$parents_str = implode(', ', $parents_arr);
|
$parents_str = implode(', ', $parents_arr);
|
||||||
|
|
@ -119,7 +120,7 @@ function notes_content(App $a, $update = false) {
|
||||||
dbesc($parents_str)
|
dbesc($parents_str)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$items = conv_sort($r,"`commented`");
|
$items = conv_sort($r,"`commented`");
|
||||||
|
|
||||||
$o .= conversation($a,$items,'notes',$update);
|
$o .= conversation($a,$items,'notes',$update);
|
||||||
|
|
|
||||||
|
|
@ -4,12 +4,13 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function notice_init(App $a) {
|
function notice_init(App $a) {
|
||||||
|
|
||||||
$id = $a->argv[1];
|
$id = $a->argv[1];
|
||||||
$r = q("SELECT `user`.`nickname` FROM `user` LEFT JOIN `item` ON `item`.`uid` = `user`.`uid` WHERE `item`.`id` = %d", intval($id));
|
$r = q("SELECT `user`.`nickname` FROM `user` LEFT JOIN `item` ON `item`.`uid` = `user`.`uid` WHERE `item`.`id` = %d", intval($id));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$nick = $r[0]['nickname'];
|
$nick = $r[0]['nickname'];
|
||||||
$url = System::baseUrl() . "/display/$nick/$id";
|
$url = System::baseUrl() . "/display/$nick/$id";
|
||||||
goaway($url);
|
goaway($url);
|
||||||
|
|
|
||||||
|
|
@ -8,6 +8,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\NotificationsManager;
|
use Friendica\Core\NotificationsManager;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once("include/contact_selectors.php");
|
require_once("include/contact_selectors.php");
|
||||||
require_once("include/network.php");
|
require_once("include/network.php");
|
||||||
|
|
@ -30,7 +31,7 @@ function notifications_post(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$intro_id = $r[0]['id'];
|
$intro_id = $r[0]['id'];
|
||||||
$contact_id = $r[0]['contact-id'];
|
$contact_id = $r[0]['contact-id'];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\NotificationsManager;
|
use Friendica\Core\NotificationsManager;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function notify_init(App $a) {
|
function notify_init(App $a) {
|
||||||
if (! local_user()) {
|
if (! local_user()) {
|
||||||
|
|
@ -55,7 +56,7 @@ function notify_content(App $a) {
|
||||||
require_once('include/bbcode.php');
|
require_once('include/bbcode.php');
|
||||||
|
|
||||||
$r = $nm->getAll(array('seen'=>0));
|
$r = $nm->getAll(array('seen'=>0));
|
||||||
if (dbm::is_result($r) > 0) {
|
if (DBM::is_result($r) > 0) {
|
||||||
foreach ($r as $it) {
|
foreach ($r as $it) {
|
||||||
$notif_content .= replace_macros($not_tpl,array(
|
$notif_content .= replace_macros($not_tpl,array(
|
||||||
'$item_link' => System::baseUrl(true).'/notify/view/'. $it['id'],
|
'$item_link' => System::baseUrl(true).'/notify/view/'. $it['id'],
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('library/openid.php');
|
require_once('library/openid.php');
|
||||||
|
|
||||||
|
|
@ -40,7 +41,7 @@ function openid_content(App $a) {
|
||||||
dbesc($authid), dbesc(normalise_openid($authid))
|
dbesc($authid), dbesc(normalise_openid($authid))
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
// successful OpenID login
|
// successful OpenID login
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@ This file is part of the Diaspora protocol. It is used for fetching single publi
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
|
|
||||||
function p_init($a){
|
function p_init($a){
|
||||||
|
|
@ -51,7 +52,7 @@ function p_init($a){
|
||||||
$r = q("SELECT `user`.`prvkey`, `contact`.`addr`, `user`.`nickname`, `contact`.`nick` FROM `user`
|
$r = q("SELECT `user`.`prvkey`, `contact`.`addr`, `user`.`nickname`, `contact`.`nick` FROM `user`
|
||||||
INNER JOIN `contact` ON `contact`.`uid` = `user`.`uid` AND `contact`.`self`
|
INNER JOIN `contact` ON `contact`.`uid` = `user`.`uid` AND `contact`.`self`
|
||||||
WHERE `user`.`uid` = %d", intval($item[0]["uid"]));
|
WHERE `user`.`uid` = %d", intval($item[0]["uid"]));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
header($_SERVER["SERVER_PROTOCOL"].' 404 '.t('Not Found'));
|
header($_SERVER["SERVER_PROTOCOL"].' 404 '.t('Not Found'));
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/security.php');
|
require_once('include/security.php');
|
||||||
require_once('include/Photo.php');
|
require_once('include/Photo.php');
|
||||||
|
|
@ -80,7 +81,7 @@ function photo_init(App $a) {
|
||||||
intval($resolution),
|
intval($resolution),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$data = $r[0]['data'];
|
$data = $r[0]['data'];
|
||||||
$mimetype = $r[0]['type'];
|
$mimetype = $r[0]['type'];
|
||||||
}
|
}
|
||||||
|
|
@ -111,7 +112,7 @@ function photo_init(App $a) {
|
||||||
dbesc($photo),
|
dbesc($photo),
|
||||||
intval($resolution)
|
intval($resolution)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
$sql_extra = permissions_sql($r[0]['uid']);
|
$sql_extra = permissions_sql($r[0]['uid']);
|
||||||
|
|
||||||
|
|
@ -122,9 +123,9 @@ function photo_init(App $a) {
|
||||||
intval($resolution)
|
intval($resolution)
|
||||||
);
|
);
|
||||||
|
|
||||||
$public = (dbm::is_result($r)) && ($r[0]['allow_cid'] == '') && ($r[0]['allow_gid'] == '') && ($r[0]['deny_cid'] == '') && ($r[0]['deny_gid'] == '');
|
$public = (DBM::is_result($r)) && ($r[0]['allow_cid'] == '') && ($r[0]['allow_gid'] == '') && ($r[0]['deny_cid'] == '') && ($r[0]['deny_gid'] == '');
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$resolution = $r[0]['scale'];
|
$resolution = $r[0]['scale'];
|
||||||
$data = $r[0]['data'];
|
$data = $r[0]['data'];
|
||||||
$mimetype = $r[0]['type'];
|
$mimetype = $r[0]['type'];
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
|
|
||||||
require_once 'include/Photo.php';
|
require_once 'include/Photo.php';
|
||||||
|
|
@ -34,7 +35,7 @@ function photos_init(App $a) {
|
||||||
dbesc($nick)
|
dbesc($nick)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($user)) {
|
if (! DBM::is_result($user)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -158,7 +159,7 @@ function photos_post(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$can_post = true;
|
$can_post = true;
|
||||||
$visitor = $contact_id;
|
$visitor = $contact_id;
|
||||||
}
|
}
|
||||||
|
|
@ -176,7 +177,7 @@ function photos_post(App $a) {
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Contact information unavailable') . EOL);
|
notice( t('Contact information unavailable') . EOL);
|
||||||
logger('photos_post: unable to locate contact record for page owner. uid=' . $page_owner_uid);
|
logger('photos_post: unable to locate contact record for page owner. uid=' . $page_owner_uid);
|
||||||
killme();
|
killme();
|
||||||
|
|
@ -197,7 +198,7 @@ function photos_post(App $a) {
|
||||||
dbesc($album),
|
dbesc($album),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
notice( t('Album not found.') . EOL);
|
notice( t('Album not found.') . EOL);
|
||||||
goaway($_SESSION['photo_return']);
|
goaway($_SESSION['photo_return']);
|
||||||
return; // NOTREACHED
|
return; // NOTREACHED
|
||||||
|
|
@ -268,7 +269,7 @@ function photos_post(App $a) {
|
||||||
dbesc($album)
|
dbesc($album)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$res[] = "'" . dbesc($rr['rid']) . "'" ;
|
$res[] = "'" . dbesc($rr['rid']) . "'" ;
|
||||||
}
|
}
|
||||||
|
|
@ -290,7 +291,7 @@ function photos_post(App $a) {
|
||||||
$r = q("SELECT `parent-uri` FROM `item` WHERE `resource-id` IN ( $str_res ) AND `uid` = %d",
|
$r = q("SELECT `parent-uri` FROM `item` WHERE `resource-id` IN ( $str_res ) AND `uid` = %d",
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
q("UPDATE `item` SET `deleted` = 1, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d",
|
q("UPDATE `item` SET `deleted` = 1, `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d",
|
||||||
dbesc(datetime_convert()),
|
dbesc(datetime_convert()),
|
||||||
|
|
@ -356,7 +357,7 @@ function photos_post(App $a) {
|
||||||
dbesc($a->argv[2])
|
dbesc($a->argv[2])
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
q("DELETE FROM `photo` WHERE `uid` = %d AND `resource-id` = '%s'",
|
q("DELETE FROM `photo` WHERE `uid` = %d AND `resource-id` = '%s'",
|
||||||
intval($page_owner_uid),
|
intval($page_owner_uid),
|
||||||
dbesc($r[0]['resource-id'])
|
dbesc($r[0]['resource-id'])
|
||||||
|
|
@ -365,7 +366,7 @@ function photos_post(App $a) {
|
||||||
dbesc($r[0]['resource-id']),
|
dbesc($r[0]['resource-id']),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($i)) {
|
if (DBM::is_result($i)) {
|
||||||
q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d",
|
q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d",
|
||||||
dbesc(datetime_convert()),
|
dbesc(datetime_convert()),
|
||||||
dbesc(datetime_convert()),
|
dbesc(datetime_convert()),
|
||||||
|
|
@ -418,7 +419,7 @@ function photos_post(App $a) {
|
||||||
dbesc($resource_id),
|
dbesc($resource_id),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$ph = new Photo($r[0]['data'], $r[0]['type']);
|
$ph = new Photo($r[0]['data'], $r[0]['type']);
|
||||||
if ($ph->is_valid()) {
|
if ($ph->is_valid()) {
|
||||||
$rotate_deg = ( (intval($_POST['rotate']) == 1) ? 270 : 90 );
|
$rotate_deg = ( (intval($_POST['rotate']) == 1) ? 270 : 90 );
|
||||||
|
|
@ -470,7 +471,7 @@ function photos_post(App $a) {
|
||||||
dbesc($resource_id),
|
dbesc($resource_id),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($p)) {
|
if (DBM::is_result($p)) {
|
||||||
$ext = $phototypes[$p[0]['type']];
|
$ext = $phototypes[$p[0]['type']];
|
||||||
$r = q("UPDATE `photo` SET `desc` = '%s', `album` = '%s', `allow_cid` = '%s', `allow_gid` = '%s', `deny_cid` = '%s', `deny_gid` = '%s' WHERE `resource-id` = '%s' AND `uid` = %d",
|
$r = q("UPDATE `photo` SET `desc` = '%s', `album` = '%s', `allow_cid` = '%s', `allow_gid` = '%s', `deny_cid` = '%s', `deny_gid` = '%s' WHERE `resource-id` = '%s' AND `uid` = %d",
|
||||||
dbesc($desc),
|
dbesc($desc),
|
||||||
|
|
@ -541,7 +542,7 @@ function photos_post(App $a) {
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$old_tag = $r[0]['tag'];
|
$old_tag = $r[0]['tag'];
|
||||||
$old_inform = $r[0]['inform'];
|
$old_inform = $r[0]['inform'];
|
||||||
}
|
}
|
||||||
|
|
@ -608,7 +609,7 @@ function photos_post(App $a) {
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
//select someone by attag or nick and the name passed in
|
//select someone by attag or nick and the name passed in
|
||||||
$r = q("SELECT * FROM `contact` WHERE `attag` = '%s' OR `nick` = '%s' AND `uid` = %d ORDER BY `attag` DESC LIMIT 1",
|
$r = q("SELECT * FROM `contact` WHERE `attag` = '%s' OR `nick` = '%s' AND `uid` = %d ORDER BY `attag` DESC LIMIT 1",
|
||||||
dbesc($name),
|
dbesc($name),
|
||||||
|
|
@ -618,7 +619,7 @@ function photos_post(App $a) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$newname = $r[0]['name'];
|
$newname = $r[0]['name'];
|
||||||
$profile = $r[0]['url'];
|
$profile = $r[0]['url'];
|
||||||
$notify = 'cid:' . $r[0]['id'];
|
$notify = 'cid:' . $r[0]['id'];
|
||||||
|
|
@ -775,7 +776,7 @@ function photos_post(App $a) {
|
||||||
dbesc($album),
|
dbesc($album),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
if ((! dbm::is_result($r)) || ($album == t('Profile Photos'))) {
|
if ((! DBM::is_result($r)) || ($album == t('Profile Photos'))) {
|
||||||
$visible = 1;
|
$visible = 1;
|
||||||
} else {
|
} else {
|
||||||
$visible = 0;
|
$visible = 0;
|
||||||
|
|
@ -1030,7 +1031,7 @@ function photos_content(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($owner_uid)
|
intval($owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$can_post = true;
|
$can_post = true;
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
$remote_contact = true;
|
$remote_contact = true;
|
||||||
|
|
@ -1058,7 +1059,7 @@ function photos_content(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($owner_uid)
|
intval($owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
$remote_contact = true;
|
$remote_contact = true;
|
||||||
}
|
}
|
||||||
|
|
@ -1205,7 +1206,7 @@ function photos_content(App $a) {
|
||||||
intval($owner_uid),
|
intval($owner_uid),
|
||||||
dbesc($album)
|
dbesc($album)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->set_pager_total(count($r));
|
$a->set_pager_total(count($r));
|
||||||
$a->set_pager_itemspage(20);
|
$a->set_pager_itemspage(20);
|
||||||
}
|
}
|
||||||
|
|
@ -1264,7 +1265,7 @@ function photos_content(App $a) {
|
||||||
|
|
||||||
$photos = array();
|
$photos = array();
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$twist = 'rotright';
|
$twist = 'rotright';
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if ($twist == 'rotright') {
|
if ($twist == 'rotright') {
|
||||||
|
|
@ -1326,13 +1327,13 @@ function photos_content(App $a) {
|
||||||
dbesc($datum)
|
dbesc($datum)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($ph)) {
|
if (! DBM::is_result($ph)) {
|
||||||
$ph = q("SELECT `id` FROM `photo` WHERE `uid` = %d AND `resource-id` = '%s'
|
$ph = q("SELECT `id` FROM `photo` WHERE `uid` = %d AND `resource-id` = '%s'
|
||||||
LIMIT 1",
|
LIMIT 1",
|
||||||
intval($owner_uid),
|
intval($owner_uid),
|
||||||
dbesc($datum)
|
dbesc($datum)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($ph)) {
|
if (DBM::is_result($ph)) {
|
||||||
notice(t('Permission denied. Access to this item may be restricted.'));
|
notice(t('Permission denied. Access to this item may be restricted.'));
|
||||||
} else {
|
} else {
|
||||||
notice(t('Photo not available') . EOL );
|
notice(t('Photo not available') . EOL );
|
||||||
|
|
@ -1358,7 +1359,7 @@ function photos_content(App $a) {
|
||||||
intval($owner_uid)
|
intval($owner_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($prvnxt)) {
|
if (DBM::is_result($prvnxt)) {
|
||||||
foreach ($prvnxt as $z => $entry) {
|
foreach ($prvnxt as $z => $entry) {
|
||||||
if ($entry['resource-id'] == $ph[0]['resource-id']) {
|
if ($entry['resource-id'] == $ph[0]['resource-id']) {
|
||||||
$prv = $z - 1;
|
$prv = $z - 1;
|
||||||
|
|
@ -1449,7 +1450,7 @@ function photos_content(App $a) {
|
||||||
|
|
||||||
$map = null;
|
$map = null;
|
||||||
|
|
||||||
if (dbm::is_result($linked_items)) {
|
if (DBM::is_result($linked_items)) {
|
||||||
$link_item = $linked_items[0];
|
$link_item = $linked_items[0];
|
||||||
|
|
||||||
$r = q("SELECT COUNT(*) AS `total`
|
$r = q("SELECT COUNT(*) AS `total`
|
||||||
|
|
@ -1464,7 +1465,7 @@ function photos_content(App $a) {
|
||||||
|
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->set_pager_total($r[0]['total']);
|
$a->set_pager_total($r[0]['total']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1607,7 +1608,7 @@ function photos_content(App $a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$comments = '';
|
$comments = '';
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
if (($can_post || can_write_wall($a, $owner_uid)) && $link_item['last-child']) {
|
if (($can_post || can_write_wall($a, $owner_uid)) && $link_item['last-child']) {
|
||||||
$comments .= replace_macros($cmnt_tpl, array(
|
$comments .= replace_macros($cmnt_tpl, array(
|
||||||
'$return_path' => '',
|
'$return_path' => '',
|
||||||
|
|
@ -1641,7 +1642,7 @@ function photos_content(App $a) {
|
||||||
);
|
);
|
||||||
|
|
||||||
// display comments
|
// display comments
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
foreach ($r as $item) {
|
foreach ($r as $item) {
|
||||||
builtin_activity_puller($item, $conv_responses);
|
builtin_activity_puller($item, $conv_responses);
|
||||||
|
|
@ -1815,7 +1816,7 @@ function photos_content(App $a) {
|
||||||
dbesc('Contact Photos'),
|
dbesc('Contact Photos'),
|
||||||
dbesc( t('Contact Photos'))
|
dbesc( t('Contact Photos'))
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->set_pager_total(count($r));
|
$a->set_pager_total(count($r));
|
||||||
$a->set_pager_itemspage(20);
|
$a->set_pager_itemspage(20);
|
||||||
}
|
}
|
||||||
|
|
@ -1833,7 +1834,7 @@ function photos_content(App $a) {
|
||||||
);
|
);
|
||||||
|
|
||||||
$photos = array();
|
$photos = array();
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$twist = 'rotright';
|
$twist = 'rotright';
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
//hide profile photos to others
|
//hide profile photos to others
|
||||||
|
|
|
||||||
23
mod/ping.php
23
mod/ping.php
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/datetime.php');
|
require_once('include/datetime.php');
|
||||||
require_once('include/bbcode.php');
|
require_once('include/bbcode.php');
|
||||||
|
|
@ -130,7 +131,7 @@ function ping_init(App $a)
|
||||||
intval(local_user()), intval(local_user())
|
intval(local_user()), intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($items_unseen)) {
|
if (DBM::is_result($items_unseen)) {
|
||||||
$arr = array('items' => $items_unseen);
|
$arr = array('items' => $items_unseen);
|
||||||
call_hooks('network_ping', $arr);
|
call_hooks('network_ping', $arr);
|
||||||
|
|
||||||
|
|
@ -147,7 +148,7 @@ function ping_init(App $a)
|
||||||
if (intval(feature_enabled(local_user(), 'groups'))) {
|
if (intval(feature_enabled(local_user(), 'groups'))) {
|
||||||
// Find out how unseen network posts are spread across groups
|
// Find out how unseen network posts are spread across groups
|
||||||
$group_counts = groups_count_unseen();
|
$group_counts = groups_count_unseen();
|
||||||
if (dbm::is_result($group_counts)) {
|
if (DBM::is_result($group_counts)) {
|
||||||
foreach ($group_counts as $group_count) {
|
foreach ($group_counts as $group_count) {
|
||||||
if ($group_count['count'] > 0) {
|
if ($group_count['count'] > 0) {
|
||||||
$groups_unseen[] = $group_count;
|
$groups_unseen[] = $group_count;
|
||||||
|
|
@ -158,7 +159,7 @@ function ping_init(App $a)
|
||||||
|
|
||||||
if (intval(feature_enabled(local_user(), 'forumlist_widget'))) {
|
if (intval(feature_enabled(local_user(), 'forumlist_widget'))) {
|
||||||
$forum_counts = ForumManager::count_unseen_items();
|
$forum_counts = ForumManager::count_unseen_items();
|
||||||
if (dbm::is_result($forums_counts)) {
|
if (DBM::is_result($forums_counts)) {
|
||||||
foreach ($forums_counts as $forum_count) {
|
foreach ($forums_counts as $forum_count) {
|
||||||
if ($forum_count['count'] > 0) {
|
if ($forum_count['count'] > 0) {
|
||||||
$forums_unseen[] = $forum_count;
|
$forums_unseen[] = $forum_count;
|
||||||
|
|
@ -197,7 +198,7 @@ function ping_init(App $a)
|
||||||
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'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -212,12 +213,12 @@ function ping_init(App $a)
|
||||||
dbesc(datetime_convert('UTC', 'UTC', 'now + 7 days')),
|
dbesc(datetime_convert('UTC', 'UTC', 'now + 7 days')),
|
||||||
dbesc(datetime_convert('UTC', 'UTC', 'now'))
|
dbesc(datetime_convert('UTC', 'UTC', 'now'))
|
||||||
);
|
);
|
||||||
if (dbm::is_result($ev)) {
|
if (DBM::is_result($ev)) {
|
||||||
Cache::set($cachekey, $ev, CACHE_HOUR);
|
Cache::set($cachekey, $ev, CACHE_HOUR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($ev)) {
|
if (DBM::is_result($ev)) {
|
||||||
$all_events = count($ev);
|
$all_events = count($ev);
|
||||||
|
|
||||||
if ($all_events) {
|
if ($all_events) {
|
||||||
|
|
@ -255,7 +256,7 @@ function ping_init(App $a)
|
||||||
$data['birthdays'] = $birthdays;
|
$data['birthdays'] = $birthdays;
|
||||||
$data['birthdays-today'] = $birthdays_today;
|
$data['birthdays-today'] = $birthdays_today;
|
||||||
|
|
||||||
if (dbm::is_result($notifs)) {
|
if (DBM::is_result($notifs)) {
|
||||||
foreach ($notifs as $notif) {
|
foreach ($notifs as $notif) {
|
||||||
if ($notif['seen'] == 0) {
|
if ($notif['seen'] == 0) {
|
||||||
$sysnotify_count ++;
|
$sysnotify_count ++;
|
||||||
|
|
@ -264,7 +265,7 @@ function ping_init(App $a)
|
||||||
}
|
}
|
||||||
|
|
||||||
// merge all notification types in one array
|
// merge all notification types in one array
|
||||||
if (dbm::is_result($intros)) {
|
if (DBM::is_result($intros)) {
|
||||||
foreach ($intros as $intro) {
|
foreach ($intros as $intro) {
|
||||||
$notif = array(
|
$notif = array(
|
||||||
'href' => System::baseUrl() . '/notifications/intros/' . $intro['id'],
|
'href' => System::baseUrl() . '/notifications/intros/' . $intro['id'],
|
||||||
|
|
@ -279,7 +280,7 @@ function ping_init(App $a)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($mails)) {
|
if (DBM::is_result($mails)) {
|
||||||
foreach ($mails as $mail) {
|
foreach ($mails as $mail) {
|
||||||
$notif = array(
|
$notif = array(
|
||||||
'href' => System::baseUrl() . '/message/' . $mail['id'],
|
'href' => System::baseUrl() . '/message/' . $mail['id'],
|
||||||
|
|
@ -294,7 +295,7 @@ function ping_init(App $a)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($regs)) {
|
if (DBM::is_result($regs)) {
|
||||||
foreach ($regs as $reg) {
|
foreach ($regs as $reg) {
|
||||||
$notif = array(
|
$notif = array(
|
||||||
'href' => System::baseUrl() . '/admin/users/',
|
'href' => System::baseUrl() . '/admin/users/',
|
||||||
|
|
@ -330,7 +331,7 @@ function ping_init(App $a)
|
||||||
};
|
};
|
||||||
usort($notifs, $sort_function);
|
usort($notifs, $sort_function);
|
||||||
|
|
||||||
if (dbm::is_result($notifs)) {
|
if (DBM::is_result($notifs)) {
|
||||||
// Are the nofications called from the regular process or via the friendica app?
|
// Are the nofications called from the regular process or via the friendica app?
|
||||||
$regularnotifications = (intval($_GET['uid']) && intval($_GET['_']));
|
$regularnotifications = (intval($_GET['uid']) && intval($_GET['_']));
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function poco_init(App $a) {
|
function poco_init(App $a) {
|
||||||
$system_mode = false;
|
$system_mode = false;
|
||||||
|
|
@ -18,7 +19,7 @@ function poco_init(App $a) {
|
||||||
}
|
}
|
||||||
if (! x($user)) {
|
if (! x($user)) {
|
||||||
$c = q("SELECT * FROM `pconfig` WHERE `cat` = 'system' AND `k` = 'suggestme' AND `v` = 1");
|
$c = q("SELECT * FROM `pconfig` WHERE `cat` = 'system' AND `k` = 'suggestme' AND `v` = 1");
|
||||||
if (! dbm::is_result($c)) {
|
if (! DBM::is_result($c)) {
|
||||||
http_status_exit(401);
|
http_status_exit(401);
|
||||||
}
|
}
|
||||||
$system_mode = true;
|
$system_mode = true;
|
||||||
|
|
@ -60,7 +61,7 @@ function poco_init(App $a) {
|
||||||
where `user`.`nickname` = '%s' and `profile`.`is-default` = 1 limit 1",
|
where `user`.`nickname` = '%s' and `profile`.`is-default` = 1 limit 1",
|
||||||
dbesc($user)
|
dbesc($user)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($users) || $users[0]['hidewall'] || $users[0]['hide-friends']) {
|
if (! DBM::is_result($users) || $users[0]['hidewall'] || $users[0]['hide-friends']) {
|
||||||
http_status_exit(404);
|
http_status_exit(404);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -100,7 +101,7 @@ function poco_init(App $a) {
|
||||||
dbesc(NETWORK_STATUSNET)
|
dbesc(NETWORK_STATUSNET)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (dbm::is_result($contacts)) {
|
if (DBM::is_result($contacts)) {
|
||||||
$totalResults = intval($contacts[0]['total']);
|
$totalResults = intval($contacts[0]['total']);
|
||||||
} else {
|
} else {
|
||||||
$totalResults = 0;
|
$totalResults = 0;
|
||||||
|
|
@ -195,7 +196,7 @@ function poco_init(App $a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_array($contacts)) {
|
if (is_array($contacts)) {
|
||||||
if (dbm::is_result($contacts)) {
|
if (DBM::is_result($contacts)) {
|
||||||
foreach ($contacts as $contact) {
|
foreach ($contacts as $contact) {
|
||||||
if (! isset($contact['generation'])) {
|
if (! isset($contact['generation'])) {
|
||||||
if ($global) {
|
if ($global) {
|
||||||
|
|
|
||||||
|
|
@ -17,6 +17,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/security.php');
|
require_once('include/security.php');
|
||||||
require_once('include/bbcode.php');
|
require_once('include/bbcode.php');
|
||||||
|
|
@ -59,7 +60,7 @@ function poke_init(App $a) {
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
logger('poke: no contact ' . $contact_id);
|
logger('poke: no contact ' . $contact_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -73,7 +74,7 @@ function poke_init(App $a) {
|
||||||
intval($parent),
|
intval($parent),
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$parent_uri = $r[0]['uri'];
|
$parent_uri = $r[0]['uri'];
|
||||||
$private = $r[0]['private'];
|
$private = $r[0]['private'];
|
||||||
$allow_cid = $r[0]['allow_cid'];
|
$allow_cid = $r[0]['allow_cid'];
|
||||||
|
|
@ -166,7 +167,7 @@ function poke_content(App $a) {
|
||||||
intval($_GET['c']),
|
intval($_GET['c']),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$name = $r[0]['name'];
|
$name = $r[0]['name'];
|
||||||
$id = $r[0]['id'];
|
$id = $r[0]['id'];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/salmon.php');
|
require_once('include/salmon.php');
|
||||||
require_once('include/crypto.php');
|
require_once('include/crypto.php');
|
||||||
|
|
@ -24,7 +25,7 @@ function post_post(App $a) {
|
||||||
AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
||||||
dbesc($nickname)
|
dbesc($nickname)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
http_status_exit(500);
|
http_status_exit(500);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/contact_widgets.php');
|
require_once('include/contact_widgets.php');
|
||||||
require_once('include/redir.php');
|
require_once('include/redir.php');
|
||||||
|
|
@ -17,7 +18,7 @@ function profile_init(App $a) {
|
||||||
$which = htmlspecialchars($a->argv[1]);
|
$which = htmlspecialchars($a->argv[1]);
|
||||||
else {
|
else {
|
||||||
$r = q("select nickname from user where blocked = 0 and account_expired = 0 and account_removed = 0 and verified = 1 order by rand() limit 1");
|
$r = q("select nickname from user where blocked = 0 and account_expired = 0 and account_removed = 0 and verified = 1 order by rand() limit 1");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
goaway(System::baseUrl() . '/profile/' . $r[0]['nickname']);
|
goaway(System::baseUrl() . '/profile/' . $r[0]['nickname']);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
@ -139,7 +140,7 @@ function profile_content(App $a, $update = 0) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($a->profile['profile_uid'])
|
intval($a->profile['profile_uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
$remote_contact = true;
|
$remote_contact = true;
|
||||||
}
|
}
|
||||||
|
|
@ -240,7 +241,7 @@ function profile_content(App $a, $update = 0) {
|
||||||
intval($a->profile['profile_uid'])
|
intval($a->profile['profile_uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return '';
|
return '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -267,7 +268,7 @@ function profile_content(App $a, $update = 0) {
|
||||||
intval(PAGE_COMMUNITY),
|
intval(PAGE_COMMUNITY),
|
||||||
intval(PAGE_PRVGROUP));
|
intval(PAGE_PRVGROUP));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$sql_extra3 = sprintf(" AND `thread`.`contact-id` = %d ", intval(intval($a->profile['contact_id'])));
|
$sql_extra3 = sprintf(" AND `thread`.`contact-id` = %d ", intval(intval($a->profile['contact_id'])));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -313,7 +314,7 @@ function profile_content(App $a, $update = 0) {
|
||||||
// search for new items (update routine)
|
// search for new items (update routine)
|
||||||
$_SESSION['last_updated'][$last_updated_key] = time();
|
$_SESSION['last_updated'][$last_updated_key] = time();
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
$parents_arr[] = $rr['item_id'];
|
$parents_arr[] = $rr['item_id'];
|
||||||
$parents_str = implode(', ', $parents_arr);
|
$parents_str = implode(', ', $parents_arr);
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once("include/Photo.php");
|
require_once("include/Photo.php");
|
||||||
|
|
||||||
|
|
@ -35,7 +36,7 @@ function profile_photo_post(App $a) {
|
||||||
intval($_REQUEST['profile']),
|
intval($_REQUEST['profile']),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r) && (! intval($r[0]['is-default'])))
|
if (DBM::is_result($r) && (! intval($r[0]['is-default'])))
|
||||||
$is_default_profile = 0;
|
$is_default_profile = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -66,7 +67,7 @@ function profile_photo_post(App $a) {
|
||||||
dbesc(local_user()),
|
dbesc(local_user()),
|
||||||
intval($scale));
|
intval($scale));
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
$base_image = $r[0];
|
$base_image = $r[0];
|
||||||
|
|
||||||
|
|
@ -202,7 +203,7 @@ function profile_photo_content(App $a) {
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
dbesc($resource_id)
|
dbesc($resource_id)
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r)){
|
if (!DBM::is_result($r)){
|
||||||
notice( t('Permission denied.') . EOL );
|
notice( t('Permission denied.') . EOL );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@ use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Network\Probe;
|
use Friendica\Network\Probe;
|
||||||
|
|
||||||
require_once 'include/Contact.php';
|
require_once 'include/Contact.php';
|
||||||
|
|
@ -23,7 +24,7 @@ function profiles_init(App $a) {
|
||||||
intval($a->argv[2]),
|
intval($a->argv[2]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Profile not found.') . EOL);
|
notice( t('Profile not found.') . EOL);
|
||||||
goaway('profiles');
|
goaway('profiles');
|
||||||
return; // NOTREACHED
|
return; // NOTREACHED
|
||||||
|
|
@ -42,7 +43,7 @@ function profiles_init(App $a) {
|
||||||
intval($a->argv[2]),
|
intval($a->argv[2]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
info(t('Profile deleted.').EOL);
|
info(t('Profile deleted.').EOL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -57,7 +58,7 @@ function profiles_init(App $a) {
|
||||||
$r0 = q("SELECT `id` FROM `profile` WHERE `uid` = %d",
|
$r0 = q("SELECT `id` FROM `profile` WHERE `uid` = %d",
|
||||||
intval(local_user()));
|
intval(local_user()));
|
||||||
|
|
||||||
$num_profiles = (dbm::is_result($r0) ? count($r0) : 0);
|
$num_profiles = (DBM::is_result($r0) ? count($r0) : 0);
|
||||||
|
|
||||||
$name = t('Profile-') . ($num_profiles + 1);
|
$name = t('Profile-') . ($num_profiles + 1);
|
||||||
|
|
||||||
|
|
@ -79,7 +80,7 @@ function profiles_init(App $a) {
|
||||||
);
|
);
|
||||||
|
|
||||||
info( t('New profile created.') . EOL);
|
info( t('New profile created.') . EOL);
|
||||||
if (dbm::is_result($r3) && count($r3) == 1) {
|
if (DBM::is_result($r3) && count($r3) == 1) {
|
||||||
goaway('profiles/' . $r3[0]['id']);
|
goaway('profiles/' . $r3[0]['id']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -93,14 +94,14 @@ function profiles_init(App $a) {
|
||||||
$r0 = q("SELECT `id` FROM `profile` WHERE `uid` = %d",
|
$r0 = q("SELECT `id` FROM `profile` WHERE `uid` = %d",
|
||||||
intval(local_user()));
|
intval(local_user()));
|
||||||
|
|
||||||
$num_profiles = (dbm::is_result($r0) ? count($r0) : 0);
|
$num_profiles = (DBM::is_result($r0) ? count($r0) : 0);
|
||||||
|
|
||||||
$name = t('Profile-') . ($num_profiles + 1);
|
$name = t('Profile-') . ($num_profiles + 1);
|
||||||
$r1 = q("SELECT * FROM `profile` WHERE `uid` = %d AND `id` = %d LIMIT 1",
|
$r1 = q("SELECT * FROM `profile` WHERE `uid` = %d AND `id` = %d LIMIT 1",
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
intval($a->argv[2])
|
intval($a->argv[2])
|
||||||
);
|
);
|
||||||
if(! dbm::is_result($r1)) {
|
if(! DBM::is_result($r1)) {
|
||||||
notice( t('Profile unavailable to clone.') . EOL);
|
notice( t('Profile unavailable to clone.') . EOL);
|
||||||
killme();
|
killme();
|
||||||
return;
|
return;
|
||||||
|
|
@ -118,7 +119,7 @@ function profiles_init(App $a) {
|
||||||
dbesc($name)
|
dbesc($name)
|
||||||
);
|
);
|
||||||
info( t('New profile created.') . EOL);
|
info( t('New profile created.') . EOL);
|
||||||
if ((dbm::is_result($r3)) && (count($r3) == 1)) {
|
if ((DBM::is_result($r3)) && (count($r3) == 1)) {
|
||||||
goaway('profiles/'.$r3[0]['id']);
|
goaway('profiles/'.$r3[0]['id']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -133,7 +134,7 @@ function profiles_init(App $a) {
|
||||||
intval($a->argv[1]),
|
intval($a->argv[1]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Profile not found.') . EOL);
|
notice( t('Profile not found.') . EOL);
|
||||||
killme();
|
killme();
|
||||||
return;
|
return;
|
||||||
|
|
@ -180,7 +181,7 @@ function profiles_post(App $a) {
|
||||||
intval($a->argv[1]),
|
intval($a->argv[1]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($orig)) {
|
if (! DBM::is_result($orig)) {
|
||||||
notice( t('Profile not found.') . EOL);
|
notice( t('Profile not found.') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -274,13 +275,13 @@ function profiles_post(App $a) {
|
||||||
dbesc($newname),
|
dbesc($newname),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$r = q("SELECT * FROM `contact` WHERE `nick` = '%s' AND `uid` = %d LIMIT 1",
|
$r = q("SELECT * FROM `contact` WHERE `nick` = '%s' AND `uid` = %d LIMIT 1",
|
||||||
dbesc($lookup),
|
dbesc($lookup),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$prf = $r[0]['url'];
|
$prf = $r[0]['url'];
|
||||||
$newname = $r[0]['name'];
|
$newname = $r[0]['name'];
|
||||||
}
|
}
|
||||||
|
|
@ -533,7 +534,7 @@ function profile_activity($changed, $value) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($self)) {
|
if (! DBM::is_result($self)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -616,7 +617,7 @@ function profiles_content(App $a) {
|
||||||
intval($a->argv[1]),
|
intval($a->argv[1]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Profile not found.') . EOL);
|
notice( t('Profile not found.') . EOL);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -757,7 +758,7 @@ function profiles_content(App $a) {
|
||||||
$r = q("SELECT * FROM `profile` WHERE `uid` = %d AND `is-default`=1",
|
$r = q("SELECT * FROM `profile` WHERE `uid` = %d AND `is-default`=1",
|
||||||
local_user()
|
local_user()
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
//Go to the default profile.
|
//Go to the default profile.
|
||||||
goaway('profiles/' . $r[0]['id']);
|
goaway('profiles/' . $r[0]['id']);
|
||||||
}
|
}
|
||||||
|
|
@ -766,7 +767,7 @@ function profiles_content(App $a) {
|
||||||
$r = q("SELECT * FROM `profile` WHERE `uid` = %d",
|
$r = q("SELECT * FROM `profile` WHERE `uid` = %d",
|
||||||
local_user());
|
local_user());
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
$tpl = get_markup_template('profile_entry.tpl');
|
$tpl = get_markup_template('profile_entry.tpl');
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function profperm_init(App $a) {
|
function profperm_init(App $a) {
|
||||||
|
|
||||||
|
|
@ -45,7 +46,7 @@ function profperm_content(App $a) {
|
||||||
intval($a->argv[2]),
|
intval($a->argv[2]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$change = intval($a->argv[2]);
|
$change = intval($a->argv[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -55,7 +56,7 @@ function profperm_content(App $a) {
|
||||||
intval($a->argv[1]),
|
intval($a->argv[1]),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('Invalid profile identifier.') . EOL );
|
notice( t('Invalid profile identifier.') . EOL );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -67,7 +68,7 @@ function profperm_content(App $a) {
|
||||||
);
|
);
|
||||||
|
|
||||||
$ingroup = array();
|
$ingroup = array();
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
foreach($r as $member)
|
foreach($r as $member)
|
||||||
$ingroup[] = $member['id'];
|
$ingroup[] = $member['id'];
|
||||||
|
|
||||||
|
|
@ -97,7 +98,7 @@ function profperm_content(App $a) {
|
||||||
$members = $r;
|
$members = $r;
|
||||||
|
|
||||||
$ingroup = array();
|
$ingroup = array();
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
foreach($r as $member)
|
foreach($r as $member)
|
||||||
$ingroup[] = $member['id'];
|
$ingroup[] = $member['id'];
|
||||||
}
|
}
|
||||||
|
|
@ -141,7 +142,7 @@ function profperm_content(App $a) {
|
||||||
dbesc(NETWORK_DFRN)
|
dbesc(NETWORK_DFRN)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$textmode = (($switchtotext && (count($r) > $switchtotext)) ? true : false);
|
$textmode = (($switchtotext && (count($r) > $switchtotext)) ? true : false);
|
||||||
foreach($r as $member) {
|
foreach($r as $member) {
|
||||||
if(! in_array($member['id'],$ingroup)) {
|
if(! in_array($member['id'],$ingroup)) {
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
define('PROXY_DEFAULT_TIME', 86400); // 1 Day
|
define('PROXY_DEFAULT_TIME', 86400); // 1 Day
|
||||||
|
|
||||||
|
|
@ -144,7 +145,7 @@ function proxy_init(App $a) {
|
||||||
|
|
||||||
if (!$direct_cache && ($cachefile == '')) {
|
if (!$direct_cache && ($cachefile == '')) {
|
||||||
$r = dba::select('photo', array('data', 'desc'), array('resource-id' => $urlhash), array('limit' => 1));
|
$r = dba::select('photo', array('data', 'desc'), array('resource-id' => $urlhash), array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$img_str = $r['data'];
|
$img_str = $r['data'];
|
||||||
$mime = $r['desc'];
|
$mime = $r['desc'];
|
||||||
if ($mime == '') {
|
if ($mime == '') {
|
||||||
|
|
@ -153,7 +154,7 @@ function proxy_init(App $a) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
// It shouldn't happen but it does - spaces in URL
|
// It shouldn't happen but it does - spaces in URL
|
||||||
$_REQUEST['url'] = str_replace(' ', '+', $_REQUEST['url']);
|
$_REQUEST['url'] = str_replace(' ', '+', $_REQUEST['url']);
|
||||||
$redirects = 0;
|
$redirects = 0;
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function hub_return($valid,$body) {
|
function hub_return($valid,$body) {
|
||||||
|
|
||||||
|
|
@ -49,7 +50,7 @@ function pubsub_init(App $a) {
|
||||||
$r = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
$r = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
||||||
dbesc($nick)
|
dbesc($nick)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
logger('pubsub: local account not found: ' . $nick);
|
logger('pubsub: local account not found: ' . $nick);
|
||||||
hub_return(false, '');
|
hub_return(false, '');
|
||||||
}
|
}
|
||||||
|
|
@ -64,7 +65,7 @@ function pubsub_init(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($owner['uid'])
|
intval($owner['uid'])
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
logger('pubsub: contact '.$contact_id.' not found.');
|
logger('pubsub: contact '.$contact_id.' not found.');
|
||||||
hub_return(false, '');
|
hub_return(false, '');
|
||||||
}
|
}
|
||||||
|
|
@ -119,7 +120,7 @@ function pubsub_post(App $a) {
|
||||||
$r = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
$r = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
||||||
dbesc($nick)
|
dbesc($nick)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
hub_post_return();
|
hub_post_return();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -134,7 +135,7 @@ function pubsub_post(App $a) {
|
||||||
dbesc(NETWORK_FEED)
|
dbesc(NETWORK_FEED)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
logger('pubsub: no contact record for "'.$nick.' ('.$contact_id.')" - ignored. '.$xml);
|
logger('pubsub: no contact record for "'.$nick.' ('.$contact_id.')" - ignored. '.$xml);
|
||||||
hub_post_return();
|
hub_post_return();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function post_var($name) {
|
function post_var($name) {
|
||||||
return (x($_POST, $name)) ? notags(trim($_POST[$name])) : '';
|
return (x($_POST, $name)) ? notags(trim($_POST[$name])) : '';
|
||||||
|
|
@ -63,7 +64,7 @@ function pubsubhubbub_init(App $a) {
|
||||||
" AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
" AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
||||||
dbesc($nick));
|
dbesc($nick));
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger('pubsubhubbub: local account not found: ' . $nick);
|
logger('pubsubhubbub: local account not found: ' . $nick);
|
||||||
http_status_exit(404);
|
http_status_exit(404);
|
||||||
}
|
}
|
||||||
|
|
@ -81,7 +82,7 @@ function pubsubhubbub_init(App $a) {
|
||||||
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND NOT `blocked`".
|
$r = q("SELECT * FROM `contact` WHERE `uid` = %d AND NOT `blocked`".
|
||||||
" AND NOT `pending` AND `self` LIMIT 1",
|
" AND NOT `pending` AND `self` LIMIT 1",
|
||||||
intval($owner['uid']));
|
intval($owner['uid']));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger('pubsubhubbub: contact not found.');
|
logger('pubsubhubbub: contact not found.');
|
||||||
http_status_exit(404);
|
http_status_exit(404);
|
||||||
}
|
}
|
||||||
|
|
@ -140,7 +141,7 @@ function pubsubhubbub_init(App $a) {
|
||||||
|
|
||||||
// if we are just updating an old subscription, keep the
|
// if we are just updating an old subscription, keep the
|
||||||
// old values for push and last_update
|
// old values for push and last_update
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$last_update = $r[0]['last_update'];
|
$last_update = $r[0]['last_update'];
|
||||||
$push_flag = $r[0]['push'];
|
$push_flag = $r[0]['push'];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function qsearch_init(App $a) {
|
function qsearch_init(App $a) {
|
||||||
|
|
||||||
|
|
@ -27,7 +28,7 @@ function qsearch_init(App $a) {
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
$results[] = array( 0, (int) $rr['id'], $rr['name'], '', '');
|
$results[] = array( 0, (int) $rr['id'], $rr['name'], '', '');
|
||||||
|
|
@ -42,7 +43,7 @@ function qsearch_init(App $a) {
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
$results[] = array( (int) $rr['id'], 0, $rr['name'],$rr['url'],$rr['photo']);
|
$results[] = array( (int) $rr['id'], 0, $rr['name'],$rr['url'],$rr['photo']);
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
|
|
||||||
require_once('include/salmon.php');
|
require_once('include/salmon.php');
|
||||||
|
|
@ -30,7 +31,7 @@ function receive_post(App $a) {
|
||||||
$guid = $a->argv[2];
|
$guid = $a->argv[2];
|
||||||
|
|
||||||
$importer = dba::select('user', array(), array('guid' => $guid, 'account_expired' => false, 'account_removed' => false), array('limit' => 1));
|
$importer = dba::select('user', array(), array('guid' => $guid, 'account_expired' => false, 'account_removed' => false), array('limit' => 1));
|
||||||
if (!dbm::is_result($importer)) {
|
if (!DBM::is_result($importer)) {
|
||||||
http_status_exit(500);
|
http_status_exit(500);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function redir_init(App $a) {
|
function redir_init(App $a) {
|
||||||
|
|
||||||
|
|
@ -21,7 +22,7 @@ function redir_init(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
goaway(System::baseUrl());
|
goaway(System::baseUrl());
|
||||||
}
|
}
|
||||||
if ($r[0]['network'] !== NETWORK_DFRN) {
|
if ($r[0]['network'] !== NETWORK_DFRN) {
|
||||||
|
|
@ -36,7 +37,7 @@ function redir_init(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
goaway(System::baseUrl());
|
goaway(System::baseUrl());
|
||||||
}
|
}
|
||||||
if ($r[0]['network'] !== NETWORK_DFRN) {
|
if ($r[0]['network'] !== NETWORK_DFRN) {
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/enotify.php');
|
require_once('include/enotify.php');
|
||||||
require_once('include/user.php');
|
require_once('include/user.php');
|
||||||
|
|
@ -17,7 +18,7 @@ function user_allow($hash) {
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
if (! dbm::is_result($register)) {
|
if (! DBM::is_result($register)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -25,7 +26,7 @@ function user_allow($hash) {
|
||||||
intval($register[0]['uid'])
|
intval($register[0]['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($user)) {
|
if (! DBM::is_result($user)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -41,7 +42,7 @@ function user_allow($hash) {
|
||||||
$r = q("SELECT * FROM `profile` WHERE `uid` = %d AND `is-default` = 1",
|
$r = q("SELECT * FROM `profile` WHERE `uid` = %d AND `is-default` = 1",
|
||||||
intval($user[0]['uid'])
|
intval($user[0]['uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r) && $r[0]['net-publish']) {
|
if (DBM::is_result($r) && $r[0]['net-publish']) {
|
||||||
$url = System::baseUrl() . '/profile/' . $user[0]['nickname'];
|
$url = System::baseUrl() . '/profile/' . $user[0]['nickname'];
|
||||||
if ($url && strlen(Config::get('system','directory'))) {
|
if ($url && strlen(Config::get('system','directory'))) {
|
||||||
Worker::add(PRIORITY_LOW, "directory", $url);
|
Worker::add(PRIORITY_LOW, "directory", $url);
|
||||||
|
|
@ -77,7 +78,7 @@ function user_deny($hash) {
|
||||||
dbesc($hash)
|
dbesc($hash)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!dbm::is_result($register)) {
|
if (!DBM::is_result($register)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/salmon.php');
|
require_once('include/salmon.php');
|
||||||
require_once('include/ostatus.php');
|
require_once('include/ostatus.php');
|
||||||
|
|
@ -34,7 +35,7 @@ function salmon_post(App $a) {
|
||||||
$r = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
$r = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `account_expired` = 0 AND `account_removed` = 0 LIMIT 1",
|
||||||
dbesc($nick)
|
dbesc($nick)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
http_status_exit(500);
|
http_status_exit(500);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -158,7 +159,7 @@ function salmon_post(App $a) {
|
||||||
dbesc(normalise_link($author_link)),
|
dbesc(normalise_link($author_link)),
|
||||||
intval($importer['uid'])
|
intval($importer['uid'])
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
logger('mod-salmon: Author unknown to us.');
|
logger('mod-salmon: Author unknown to us.');
|
||||||
if(PConfig::get($importer['uid'],'system','ostatus_autofriend')) {
|
if(PConfig::get($importer['uid'],'system','ostatus_autofriend')) {
|
||||||
$result = new_contact($importer['uid'],$author_link);
|
$result = new_contact($importer['uid'],$author_link);
|
||||||
|
|
@ -177,8 +178,8 @@ function salmon_post(App $a) {
|
||||||
// Have we ignored the person?
|
// Have we ignored the person?
|
||||||
// If so we can not accept this post.
|
// If so we can not accept this post.
|
||||||
|
|
||||||
//if((dbm::is_result($r)) && (($r[0]['readonly']) || ($r[0]['rel'] == CONTACT_IS_FOLLOWER) || ($r[0]['blocked']))) {
|
//if((DBM::is_result($r)) && (($r[0]['readonly']) || ($r[0]['rel'] == CONTACT_IS_FOLLOWER) || ($r[0]['blocked']))) {
|
||||||
if (dbm::is_result($r) && $r[0]['blocked']) {
|
if (DBM::is_result($r) && $r[0]['blocked']) {
|
||||||
logger('mod-salmon: Ignoring this author.');
|
logger('mod-salmon: Ignoring this author.');
|
||||||
http_status_exit(202);
|
http_status_exit(202);
|
||||||
// NOTREACHED
|
// NOTREACHED
|
||||||
|
|
@ -187,7 +188,7 @@ function salmon_post(App $a) {
|
||||||
// Placeholder for hub discovery.
|
// Placeholder for hub discovery.
|
||||||
$hub = '';
|
$hub = '';
|
||||||
|
|
||||||
$contact_rec = ((dbm::is_result($r)) ? $r[0] : null);
|
$contact_rec = ((DBM::is_result($r)) ? $r[0] : null);
|
||||||
|
|
||||||
ostatus::import($data,$importer,$contact_rec, $hub);
|
ostatus::import($data,$importer,$contact_rec, $hub);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once("include/bbcode.php");
|
require_once("include/bbcode.php");
|
||||||
require_once('include/security.php');
|
require_once('include/security.php');
|
||||||
|
|
@ -19,7 +20,7 @@ function search_saved_searches() {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$saved = array();
|
$saved = array();
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$saved[] = array(
|
$saved[] = array(
|
||||||
|
|
@ -57,7 +58,7 @@ function search_init(App $a) {
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
dbesc($search)
|
dbesc($search)
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
dba::insert('search', array('uid' => local_user(), 'term' => $search));
|
dba::insert('search', array('uid' => local_user(), 'term' => $search));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -212,7 +213,7 @@ function search_content(App $a) {
|
||||||
intval($a->pager['start']), intval($a->pager['itemspage']));
|
intval($a->pager['start']), intval($a->pager['itemspage']));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
info( t('No results.') . EOL);
|
info( t('No results.') . EOL);
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@ use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/group.php');
|
require_once('include/group.php');
|
||||||
require_once('include/socgraph.php');
|
require_once('include/socgraph.php');
|
||||||
|
|
@ -228,7 +229,7 @@ function settings_post(App $a) {
|
||||||
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d LIMIT 1",
|
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d LIMIT 1",
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
dba::insert('mailacct', array('uid' => local_user()));
|
dba::insert('mailacct', array('uid' => local_user()));
|
||||||
}
|
}
|
||||||
if (strlen($mail_pass)) {
|
if (strlen($mail_pass)) {
|
||||||
|
|
@ -253,7 +254,7 @@ function settings_post(App $a) {
|
||||||
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d LIMIT 1",
|
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d LIMIT 1",
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$eacct = $r[0];
|
$eacct = $r[0];
|
||||||
require_once('include/email.php');
|
require_once('include/email.php');
|
||||||
$mb = construct_mailbox_name($eacct);
|
$mb = construct_mailbox_name($eacct);
|
||||||
|
|
@ -704,7 +705,7 @@ function settings_content(App $a) {
|
||||||
dbesc($a->argv[3]),
|
dbesc($a->argv[3]),
|
||||||
local_user());
|
local_user());
|
||||||
|
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
notice(t("You can't edit this application."));
|
notice(t("You can't edit this application."));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -735,7 +736,7 @@ function settings_content(App $a) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// @TODO validate result with dbm::is_result()
|
/// @TODO validate result with DBM::is_result()
|
||||||
$r = q("SELECT clients.*, tokens.id as oauth_token, (clients.uid=%d) AS my
|
$r = q("SELECT clients.*, tokens.id as oauth_token, (clients.uid=%d) AS my
|
||||||
FROM clients
|
FROM clients
|
||||||
LEFT JOIN tokens ON clients.client_id=tokens.client_id
|
LEFT JOIN tokens ON clients.client_id=tokens.client_id
|
||||||
|
|
@ -765,7 +766,7 @@ function settings_content(App $a) {
|
||||||
$settings_addons = "";
|
$settings_addons = "";
|
||||||
|
|
||||||
$r = q("SELECT * FROM `hook` WHERE `hook` = 'plugin_settings' ");
|
$r = q("SELECT * FROM `hook` WHERE `hook` = 'plugin_settings' ");
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$settings_addons = t('No Plugin settings configured');
|
$settings_addons = t('No Plugin settings configured');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -874,15 +875,15 @@ function settings_content(App $a) {
|
||||||
$r = null;
|
$r = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
$mail_server = ((dbm::is_result($r)) ? $r[0]['server'] : '');
|
$mail_server = ((DBM::is_result($r)) ? $r[0]['server'] : '');
|
||||||
$mail_port = ((dbm::is_result($r) && intval($r[0]['port'])) ? intval($r[0]['port']) : '');
|
$mail_port = ((DBM::is_result($r) && intval($r[0]['port'])) ? intval($r[0]['port']) : '');
|
||||||
$mail_ssl = ((dbm::is_result($r)) ? $r[0]['ssltype'] : '');
|
$mail_ssl = ((DBM::is_result($r)) ? $r[0]['ssltype'] : '');
|
||||||
$mail_user = ((dbm::is_result($r)) ? $r[0]['user'] : '');
|
$mail_user = ((DBM::is_result($r)) ? $r[0]['user'] : '');
|
||||||
$mail_replyto = ((dbm::is_result($r)) ? $r[0]['reply_to'] : '');
|
$mail_replyto = ((DBM::is_result($r)) ? $r[0]['reply_to'] : '');
|
||||||
$mail_pubmail = ((dbm::is_result($r)) ? $r[0]['pubmail'] : 0);
|
$mail_pubmail = ((DBM::is_result($r)) ? $r[0]['pubmail'] : 0);
|
||||||
$mail_action = ((dbm::is_result($r)) ? $r[0]['action'] : 0);
|
$mail_action = ((DBM::is_result($r)) ? $r[0]['action'] : 0);
|
||||||
$mail_movetofolder = ((dbm::is_result($r)) ? $r[0]['movetofolder'] : '');
|
$mail_movetofolder = ((DBM::is_result($r)) ? $r[0]['movetofolder'] : '');
|
||||||
$mail_chk = ((dbm::is_result($r)) ? $r[0]['last_check'] : NULL_DATE);
|
$mail_chk = ((DBM::is_result($r)) ? $r[0]['last_check'] : NULL_DATE);
|
||||||
|
|
||||||
|
|
||||||
$tpl = get_markup_template("settings_connectors.tpl");
|
$tpl = get_markup_template("settings_connectors.tpl");
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function share_init(App $a) {
|
function share_init(App $a) {
|
||||||
|
|
||||||
|
|
@ -15,7 +16,7 @@ function share_init(App $a) {
|
||||||
intval($post_id),
|
intval($post_id),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if(! dbm::is_result($r) || ($r[0]['private'] == 1))
|
if(! DBM::is_result($r) || ($r[0]['private'] == 1))
|
||||||
killme();
|
killme();
|
||||||
|
|
||||||
if (strpos($r[0]['body'], "[/share]") !== false) {
|
if (strpos($r[0]['body'], "[/share]") !== false) {
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function starred_init(App $a) {
|
function starred_init(App $a) {
|
||||||
|
|
||||||
|
|
@ -23,7 +24,7 @@ function starred_init(App $a) {
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
intval($message_id)
|
intval($message_id)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/security.php');
|
require_once('include/security.php');
|
||||||
require_once('include/bbcode.php');
|
require_once('include/bbcode.php');
|
||||||
|
|
@ -22,7 +23,7 @@ function subthread_content(App $a) {
|
||||||
dbesc($item_id)
|
dbesc($item_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if(! $item_id || (! dbm::is_result($r))) {
|
if(! $item_id || (! DBM::is_result($r))) {
|
||||||
logger('subthread: no item ' . $item_id);
|
logger('subthread: no item ' . $item_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -43,7 +44,7 @@ function subthread_content(App $a) {
|
||||||
intval($item['contact-id']),
|
intval($item['contact-id']),
|
||||||
intval($item['uid'])
|
intval($item['uid'])
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (! $r[0]['self']) {
|
if (! $r[0]['self']) {
|
||||||
|
|
@ -57,7 +58,7 @@ function subthread_content(App $a) {
|
||||||
WHERE `contact`.`self` = 1 AND `contact`.`uid` = %d LIMIT 1",
|
WHERE `contact`.`self` = 1 AND `contact`.`uid` = %d LIMIT 1",
|
||||||
intval($owner_uid)
|
intval($owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$owner = $r[0];
|
$owner = $r[0];
|
||||||
|
|
||||||
if (! $owner) {
|
if (! $owner) {
|
||||||
|
|
@ -78,7 +79,7 @@ function subthread_content(App $a) {
|
||||||
intval($_SESSION['visitor_id']),
|
intval($_SESSION['visitor_id']),
|
||||||
intval($owner_uid)
|
intval($owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
}
|
}
|
||||||
if (! $contact) {
|
if (! $contact) {
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/socgraph.php');
|
require_once('include/socgraph.php');
|
||||||
require_once('include/contact_widgets.php');
|
require_once('include/contact_widgets.php');
|
||||||
|
|
@ -67,7 +68,7 @@ function suggest_content(App $a) {
|
||||||
|
|
||||||
$r = suggestion_query(local_user());
|
$r = suggestion_query(local_user());
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$o .= t('No suggestions available. If this is a new site, please try again in 24 hours.');
|
$o .= t('No suggestions available. If this is a new site, please try again in 24 hours.');
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/security.php');
|
require_once('include/security.php');
|
||||||
require_once('include/bbcode.php');
|
require_once('include/bbcode.php');
|
||||||
|
|
@ -30,7 +31,7 @@ function tagger_content(App $a) {
|
||||||
dbesc($item_id)
|
dbesc($item_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if(! $item_id || (! dbm::is_result($r))) {
|
if(! $item_id || (! DBM::is_result($r))) {
|
||||||
logger('tagger: no item ' . $item_id);
|
logger('tagger: no item ' . $item_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -42,7 +43,7 @@ function tagger_content(App $a) {
|
||||||
$r = q("select `nickname`,`blocktags` from user where uid = %d limit 1",
|
$r = q("select `nickname`,`blocktags` from user where uid = %d limit 1",
|
||||||
intval($owner_uid)
|
intval($owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$owner_nick = $r[0]['nickname'];
|
$owner_nick = $r[0]['nickname'];
|
||||||
$blocktags = $r[0]['blocktags'];
|
$blocktags = $r[0]['blocktags'];
|
||||||
}
|
}
|
||||||
|
|
@ -53,7 +54,7 @@ function tagger_content(App $a) {
|
||||||
$r = q("select * from contact where self = 1 and uid = %d limit 1",
|
$r = q("select * from contact where self = 1 and uid = %d limit 1",
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
else {
|
else {
|
||||||
logger('tagger: no contact_id');
|
logger('tagger: no contact_id');
|
||||||
|
|
@ -182,7 +183,7 @@ EOT;
|
||||||
$r = q("select `tag`,`id`,`uid` from item where `origin` = 1 AND `uri` = '%s' LIMIT 1",
|
$r = q("select `tag`,`id`,`uid` from item where `origin` = 1 AND `uri` = '%s' LIMIT 1",
|
||||||
dbesc($item['uri'])
|
dbesc($item['uri'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$x = q("SELECT `blocktags` FROM `user` WHERE `uid` = %d limit 1",
|
$x = q("SELECT `blocktags` FROM `user` WHERE `uid` = %d limit 1",
|
||||||
intval($r[0]['uid'])
|
intval($r[0]['uid'])
|
||||||
);
|
);
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/bbcode.php');
|
require_once('include/bbcode.php');
|
||||||
|
|
||||||
|
|
@ -23,7 +24,7 @@ function tagrm_post(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
goaway(System::baseUrl() . '/' . $_SESSION['photo_return']);
|
goaway(System::baseUrl() . '/' . $_SESSION['photo_return']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -72,7 +73,7 @@ function tagrm_content(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
goaway(System::baseUrl() . '/' . $_SESSION['photo_return']);
|
goaway(System::baseUrl() . '/' . $_SESSION['photo_return']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function uexport_init(App $a) {
|
function uexport_init(App $a) {
|
||||||
if (!local_user()) {
|
if (!local_user()) {
|
||||||
|
|
@ -52,7 +53,7 @@ function uexport_content(App $a) {
|
||||||
function _uexport_multirow($query) {
|
function _uexport_multirow($query) {
|
||||||
$result = array();
|
$result = array();
|
||||||
$r = q($query);
|
$r = q($query);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$p = array();
|
$p = array();
|
||||||
foreach ($rr as $k => $v) {
|
foreach ($rr as $k => $v) {
|
||||||
|
|
@ -67,7 +68,7 @@ function _uexport_multirow($query) {
|
||||||
function _uexport_row($query) {
|
function _uexport_row($query) {
|
||||||
$result = array();
|
$result = array();
|
||||||
$r = q($query);
|
$r = q($query);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
foreach ($rr as $k => $v) {
|
foreach ($rr as $k => $v) {
|
||||||
$result[$k] = $v;
|
$result[$k] = $v;
|
||||||
|
|
@ -139,7 +140,7 @@ function uexport_all(App $a) {
|
||||||
$r = q("SELECT count(*) as `total` FROM `item` WHERE `uid` = %d ",
|
$r = q("SELECT count(*) as `total` FROM `item` WHERE `uid` = %d ",
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$total = $r[0]['total'];
|
$total = $r[0]['total'];
|
||||||
}
|
}
|
||||||
// chunk the output to avoid exhausting memory
|
// chunk the output to avoid exhausting memory
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/follow.php';
|
require_once 'include/follow.php';
|
||||||
require_once 'include/Contact.php';
|
require_once 'include/Contact.php';
|
||||||
|
|
@ -28,7 +29,7 @@ function unfollow_post(App $a) {
|
||||||
normalise_link($url), $url, NETWORK_STATUSNET);
|
normalise_link($url), $url, NETWORK_STATUSNET);
|
||||||
$contact = dba::select('contact', array(), $condition, array('limit' => 1));
|
$contact = dba::select('contact', array(), $condition, array('limit' => 1));
|
||||||
|
|
||||||
if (!dbm::is_result($contact)) {
|
if (!DBM::is_result($contact)) {
|
||||||
notice(t("Contact wasn't found or can't be unfollowed."));
|
notice(t("Contact wasn't found or can't be unfollowed."));
|
||||||
} else {
|
} else {
|
||||||
if (in_array($contact['network'], array(NETWORK_OSTATUS, NETWORK_DIASPORA))) {
|
if (in_array($contact['network'], array(NETWORK_OSTATUS, NETWORK_DIASPORA))) {
|
||||||
|
|
@ -36,7 +37,7 @@ function unfollow_post(App $a) {
|
||||||
WHERE `user`.`uid` = %d AND `contact`.`self` LIMIT 1",
|
WHERE `user`.`uid` = %d AND `contact`.`self` LIMIT 1",
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$self = ""; // Unused parameter
|
$self = ""; // Unused parameter
|
||||||
terminate_friendship($r[0], $self, $contact);
|
terminate_friendship($r[0], $self, $contact);
|
||||||
}
|
}
|
||||||
|
|
@ -68,7 +69,7 @@ function unfollow_content(App $a) {
|
||||||
normalise_link($url), $url, NETWORK_STATUSNET);
|
normalise_link($url), $url, NETWORK_STATUSNET);
|
||||||
$contact = dba::select('contact', array('url', 'network', 'addr', 'name'), $condition, array('limit' => 1));
|
$contact = dba::select('contact', array('url', 'network', 'addr', 'name'), $condition, array('limit' => 1));
|
||||||
|
|
||||||
if (!dbm::is_result($contact)) {
|
if (!DBM::is_result($contact)) {
|
||||||
notice(t("You aren't a friend of this contact.").EOL);
|
notice(t("You aren't a friend of this contact.").EOL);
|
||||||
$submit = "";
|
$submit = "";
|
||||||
// NOTREACHED
|
// NOTREACHED
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/items.php');
|
require_once('include/items.php');
|
||||||
require_once('include/acl_selectors.php');
|
require_once('include/acl_selectors.php');
|
||||||
|
|
@ -148,7 +149,7 @@ function videos_post(App $a) {
|
||||||
dbesc($video_id)
|
dbesc($video_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
q("DELETE FROM `attach` WHERE `uid` = %d AND `id` = '%s'",
|
q("DELETE FROM `attach` WHERE `uid` = %d AND `id` = '%s'",
|
||||||
intval(local_user()),
|
intval(local_user()),
|
||||||
dbesc($video_id)
|
dbesc($video_id)
|
||||||
|
|
@ -158,7 +159,7 @@ function videos_post(App $a) {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
//echo "<pre>"; var_dump($i); killme();
|
//echo "<pre>"; var_dump($i); killme();
|
||||||
if (dbm::is_result($i)) {
|
if (DBM::is_result($i)) {
|
||||||
q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d",
|
q("UPDATE `item` SET `deleted` = 1, `edited` = '%s', `changed` = '%s' WHERE `parent-uri` = '%s' AND `uid` = %d",
|
||||||
dbesc(datetime_convert()),
|
dbesc(datetime_convert()),
|
||||||
dbesc(datetime_convert()),
|
dbesc(datetime_convert()),
|
||||||
|
|
@ -268,7 +269,7 @@ function videos_content(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($owner_uid)
|
intval($owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$can_post = true;
|
$can_post = true;
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
$remote_contact = true;
|
$remote_contact = true;
|
||||||
|
|
@ -296,7 +297,7 @@ function videos_content(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($owner_uid)
|
intval($owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
$remote_contact = true;
|
$remote_contact = true;
|
||||||
}
|
}
|
||||||
|
|
@ -356,7 +357,7 @@ function videos_content(App $a) {
|
||||||
$sql_extra GROUP BY hash",
|
$sql_extra GROUP BY hash",
|
||||||
intval($a->data['user']['uid'])
|
intval($a->data['user']['uid'])
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$a->set_pager_total(count($r));
|
$a->set_pager_total(count($r));
|
||||||
$a->set_pager_itemspage(20);
|
$a->set_pager_itemspage(20);
|
||||||
}
|
}
|
||||||
|
|
@ -374,7 +375,7 @@ function videos_content(App $a) {
|
||||||
|
|
||||||
|
|
||||||
$videos = array();
|
$videos = array();
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if ($a->theme['template_engine'] === 'internal') {
|
if ($a->theme['template_engine'] === 'internal') {
|
||||||
$alt_e = template_escape($rr['filename']);
|
$alt_e = template_escape($rr['filename']);
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/Contact.php');
|
require_once('include/Contact.php');
|
||||||
require_once('include/contact_selectors.php');
|
require_once('include/contact_selectors.php');
|
||||||
|
|
@ -20,7 +21,7 @@ function viewcontacts_init(App $a) {
|
||||||
dbesc($nick)
|
dbesc($nick)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -60,7 +61,7 @@ function viewcontacts_content(App $a) {
|
||||||
dbesc(NETWORK_DIASPORA),
|
dbesc(NETWORK_DIASPORA),
|
||||||
dbesc(NETWORK_OSTATUS)
|
dbesc(NETWORK_OSTATUS)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$a->set_pager_total($r[0]['total']);
|
$a->set_pager_total($r[0]['total']);
|
||||||
|
|
||||||
$r = q("SELECT * FROM `contact`
|
$r = q("SELECT * FROM `contact`
|
||||||
|
|
@ -75,7 +76,7 @@ function viewcontacts_content(App $a) {
|
||||||
intval($a->pager['start']),
|
intval($a->pager['start']),
|
||||||
intval($a->pager['itemspage'])
|
intval($a->pager['itemspage'])
|
||||||
);
|
);
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
info(t('No contacts.').EOL);
|
info(t('No contacts.').EOL);
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
function viewsrc_content(App $a) {
|
function viewsrc_content(App $a) {
|
||||||
|
|
||||||
|
|
@ -25,7 +26,7 @@ function viewsrc_content(App $a) {
|
||||||
dbesc($item_id)
|
dbesc($item_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
if(is_ajax()) {
|
if(is_ajax()) {
|
||||||
echo str_replace("\n",'<br />',$r[0]['body']);
|
echo str_replace("\n",'<br />',$r[0]['body']);
|
||||||
killme();
|
killme();
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/attach.php');
|
require_once('include/attach.php');
|
||||||
require_once('include/datetime.php');
|
require_once('include/datetime.php');
|
||||||
|
|
@ -15,7 +16,7 @@ function wall_attach_post(App $a) {
|
||||||
$r = q("SELECT `user`.*, `contact`.`id` FROM `user` LEFT JOIN `contact` on `user`.`uid` = `contact`.`uid` WHERE `user`.`nickname` = '%s' AND `user`.`blocked` = 0 and `contact`.`self` = 1 LIMIT 1",
|
$r = q("SELECT `user`.*, `contact`.`id` FROM `user` LEFT JOIN `contact` on `user`.`uid` = `contact`.`uid` WHERE `user`.`nickname` = '%s' AND `user`.`blocked` = 0 and `contact`.`self` = 1 LIMIT 1",
|
||||||
dbesc($nick)
|
dbesc($nick)
|
||||||
);
|
);
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
if ($r_json) {
|
if ($r_json) {
|
||||||
echo json_encode(array('error'=>t('Invalid request.')));
|
echo json_encode(array('error'=>t('Invalid request.')));
|
||||||
killme();
|
killme();
|
||||||
|
|
@ -58,7 +59,7 @@ function wall_attach_post(App $a) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$can_post = true;
|
$can_post = true;
|
||||||
$visitor = $contact_id;
|
$visitor = $contact_id;
|
||||||
}
|
}
|
||||||
|
|
@ -144,7 +145,7 @@ function wall_attach_post(App $a) {
|
||||||
dbesc($hash)
|
dbesc($hash)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
$msg = t('File upload failed.');
|
$msg = t('File upload failed.');
|
||||||
if ($r_json) {
|
if ($r_json) {
|
||||||
echo json_encode(array('error'=>$msg));
|
echo json_encode(array('error'=>$msg));
|
||||||
|
|
|
||||||
|
|
@ -12,6 +12,7 @@
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/Photo.php';
|
require_once 'include/Photo.php';
|
||||||
|
|
||||||
|
|
@ -32,7 +33,7 @@ function wall_upload_post(App $a, $desktopmode = true) {
|
||||||
dbesc($nick)
|
dbesc($nick)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
if ($r_json) {
|
if ($r_json) {
|
||||||
echo json_encode(array('error'=>t('Invalid request.')));
|
echo json_encode(array('error'=>t('Invalid request.')));
|
||||||
killme();
|
killme();
|
||||||
|
|
@ -88,7 +89,7 @@ function wall_upload_post(App $a, $desktopmode = true) {
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$can_post = true;
|
$can_post = true;
|
||||||
$visitor = $contact_id;
|
$visitor = $contact_id;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use \Friendica\Core\System;
|
use \Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/message.php');
|
require_once('include/message.php');
|
||||||
|
|
||||||
|
|
@ -25,7 +26,7 @@ function wallmessage_post(App $a) {
|
||||||
dbesc($recipient)
|
dbesc($recipient)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
logger('wallmessage: no recipient');
|
logger('wallmessage: no recipient');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -88,7 +89,7 @@ function wallmessage_content(App $a) {
|
||||||
dbesc($recipient)
|
dbesc($recipient)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
notice( t('No recipient.') . EOL);
|
notice( t('No recipient.') . EOL);
|
||||||
logger('wallmessage: no recipient');
|
logger('wallmessage: no recipient');
|
||||||
return;
|
return;
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once('include/crypto.php');
|
require_once('include/crypto.php');
|
||||||
|
|
||||||
|
|
@ -33,7 +34,7 @@ function xrd_init(App $a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = dba::select('user', array(), array('nickname' => $name), array('limit' => 1));
|
$r = dba::select('user', array(), array('nickname' => $name), array('limit' => 1));
|
||||||
if (!dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ if(class_exists('Item'))
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Protocol\Diaspora;
|
use Friendica\Protocol\Diaspora;
|
||||||
|
|
||||||
require_once('object/BaseObject.php');
|
require_once('object/BaseObject.php');
|
||||||
|
|
@ -255,7 +256,7 @@ class Item extends BaseObject {
|
||||||
'starred' => t('starred'),
|
'starred' => t('starred'),
|
||||||
);
|
);
|
||||||
$r = dba::select('thread', array('ignored'), array('uid' => $item['uid'], 'iid' => $item['id']), array('limit' => 1));
|
$r = dba::select('thread', array('ignored'), array('uid' => $item['uid'], 'iid' => $item['id']), array('limit' => 1));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$ignore = array(
|
$ignore = array(
|
||||||
'do' => t("ignore thread"),
|
'do' => t("ignore thread"),
|
||||||
'undo' => t("unignore thread"),
|
'undo' => t("unignore thread"),
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@ namespace Friendica;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
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 Cache;
|
||||||
use dba;
|
use dba;
|
||||||
|
|
@ -706,7 +706,7 @@ class App {
|
||||||
dba::transaction();
|
dba::transaction();
|
||||||
|
|
||||||
$r = q('SELECT `pid` FROM `process` WHERE `pid` = %d', intval(getmypid()));
|
$r = q('SELECT `pid` FROM `process` WHERE `pid` = %d', intval(getmypid()));
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
dba::insert('process', array('pid' => getmypid(), 'command' => $command, 'created' => datetime_convert()));
|
dba::insert('process', array('pid' => getmypid(), 'command' => $command, 'created' => datetime_convert()));
|
||||||
}
|
}
|
||||||
dba::commit();
|
dba::commit();
|
||||||
|
|
@ -719,7 +719,7 @@ class App {
|
||||||
dba::transaction();
|
dba::transaction();
|
||||||
|
|
||||||
$r = q('SELECT `pid` FROM `process`');
|
$r = q('SELECT `pid` FROM `process`');
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r AS $process) {
|
foreach ($r AS $process) {
|
||||||
if (!posix_kill($process['pid'], 0)) {
|
if (!posix_kill($process['pid'], 0)) {
|
||||||
q('DELETE FROM `process` WHERE `pid` = %d', intval($process['pid']));
|
q('DELETE FROM `process` WHERE `pid` = %d', intval($process['pid']));
|
||||||
|
|
@ -806,7 +806,7 @@ class App {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$processlist = Dbm::processlist();
|
$processlist = DBM::processlist();
|
||||||
if ($processlist['list'] != '') {
|
if ($processlist['list'] != '') {
|
||||||
logger('Processcheck: Processes: ' . $processlist['amount'] . ' - Processlist: ' . $processlist['list'], LOGGER_DEBUG);
|
logger('Processcheck: Processes: ' . $processlist['amount'] . ' - Processlist: ' . $processlist['list'], LOGGER_DEBUG);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
namespace Friendica\Core;
|
namespace Friendica\Core;
|
||||||
|
|
||||||
use Friendica\Database\Dbm;
|
use Friendica\Database\DBM;
|
||||||
use dba;
|
use dba;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -99,7 +99,7 @@ class Config {
|
||||||
}
|
}
|
||||||
|
|
||||||
$ret = dba::select('config', array('v'), array('cat' => $family, 'k' => $key), array('limit' => 1));
|
$ret = dba::select('config', array('v'), array('cat' => $family, 'k' => $key), array('limit' => 1));
|
||||||
if (Dbm::is_result($ret)) {
|
if (DBM::is_result($ret)) {
|
||||||
// manage array value
|
// manage array value
|
||||||
$val = (preg_match("|^a:[0-9]+:{.*}$|s", $ret['v']) ? unserialize($ret['v']) : $ret['v']);
|
$val = (preg_match("|^a:[0-9]+:{.*}$|s", $ret['v']) ? unserialize($ret['v']) : $ret['v']);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,7 @@ namespace Friendica\Core;
|
||||||
|
|
||||||
use Friendica\Core\Pconfig;
|
use Friendica\Core\Pconfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Database\Dbm;
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once 'include/html2plain.php';
|
require_once 'include/html2plain.php';
|
||||||
require_once 'include/datetime.php';
|
require_once 'include/datetime.php';
|
||||||
|
|
@ -95,7 +95,7 @@ class NotificationsManager {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $this->_set_extra($r);
|
return $this->_set_extra($r);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|
@ -112,7 +112,7 @@ class NotificationsManager {
|
||||||
intval($id),
|
intval($id),
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $this->_set_extra($r)[0];
|
return $this->_set_extra($r)[0];
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
|
|
@ -215,7 +215,7 @@ class NotificationsManager {
|
||||||
$notif = array();
|
$notif = array();
|
||||||
$arr = array();
|
$arr = array();
|
||||||
|
|
||||||
if (Dbm::is_result($notifs)) {
|
if (DBM::is_result($notifs)) {
|
||||||
|
|
||||||
foreach ($notifs as $it) {
|
foreach ($notifs as $it) {
|
||||||
// Because we use different db tables for the notification query
|
// Because we use different db tables for the notification query
|
||||||
|
|
@ -386,7 +386,7 @@ class NotificationsManager {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0]['total'];
|
return $r[0]['total'];
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -429,7 +429,7 @@ class NotificationsManager {
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$notifs = $this->formatNotifs($r, $ident);
|
$notifs = $this->formatNotifs($r, $ident);
|
||||||
|
|
||||||
$arr = array (
|
$arr = array (
|
||||||
|
|
@ -458,7 +458,7 @@ class NotificationsManager {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0]['total'];
|
return $r[0]['total'];
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -494,7 +494,7 @@ class NotificationsManager {
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$notifs = $this->formatNotifs($r, $ident);
|
$notifs = $this->formatNotifs($r, $ident);
|
||||||
|
|
||||||
$arr = array (
|
$arr = array (
|
||||||
|
|
@ -548,7 +548,7 @@ class NotificationsManager {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0]['total'];
|
return $r[0]['total'];
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -592,7 +592,7 @@ class NotificationsManager {
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$notifs = $this->formatNotifs($r, $ident);
|
$notifs = $this->formatNotifs($r, $ident);
|
||||||
|
|
||||||
$arr = array (
|
$arr = array (
|
||||||
|
|
@ -624,7 +624,7 @@ class NotificationsManager {
|
||||||
intval(local_user())
|
intval(local_user())
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0]['total'];
|
return $r[0]['total'];
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -666,7 +666,7 @@ class NotificationsManager {
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$notifs = $this->formatNotifs($r, $ident);
|
$notifs = $this->formatNotifs($r, $ident);
|
||||||
|
|
||||||
$arr = array (
|
$arr = array (
|
||||||
|
|
@ -696,7 +696,7 @@ class NotificationsManager {
|
||||||
intval($_SESSION['uid'])
|
intval($_SESSION['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return $r[0]['total'];
|
return $r[0]['total'];
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -743,7 +743,7 @@ class NotificationsManager {
|
||||||
intval($limit)
|
intval($limit)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
$notifs = $this->formatIntros($r);
|
$notifs = $this->formatIntros($r);
|
||||||
|
|
||||||
$arr = array (
|
$arr = array (
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
namespace Friendica\Core;
|
namespace Friendica\Core;
|
||||||
|
|
||||||
use Friendica\Database\Dbm;
|
use Friendica\Database\DBM;
|
||||||
use dba;
|
use dba;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
@ -37,7 +37,7 @@ class PConfig {
|
||||||
$a = get_app();
|
$a = get_app();
|
||||||
|
|
||||||
$r = dba::select('pconfig', array('v', 'k'), array('cat' => $family, 'uid' => $uid));
|
$r = dba::select('pconfig', array('v', 'k'), array('cat' => $family, 'uid' => $uid));
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
while ($rr = dba::fetch($r)) {
|
while ($rr = dba::fetch($r)) {
|
||||||
$k = $rr['k'];
|
$k = $rr['k'];
|
||||||
$a->config[$uid][$family][$k] = $rr['v'];
|
$a->config[$uid][$family][$k] = $rr['v'];
|
||||||
|
|
@ -90,7 +90,7 @@ class PConfig {
|
||||||
}
|
}
|
||||||
|
|
||||||
$ret = dba::select('pconfig', array('v'), array('uid' => $uid, 'cat' => $family, 'k' => $key), array('limit' => 1));
|
$ret = dba::select('pconfig', array('v'), array('uid' => $uid, 'cat' => $family, 'k' => $key), array('limit' => 1));
|
||||||
if (Dbm::is_result($ret)) {
|
if (DBM::is_result($ret)) {
|
||||||
$val = (preg_match("|^a:[0-9]+:{.*}$|s", $ret['v']) ? unserialize($ret['v']) : $ret['v']);
|
$val = (preg_match("|^a:[0-9]+:{.*}$|s", $ret['v']) ? unserialize($ret['v']) : $ret['v']);
|
||||||
$a->config[$uid][$family][$key] = $val;
|
$a->config[$uid][$family][$key] = $val;
|
||||||
self::$in_db[$uid][$family][$key] = true;
|
self::$in_db[$uid][$family][$key] = true;
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
use Friendica\Database\Dbm;
|
use Friendica\Database\DBM;
|
||||||
use Friendica\Util\Lock;
|
use Friendica\Util\Lock;
|
||||||
|
|
||||||
use dba;
|
use dba;
|
||||||
|
|
@ -142,7 +142,7 @@ class Worker {
|
||||||
*/
|
*/
|
||||||
private static function totalEntries() {
|
private static function totalEntries() {
|
||||||
$s = dba::fetch_first("SELECT COUNT(*) AS `total` FROM `workerqueue` WHERE `executed` <= ? AND NOT `done`", NULL_DATE);
|
$s = dba::fetch_first("SELECT COUNT(*) AS `total` FROM `workerqueue` WHERE `executed` <= ? AND NOT `done`", NULL_DATE);
|
||||||
if (Dbm::is_result($s)) {
|
if (DBM::is_result($s)) {
|
||||||
return $s["total"];
|
return $s["total"];
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -157,7 +157,7 @@ class Worker {
|
||||||
private static function highestPriority() {
|
private static function highestPriority() {
|
||||||
$condition = array("`executed` <= ? AND NOT `done`", NULL_DATE);
|
$condition = array("`executed` <= ? AND NOT `done`", NULL_DATE);
|
||||||
$s = dba::select('workerqueue', array('priority'), $condition, array('limit' => 1, 'order' => array('priority')));
|
$s = dba::select('workerqueue', array('priority'), $condition, array('limit' => 1, 'order' => array('priority')));
|
||||||
if (Dbm::is_result($s)) {
|
if (DBM::is_result($s)) {
|
||||||
return $s["priority"];
|
return $s["priority"];
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -405,7 +405,7 @@ class Worker {
|
||||||
if ($max == 0) {
|
if ($max == 0) {
|
||||||
// the maximum number of possible user connections can be a system variable
|
// the maximum number of possible user connections can be a system variable
|
||||||
$r = dba::fetch_first("SHOW VARIABLES WHERE `variable_name` = 'max_user_connections'");
|
$r = dba::fetch_first("SHOW VARIABLES WHERE `variable_name` = 'max_user_connections'");
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$max = $r["Value"];
|
$max = $r["Value"];
|
||||||
}
|
}
|
||||||
// Or it can be granted. This overrides the system variable
|
// Or it can be granted. This overrides the system variable
|
||||||
|
|
@ -441,7 +441,7 @@ class Worker {
|
||||||
// We will now check for the system values.
|
// We will now check for the system values.
|
||||||
// This limit could be reached although the user limits are fine.
|
// This limit could be reached although the user limits are fine.
|
||||||
$r = dba::fetch_first("SHOW VARIABLES WHERE `variable_name` = 'max_connections'");
|
$r = dba::fetch_first("SHOW VARIABLES WHERE `variable_name` = 'max_connections'");
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$max = intval($r["Value"]);
|
$max = intval($r["Value"]);
|
||||||
|
|
@ -449,7 +449,7 @@ class Worker {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$r = dba::fetch_first("SHOW STATUS WHERE `variable_name` = 'Threads_connected'");
|
$r = dba::fetch_first("SHOW STATUS WHERE `variable_name` = 'Threads_connected'");
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$used = intval($r["Value"]);
|
$used = intval($r["Value"]);
|
||||||
|
|
@ -631,7 +631,7 @@ class Worker {
|
||||||
INNER JOIN `workerqueue` ON `workerqueue`.`pid` = `process`.`pid` AND NOT `done`");
|
INNER JOIN `workerqueue` ON `workerqueue`.`pid` = `process`.`pid` AND NOT `done`");
|
||||||
|
|
||||||
// No active processes at all? Fine
|
// No active processes at all? Fine
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$priorities = array();
|
$priorities = array();
|
||||||
|
|
@ -754,7 +754,7 @@ class Worker {
|
||||||
|
|
||||||
// There can already be jobs for us in the queue.
|
// There can already be jobs for us in the queue.
|
||||||
$r = dba::select('workerqueue', array(), array('pid' => getmypid(), 'done' => false));
|
$r = dba::select('workerqueue', array(), array('pid' => getmypid(), 'done' => false));
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
self::$db_duration += (microtime(true) - $stamp);
|
self::$db_duration += (microtime(true) - $stamp);
|
||||||
return dba::inArray($r);
|
return dba::inArray($r);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -7,7 +7,7 @@ use dba;
|
||||||
*
|
*
|
||||||
* This class contains functions that doesn't need to know if pdo, mysqli or whatever is used.
|
* This class contains functions that doesn't need to know if pdo, mysqli or whatever is used.
|
||||||
*/
|
*/
|
||||||
class Dbm {
|
class DBM {
|
||||||
/**
|
/**
|
||||||
* @brief Return a list of database processes
|
* @brief Return a list of database processes
|
||||||
*
|
*
|
||||||
|
|
@ -11,7 +11,7 @@ namespace Friendica\Network;
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Database\Dbm;
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
use dba;
|
use dba;
|
||||||
use Cache;
|
use Cache;
|
||||||
|
|
@ -397,7 +397,7 @@ class Probe {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$fields['updated'] = Dbm::date();
|
$fields['updated'] = DBM::date();
|
||||||
|
|
||||||
$condition = array('nurl' => normalise_link($data["url"]));
|
$condition = array('nurl' => normalise_link($data["url"]));
|
||||||
|
|
||||||
|
|
@ -420,7 +420,7 @@ class Probe {
|
||||||
'confirm' => $data['confirm'],
|
'confirm' => $data['confirm'],
|
||||||
'poco' => $data['poco'],
|
'poco' => $data['poco'],
|
||||||
'network' => $data['network'],
|
'network' => $data['network'],
|
||||||
'success_update' => Dbm::date());
|
'success_update' => DBM::date());
|
||||||
|
|
||||||
$fieldnames = array();
|
$fieldnames = array();
|
||||||
|
|
||||||
|
|
@ -1501,7 +1501,7 @@ class Probe {
|
||||||
|
|
||||||
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d AND `server` != '' LIMIT 1", intval($uid));
|
$r = q("SELECT * FROM `mailacct` WHERE `uid` = %d AND `server` != '' LIMIT 1", intval($uid));
|
||||||
|
|
||||||
if (Dbm::is_result($x) && Dbm::is_result($r)) {
|
if (DBM::is_result($x) && DBM::is_result($r)) {
|
||||||
$mailbox = construct_mailbox_name($r[0]);
|
$mailbox = construct_mailbox_name($r[0]);
|
||||||
$password = '';
|
$password = '';
|
||||||
openssl_private_decrypt(hex2bin($r[0]['pass']), $password, $x[0]['prvkey']);
|
openssl_private_decrypt(hex2bin($r[0]['pass']), $password, $x[0]['prvkey']);
|
||||||
|
|
|
||||||
|
|
@ -12,7 +12,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
use Friendica\Database\Dbm;
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
use dba;
|
use dba;
|
||||||
|
|
||||||
|
|
@ -35,7 +35,7 @@ require_once("include/xml.php");
|
||||||
* @brief This class contain functions to create and send DFRN XML files
|
* @brief This class contain functions to create and send DFRN XML files
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
class Dfrn {
|
class DFRN {
|
||||||
|
|
||||||
const DFRN_TOP_LEVEL = 0; // Top level posting
|
const DFRN_TOP_LEVEL = 0; // Top level posting
|
||||||
const DFRN_REPLY = 1; // Regular reply that is stored locally
|
const DFRN_REPLY = 1; // Regular reply that is stored locally
|
||||||
|
|
@ -119,7 +119,7 @@ class Dfrn {
|
||||||
dbesc($owner_nick)
|
dbesc($owner_nick)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! Dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -154,7 +154,7 @@ class Dfrn {
|
||||||
intval($owner_id)
|
intval($owner_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! Dbm::is_result($r)) {
|
if (! DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -252,7 +252,7 @@ class Dfrn {
|
||||||
/// @TODO This hook can't work anymore
|
/// @TODO This hook can't work anymore
|
||||||
// call_hooks('atom_feed', $atom);
|
// call_hooks('atom_feed', $atom);
|
||||||
|
|
||||||
if (!Dbm::is_result($items) || $onlyheader) {
|
if (!DBM::is_result($items) || $onlyheader) {
|
||||||
$atom = trim($doc->saveXML());
|
$atom = trim($doc->saveXML());
|
||||||
|
|
||||||
call_hooks('atom_feed_end', $atom);
|
call_hooks('atom_feed_end', $atom);
|
||||||
|
|
@ -321,7 +321,7 @@ class Dfrn {
|
||||||
intval($item_id)
|
intval($item_id)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -334,7 +334,7 @@ class Dfrn {
|
||||||
intval($item['uid'])
|
intval($item['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -582,7 +582,7 @@ class Dfrn {
|
||||||
$r = q("SELECT `id` FROM `profile` INNER JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
$r = q("SELECT `id` FROM `profile` INNER JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
||||||
WHERE (`hidewall` OR NOT `net-publish`) AND `user`.`uid` = %d",
|
WHERE (`hidewall` OR NOT `net-publish`) AND `user`.`uid` = %d",
|
||||||
intval($owner['uid']));
|
intval($owner['uid']));
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$hidewall = true;
|
$hidewall = true;
|
||||||
} else {
|
} else {
|
||||||
$hidewall = false;
|
$hidewall = false;
|
||||||
|
|
@ -638,7 +638,7 @@ class Dfrn {
|
||||||
INNER JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
INNER JOIN `user` ON `user`.`uid` = `profile`.`uid`
|
||||||
WHERE `profile`.`is-default` AND NOT `user`.`hidewall` AND `user`.`uid` = %d",
|
WHERE `profile`.`is-default` AND NOT `user`.`hidewall` AND `user`.`uid` = %d",
|
||||||
intval($owner['uid']));
|
intval($owner['uid']));
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$profile = $r[0];
|
$profile = $r[0];
|
||||||
|
|
||||||
xml::add_element($doc, $author, "poco:displayName", $profile["name"]);
|
xml::add_element($doc, $author, "poco:displayName", $profile["name"]);
|
||||||
|
|
@ -929,7 +929,7 @@ class Dfrn {
|
||||||
|
|
||||||
if (isset($parent_item)) {
|
if (isset($parent_item)) {
|
||||||
$r = dba::fetch_first("SELECT `conversation-uri`, `conversation-href` FROM `conversation` WHERE `item-uri` = ?", $item['parent-uri']);
|
$r = dba::fetch_first("SELECT `conversation-uri`, `conversation-href` FROM `conversation` WHERE `item-uri` = ?", $item['parent-uri']);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
if ($r['conversation-uri'] != '') {
|
if ($r['conversation-uri'] != '') {
|
||||||
$conversation_uri = $r['conversation-uri'];
|
$conversation_uri = $r['conversation-uri'];
|
||||||
}
|
}
|
||||||
|
|
@ -1044,7 +1044,7 @@ class Dfrn {
|
||||||
intval($owner["uid"]),
|
intval($owner["uid"]),
|
||||||
dbesc(normalise_link($mention)));
|
dbesc(normalise_link($mention)));
|
||||||
|
|
||||||
if (Dbm::is_result($r) && ($r[0]["forum"] || $r[0]["prv"])) {
|
if (DBM::is_result($r) && ($r[0]["forum"] || $r[0]["prv"])) {
|
||||||
xml::add_element($doc, $entry, "link", "", array("rel" => "mentioned",
|
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));
|
||||||
|
|
@ -1356,7 +1356,7 @@ class Dfrn {
|
||||||
dbesc(datetime_convert("UTC","UTC", $birthday)),
|
dbesc(datetime_convert("UTC","UTC", $birthday)),
|
||||||
dbesc("birthday"));
|
dbesc("birthday"));
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1402,7 +1402,7 @@ class Dfrn {
|
||||||
FROM `contact` WHERE `uid` = %d AND `nurl` = '%s' AND `network` != '%s'",
|
FROM `contact` WHERE `uid` = %d AND `nurl` = '%s' AND `network` != '%s'",
|
||||||
intval($importer["uid"]), dbesc(normalise_link($author["link"])), dbesc(NETWORK_STATUSNET));
|
intval($importer["uid"]), dbesc(normalise_link($author["link"])), dbesc(NETWORK_STATUSNET));
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
$author["contact-id"] = $r[0]["id"];
|
$author["contact-id"] = $r[0]["id"];
|
||||||
$author["network"] = $r[0]["network"];
|
$author["network"] = $r[0]["network"];
|
||||||
|
|
@ -1444,7 +1444,7 @@ class Dfrn {
|
||||||
$author["avatar"] = current($avatarlist);
|
$author["avatar"] = current($avatarlist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Dbm::is_result($r) && !$onlyfetch) {
|
if (DBM::is_result($r) && !$onlyfetch) {
|
||||||
logger("Check if contact details for contact " . $r[0]["id"] . " (" . $r[0]["nick"] . ") have to be updated.", LOGGER_DEBUG);
|
logger("Check if contact details for contact " . $r[0]["id"] . " (" . $r[0]["nick"] . ") have to be updated.", LOGGER_DEBUG);
|
||||||
|
|
||||||
$poco = array("url" => $contact["url"]);
|
$poco = array("url" => $contact["url"]);
|
||||||
|
|
@ -1596,7 +1596,7 @@ class Dfrn {
|
||||||
dbesc($contact["name"]), dbesc($contact["nick"]), dbesc($contact["about"]), dbesc($contact["location"]),
|
dbesc($contact["name"]), dbesc($contact["nick"]), dbesc($contact["about"]), dbesc($contact["location"]),
|
||||||
dbesc($contact["addr"]), dbesc($contact["keywords"]), dbesc($contact["bdyear"]),
|
dbesc($contact["addr"]), dbesc($contact["keywords"]), dbesc($contact["bdyear"]),
|
||||||
dbesc($contact["bd"]), intval($contact["hidden"]), dbesc($contact["xmpp"]),
|
dbesc($contact["bd"]), intval($contact["hidden"]), dbesc($contact["xmpp"]),
|
||||||
dbesc(Dbm::date($contact["name-date"])), dbesc(Dbm::date($contact["uri-date"])),
|
dbesc(DBM::date($contact["name-date"])), dbesc(DBM::date($contact["uri-date"])),
|
||||||
intval($contact["id"]), dbesc($contact["network"]));
|
intval($contact["id"]), dbesc($contact["network"]));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1765,7 +1765,7 @@ class Dfrn {
|
||||||
*
|
*
|
||||||
* @see https://github.com/friendica/friendica/pull/3254#discussion_r107315246
|
* @see https://github.com/friendica/friendica/pull/3254#discussion_r107315246
|
||||||
*/
|
*/
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1777,7 +1777,7 @@ class Dfrn {
|
||||||
dbesc($suggest["name"]),
|
dbesc($suggest["name"]),
|
||||||
dbesc($suggest["request"])
|
dbesc($suggest["request"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$fid = $r[0]["id"];
|
$fid = $r[0]["id"];
|
||||||
|
|
||||||
// OK, we do. Do we already have an introduction for this person ?
|
// OK, we do. Do we already have an introduction for this person ?
|
||||||
|
|
@ -1793,7 +1793,7 @@ class Dfrn {
|
||||||
*
|
*
|
||||||
* @see https://github.com/friendica/friendica/pull/3254#discussion_r107315246
|
* @see https://github.com/friendica/friendica/pull/3254#discussion_r107315246
|
||||||
*/
|
*/
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -1815,7 +1815,7 @@ class Dfrn {
|
||||||
* If no record in fcontact is found, below INSERT statement will not
|
* If no record in fcontact is found, below INSERT statement will not
|
||||||
* link an introduction to it.
|
* link an introduction to it.
|
||||||
*/
|
*/
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
// database record did not get created. Quietly give up.
|
// database record did not get created. Quietly give up.
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
@ -1897,7 +1897,7 @@ class Dfrn {
|
||||||
intval($importer["id"]),
|
intval($importer["id"]),
|
||||||
intval($importer["importer_uid"]));
|
intval($importer["importer_uid"]));
|
||||||
|
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger("Query failed to execute, no result returned in " . __FUNCTION__);
|
logger("Query failed to execute, no result returned in " . __FUNCTION__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
@ -1973,7 +1973,7 @@ class Dfrn {
|
||||||
$n, dbesc($f[0]),
|
$n, dbesc($f[0]),
|
||||||
intval($importer["importer_uid"]));
|
intval($importer["importer_uid"]));
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$x = q("UPDATE `item` SET `%s` = '%s' WHERE `%s` = '%s' AND `uid` = %d",
|
$x = q("UPDATE `item` SET `%s` = '%s' WHERE `%s` = '%s' AND `uid` = %d",
|
||||||
$n, dbesc($f[1]),
|
$n, dbesc($f[1]),
|
||||||
$n, dbesc($f[0]),
|
$n, dbesc($f[0]),
|
||||||
|
|
@ -2077,7 +2077,7 @@ class Dfrn {
|
||||||
LIMIT 1",
|
LIMIT 1",
|
||||||
dbesc($item["parent-uri"])
|
dbesc($item["parent-uri"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$r = q("SELECT `item`.`forum_mode`, `item`.`wall` FROM `item`
|
$r = q("SELECT `item`.`forum_mode`, `item`.`wall` FROM `item`
|
||||||
INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id`
|
INNER JOIN `contact` ON `contact`.`id` = `item`.`contact-id`
|
||||||
WHERE `item`.`uri` = '%s' AND (`item`.`parent-uri` = '%s' OR `item`.`thr-parent` = '%s')
|
WHERE `item`.`uri` = '%s' AND (`item`.`parent-uri` = '%s' OR `item`.`thr-parent` = '%s')
|
||||||
|
|
@ -2089,7 +2089,7 @@ class Dfrn {
|
||||||
dbesc($r[0]["parent-uri"]),
|
dbesc($r[0]["parent-uri"]),
|
||||||
intval($importer["importer_uid"])
|
intval($importer["importer_uid"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$is_a_remote_action = true;
|
$is_a_remote_action = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -2233,7 +2233,7 @@ class Dfrn {
|
||||||
dbesc($item["verb"]),
|
dbesc($item["verb"]),
|
||||||
dbesc($item["parent-uri"])
|
dbesc($item["parent-uri"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -2243,7 +2243,7 @@ class Dfrn {
|
||||||
dbesc($item["verb"]),
|
dbesc($item["verb"]),
|
||||||
dbesc($item["parent-uri"])
|
dbesc($item["parent-uri"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -2261,7 +2261,7 @@ class Dfrn {
|
||||||
intval($importer["importer_uid"])
|
intval($importer["importer_uid"])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger("Query failed to execute, no result returned in " . __FUNCTION__);
|
logger("Query failed to execute, no result returned in " . __FUNCTION__);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
@ -2362,7 +2362,7 @@ class Dfrn {
|
||||||
);
|
);
|
||||||
|
|
||||||
// Is there an existing item?
|
// Is there an existing item?
|
||||||
if (Dbm::is_result($current) && edited_timestamp_is_newer($current[0], $item) &&
|
if (DBM::is_result($current) && edited_timestamp_is_newer($current[0], $item) &&
|
||||||
(datetime_convert("UTC","UTC",$item["edited"]) < $current[0]["edited"])) {
|
(datetime_convert("UTC","UTC",$item["edited"]) < $current[0]["edited"])) {
|
||||||
logger("Item ".$item["uri"]." already existed.", LOGGER_DEBUG);
|
logger("Item ".$item["uri"]." already existed.", LOGGER_DEBUG);
|
||||||
return;
|
return;
|
||||||
|
|
@ -2597,7 +2597,7 @@ class Dfrn {
|
||||||
dbesc($item["uri"]),
|
dbesc($item["uri"]),
|
||||||
intval($importer["uid"])
|
intval($importer["uid"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$ev["id"] = $r[0]["id"];
|
$ev["id"] = $r[0]["id"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -2614,7 +2614,7 @@ class Dfrn {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update content if 'updated' changes
|
// Update content if 'updated' changes
|
||||||
if (Dbm::is_result($current)) {
|
if (DBM::is_result($current)) {
|
||||||
if (self::update_content($r[0], $item, $importer, $entrytype)) {
|
if (self::update_content($r[0], $item, $importer, $entrytype)) {
|
||||||
logger("Item ".$item["uri"]." was updated.", LOGGER_DEBUG);
|
logger("Item ".$item["uri"]." was updated.", LOGGER_DEBUG);
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -2637,7 +2637,7 @@ class Dfrn {
|
||||||
intval($posted_id),
|
intval($posted_id),
|
||||||
intval($importer["importer_uid"])
|
intval($importer["importer_uid"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$parent = $r[0]["parent"];
|
$parent = $r[0]["parent"];
|
||||||
$parent_uri = $r[0]["parent-uri"];
|
$parent_uri = $r[0]["parent-uri"];
|
||||||
}
|
}
|
||||||
|
|
@ -2732,7 +2732,7 @@ class Dfrn {
|
||||||
intval($importer["uid"]),
|
intval($importer["uid"]),
|
||||||
intval($importer["id"])
|
intval($importer["id"])
|
||||||
);
|
);
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger("Item with uri " . $uri . " from contact " . $importer["id"] . " for user " . $importer["uid"] . " wasn't found.", LOGGER_DEBUG);
|
logger("Item with uri " . $uri . " from contact " . $importer["id"] . " for user " . $importer["uid"] . " wasn't found.", LOGGER_DEBUG);
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -2762,7 +2762,7 @@ class Dfrn {
|
||||||
dbesc($xt->id),
|
dbesc($xt->id),
|
||||||
intval($importer["importer_uid"])
|
intval($importer["importer_uid"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($i)) {
|
if (DBM::is_result($i)) {
|
||||||
|
|
||||||
// For tags, the owner cannot remove the tag on the author's copy of the post.
|
// For tags, the owner cannot remove the tag on the author's copy of the post.
|
||||||
|
|
||||||
|
|
@ -2830,7 +2830,7 @@ class Dfrn {
|
||||||
dbesc($item["parent-uri"]),
|
dbesc($item["parent-uri"]),
|
||||||
intval($importer["uid"])
|
intval($importer["uid"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
q("UPDATE `item` SET `last-child` = 1 WHERE `id` = %d",
|
q("UPDATE `item` SET `last-child` = 1 WHERE `id` = %d",
|
||||||
intval($r[0]["id"])
|
intval($r[0]["id"])
|
||||||
);
|
);
|
||||||
|
|
@ -15,7 +15,7 @@ use Friendica\Core\System;
|
||||||
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 dba;
|
use dba;
|
||||||
|
|
@ -459,7 +459,7 @@ class Diaspora {
|
||||||
dbesc($msg["author"])
|
dbesc($msg["author"])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
logger("delivering to: ".$rr["username"]);
|
logger("delivering to: ".$rr["username"]);
|
||||||
self::dispatch($rr, $msg, $fields);
|
self::dispatch($rr, $msg, $fields);
|
||||||
|
|
@ -840,7 +840,7 @@ class Diaspora {
|
||||||
$r = q("SELECT `addr` FROM `gcontact` WHERE `id` = %d AND `addr` != ''",
|
$r = q("SELECT `addr` FROM `gcontact` WHERE `id` = %d AND `addr` != ''",
|
||||||
intval($gcontact_id));
|
intval($gcontact_id));
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return strtolower($r[0]["addr"]);
|
return strtolower($r[0]["addr"]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -848,7 +848,7 @@ class Diaspora {
|
||||||
$r = q("SELECT `network`, `addr`, `self`, `url`, `nick` FROM `contact` WHERE `id` = %d",
|
$r = q("SELECT `network`, `addr`, `self`, `url`, `nick` FROM `contact` WHERE `id` = %d",
|
||||||
intval($contact_id));
|
intval($contact_id));
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$contact = $r[0];
|
$contact = $r[0];
|
||||||
|
|
||||||
logger("contact 'self' = ".$contact['self']." 'url' = ".$contact['url'], LOGGER_DEBUG);
|
logger("contact 'self' = ".$contact['self']." 'url' = ".$contact['url'], LOGGER_DEBUG);
|
||||||
|
|
@ -882,7 +882,7 @@ class Diaspora {
|
||||||
dbesc($fcontact_guid)
|
dbesc($fcontact_guid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0]['url'];
|
return $r[0]['url'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -905,7 +905,7 @@ class Diaspora {
|
||||||
dbesc($handle)
|
dbesc($handle)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0];
|
return $r[0];
|
||||||
} else {
|
} else {
|
||||||
/*
|
/*
|
||||||
|
|
@ -918,7 +918,7 @@ class Diaspora {
|
||||||
/// @TODO Contact retrieval should be encapsulated into an "entity" class like `Contact`
|
/// @TODO Contact retrieval should be encapsulated into an "entity" class like `Contact`
|
||||||
$r = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1", intval($cid));
|
$r = q("SELECT * FROM `contact` WHERE `id` = %d LIMIT 1", intval($cid));
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0];
|
return $r[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -931,7 +931,7 @@ class Diaspora {
|
||||||
intval($uid),
|
intval($uid),
|
||||||
dbesc($nurl_sql)
|
dbesc($nurl_sql)
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0];
|
return $r[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1026,7 +1026,7 @@ class Diaspora {
|
||||||
dbesc($guid)
|
dbesc($guid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger("message ".$guid." already exists for user ".$uid);
|
logger("message ".$guid." already exists for user ".$uid);
|
||||||
return $r[0]["id"];
|
return $r[0]["id"];
|
||||||
}
|
}
|
||||||
|
|
@ -1298,7 +1298,7 @@ class Diaspora {
|
||||||
$r = q("SELECT `url`, `nick`, `network` FROM `fcontact` WHERE `addr`='%s' LIMIT 1", dbesc($addr));
|
$r = q("SELECT `url`, `nick`, `network` FROM `fcontact` WHERE `addr`='%s' LIMIT 1", dbesc($addr));
|
||||||
|
|
||||||
// Fallback
|
// Fallback
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
if ($parent_guid != '') {
|
if ($parent_guid != '') {
|
||||||
return "https://".substr($addr,strpos($addr,"@") + 1)."/posts/".$parent_guid."#".$guid;
|
return "https://".substr($addr,strpos($addr,"@") + 1)."/posts/".$parent_guid."#".$guid;
|
||||||
} else {
|
} else {
|
||||||
|
|
@ -1309,7 +1309,7 @@ class Diaspora {
|
||||||
// Friendica contacts are often detected as Diaspora contacts in the "fcontact" table
|
// Friendica contacts are often detected as Diaspora contacts in the "fcontact" table
|
||||||
// So we try another way as well.
|
// So we try another way as well.
|
||||||
$s = q("SELECT `network` FROM `gcontact` WHERE `nurl`='%s' LIMIT 1", dbesc(normalise_link($r[0]["url"])));
|
$s = q("SELECT `network` FROM `gcontact` WHERE `nurl`='%s' LIMIT 1", dbesc(normalise_link($r[0]["url"])));
|
||||||
if (Dbm::is_result($s)) {
|
if (DBM::is_result($s)) {
|
||||||
$r[0]["network"] = $s[0]["network"];
|
$r[0]["network"] = $s[0]["network"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1396,7 +1396,7 @@ class Diaspora {
|
||||||
$n, dbesc($f[0]),
|
$n, dbesc($f[0]),
|
||||||
intval($importer["uid"]));
|
intval($importer["uid"]));
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$x = q("UPDATE `item` SET `%s` = '%s' WHERE `%s` = '%s' AND `uid` = %d",
|
$x = q("UPDATE `item` SET `%s` = '%s' WHERE `%s` = '%s' AND `uid` = %d",
|
||||||
$n, dbesc($f[1]),
|
$n, dbesc($f[1]),
|
||||||
$n, dbesc($f[0]),
|
$n, dbesc($f[0]),
|
||||||
|
|
@ -1450,7 +1450,7 @@ class Diaspora {
|
||||||
private static function get_uri_from_guid($author, $guid, $onlyfound = false) {
|
private static function get_uri_from_guid($author, $guid, $onlyfound = false) {
|
||||||
|
|
||||||
$r = q("SELECT `uri` FROM `item` WHERE `guid` = '%s' LIMIT 1", dbesc($guid));
|
$r = q("SELECT `uri` FROM `item` WHERE `guid` = '%s' LIMIT 1", dbesc($guid));
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0]["uri"];
|
return $r[0]["uri"];
|
||||||
} elseif (!$onlyfound) {
|
} elseif (!$onlyfound) {
|
||||||
return $author.":".$guid;
|
return $author.":".$guid;
|
||||||
|
|
@ -1470,7 +1470,7 @@ class Diaspora {
|
||||||
private static function get_guid_from_uri($uri, $uid) {
|
private static function get_guid_from_uri($uri, $uid) {
|
||||||
|
|
||||||
$r = q("SELECT `guid` FROM `item` WHERE `uri` = '%s' AND `uid` = %d LIMIT 1", dbesc($uri), intval($uid));
|
$r = q("SELECT `guid` FROM `item` WHERE `uri` = '%s' AND `uid` = %d LIMIT 1", dbesc($uri), intval($uid));
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
return $r[0]["guid"];
|
return $r[0]["guid"];
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
|
@ -1487,10 +1487,10 @@ class Diaspora {
|
||||||
private static function importer_for_guid($guid) {
|
private static function importer_for_guid($guid) {
|
||||||
$item = dba::fetch_first("SELECT `uid` FROM `item` WHERE `origin` AND `guid` = ? LIMIT 1", $guid);
|
$item = dba::fetch_first("SELECT `uid` FROM `item` WHERE `origin` AND `guid` = ? LIMIT 1", $guid);
|
||||||
|
|
||||||
if (Dbm::is_result($item)) {
|
if (DBM::is_result($item)) {
|
||||||
logger("Found user ".$item['uid']." as owner of item ".$guid, LOGGER_DEBUG);
|
logger("Found user ".$item['uid']." as owner of item ".$guid, LOGGER_DEBUG);
|
||||||
$contact = dba::fetch_first("SELECT * FROM `contact` WHERE `self` AND `uid` = ?", $item['uid']);
|
$contact = dba::fetch_first("SELECT * FROM `contact` WHERE `self` AND `uid` = ?", $item['uid']);
|
||||||
if (Dbm::is_result($contact)) {
|
if (DBM::is_result($contact)) {
|
||||||
return $contact;
|
return $contact;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -1664,7 +1664,7 @@ class Diaspora {
|
||||||
dbesc($msg_guid),
|
dbesc($msg_guid),
|
||||||
intval($importer["uid"])
|
intval($importer["uid"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger("duplicate message already delivered.", LOGGER_DEBUG);
|
logger("duplicate message already delivered.", LOGGER_DEBUG);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
@ -1977,7 +1977,7 @@ class Diaspora {
|
||||||
dbesc($guid),
|
dbesc($guid),
|
||||||
intval($importer["uid"])
|
intval($importer["uid"])
|
||||||
);
|
);
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger("duplicate message already delivered.", LOGGER_DEBUG);
|
logger("duplicate message already delivered.", LOGGER_DEBUG);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
@ -2419,7 +2419,7 @@ class Diaspora {
|
||||||
FROM `item` WHERE `guid` = '%s' AND `visible` AND NOT `deleted` AND `body` != '' LIMIT 1",
|
FROM `item` WHERE `guid` = '%s' AND `visible` AND NOT `deleted` AND `body` != '' LIMIT 1",
|
||||||
dbesc($guid));
|
dbesc($guid));
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
logger("reshared message ".$guid." already exists on system.");
|
logger("reshared message ".$guid." already exists on system.");
|
||||||
|
|
||||||
// Maybe it is already a reshared item?
|
// Maybe it is already a reshared item?
|
||||||
|
|
@ -2441,7 +2441,7 @@ class Diaspora {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
$server = "https://".substr($orig_author, strpos($orig_author, "@") + 1);
|
$server = "https://".substr($orig_author, strpos($orig_author, "@") + 1);
|
||||||
logger("1st try: reshared message ".$guid." will be fetched via SSL from the server ".$server);
|
logger("1st try: reshared message ".$guid." will be fetched via SSL from the server ".$server);
|
||||||
$item_id = self::store_by_guid($guid, $server);
|
$item_id = self::store_by_guid($guid, $server);
|
||||||
|
|
@ -2458,7 +2458,7 @@ class Diaspora {
|
||||||
FROM `item` WHERE `id` = %d AND `visible` AND NOT `deleted` AND `body` != '' LIMIT 1",
|
FROM `item` WHERE `id` = %d AND `visible` AND NOT `deleted` AND `body` != '' LIMIT 1",
|
||||||
intval($item_id));
|
intval($item_id));
|
||||||
|
|
||||||
if (Dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
// If it is a reshared post from another network then reformat to avoid display problems with two share elements
|
// If it is a reshared post from another network then reformat to avoid display problems with two share elements
|
||||||
if (self::is_reshare($r[0]["body"], false)) {
|
if (self::is_reshare($r[0]["body"], false)) {
|
||||||
$r[0]["body"] = diaspora2bb(bb2diaspora($r[0]["body"]));
|
$r[0]["body"] = diaspora2bb(bb2diaspora($r[0]["body"]));
|
||||||
|
|
@ -2589,7 +2589,7 @@ class Diaspora {
|
||||||
$condition = array("`guid` = ? AND `uid` = ? AND NOT `file` LIKE '%%[%%' AND NOT `deleted`", $target_guid, $importer['uid']);
|
$condition = array("`guid` = ? AND `uid` = ? AND NOT `file` LIKE '%%[%%' AND NOT `deleted`", $target_guid, $importer['uid']);
|
||||||
}
|
}
|
||||||
$r = dba::select('item', $fields, $condition);
|
$r = dba::select('item', $fields, $condition);
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger("Target guid ".$target_guid." was not found on this system for user ".$importer['uid'].".");
|
logger("Target guid ".$target_guid." was not found on this system for user ".$importer['uid'].".");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
@ -3231,7 +3231,7 @@ class Diaspora {
|
||||||
private static function build_event($event_id) {
|
private static function build_event($event_id) {
|
||||||
|
|
||||||
$r = q("SELECT `guid`, `uid`, `start`, `finish`, `nofinish`, `summary`, `desc`, `location`, `adjust` FROM `event` WHERE `id` = %d", intval($event_id));
|
$r = q("SELECT `guid`, `uid`, `start`, `finish`, `nofinish`, `summary`, `desc`, `location`, `adjust` FROM `event` WHERE `id` = %d", intval($event_id));
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return array();
|
return array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -3240,14 +3240,14 @@ class Diaspora {
|
||||||
$eventdata = array();
|
$eventdata = array();
|
||||||
|
|
||||||
$r = q("SELECT `timezone` FROM `user` WHERE `uid` = %d", intval($event['uid']));
|
$r = q("SELECT `timezone` FROM `user` WHERE `uid` = %d", intval($event['uid']));
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return array();
|
return array();
|
||||||
}
|
}
|
||||||
|
|
||||||
$user = $r[0];
|
$user = $r[0];
|
||||||
|
|
||||||
$r = q("SELECT `addr`, `nick` FROM `contact` WHERE `uid` = %d AND `self`", intval($event['uid']));
|
$r = q("SELECT `addr`, `nick` FROM `contact` WHERE `uid` = %d AND `self`", intval($event['uid']));
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return array();
|
return array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -3424,7 +3424,7 @@ class Diaspora {
|
||||||
|
|
||||||
$p = q("SELECT `guid`, `uri`, `parent-uri` FROM `item` WHERE `uri` = '%s' LIMIT 1",
|
$p = q("SELECT `guid`, `uri`, `parent-uri` FROM `item` WHERE `uri` = '%s' LIMIT 1",
|
||||||
dbesc($item["thr-parent"]));
|
dbesc($item["thr-parent"]));
|
||||||
if (!Dbm::is_result($p))
|
if (!DBM::is_result($p))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
$parent = $p[0];
|
$parent = $p[0];
|
||||||
|
|
@ -3456,7 +3456,7 @@ class Diaspora {
|
||||||
|
|
||||||
$p = q("SELECT `guid`, `uri`, `parent-uri` FROM `item` WHERE `uri` = '%s' LIMIT 1",
|
$p = q("SELECT `guid`, `uri`, `parent-uri` FROM `item` WHERE `uri` = '%s' LIMIT 1",
|
||||||
dbesc($item["thr-parent"]));
|
dbesc($item["thr-parent"]));
|
||||||
if (!Dbm::is_result($p))
|
if (!DBM::is_result($p))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
$parent = $p[0];
|
$parent = $p[0];
|
||||||
|
|
@ -3505,7 +3505,7 @@ class Diaspora {
|
||||||
intval($item["parent"])
|
intval($item["parent"])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!Dbm::is_result($p))
|
if (!DBM::is_result($p))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
$parent = $p[0];
|
$parent = $p[0];
|
||||||
|
|
@ -3727,7 +3727,7 @@ class Diaspora {
|
||||||
intval($item["uid"])
|
intval($item["uid"])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
logger("conversation not found.");
|
logger("conversation not found.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -3886,14 +3886,14 @@ class Diaspora {
|
||||||
}
|
}
|
||||||
|
|
||||||
$r = q("SELECT `prvkey` FROM `user` WHERE `uid` = %d LIMIT 1", intval($contact['uid']));
|
$r = q("SELECT `prvkey` FROM `user` WHERE `uid` = %d LIMIT 1", intval($contact['uid']));
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$contact["uprvkey"] = $r[0]['prvkey'];
|
$contact["uprvkey"] = $r[0]['prvkey'];
|
||||||
|
|
||||||
$r = q("SELECT * FROM `item` WHERE `id` = %d LIMIT 1", intval($post_id));
|
$r = q("SELECT * FROM `item` WHERE `id` = %d LIMIT 1", intval($post_id));
|
||||||
if (!Dbm::is_result($r)) {
|
if (!DBM::is_result($r)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -9,7 +9,7 @@ namespace Friendica\Util;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Database\Dbm;
|
use Friendica\Database\DBM;
|
||||||
use Memcache;
|
use Memcache;
|
||||||
use dba;
|
use dba;
|
||||||
|
|
||||||
|
|
@ -121,7 +121,7 @@ class Lock {
|
||||||
dba::lock('locks');
|
dba::lock('locks');
|
||||||
$lock = dba::select('locks', array('locked', 'pid'), array('name' => $fn_name), array('limit' => 1));
|
$lock = dba::select('locks', array('locked', 'pid'), array('name' => $fn_name), array('limit' => 1));
|
||||||
|
|
||||||
if (Dbm::is_result($lock)) {
|
if (DBM::is_result($lock)) {
|
||||||
if ($lock['locked']) {
|
if ($lock['locked']) {
|
||||||
// When the process id isn't used anymore, we can safely claim the lock for us.
|
// When the process id isn't used anymore, we can safely claim the lock for us.
|
||||||
if (!posix_kill($lock['pid'], 0)) {
|
if (!posix_kill($lock['pid'], 0)) {
|
||||||
|
|
@ -136,7 +136,7 @@ class Lock {
|
||||||
dba::update('locks', array('locked' => true, 'pid' => getmypid()), array('name' => $fn_name));
|
dba::update('locks', array('locked' => true, 'pid' => getmypid()), array('name' => $fn_name));
|
||||||
$got_lock = true;
|
$got_lock = true;
|
||||||
}
|
}
|
||||||
} elseif (!Dbm::is_result($lock)) {
|
} elseif (!DBM::is_result($lock)) {
|
||||||
dba::insert('locks', array('name' => $fn_name, 'locked' => true, 'pid' => getmypid()));
|
dba::insert('locks', array('name' => $fn_name, 'locked' => true, 'pid' => getmypid()));
|
||||||
$got_lock = true;
|
$got_lock = true;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
33
update.php
33
update.php
|
|
@ -5,6 +5,7 @@ define('UPDATE_VERSION' , 1235);
|
||||||
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;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
|
@ -89,7 +90,7 @@ function update_1006() {
|
||||||
// create 's' keys for everybody that does not have one
|
// create 's' keys for everybody that does not have one
|
||||||
|
|
||||||
$r = q("SELECT * FROM `user` WHERE `spubkey` = '' ");
|
$r = q("SELECT * FROM `user` WHERE `spubkey` = '' ");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$sres=openssl_pkey_new(array('encrypt_key' => false ));
|
$sres=openssl_pkey_new(array('encrypt_key' => false ));
|
||||||
$sprvkey = '';
|
$sprvkey = '';
|
||||||
|
|
@ -126,7 +127,7 @@ function update_1010() {
|
||||||
function update_1011() {
|
function update_1011() {
|
||||||
q("ALTER TABLE `contact` ADD `nick` CHAR( 255 ) NOT NULL AFTER `name` ");
|
q("ALTER TABLE `contact` ADD `nick` CHAR( 255 ) NOT NULL AFTER `name` ");
|
||||||
$r = q("SELECT * FROM `contact` WHERE 1");
|
$r = q("SELECT * FROM `contact` WHERE 1");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
q("UPDATE `contact` SET `nick` = '%s' WHERE `id` = %d",
|
q("UPDATE `contact` SET `nick` = '%s' WHERE `id` = %d",
|
||||||
dbesc(basename($rr['url'])),
|
dbesc(basename($rr['url'])),
|
||||||
|
|
@ -149,7 +150,7 @@ function update_1014() {
|
||||||
require_once('include/Photo.php');
|
require_once('include/Photo.php');
|
||||||
q("ALTER TABLE `contact` ADD `micro` TEXT NOT NULL AFTER `thumb` ");
|
q("ALTER TABLE `contact` ADD `micro` TEXT NOT NULL AFTER `thumb` ");
|
||||||
$r = q("SELECT * FROM `photo` WHERE `scale` = 4");
|
$r = q("SELECT * FROM `photo` WHERE `scale` = 4");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$ph = new Photo($rr['data']);
|
$ph = new Photo($rr['data']);
|
||||||
if ($ph->is_valid()) {
|
if ($ph->is_valid()) {
|
||||||
|
|
@ -159,7 +160,7 @@ function update_1014() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$r = q("SELECT * FROM `contact` WHERE 1");
|
$r = q("SELECT * FROM `contact` WHERE 1");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if(stristr($rr['thumb'],'avatar'))
|
if(stristr($rr['thumb'],'avatar'))
|
||||||
q("UPDATE `contact` SET `micro` = '%s' WHERE `id` = %d",
|
q("UPDATE `contact` SET `micro` = '%s' WHERE `id` = %d",
|
||||||
|
|
@ -312,7 +313,7 @@ function update_1030() {
|
||||||
function update_1031() {
|
function update_1031() {
|
||||||
// Repair any bad links that slipped into the item table
|
// Repair any bad links that slipped into the item table
|
||||||
$r = q("SELECT `id`, `object` FROM `item` WHERE `object` != '' ");
|
$r = q("SELECT `id`, `object` FROM `item` WHERE `object` != '' ");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
if (strstr($rr['object'],'type="http')) {
|
if (strstr($rr['object'],'type="http')) {
|
||||||
q("UPDATE `item` SET `object` = '%s' WHERE `id` = %d",
|
q("UPDATE `item` SET `object` = '%s' WHERE `id` = %d",
|
||||||
|
|
@ -361,7 +362,7 @@ function update_1035() {
|
||||||
function update_1036() {
|
function update_1036() {
|
||||||
|
|
||||||
$r = dbq("SELECT * FROM `contact` WHERE `network` = 'dfrn' AND `photo` LIKE '%include/photo%' ");
|
$r = dbq("SELECT * FROM `contact` WHERE `network` = 'dfrn' AND `photo` LIKE '%include/photo%' ");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
q("UPDATE `contact` SET `photo` = '%s', `thumb` = '%s', `micro` = '%s' WHERE `id` = %d",
|
q("UPDATE `contact` SET `photo` = '%s', `thumb` = '%s', `micro` = '%s' WHERE `id` = %d",
|
||||||
dbesc(str_replace('include/photo','photo',$rr['photo'])),
|
dbesc(str_replace('include/photo','photo',$rr['photo'])),
|
||||||
|
|
@ -599,7 +600,7 @@ function update_1073() {
|
||||||
function update_1074() {
|
function update_1074() {
|
||||||
q("ALTER TABLE `user` ADD `hidewall` TINYINT( 1) NOT NULL DEFAULT '0' AFTER `blockwall` ");
|
q("ALTER TABLE `user` ADD `hidewall` TINYINT( 1) NOT NULL DEFAULT '0' AFTER `blockwall` ");
|
||||||
$r = q("SELECT `uid` FROM `profile` WHERE `is-default` = 1 AND `hidewall` = 1");
|
$r = q("SELECT `uid` FROM `profile` WHERE `is-default` = 1 AND `hidewall` = 1");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
q("UPDATE `user` SET `hidewall` = 1 WHERE `uid` = %d",
|
q("UPDATE `user` SET `hidewall` = 1 WHERE `uid` = %d",
|
||||||
intval($rr['uid'])
|
intval($rr['uid'])
|
||||||
|
|
@ -611,7 +612,7 @@ function update_1074() {
|
||||||
function update_1075() {
|
function update_1075() {
|
||||||
q("ALTER TABLE `user` ADD `guid` CHAR( 16 ) NOT NULL AFTER `uid` ");
|
q("ALTER TABLE `user` ADD `guid` CHAR( 16 ) NOT NULL AFTER `uid` ");
|
||||||
$r = q("SELECT `uid` FROM `user` WHERE 1");
|
$r = q("SELECT `uid` FROM `user` WHERE 1");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$found = true;
|
$found = true;
|
||||||
do {
|
do {
|
||||||
|
|
@ -690,10 +691,10 @@ function update_1082() {
|
||||||
ADD INDEX ( `guid` ) ");
|
ADD INDEX ( `guid` ) ");
|
||||||
// make certain the following code is only executed once
|
// make certain the following code is only executed once
|
||||||
$r = q("select `id` from `photo` where `guid` != '' limit 1");
|
$r = q("select `id` from `photo` where `guid` != '' limit 1");
|
||||||
if (dbm::is_result($r))
|
if (DBM::is_result($r))
|
||||||
return;
|
return;
|
||||||
$r = q("SELECT distinct(`resource-id`) FROM `photo` WHERE 1 group by `id`");
|
$r = q("SELECT distinct(`resource-id`) FROM `photo` WHERE 1 group by `id`");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$guid = get_guid();
|
$guid = get_guid();
|
||||||
q("update `photo` set `guid` = '%s' where `resource-id` = '%s'",
|
q("update `photo` set `guid` = '%s' where `resource-id` = '%s'",
|
||||||
|
|
@ -736,7 +737,7 @@ function update_1087() {
|
||||||
q("ALTER TABLE `item` ADD `commented` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' AFTER `edited` ");
|
q("ALTER TABLE `item` ADD `commented` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' AFTER `edited` ");
|
||||||
|
|
||||||
$r = q("SELECT `id` FROM `item` WHERE `parent` = `id` ");
|
$r = q("SELECT `id` FROM `item` WHERE `parent` = `id` ");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$x = q("SELECT max(`created`) AS `cdate` FROM `item` WHERE `parent` = %d LIMIT 1",
|
$x = q("SELECT max(`created`) AS `cdate` FROM `item` WHERE `parent` = %d LIMIT 1",
|
||||||
intval($rr['id'])
|
intval($rr['id'])
|
||||||
|
|
@ -859,7 +860,7 @@ function update_1100() {
|
||||||
require_once('include/text.php');
|
require_once('include/text.php');
|
||||||
|
|
||||||
$r = q("select id, url from contact where url != '' and nurl = '' ");
|
$r = q("select id, url from contact where url != '' and nurl = '' ");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
q("update contact set nurl = '%s' where id = %d",
|
q("update contact set nurl = '%s' where id = %d",
|
||||||
dbesc(normalise_link($rr['url'])),
|
dbesc(normalise_link($rr['url'])),
|
||||||
|
|
@ -1035,7 +1036,7 @@ function update_1120() {
|
||||||
// might be missing on new installs. We'll check.
|
// might be missing on new installs. We'll check.
|
||||||
|
|
||||||
$r = q("describe item");
|
$r = q("describe item");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach($r as $rr)
|
foreach($r as $rr)
|
||||||
if($rr['Field'] == 'spam')
|
if($rr['Field'] == 'spam')
|
||||||
return;
|
return;
|
||||||
|
|
@ -1173,7 +1174,7 @@ function update_1136() {
|
||||||
// order in reverse so that we save the newest entry
|
// order in reverse so that we save the newest entry
|
||||||
|
|
||||||
$r = q("select * from config where 1 order by id desc");
|
$r = q("select * from config where 1 order by id desc");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$found = false;
|
$found = false;
|
||||||
foreach($arr as $x) {
|
foreach($arr as $x) {
|
||||||
|
|
@ -1192,7 +1193,7 @@ function update_1136() {
|
||||||
|
|
||||||
$arr = array();
|
$arr = array();
|
||||||
$r = q("select * from pconfig where 1 order by id desc");
|
$r = q("select * from pconfig where 1 order by id desc");
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$found = false;
|
$found = false;
|
||||||
foreach($arr as $x) {
|
foreach($arr as $x) {
|
||||||
|
|
@ -1697,7 +1698,7 @@ function update_1190() {
|
||||||
);
|
);
|
||||||
|
|
||||||
// convert old forumlist addon entries in new config entries
|
// convert old forumlist addon entries in new config entries
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$uid = $rr['uid'];
|
$uid = $rr['uid'];
|
||||||
$family = $rr['cat'];
|
$family = $rr['cat'];
|
||||||
|
|
|
||||||
|
|
@ -11,6 +11,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
$frio = "view/theme/frio";
|
$frio = "view/theme/frio";
|
||||||
|
|
||||||
|
|
@ -225,7 +226,7 @@ function frio_remote_nav($a,&$nav) {
|
||||||
// user info
|
// user info
|
||||||
$r = q("SELECT `micro` FROM `contact` WHERE `uid` = %d AND `self`", intval($a->user['uid']));
|
$r = q("SELECT `micro` FROM `contact` WHERE `uid` = %d AND `self`", intval($a->user['uid']));
|
||||||
|
|
||||||
$r[0]['photo'] = (dbm::is_result($r) ? $a->remove_baseurl($r[0]['micro']) : "images/person-48.jpg");
|
$r[0]['photo'] = (DBM::is_result($r) ? $a->remove_baseurl($r[0]['micro']) : "images/person-48.jpg");
|
||||||
$r[0]['name'] = $a->user['username'];
|
$r[0]['name'] = $a->user['username'];
|
||||||
|
|
||||||
} elseif (!local_user() && remote_user()) {
|
} elseif (!local_user() && remote_user()) {
|
||||||
|
|
@ -241,9 +242,9 @@ function frio_remote_nav($a,&$nav) {
|
||||||
$r = false;
|
$r = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$nav['userinfo'] = array(
|
$nav['userinfo'] = array(
|
||||||
'icon' => (dbm::is_result($r) ? $r[0]['photo'] : "images/person-48.jpg"),
|
'icon' => (DBM::is_result($r) ? $r[0]['photo'] : "images/person-48.jpg"),
|
||||||
'name' => $r[0]['name'],
|
'name' => $r[0]['name'],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
@ -306,7 +307,7 @@ function frio_acl_lookup(App $a, &$results) {
|
||||||
$r = q("SELECT COUNT(*) AS `total` FROM `contact`
|
$r = q("SELECT COUNT(*) AS `total` FROM `contact`
|
||||||
WHERE `uid` = %d AND NOT `self` AND NOT `pending` $sql_extra $sql_extra2 ",
|
WHERE `uid` = %d AND NOT `self` AND NOT `pending` $sql_extra $sql_extra2 ",
|
||||||
intval($_SESSION['uid']));
|
intval($_SESSION['uid']));
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
$total = $r[0]["total"];
|
$total = $r[0]["total"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -318,7 +319,7 @@ function frio_acl_lookup(App $a, &$results) {
|
||||||
|
|
||||||
$contacts = array();
|
$contacts = array();
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$contacts[] = _contact_detail_for_template($rr);
|
$contacts[] = _contact_detail_for_template($rr);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -13,6 +13,7 @@ use Friendica\App;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Core\PConfig;
|
use Friendica\Core\PConfig;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
|
||||||
require_once "include/plugin.php";
|
require_once "include/plugin.php";
|
||||||
require_once "include/socgraph.php";
|
require_once "include/socgraph.php";
|
||||||
|
|
@ -141,7 +142,7 @@ function vier_community_info() {
|
||||||
$r = suggestion_query(local_user(), 0, 9);
|
$r = suggestion_query(local_user(), 0, 9);
|
||||||
|
|
||||||
$tpl = get_markup_template('ch_directory_item.tpl');
|
$tpl = get_markup_template('ch_directory_item.tpl');
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
$aside['$comunity_profiles_title'] = t('Community Profiles');
|
$aside['$comunity_profiles_title'] = t('Community Profiles');
|
||||||
$aside['$comunity_profiles_items'] = array();
|
$aside['$comunity_profiles_items'] = array();
|
||||||
|
|
@ -171,7 +172,7 @@ function vier_community_info() {
|
||||||
WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 $order LIMIT %d , %d ",
|
WHERE `is-default` = 1 $publish AND `user`.`blocked` = 0 $order LIMIT %d , %d ",
|
||||||
0, 9);
|
0, 9);
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
$aside['$lastusers_title'] = t('Last users');
|
$aside['$lastusers_title'] = t('Last users');
|
||||||
$aside['$lastusers_items'] = array();
|
$aside['$lastusers_items'] = array();
|
||||||
|
|
@ -381,7 +382,7 @@ function vier_community_info() {
|
||||||
|
|
||||||
$tpl = get_markup_template('ch_connectors.tpl');
|
$tpl = get_markup_template('ch_connectors.tpl');
|
||||||
|
|
||||||
if (dbm::is_result($r)) {
|
if (DBM::is_result($r)) {
|
||||||
|
|
||||||
$con_services = array();
|
$con_services = array();
|
||||||
$con_services['title'] = array("", t('Connect Services'), "", "");
|
$con_services['title'] = array("", t('Connect Services'), "", "");
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue