mirror of
https://github.com/friendica/friendica
synced 2024-11-12 00:23:00 +00:00
Merge branch 'develop' of https://github.com/friendica/friendica into develop
This commit is contained in:
commit
8ca53993a5
18 changed files with 132 additions and 65 deletions
|
@ -29,6 +29,10 @@ function add_page_info_data(array $data, $no_photos = false)
|
||||||
{
|
{
|
||||||
Addon::callHooks('page_info_data', $data);
|
Addon::callHooks('page_info_data', $data);
|
||||||
|
|
||||||
|
if (empty($data['type'])) {
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
// It maybe is a rich content, but if it does have everything that a link has,
|
// It maybe is a rich content, but if it does have everything that a link has,
|
||||||
// then treat it that way
|
// then treat it that way
|
||||||
if (($data["type"] == "rich") && is_string($data["title"]) &&
|
if (($data["type"] == "rich") && is_string($data["title"]) &&
|
||||||
|
|
|
@ -308,6 +308,7 @@ function dfrn_confirm_post(App $a, $handsfree = null)
|
||||||
|
|
||||||
if ($network === Protocol::DFRN) {
|
if ($network === Protocol::DFRN) {
|
||||||
$new_relation = Contact::FOLLOWER;
|
$new_relation = Contact::FOLLOWER;
|
||||||
|
|
||||||
if (($relation == Contact::SHARING) || ($duplex)) {
|
if (($relation == Contact::SHARING) || ($duplex)) {
|
||||||
$new_relation = Contact::FRIEND;
|
$new_relation = Contact::FRIEND;
|
||||||
}
|
}
|
||||||
|
@ -550,6 +551,7 @@ function dfrn_confirm_post(App $a, $handsfree = null)
|
||||||
logger('dfrn_confirm: request - photos imported');
|
logger('dfrn_confirm: request - photos imported');
|
||||||
|
|
||||||
$new_relation = Contact::SHARING;
|
$new_relation = Contact::SHARING;
|
||||||
|
|
||||||
if (($relation == Contact::FOLLOWER) || ($duplex)) {
|
if (($relation == Contact::FOLLOWER) || ($duplex)) {
|
||||||
$new_relation = Contact::FRIEND;
|
$new_relation = Contact::FRIEND;
|
||||||
}
|
}
|
||||||
|
|
|
@ -79,6 +79,7 @@ function photos_init(App $a) {
|
||||||
|
|
||||||
if ($albums) {
|
if ($albums) {
|
||||||
$a->data['albums'] = $albums;
|
$a->data['albums'] = $albums;
|
||||||
|
|
||||||
if ($albums_visible) {
|
if ($albums_visible) {
|
||||||
$ret['success'] = true;
|
$ret['success'] = true;
|
||||||
}
|
}
|
||||||
|
@ -117,7 +118,6 @@ function photos_init(App $a) {
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (empty($a->page['aside'])) {
|
if (empty($a->page['aside'])) {
|
||||||
$a->page['aside'] = '';
|
$a->page['aside'] = '';
|
||||||
}
|
}
|
||||||
|
@ -166,7 +166,7 @@ function photos_post(App $a)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($contact_id) {
|
if ($contact_id > 0) {
|
||||||
$r = q("SELECT `uid` FROM `contact` WHERE `blocked` = 0 AND `pending` = 0 AND `id` = %d AND `uid` = %d LIMIT 1",
|
$r = q("SELECT `uid` FROM `contact` WHERE `blocked` = 0 AND `pending` = 0 AND `id` = %d AND `uid` = %d LIMIT 1",
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
|
@ -204,6 +204,7 @@ function photos_post(App $a)
|
||||||
DBA::escape($album),
|
DBA::escape($album),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!DBA::isResult($r)) {
|
if (!DBA::isResult($r)) {
|
||||||
notice(L10n::t('Album not found.') . EOL);
|
notice(L10n::t('Album not found.') . EOL);
|
||||||
goaway($_SESSION['photo_return']);
|
goaway($_SESSION['photo_return']);
|
||||||
|
@ -253,6 +254,7 @@ function photos_post(App $a)
|
||||||
'$confirm_name' => 'dropalbum', // Needed so that confirmation will bring us back into this if statement
|
'$confirm_name' => 'dropalbum', // Needed so that confirmation will bring us back into this if statement
|
||||||
'$cancel' => L10n::t('Cancel'),
|
'$cancel' => L10n::t('Cancel'),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$a->error = 1; // Set $a->error so the other module functions don't execute
|
$a->error = 1; // Set $a->error so the other module functions don't execute
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -273,6 +275,7 @@ function photos_post(App $a)
|
||||||
DBA::escape($album)
|
DBA::escape($album)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (DBA::isResult($r)) {
|
if (DBA::isResult($r)) {
|
||||||
foreach ($r as $rr) {
|
foreach ($r as $rr) {
|
||||||
$res[] = "'" . DBA::escape($rr['rid']) . "'" ;
|
$res[] = "'" . DBA::escape($rr['rid']) . "'" ;
|
||||||
|
@ -313,6 +316,7 @@ function photos_post(App $a)
|
||||||
// Check if we should do HTML-based delete confirmation
|
// Check if we should do HTML-based delete confirmation
|
||||||
if (!empty($_REQUEST['confirm'])) {
|
if (!empty($_REQUEST['confirm'])) {
|
||||||
$drop_url = $a->query_string;
|
$drop_url = $a->query_string;
|
||||||
|
|
||||||
$a->page['content'] = replace_macros(get_markup_template('confirm.tpl'), [
|
$a->page['content'] = replace_macros(get_markup_template('confirm.tpl'), [
|
||||||
'$method' => 'post',
|
'$method' => 'post',
|
||||||
'$message' => L10n::t('Do you really want to delete this photo?'),
|
'$message' => L10n::t('Do you really want to delete this photo?'),
|
||||||
|
@ -322,6 +326,7 @@ function photos_post(App $a)
|
||||||
'$confirm_name' => 'delete', // Needed so that confirmation will bring us back into this if statement
|
'$confirm_name' => 'delete', // Needed so that confirmation will bring us back into this if statement
|
||||||
'$cancel' => L10n::t('Cancel'),
|
'$cancel' => L10n::t('Cancel'),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$a->error = 1; // Set $a->error so the other module functions don't execute
|
$a->error = 1; // Set $a->error so the other module functions don't execute
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -434,6 +439,7 @@ function photos_post(App $a)
|
||||||
DBA::escape($resource_id),
|
DBA::escape($resource_id),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (DBA::isResult($p)) {
|
if (DBA::isResult($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",
|
||||||
|
@ -521,28 +527,35 @@ function photos_post(App $a)
|
||||||
if (strpos($tag, '@') === 0) {
|
if (strpos($tag, '@') === 0) {
|
||||||
$profile = '';
|
$profile = '';
|
||||||
$name = substr($tag,1);
|
$name = substr($tag,1);
|
||||||
|
|
||||||
if ((strpos($name, '@')) || (strpos($name, 'http://'))) {
|
if ((strpos($name, '@')) || (strpos($name, 'http://'))) {
|
||||||
$newname = $name;
|
$newname = $name;
|
||||||
$links = @Probe::lrdd($name);
|
$links = @Probe::lrdd($name);
|
||||||
|
|
||||||
if (count($links)) {
|
if (count($links)) {
|
||||||
foreach ($links as $link) {
|
foreach ($links as $link) {
|
||||||
if ($link['@attributes']['rel'] === 'http://webfinger.net/rel/profile-page') {
|
if ($link['@attributes']['rel'] === 'http://webfinger.net/rel/profile-page') {
|
||||||
$profile = $link['@attributes']['href'];
|
$profile = $link['@attributes']['href'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($link['@attributes']['rel'] === 'salmon') {
|
if ($link['@attributes']['rel'] === 'salmon') {
|
||||||
$salmon = '$url:' . str_replace(',', '%sc', $link['@attributes']['href']);
|
$salmon = '$url:' . str_replace(',', '%sc', $link['@attributes']['href']);
|
||||||
|
|
||||||
if (strlen($inform)) {
|
if (strlen($inform)) {
|
||||||
$inform .= ',';
|
$inform .= ',';
|
||||||
}
|
}
|
||||||
|
|
||||||
$inform .= $salmon;
|
$inform .= $salmon;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$taginfo[] = [$newname, $profile, $salmon];
|
$taginfo[] = [$newname, $profile, $salmon];
|
||||||
} else {
|
} else {
|
||||||
$newname = $name;
|
$newname = $name;
|
||||||
$alias = '';
|
$alias = '';
|
||||||
$tagcid = 0;
|
$tagcid = 0;
|
||||||
|
|
||||||
if (strrpos($newname, '+')) {
|
if (strrpos($newname, '+')) {
|
||||||
$tagcid = intval(substr($newname, strrpos($newname, '+') + 1));
|
$tagcid = intval(substr($newname, strrpos($newname, '+') + 1));
|
||||||
}
|
}
|
||||||
|
@ -574,6 +587,7 @@ function photos_post(App $a)
|
||||||
if (DBA::isResult($r)) {
|
if (DBA::isResult($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'];
|
||||||
if (strlen($inform)) {
|
if (strlen($inform)) {
|
||||||
$inform .= ',';
|
$inform .= ',';
|
||||||
|
@ -581,15 +595,18 @@ function photos_post(App $a)
|
||||||
$inform .= $notify;
|
$inform .= $notify;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($profile) {
|
if ($profile) {
|
||||||
if (substr($notify, 0, 4) === 'cid:') {
|
if (substr($notify, 0, 4) === 'cid:') {
|
||||||
$taginfo[] = [$newname, $profile, $notify, $r[0], '@[url=' . str_replace(',','%2c',$profile) . ']' . $newname . '[/url]'];
|
$taginfo[] = [$newname, $profile, $notify, $r[0], '@[url=' . str_replace(',','%2c',$profile) . ']' . $newname . '[/url]'];
|
||||||
} else {
|
} else {
|
||||||
$taginfo[] = [$newname, $profile, $notify, null, $str_tags .= '@[url=' . $profile . ']' . $newname . '[/url]'];
|
$taginfo[] = [$newname, $profile, $notify, null, $str_tags .= '@[url=' . $profile . ']' . $newname . '[/url]'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strlen($str_tags)) {
|
if (strlen($str_tags)) {
|
||||||
$str_tags .= ',';
|
$str_tags .= ',';
|
||||||
}
|
}
|
||||||
|
|
||||||
$profile = str_replace(',', '%2c', $profile);
|
$profile = str_replace(',', '%2c', $profile);
|
||||||
$str_tags .= '@[url='.$profile.']'.$newname.'[/url]';
|
$str_tags .= '@[url='.$profile.']'.$newname.'[/url]';
|
||||||
}
|
}
|
||||||
|
@ -622,6 +639,7 @@ function photos_post(App $a)
|
||||||
$best = 2;
|
$best = 2;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (intval($scales['scale']) == 4) {
|
if (intval($scales['scale']) == 4) {
|
||||||
$best = 4;
|
$best = 4;
|
||||||
break;
|
break;
|
||||||
|
@ -1376,7 +1394,7 @@ function photos_content(App $a)
|
||||||
$a->set_pager_total(DBA::count('item', $condition));
|
$a->set_pager_total(DBA::count('item', $condition));
|
||||||
|
|
||||||
$params = ['order' => ['id'], 'limit' => [$a->pager['start'], $a->pager['itemspage']]];
|
$params = ['order' => ['id'], 'limit' => [$a->pager['start'], $a->pager['itemspage']]];
|
||||||
$result = Item::selectForUser($link_item['uid'], [], $condition, $params);
|
$result = Item::selectForUser($link_item['uid'], Item::ITEM_FIELDLIST, $condition, $params);
|
||||||
$items = Item::inArray($result);
|
$items = Item::inArray($result);
|
||||||
|
|
||||||
if (local_user() && (local_user() == $link_item['uid'])) {
|
if (local_user() && (local_user() == $link_item['uid'])) {
|
||||||
|
@ -1551,7 +1569,7 @@ function photos_content(App $a)
|
||||||
$body_e = BBCode::convert($item['body']);
|
$body_e = BBCode::convert($item['body']);
|
||||||
|
|
||||||
$comments .= replace_macros($template,[
|
$comments .= replace_macros($template,[
|
||||||
'$id' => $item['item_id'],
|
'$id' => $item['id'],
|
||||||
'$profile_url' => $profile_url,
|
'$profile_url' => $profile_url,
|
||||||
'$name' => $item['author-name'],
|
'$name' => $item['author-name'],
|
||||||
'$thumb' => $item['author-avatar'],
|
'$thumb' => $item['author-avatar'],
|
||||||
|
|
|
@ -33,8 +33,9 @@ function repair_ostatus_content(App $a) {
|
||||||
intval(Contact::FRIEND),
|
intval(Contact::FRIEND),
|
||||||
intval(Contact::SHARING));
|
intval(Contact::SHARING));
|
||||||
|
|
||||||
if (!$r)
|
if (!DBA::isResult($r)) {
|
||||||
return ($o . L10n::t("Error"));
|
return ($o . L10n::t("Error"));
|
||||||
|
}
|
||||||
|
|
||||||
$total = $r[0]["total"];
|
$total = $r[0]["total"];
|
||||||
|
|
||||||
|
@ -47,7 +48,7 @@ function repair_ostatus_content(App $a) {
|
||||||
intval(Contact::FRIEND),
|
intval(Contact::FRIEND),
|
||||||
intval(Contact::SHARING), $counter++);
|
intval(Contact::SHARING), $counter++);
|
||||||
|
|
||||||
if (!$r) {
|
if (!DBA::isResult($r)) {
|
||||||
$o .= L10n::t("Done");
|
$o .= L10n::t("Done");
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
|
@ -153,10 +153,13 @@ function salmon_post(App $a, $xml = '') {
|
||||||
DBA::escape(normalise_link($author_link)),
|
DBA::escape(normalise_link($author_link)),
|
||||||
intval($importer['uid'])
|
intval($importer['uid'])
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!DBA::isResult($r)) {
|
if (!DBA::isResult($r)) {
|
||||||
logger('Author ' . $author_link . ' unknown to user ' . $importer['uid'] . '.');
|
logger('Author ' . $author_link . ' unknown to user ' . $importer['uid'] . '.');
|
||||||
|
|
||||||
if (PConfig::get($importer['uid'], 'system', 'ostatus_autofriend')) {
|
if (PConfig::get($importer['uid'], 'system', 'ostatus_autofriend')) {
|
||||||
$result = Contact::createFromProbe($importer['uid'], $author_link);
|
$result = Contact::createFromProbe($importer['uid'], $author_link);
|
||||||
|
|
||||||
if ($result['success']) {
|
if ($result['success']) {
|
||||||
$r = q("SELECT * FROM `contact` WHERE `network` = '%s' AND ( `url` = '%s' OR `alias` = '%s')
|
$r = q("SELECT * FROM `contact` WHERE `network` = '%s' AND ( `url` = '%s' OR `alias` = '%s')
|
||||||
AND `uid` = %d LIMIT 1",
|
AND `uid` = %d LIMIT 1",
|
||||||
|
|
|
@ -13,7 +13,8 @@ use Friendica\Model\Contact;
|
||||||
use Friendica\Model\GContact;
|
use Friendica\Model\GContact;
|
||||||
use Friendica\Util\Proxy as ProxyUtils;
|
use Friendica\Util\Proxy as ProxyUtils;
|
||||||
|
|
||||||
function suggest_init(App $a) {
|
function suggest_init(App $a)
|
||||||
|
{
|
||||||
if (! local_user()) {
|
if (! local_user()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -274,6 +274,7 @@ function videos_content(App $a)
|
||||||
// perhaps they're visiting - but not a community page, so they wouldn't have write access
|
// perhaps they're visiting - but not a community page, so they wouldn't have write access
|
||||||
if (remote_user() && (!$visitor)) {
|
if (remote_user() && (!$visitor)) {
|
||||||
$contact_id = 0;
|
$contact_id = 0;
|
||||||
|
|
||||||
if (!empty($_SESSION['remote'])) {
|
if (!empty($_SESSION['remote'])) {
|
||||||
foreach($_SESSION['remote'] as $v) {
|
foreach($_SESSION['remote'] as $v) {
|
||||||
if($v['uid'] == $owner_uid) {
|
if($v['uid'] == $owner_uid) {
|
||||||
|
|
|
@ -21,6 +21,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",
|
||||||
DBA::escape($nick)
|
DBA::escape($nick)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (! DBA::isResult($r)) {
|
if (! DBA::isResult($r)) {
|
||||||
if ($r_json) {
|
if ($r_json) {
|
||||||
echo json_encode(['error' => L10n::t('Invalid request.')]);
|
echo json_encode(['error' => L10n::t('Invalid request.')]);
|
||||||
|
@ -28,12 +29,12 @@ function wall_attach_post(App $a) {
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if ($r_json) {
|
if ($r_json) {
|
||||||
echo json_encode(['error' => L10n::t('Invalid request.')]);
|
echo json_encode(['error' => L10n::t('Invalid request.')]);
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,11 +46,12 @@ function wall_attach_post(App $a) {
|
||||||
$page_owner_nick = $r[0]['nickname'];
|
$page_owner_nick = $r[0]['nickname'];
|
||||||
$community_page = (($r[0]['page-flags'] == Contact::PAGE_COMMUNITY) ? true : false);
|
$community_page = (($r[0]['page-flags'] == Contact::PAGE_COMMUNITY) ? true : false);
|
||||||
|
|
||||||
if((local_user()) && (local_user() == $page_owner_uid))
|
if ((local_user()) && (local_user() == $page_owner_uid)) {
|
||||||
$can_post = true;
|
$can_post = true;
|
||||||
else {
|
} else {
|
||||||
if ($community_page && remote_user()) {
|
if ($community_page && remote_user()) {
|
||||||
$contact_id = 0;
|
$contact_id = 0;
|
||||||
|
|
||||||
if (is_array($_SESSION['remote'])) {
|
if (is_array($_SESSION['remote'])) {
|
||||||
foreach ($_SESSION['remote'] as $v) {
|
foreach ($_SESSION['remote'] as $v) {
|
||||||
if ($v['uid'] == $page_owner_uid) {
|
if ($v['uid'] == $page_owner_uid) {
|
||||||
|
@ -58,12 +60,13 @@ function wall_attach_post(App $a) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if($contact_id) {
|
|
||||||
|
|
||||||
|
if ($contact_id > 0) {
|
||||||
$r = q("SELECT `uid` FROM `contact` WHERE `blocked` = 0 AND `pending` = 0 AND `id` = %d AND `uid` = %d LIMIT 1",
|
$r = q("SELECT `uid` FROM `contact` WHERE `blocked` = 0 AND `pending` = 0 AND `id` = %d AND `uid` = %d LIMIT 1",
|
||||||
intval($contact_id),
|
intval($contact_id),
|
||||||
intval($page_owner_uid)
|
intval($page_owner_uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (DBA::isResult($r)) {
|
if (DBA::isResult($r)) {
|
||||||
$can_post = true;
|
$can_post = true;
|
||||||
$visitor = $contact_id;
|
$visitor = $contact_id;
|
||||||
|
@ -71,6 +74,7 @@ function wall_attach_post(App $a) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! $can_post) {
|
if (! $can_post) {
|
||||||
if ($r_json) {
|
if ($r_json) {
|
||||||
echo json_encode(['error' => L10n::t('Permission denied.')]);
|
echo json_encode(['error' => L10n::t('Permission denied.')]);
|
||||||
|
@ -110,7 +114,7 @@ function wall_attach_post(App $a) {
|
||||||
killme();
|
killme();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(($maxfilesize) && ($filesize > $maxfilesize)) {
|
if ($maxfilesize && $filesize > $maxfilesize) {
|
||||||
$msg = L10n::t('File exceeds size limit of %s', formatBytes($maxfilesize));
|
$msg = L10n::t('File exceeds size limit of %s', formatBytes($maxfilesize));
|
||||||
if ($r_json) {
|
if ($r_json) {
|
||||||
echo json_encode(['error' => $msg]);
|
echo json_encode(['error' => $msg]);
|
||||||
|
|
|
@ -91,6 +91,7 @@ class DBA
|
||||||
self::$connection->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
|
self::$connection->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
|
||||||
self::$connected = true;
|
self::$connected = true;
|
||||||
} catch (PDOException $e) {
|
} catch (PDOException $e) {
|
||||||
|
/// @TODO At least log exception, don't ignore it!
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -255,6 +256,7 @@ class DBA
|
||||||
switch (self::$driver) {
|
switch (self::$driver) {
|
||||||
case 'pdo':
|
case 'pdo':
|
||||||
return substr(@self::$connection->quote($str, PDO::PARAM_STR), 1, -1);
|
return substr(@self::$connection->quote($str, PDO::PARAM_STR), 1, -1);
|
||||||
|
|
||||||
case 'mysqli':
|
case 'mysqli':
|
||||||
return @self::$connection->real_escape_string($str);
|
return @self::$connection->real_escape_string($str);
|
||||||
}
|
}
|
||||||
|
@ -932,13 +934,11 @@ class DBA
|
||||||
|
|
||||||
switch (self::$driver) {
|
switch (self::$driver) {
|
||||||
case 'pdo':
|
case 'pdo':
|
||||||
if (self::$connection->inTransaction()) {
|
if (!self::$connection->inTransaction() && !self::$connection->beginTransaction()) {
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (!self::$connection->beginTransaction()) {
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'mysqli':
|
case 'mysqli':
|
||||||
if (!self::$connection->begin_transaction()) {
|
if (!self::$connection->begin_transaction()) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -957,10 +957,13 @@ class DBA
|
||||||
if (!self::$connection->inTransaction()) {
|
if (!self::$connection->inTransaction()) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return self::$connection->commit();
|
return self::$connection->commit();
|
||||||
|
|
||||||
case 'mysqli':
|
case 'mysqli':
|
||||||
return self::$connection->commit();
|
return self::$connection->commit();
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -993,6 +996,7 @@ class DBA
|
||||||
}
|
}
|
||||||
$ret = self::$connection->rollBack();
|
$ret = self::$connection->rollBack();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'mysqli':
|
case 'mysqli':
|
||||||
$ret = self::$connection->rollback();
|
$ret = self::$connection->rollback();
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -1526,7 +1526,9 @@ class Contact extends BaseObject
|
||||||
$item['guid'] = '';
|
$item['guid'] = '';
|
||||||
$item['tag'] = '';
|
$item['tag'] = '';
|
||||||
$item['attach'] = '';
|
$item['attach'] = '';
|
||||||
|
|
||||||
$slap = OStatus::salmon($item, $owner);
|
$slap = OStatus::salmon($item, $owner);
|
||||||
|
|
||||||
if (!empty($contact['notify'])) {
|
if (!empty($contact['notify'])) {
|
||||||
Salmon::slapper($owner, $contact['notify'], $slap);
|
Salmon::slapper($owner, $contact['notify'], $slap);
|
||||||
}
|
}
|
||||||
|
@ -1540,7 +1542,15 @@ class Contact extends BaseObject
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function updateSslPolicy($contact, $new_policy)
|
/**
|
||||||
|
* @brief Updated contact's SSL policy
|
||||||
|
*
|
||||||
|
* @param array $contact Contact array
|
||||||
|
* @param string $new_policy New policy, valid: self,full
|
||||||
|
*
|
||||||
|
* @return array Contact array with updated values
|
||||||
|
*/
|
||||||
|
public static function updateSslPolicy(array $contact, $new_policy)
|
||||||
{
|
{
|
||||||
$ssl_changed = false;
|
$ssl_changed = false;
|
||||||
if ((intval($new_policy) == SSL_POLICY_SELFSIGN || $new_policy === 'self') && strstr($contact['url'], 'https:')) {
|
if ((intval($new_policy) == SSL_POLICY_SELFSIGN || $new_policy === 'self') && strstr($contact['url'], 'https:')) {
|
||||||
|
|
|
@ -40,6 +40,7 @@ class Conversation
|
||||||
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'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($arr['thr-parent']) && ($arr['thr-parent'] != $arr['uri'])) {
|
if (isset($arr['thr-parent']) && ($arr['thr-parent'] != $arr['uri'])) {
|
||||||
$conversation['reply-to-uri'] = $arr['thr-parent'];
|
$conversation['reply-to-uri'] = $arr['thr-parent'];
|
||||||
}
|
}
|
||||||
|
|
|
@ -915,6 +915,11 @@ class GContact
|
||||||
intval($uid)
|
intval($uid)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
if (!DBA::isResult($r)) {
|
||||||
|
logger('Cannot find user with uid=' . $uid, LOGGER_INFO);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
$location = Profile::formatLocation(
|
$location = Profile::formatLocation(
|
||||||
["locality" => $r[0]["locality"], "region" => $r[0]["region"], "country-name" => $r[0]["country-name"]]
|
["locality" => $r[0]["locality"], "region" => $r[0]["region"], "country-name" => $r[0]["country-name"]]
|
||||||
);
|
);
|
||||||
|
|
|
@ -71,9 +71,11 @@ class User
|
||||||
public static function getOwnerDataByNick($nick)
|
public static function getOwnerDataByNick($nick)
|
||||||
{
|
{
|
||||||
$user = DBA::selectFirst('user', ['uid'], ['nickname' => $nick]);
|
$user = DBA::selectFirst('user', ['uid'], ['nickname' => $nick]);
|
||||||
|
|
||||||
if (!DBA::isResult($user)) {
|
if (!DBA::isResult($user)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return self::getOwnerDataById($user['uid']);
|
return self::getOwnerDataById($user['uid']);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -934,11 +934,12 @@ class Probe
|
||||||
|
|
||||||
$prof_data = [];
|
$prof_data = [];
|
||||||
|
|
||||||
// The "addr" is not always part of the fetched data
|
if (empty($data["addr"])) {
|
||||||
if (!empty($data["addr"])) {
|
$probe_data = self::uri($profile_link);
|
||||||
$prof_data["addr"] = $data["addr"];
|
$data["addr"] = $probe_data["addr"];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$prof_data["addr"] = $data["addr"];
|
||||||
$prof_data["nick"] = $data["nick"];
|
$prof_data["nick"] = $data["nick"];
|
||||||
$prof_data["dfrn-request"] = $data["request"];
|
$prof_data["dfrn-request"] = $data["request"];
|
||||||
$prof_data["dfrn-confirm"] = $data["confirm"];
|
$prof_data["dfrn-confirm"] = $data["confirm"];
|
||||||
|
|
|
@ -1330,6 +1330,7 @@ class DFRN
|
||||||
$key = openssl_random_pseudo_bytes(16);
|
$key = openssl_random_pseudo_bytes(16);
|
||||||
$data = self::aesEncrypt($postvars['data'], $key);
|
$data = self::aesEncrypt($postvars['data'], $key);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
logger("rino: invalid requested version '$rino_remote_version'");
|
logger("rino: invalid requested version '$rino_remote_version'");
|
||||||
Contact::markForArchival($contact);
|
Contact::markForArchival($contact);
|
||||||
|
|
|
@ -2425,10 +2425,11 @@ class Diaspora
|
||||||
|
|
||||||
Contact::updateAvatar($contact_record["photo"], $importer["uid"], $contact_record["id"]);
|
Contact::updateAvatar($contact_record["photo"], $importer["uid"], $contact_record["id"]);
|
||||||
|
|
||||||
// technically they are sharing with us (Contact::SHARING),
|
/*
|
||||||
// but if our page-type is PAGE_COMMUNITY or PAGE_SOAPBOX
|
* technically they are sharing with us (Contact::SHARING),
|
||||||
// we are going to change the relationship and make them a follower.
|
* but if our page-type is Profile::PAGE_COMMUNITY or Profile::PAGE_SOAPBOX
|
||||||
|
* we are going to change the relationship and make them a follower.
|
||||||
|
*/
|
||||||
if (($importer["page-flags"] == Contact::PAGE_FREELOVE) && $sharing && $following) {
|
if (($importer["page-flags"] == Contact::PAGE_FREELOVE) && $sharing && $following) {
|
||||||
$new_relation = Contact::FRIEND;
|
$new_relation = Contact::FRIEND;
|
||||||
} elseif (($importer["page-flags"] == Contact::PAGE_FREELOVE) && $sharing) {
|
} elseif (($importer["page-flags"] == Contact::PAGE_FREELOVE) && $sharing) {
|
||||||
|
@ -2755,7 +2756,7 @@ class Diaspora
|
||||||
*
|
*
|
||||||
* @return int The message id of the newly created item
|
* @return int The message id of the newly created item
|
||||||
*/
|
*/
|
||||||
private static function receiveStatusMessage(array $importer, $data, $xml)
|
private static function receiveStatusMessage(array $importer, SimpleXMLElement $data, $xml)
|
||||||
{
|
{
|
||||||
$author = notags(unxmlify($data->author));
|
$author = notags(unxmlify($data->author));
|
||||||
$guid = notags(unxmlify($data->guid));
|
$guid = notags(unxmlify($data->guid));
|
||||||
|
|
|
@ -444,25 +444,30 @@ class Delivery extends BaseObject
|
||||||
if (($target_item["thr-parent"] != "") && ($target_item["thr-parent"] != $target_item["parent-uri"])) {
|
if (($target_item["thr-parent"] != "") && ($target_item["thr-parent"] != $target_item["parent-uri"])) {
|
||||||
$headers .= " <".Email::iri2msgid($target_item["thr-parent"]).">";
|
$headers .= " <".Email::iri2msgid($target_item["thr-parent"]).">";
|
||||||
}
|
}
|
||||||
|
|
||||||
$headers .= "\n";
|
$headers .= "\n";
|
||||||
|
|
||||||
if (empty($target_item['title'])) {
|
if (empty($target_item['title'])) {
|
||||||
$condition = ['uri' => $target_item['parent-uri'], 'uid' => $owner['uid']];
|
$condition = ['uri' => $target_item['parent-uri'], 'uid' => $owner['uid']];
|
||||||
$title = Item::selectFirst(['title'], $condition);
|
$title = Item::selectFirst(['title'], $condition);
|
||||||
|
|
||||||
if (DBA::isResult($title) && ($title['title'] != '')) {
|
if (DBA::isResult($title) && ($title['title'] != '')) {
|
||||||
$subject = $title['title'];
|
$subject = $title['title'];
|
||||||
} else {
|
} else {
|
||||||
$condition = ['parent-uri' => $target_item['parent-uri'], 'uid' => $owner['uid']];
|
$condition = ['parent-uri' => $target_item['parent-uri'], 'uid' => $owner['uid']];
|
||||||
$title = Item::selectFirst(['title'], $condition);
|
$title = Item::selectFirst(['title'], $condition);
|
||||||
|
|
||||||
if (DBA::isResult($title) && ($title['title'] != '')) {
|
if (DBA::isResult($title) && ($title['title'] != '')) {
|
||||||
$subject = $title['title'];
|
$subject = $title['title'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strncasecmp($subject, 'RE:', 3)) {
|
if (strncasecmp($subject, 'RE:', 3)) {
|
||||||
$subject = 'Re: ' . $subject;
|
$subject = 'Re: ' . $subject;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Email::send($addr, $subject, $headers, $target_item);
|
Email::send($addr, $subject, $headers, $target_item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -607,12 +607,15 @@ class OnePoll
|
||||||
if (strlen($hub) && $hub_update && (($contact['rel'] != Contact::FOLLOWER) || $contact['network'] == Protocol::FEED)) {
|
if (strlen($hub) && $hub_update && (($contact['rel'] != Contact::FOLLOWER) || $contact['network'] == Protocol::FEED)) {
|
||||||
logger('hub ' . $hubmode . ' : ' . $hub . ' contact name : ' . $contact['name'] . ' local user : ' . $importer['name']);
|
logger('hub ' . $hubmode . ' : ' . $hub . ' contact name : ' . $contact['name'] . ' local user : ' . $importer['name']);
|
||||||
$hubs = explode(',', $hub);
|
$hubs = explode(',', $hub);
|
||||||
|
|
||||||
if (count($hubs)) {
|
if (count($hubs)) {
|
||||||
foreach ($hubs as $h) {
|
foreach ($hubs as $h) {
|
||||||
$h = trim($h);
|
$h = trim($h);
|
||||||
|
|
||||||
if (!strlen($h)) {
|
if (!strlen($h)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
subscribe_to_hub($h, $importer, $contact, $hubmode);
|
subscribe_to_hub($h, $importer, $contact, $hubmode);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -652,7 +655,7 @@ class OnePoll
|
||||||
* @param array $contact The personal contact entry
|
* @param array $contact The personal contact entry
|
||||||
* @param array $fields The fields that are updated
|
* @param array $fields The fields that are updated
|
||||||
*/
|
*/
|
||||||
private static function updateContact($contact, $fields)
|
private static function updateContact(array $contact, array $fields)
|
||||||
{
|
{
|
||||||
DBA::update('contact', $fields, ['id' => $contact['id']]);
|
DBA::update('contact', $fields, ['id' => $contact['id']]);
|
||||||
DBA::update('contact', $fields, ['uid' => 0, 'nurl' => $contact['nurl']]);
|
DBA::update('contact', $fields, ['uid' => 0, 'nurl' => $contact['nurl']]);
|
||||||
|
|
Loading…
Reference in a new issue