Merge pull request #11699 from Quix0r/rewrites/type-hints-001
Type-hints added, method renamed
This commit is contained in:
commit
ef5d178e00
23 changed files with 290 additions and 231 deletions
|
@ -83,7 +83,7 @@ function editpost_content(App $a)
|
||||||
|
|
||||||
Hook::callAll('jot_tool', $jotplugins);
|
Hook::callAll('jot_tool', $jotplugins);
|
||||||
|
|
||||||
$tpl = Renderer::getMarkupTemplate("jot.tpl");
|
$tpl = Renderer::getMarkupTemplate('jot.tpl');
|
||||||
$o .= Renderer::replaceMacros($tpl, [
|
$o .= Renderer::replaceMacros($tpl, [
|
||||||
'$is_edit' => true,
|
'$is_edit' => true,
|
||||||
'$return_path' => '/display/' . $item['guid'],
|
'$return_path' => '/display/' . $item['guid'],
|
||||||
|
|
|
@ -130,6 +130,9 @@ class BoundariesPager extends Pager
|
||||||
return Renderer::replaceMacros($tpl, ['pager' => $data]);
|
return Renderer::replaceMacros($tpl, ['pager' => $data]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unsupported method, must be type-compatible
|
||||||
|
*/
|
||||||
public function renderFull(int $itemCount): string
|
public function renderFull(int $itemCount): string
|
||||||
{
|
{
|
||||||
throw new \BadMethodCallException();
|
throw new \BadMethodCallException();
|
||||||
|
|
|
@ -582,7 +582,7 @@ class Conversation
|
||||||
|
|
||||||
$uriids[] = $item['uri-id'];
|
$uriids[] = $item['uri-id'];
|
||||||
|
|
||||||
if (!$this->item->visibleActivity($item)) {
|
if (!$this->item->isVisibleActivity($item)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -745,7 +745,7 @@ class Conversation
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$this->item->visibleActivity($item)) {
|
if (!$this->item->isVisibleActivity($item)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -85,7 +85,7 @@ class Item
|
||||||
* ]
|
* ]
|
||||||
* ]
|
* ]
|
||||||
*/
|
*/
|
||||||
public function determineCategoriesTerms(array $item, int $uid = 0)
|
public function determineCategoriesTerms(array $item, int $uid = 0): array
|
||||||
{
|
{
|
||||||
$categories = [];
|
$categories = [];
|
||||||
$folders = [];
|
$folders = [];
|
||||||
|
@ -142,15 +142,15 @@ class Item
|
||||||
* the appropriate link.
|
* the appropriate link.
|
||||||
*
|
*
|
||||||
* @param string $body the text to replace the tag in
|
* @param string $body the text to replace the tag in
|
||||||
* @param integer $profile_uid the user id to replace the tag for (0 = anyone)
|
* @param int $profile_uid the user id to replace the tag for (0 = anyone)
|
||||||
* @param string $tag the tag to replace
|
* @param string $tag the tag to replace
|
||||||
* @param string $network The network of the post
|
* @param string $network The network of the post
|
||||||
*
|
*
|
||||||
* @return array|bool ['replaced' => $replaced, 'contact' => $contact];
|
* @return array|bool ['replaced' => $replaced, 'contact' => $contact] or "false" on if already replaced
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
* @throws \ImagickException
|
* @throws \ImagickException
|
||||||
*/
|
*/
|
||||||
public static function replaceTag(&$body, $profile_uid, $tag, $network = '')
|
public static function replaceTag(string &$body, int $profile_uid, string $tag, string $network = '')
|
||||||
{
|
{
|
||||||
$replaced = false;
|
$replaced = false;
|
||||||
|
|
||||||
|
@ -244,16 +244,17 @@ class Item
|
||||||
/**
|
/**
|
||||||
* Render actions localized
|
* Render actions localized
|
||||||
*
|
*
|
||||||
* @param $item
|
* @param array $item
|
||||||
|
* @return void
|
||||||
* @throws ImagickException
|
* @throws ImagickException
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public function localize(&$item)
|
public function localize(array &$item)
|
||||||
{
|
{
|
||||||
$this->profiler->startRecording('rendering');
|
$this->profiler->startRecording('rendering');
|
||||||
/// @todo The following functionality needs to be cleaned up.
|
/// @todo The following functionality needs to be cleaned up.
|
||||||
if (!empty($item['verb'])) {
|
if (!empty($item['verb'])) {
|
||||||
$xmlhead = "<" . "?xml version='1.0' encoding='UTF-8' ?" . ">";
|
$xmlhead = '<?xml version="1.0" encoding="UTF-8" ?>';
|
||||||
|
|
||||||
if (stristr($item['verb'], Activity::POKE)) {
|
if (stristr($item['verb'], Activity::POKE)) {
|
||||||
$verb = urldecode(substr($item['verb'], strpos($item['verb'],'#') + 1));
|
$verb = urldecode(substr($item['verb'], strpos($item['verb'],'#') + 1));
|
||||||
|
@ -261,7 +262,7 @@ class Item
|
||||||
$this->profiler->stopRecording();
|
$this->profiler->stopRecording();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if ($item['object-type'] == "" || $item['object-type'] !== Activity\ObjectType::PERSON) {
|
if ($item['object-type'] == '' || $item['object-type'] !== Activity\ObjectType::PERSON) {
|
||||||
$this->profiler->stopRecording();
|
$this->profiler->stopRecording();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -270,18 +271,22 @@ class Item
|
||||||
|
|
||||||
$Bname = $obj->title;
|
$Bname = $obj->title;
|
||||||
$Blink = $obj->id;
|
$Blink = $obj->id;
|
||||||
$Bphoto = "";
|
$Bphoto = '';
|
||||||
|
|
||||||
foreach ($obj->link as $l) {
|
foreach ($obj->link as $l) {
|
||||||
$atts = $l->attributes();
|
$atts = $l->attributes();
|
||||||
switch ($atts['rel']) {
|
switch ($atts['rel']) {
|
||||||
case "alternate": $Blink = $atts['href'];
|
case 'alternate': $Blink = $atts['href'];
|
||||||
case "photo": $Bphoto = $atts['href'];
|
case 'photo': $Bphoto = $atts['href'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$author = ['uid' => 0, 'id' => $item['author-id'],
|
$author = [
|
||||||
'network' => $item['author-network'], 'url' => $item['author-link']];
|
'uid' => 0,
|
||||||
|
'id' => $item['author-id'],
|
||||||
|
'network' => $item['author-network'],
|
||||||
|
'url' => $item['author-link'],
|
||||||
|
];
|
||||||
$A = '[url=' . Contact::magicLinkByContact($author) . ']' . $item['author-name'] . '[/url]';
|
$A = '[url=' . Contact::magicLinkByContact($author) . ']' . $item['author-name'] . '[/url]';
|
||||||
|
|
||||||
if (!empty($Blink)) {
|
if (!empty($Blink)) {
|
||||||
|
@ -290,7 +295,7 @@ class Item
|
||||||
$B = '';
|
$B = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Bphoto != "" && !empty($Blink)) {
|
if ($Bphoto != '' && !empty($Blink)) {
|
||||||
$Bphoto = '[url=' . Contact::magicLink($Blink) . '][img=80x80]' . $Bphoto . '[/img][/url]';
|
$Bphoto = '[url=' . Contact::magicLink($Blink) . '][img=80x80]' . $Bphoto . '[/img][/url]';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -305,9 +310,7 @@ class Item
|
||||||
$txt = str_replace($poked_t, $this->l10n->t($verb), $txt);
|
$txt = str_replace($poked_t, $this->l10n->t($verb), $txt);
|
||||||
|
|
||||||
// then do the sprintf on the translation string
|
// then do the sprintf on the translation string
|
||||||
|
|
||||||
$item['body'] = sprintf($txt, $A, $B) . "\n\n\n" . $Bphoto;
|
$item['body'] = sprintf($txt, $A, $B) . "\n\n\n" . $Bphoto;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($this->activity->match($item['verb'], Activity::TAG)) {
|
if ($this->activity->match($item['verb'], Activity::TAG)) {
|
||||||
|
@ -319,12 +322,20 @@ class Item
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$author_arr = ['uid' => 0, 'id' => $item['author-id'],
|
$author_arr = [
|
||||||
'network' => $item['author-network'], 'url' => $item['author-link']];
|
'uid' => 0,
|
||||||
|
'id' => $item['author-id'],
|
||||||
|
'network' => $item['author-network'],
|
||||||
|
'url' => $item['author-link'],
|
||||||
|
];
|
||||||
$author = '[url=' . Contact::magicLinkByContact($author_arr) . ']' . $item['author-name'] . '[/url]';
|
$author = '[url=' . Contact::magicLinkByContact($author_arr) . ']' . $item['author-name'] . '[/url]';
|
||||||
|
|
||||||
$author_arr = ['uid' => 0, 'id' => $obj['author-id'],
|
$author_arr = [
|
||||||
'network' => $obj['author-network'], 'url' => $obj['author-link']];
|
'uid' => 0,
|
||||||
|
'id' => $obj['author-id'],
|
||||||
|
'network' => $obj['author-network'],
|
||||||
|
'url' => $obj['author-link'],
|
||||||
|
];
|
||||||
$objauthor = '[url=' . Contact::magicLinkByContact($author_arr) . ']' . $obj['author-name'] . '[/url]';
|
$objauthor = '[url=' . Contact::magicLinkByContact($author_arr) . ']' . $obj['author-name'] . '[/url]';
|
||||||
|
|
||||||
switch ($obj['verb']) {
|
switch ($obj['verb']) {
|
||||||
|
@ -337,6 +348,7 @@ class Item
|
||||||
$post_type = $this->l10n->t('status');
|
$post_type = $this->l10n->t('status');
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if ($obj['resource-id']) {
|
if ($obj['resource-id']) {
|
||||||
$post_type = $this->l10n->t('photo');
|
$post_type = $this->l10n->t('photo');
|
||||||
|
@ -360,25 +372,29 @@ class Item
|
||||||
$this->profiler->stopRecording();
|
$this->profiler->stopRecording();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function photoMenu($item, string $formSecurityToken)
|
/**
|
||||||
|
* Renders photo menu based on item
|
||||||
|
*
|
||||||
|
* @param array $item
|
||||||
|
* @param string $formSecurityToken
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function photoMenu(array $item, string $formSecurityToken): string
|
||||||
{
|
{
|
||||||
$this->profiler->startRecording('rendering');
|
$this->profiler->startRecording('rendering');
|
||||||
$sub_link = '';
|
$sub_link = $poke_link = $contact_url = $pm_url = $status_link = '';
|
||||||
$poke_link = '';
|
$photos_link = $posts_link = $block_link = $ignore_link = '';
|
||||||
$contact_url = '';
|
|
||||||
$pm_url = '';
|
|
||||||
$status_link = '';
|
|
||||||
$photos_link = '';
|
|
||||||
$posts_link = '';
|
|
||||||
$block_link = '';
|
|
||||||
$ignore_link = '';
|
|
||||||
|
|
||||||
if (local_user() && local_user() == $item['uid'] && $item['gravity'] == GRAVITY_PARENT && !$item['self'] && !$item['mention']) {
|
if (local_user() && local_user() == $item['uid'] && $item['gravity'] == GRAVITY_PARENT && !$item['self'] && !$item['mention']) {
|
||||||
$sub_link = 'javascript:doFollowThread(' . $item['id'] . '); return false;';
|
$sub_link = 'javascript:doFollowThread(' . $item['id'] . '); return false;';
|
||||||
}
|
}
|
||||||
|
|
||||||
$author = ['uid' => 0, 'id' => $item['author-id'],
|
$author = [
|
||||||
'network' => $item['author-network'], 'url' => $item['author-link']];
|
'uid' => 0,
|
||||||
|
'id' => $item['author-id'],
|
||||||
|
'network' => $item['author-network'],
|
||||||
|
'url' => $item['author-link'],
|
||||||
|
];
|
||||||
$profile_link = Contact::magicLinkByContact($author, $item['author-link']);
|
$profile_link = Contact::magicLinkByContact($author, $item['author-link']);
|
||||||
$sparkle = (strpos($profile_link, 'redir/') === 0);
|
$sparkle = (strpos($profile_link, 'redir/') === 0);
|
||||||
|
|
||||||
|
@ -435,7 +451,7 @@ class Item
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($network == Protocol::DFRN) {
|
if ($network == Protocol::DFRN) {
|
||||||
$menu[$this->l10n->t("Poke")] = $poke_link;
|
$menu[$this->l10n->t('Poke')] = $poke_link;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((($cid == 0) || ($rel == Contact::FOLLOWER)) &&
|
if ((($cid == 0) || ($rel == Contact::FOLLOWER)) &&
|
||||||
|
@ -465,24 +481,28 @@ class Item
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function visibleActivity($item) {
|
/**
|
||||||
|
* Checks if the activity is visible to current user
|
||||||
|
*
|
||||||
|
* @param array $item Activity item
|
||||||
|
* @return bool Whether the item is visible to the user
|
||||||
|
*/
|
||||||
|
public function isVisibleActivity(array $item): bool
|
||||||
|
{
|
||||||
|
// Empty verb or hidden?
|
||||||
if (empty($item['verb']) || $this->activity->isHidden($item['verb'])) {
|
if (empty($item['verb']) || $this->activity->isHidden($item['verb'])) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// @TODO below if() block can be rewritten to a single line: $isVisible = allConditionsHere;
|
// Check conditions
|
||||||
if ($this->activity->match($item['verb'], Activity::FOLLOW) &&
|
return (!($this->activity->match($item['verb'], Activity::FOLLOW) &&
|
||||||
$item['object-type'] === Activity\ObjectType::NOTE &&
|
$item['object-type'] === Activity\ObjectType::NOTE &&
|
||||||
empty($item['self']) &&
|
empty($item['self']) &&
|
||||||
$item['uid'] == local_user()) {
|
$item['uid'] == local_user())
|
||||||
return false;
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
public function expandTags(array $item, bool $setPermissions = false): array
|
||||||
}
|
|
||||||
|
|
||||||
public function expandTags(array $item, bool $setPermissions = false)
|
|
||||||
{
|
{
|
||||||
// Look for any tags and linkify them
|
// Look for any tags and linkify them
|
||||||
$item['inform'] = '';
|
$item['inform'] = '';
|
||||||
|
|
|
@ -62,7 +62,7 @@ class Nav
|
||||||
*
|
*
|
||||||
* @param string $item
|
* @param string $item
|
||||||
*/
|
*/
|
||||||
public static function setSelected($item)
|
public static function setSelected(string $item)
|
||||||
{
|
{
|
||||||
self::$selected[$item] = 'selected';
|
self::$selected[$item] = 'selected';
|
||||||
}
|
}
|
||||||
|
@ -74,7 +74,7 @@ class Nav
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function build(App $a)
|
public static function build(App $a): string
|
||||||
{
|
{
|
||||||
// Placeholder div for popup panel
|
// Placeholder div for popup panel
|
||||||
$nav = '<div id="panel" style="display: none;"></div>';
|
$nav = '<div id="panel" style="display: none;"></div>';
|
||||||
|
@ -106,7 +106,7 @@ class Nav
|
||||||
*
|
*
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
public static function getAppMenu()
|
public static function getAppMenu(): array
|
||||||
{
|
{
|
||||||
if (is_null(self::$app_menu)) {
|
if (is_null(self::$app_menu)) {
|
||||||
self::populateAppMenu();
|
self::populateAppMenu();
|
||||||
|
@ -117,6 +117,8 @@ class Nav
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Fills the apps static variable with apps that require a menu
|
* Fills the apps static variable with apps that require a menu
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
*/
|
*/
|
||||||
private static function populateAppMenu()
|
private static function populateAppMenu()
|
||||||
{
|
{
|
||||||
|
|
|
@ -49,7 +49,13 @@ use Friendica\Util\Strings;
|
||||||
*/
|
*/
|
||||||
class OEmbed
|
class OEmbed
|
||||||
{
|
{
|
||||||
public static function replaceCallback($matches)
|
/**
|
||||||
|
* Callback for fetching URL, checking allowance and returning formatted HTML
|
||||||
|
*
|
||||||
|
* @param array $matches
|
||||||
|
* @return string Formatted HTML
|
||||||
|
*/
|
||||||
|
public static function replaceCallback(array $matches): string
|
||||||
{
|
{
|
||||||
$embedurl = $matches[1];
|
$embedurl = $matches[1];
|
||||||
$j = self::fetchURL($embedurl, !self::isAllowedURL($embedurl));
|
$j = self::fetchURL($embedurl, !self::isAllowedURL($embedurl));
|
||||||
|
@ -68,7 +74,7 @@ class OEmbed
|
||||||
* @return \Friendica\Object\OEmbed
|
* @return \Friendica\Object\OEmbed
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function fetchURL($embedurl, bool $no_rich_type = false, bool $use_parseurl = true)
|
public static function fetchURL(string $embedurl, bool $no_rich_type = false, bool $use_parseurl = true): \Friendica\Object\OEmbed
|
||||||
{
|
{
|
||||||
$embedurl = trim($embedurl, '\'"');
|
$embedurl = trim($embedurl, '\'"');
|
||||||
|
|
||||||
|
@ -209,12 +215,18 @@ class OEmbed
|
||||||
return $oembed;
|
return $oembed;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function formatObject(\Friendica\Object\OEmbed $oembed)
|
/**
|
||||||
|
* Returns a formatted string from OEmbed object
|
||||||
|
*
|
||||||
|
* @param \Friendica\Object\OEmbed $oembed
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
private static function formatObject(\Friendica\Object\OEmbed $oembed): string
|
||||||
{
|
{
|
||||||
$ret = '<div class="oembed ' . $oembed->type . '">';
|
$ret = '<div class="oembed ' . $oembed->type . '">';
|
||||||
|
|
||||||
switch ($oembed->type) {
|
switch ($oembed->type) {
|
||||||
case "video":
|
case 'video':
|
||||||
if ($oembed->thumbnail_url) {
|
if ($oembed->thumbnail_url) {
|
||||||
$tw = (isset($oembed->thumbnail_width) && intval($oembed->thumbnail_width)) ? $oembed->thumbnail_width : 200;
|
$tw = (isset($oembed->thumbnail_width) && intval($oembed->thumbnail_width)) ? $oembed->thumbnail_width : 200;
|
||||||
$th = (isset($oembed->thumbnail_height) && intval($oembed->thumbnail_height)) ? $oembed->thumbnail_height : 180;
|
$th = (isset($oembed->thumbnail_height) && intval($oembed->thumbnail_height)) ? $oembed->thumbnail_height : 180;
|
||||||
|
@ -236,14 +248,14 @@ class OEmbed
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "photo":
|
case 'photo':
|
||||||
$ret .= '<img width="' . $oembed->width . '" src="' . Proxy::proxifyUrl($oembed->url) . '">';
|
$ret .= '<img width="' . $oembed->width . '" src="' . Proxy::proxifyUrl($oembed->url) . '">';
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "link":
|
case 'link':
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "rich":
|
case 'rich':
|
||||||
$ret .= Proxy::proxifyHtml($oembed->html);
|
$ret .= Proxy::proxifyHtml($oembed->html);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -292,9 +304,15 @@ class OEmbed
|
||||||
return str_replace("\n", "", $ret);
|
return str_replace("\n", "", $ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function BBCode2HTML($text)
|
/**
|
||||||
|
* Converts BBCode to HTML code
|
||||||
|
*
|
||||||
|
* @param string $text
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function BBCode2HTML(string $text): string
|
||||||
{
|
{
|
||||||
$stopoembed = DI::config()->get("system", "no_oembed");
|
$stopoembed = DI::config()->get('system', 'no_oembed');
|
||||||
if ($stopoembed == true) {
|
if ($stopoembed == true) {
|
||||||
return preg_replace("/\[embed\](.+?)\[\/embed\]/is", "<!-- oembed $1 --><i>" . DI::l10n()->t('Embedding disabled') . " : $1</i><!-- /oembed $1 -->", $text);
|
return preg_replace("/\[embed\](.+?)\[\/embed\]/is", "<!-- oembed $1 --><i>" . DI::l10n()->t('Embedding disabled') . " : $1</i><!-- /oembed $1 -->", $text);
|
||||||
}
|
}
|
||||||
|
@ -305,14 +323,13 @@ class OEmbed
|
||||||
* Find <span class='oembed'>..<a href='url' rel='oembed'>..</a></span>
|
* Find <span class='oembed'>..<a href='url' rel='oembed'>..</a></span>
|
||||||
* and replace it with [embed]url[/embed]
|
* and replace it with [embed]url[/embed]
|
||||||
*
|
*
|
||||||
* @param $text
|
* @param string $text
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function HTML2BBCode($text)
|
public static function HTML2BBCode(string $text): string
|
||||||
{
|
{
|
||||||
// start parser only if 'oembed' is in text
|
// start parser only if 'oembed' is in text
|
||||||
if (strpos($text, "oembed")) {
|
if (strpos($text, 'oembed')) {
|
||||||
|
|
||||||
// convert non ascii chars to html entities
|
// convert non ascii chars to html entities
|
||||||
$html_text = mb_convert_encoding($text, 'HTML-ENTITIES', mb_detect_encoding($text));
|
$html_text = mb_convert_encoding($text, 'HTML-ENTITIES', mb_detect_encoding($text));
|
||||||
|
|
||||||
|
@ -323,17 +340,17 @@ class OEmbed
|
||||||
}
|
}
|
||||||
$xpath = new DOMXPath($dom);
|
$xpath = new DOMXPath($dom);
|
||||||
|
|
||||||
$xattr = self::buildXPath("class", "oembed");
|
$xattr = self::buildXPath('class', 'oembed');
|
||||||
$entries = $xpath->query("//div[$xattr]");
|
$entries = $xpath->query("//div[$xattr]");
|
||||||
|
|
||||||
$xattr = "@rel='oembed'"; //oe_build_xpath("rel","oembed");
|
$xattr = "@rel='oembed'"; //oe_build_xpath("rel","oembed");
|
||||||
foreach ($entries as $e) {
|
foreach ($entries as $e) {
|
||||||
$href = $xpath->evaluate("a[$xattr]/@href", $e)->item(0)->nodeValue;
|
$href = $xpath->evaluate("a[$xattr]/@href", $e)->item(0)->nodeValue;
|
||||||
if (!is_null($href)) {
|
if (!is_null($href)) {
|
||||||
$e->parentNode->replaceChild(new DOMText("[embed]" . $href . "[/embed]"), $e);
|
$e->parentNode->replaceChild(new DOMText('[embed]' . $href . '[/embed]'), $e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return self::getInnerHTML($dom->getElementsByTagName("body")->item(0));
|
return self::getInnerHTML($dom->getElementsByTagName('body')->item(0));
|
||||||
} else {
|
} else {
|
||||||
return $text;
|
return $text;
|
||||||
}
|
}
|
||||||
|
@ -346,7 +363,7 @@ class OEmbed
|
||||||
* @return boolean
|
* @return boolean
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function isAllowedURL($url)
|
public static function isAllowedURL(string $url): bool
|
||||||
{
|
{
|
||||||
if (!DI::config()->get('system', 'no_oembed_rich_content')) {
|
if (!DI::config()->get('system', 'no_oembed_rich_content')) {
|
||||||
return true;
|
return true;
|
||||||
|
@ -367,7 +384,14 @@ class OEmbed
|
||||||
return Network::isDomainAllowed($domain, $allowed);
|
return Network::isDomainAllowed($domain, $allowed);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getHTML($url, $title = null)
|
/**
|
||||||
|
* Returns a formmated HTML code from given URL and sets optional title
|
||||||
|
*
|
||||||
|
* @param string $url URL to fetch
|
||||||
|
* @param string $title Optional title (default: what comes from OEmbed object)
|
||||||
|
* @return string Formatted HTML
|
||||||
|
*/
|
||||||
|
public static function getHTML(string $url, string $title = '')
|
||||||
{
|
{
|
||||||
$o = self::fetchURL($url, !self::isAllowedURL($url));
|
$o = self::fetchURL($url, !self::isAllowedURL($url));
|
||||||
|
|
||||||
|
@ -401,12 +425,12 @@ class OEmbed
|
||||||
* @param string $src Original remote URL to embed
|
* @param string $src Original remote URL to embed
|
||||||
* @param string $width
|
* @param string $width
|
||||||
* @param string $height
|
* @param string $height
|
||||||
* @return string formatted HTML
|
* @return string Formatted HTML
|
||||||
*
|
*
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
* @see oembed_format_object()
|
* @see oembed_format_object()
|
||||||
*/
|
*/
|
||||||
private static function iframe($src, $width, $height)
|
private static function iframe(string $src, string $width, string $height): string
|
||||||
{
|
{
|
||||||
if (!$height || strstr($height, '%')) {
|
if (!$height || strstr($height, '%')) {
|
||||||
$height = '200';
|
$height = '200';
|
||||||
|
@ -427,7 +451,7 @@ class OEmbed
|
||||||
* @param string $value Value to search in a space-separated list
|
* @param string $value Value to search in a space-separated list
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
private static function buildXPath($attr, $value)
|
private static function buildXPath(string $attr, $value): string
|
||||||
{
|
{
|
||||||
// https://www.westhoffswelt.de/blog/2009/6/9/select-html-elements-with-more-than-one-css-class-using-xpath
|
// https://www.westhoffswelt.de/blog/2009/6/9/select-html-elements-with-more-than-one-css-class-using-xpath
|
||||||
return "contains(normalize-space(@$attr), ' $value ') or substring(normalize-space(@$attr), 1, string-length('$value') + 1) = '$value ' or substring(normalize-space(@$attr), string-length(@$attr) - string-length('$value')) = ' $value' or @$attr = '$value'";
|
return "contains(normalize-space(@$attr), ' $value ') or substring(normalize-space(@$attr), 1, string-length('$value') + 1) = '$value ' or substring(normalize-space(@$attr), string-length(@$attr) - string-length('$value')) = ' $value' or @$attr = '$value'";
|
||||||
|
@ -439,7 +463,7 @@ class OEmbed
|
||||||
* @param DOMNode $node
|
* @param DOMNode $node
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
private static function getInnerHTML(DOMNode $node)
|
private static function getInnerHTML(DOMNode $node): string
|
||||||
{
|
{
|
||||||
$innerHTML = '';
|
$innerHTML = '';
|
||||||
$children = $node->childNodes;
|
$children = $node->childNodes;
|
||||||
|
|
|
@ -64,7 +64,7 @@ class PageInfo
|
||||||
* @return string
|
* @return string
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function appendDataToBody(string $body, array $data, bool $no_photos = false)
|
public static function appendDataToBody(string $body, array $data, bool $no_photos = false): string
|
||||||
{
|
{
|
||||||
// Only one [attachment] tag per body is allowed
|
// Only one [attachment] tag per body is allowed
|
||||||
$existingAttachmentPos = strpos($body, '[attachment');
|
$existingAttachmentPos = strpos($body, '[attachment');
|
||||||
|
@ -90,7 +90,7 @@ class PageInfo
|
||||||
* @return string
|
* @return string
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function getFooterFromUrl(string $url, bool $no_photos = false, string $photo = '', bool $keywords = false, string $keyword_denylist = '')
|
public static function getFooterFromUrl(string $url, bool $no_photos = false, string $photo = '', bool $keywords = false, string $keyword_denylist = ''): string
|
||||||
{
|
{
|
||||||
$data = self::queryUrl($url, $photo, $keywords, $keyword_denylist);
|
$data = self::queryUrl($url, $photo, $keywords, $keyword_denylist);
|
||||||
|
|
||||||
|
@ -103,7 +103,7 @@ class PageInfo
|
||||||
* @return string
|
* @return string
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function getFooterFromData(array $data, bool $no_photos = false)
|
public static function getFooterFromData(array $data, bool $no_photos = false): string
|
||||||
{
|
{
|
||||||
Hook::callAll('page_info_data', $data);
|
Hook::callAll('page_info_data', $data);
|
||||||
|
|
||||||
|
@ -220,7 +220,7 @@ class PageInfo
|
||||||
* @return array
|
* @return array
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function getTagsFromUrl(string $url, string $photo = '', string $keyword_denylist = '')
|
public static function getTagsFromUrl(string $url, string $photo = '', string $keyword_denylist = ''): array
|
||||||
{
|
{
|
||||||
$data = self::queryUrl($url, $photo, true, $keyword_denylist);
|
$data = self::queryUrl($url, $photo, true, $keyword_denylist);
|
||||||
|
|
||||||
|
@ -282,7 +282,7 @@ class PageInfo
|
||||||
* @param string $url
|
* @param string $url
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
protected static function stripTrailingUrlFromBody(string $body, string $url)
|
protected static function stripTrailingUrlFromBody(string $body, string $url): string
|
||||||
{
|
{
|
||||||
$quotedUrl = preg_quote($url, '#');
|
$quotedUrl = preg_quote($url, '#');
|
||||||
$body = preg_replace_callback("#(?:
|
$body = preg_replace_callback("#(?:
|
||||||
|
|
|
@ -50,9 +50,9 @@ class Pager
|
||||||
*
|
*
|
||||||
* @param L10n $l10n
|
* @param L10n $l10n
|
||||||
* @param string $queryString The query string of the current page
|
* @param string $queryString The query string of the current page
|
||||||
* @param integer $itemsPerPage An optional number of items per page to override the default value
|
* @param int $itemsPerPage An optional number of items per page to override the default value
|
||||||
*/
|
*/
|
||||||
public function __construct(L10n $l10n, $queryString, $itemsPerPage = 50)
|
public function __construct(L10n $l10n, string $queryString, int $itemsPerPage = 50)
|
||||||
{
|
{
|
||||||
$this->l10n = $l10n;
|
$this->l10n = $l10n;
|
||||||
|
|
||||||
|
@ -64,9 +64,9 @@ class Pager
|
||||||
/**
|
/**
|
||||||
* Returns the start offset for a LIMIT clause. Starts at 0.
|
* Returns the start offset for a LIMIT clause. Starts at 0.
|
||||||
*
|
*
|
||||||
* @return integer
|
* @return int
|
||||||
*/
|
*/
|
||||||
public function getStart()
|
public function getStart(): int
|
||||||
{
|
{
|
||||||
return max(0, ($this->page * $this->itemsPerPage) - $this->itemsPerPage);
|
return max(0, ($this->page * $this->itemsPerPage) - $this->itemsPerPage);
|
||||||
}
|
}
|
||||||
|
@ -74,9 +74,9 @@ class Pager
|
||||||
/**
|
/**
|
||||||
* Returns the number of items per page
|
* Returns the number of items per page
|
||||||
*
|
*
|
||||||
* @return integer
|
* @return int
|
||||||
*/
|
*/
|
||||||
public function getItemsPerPage()
|
public function getItemsPerPage(): int
|
||||||
{
|
{
|
||||||
return $this->itemsPerPage;
|
return $this->itemsPerPage;
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,7 @@ class Pager
|
||||||
*
|
*
|
||||||
* @return int
|
* @return int
|
||||||
*/
|
*/
|
||||||
public function getPage()
|
public function getPage(): int
|
||||||
{
|
{
|
||||||
return $this->page;
|
return $this->page;
|
||||||
}
|
}
|
||||||
|
@ -108,9 +108,9 @@ class Pager
|
||||||
/**
|
/**
|
||||||
* Sets the number of items per page, 1 minimum.
|
* Sets the number of items per page, 1 minimum.
|
||||||
*
|
*
|
||||||
* @param integer $itemsPerPage
|
* @param int $itemsPerPage
|
||||||
*/
|
*/
|
||||||
public function setItemsPerPage($itemsPerPage)
|
public function setItemsPerPage(int $itemsPerPage)
|
||||||
{
|
{
|
||||||
$this->itemsPerPage = max(1, intval($itemsPerPage));
|
$this->itemsPerPage = max(1, intval($itemsPerPage));
|
||||||
}
|
}
|
||||||
|
@ -118,11 +118,11 @@ class Pager
|
||||||
/**
|
/**
|
||||||
* Sets the current page number. Starts at 1.
|
* Sets the current page number. Starts at 1.
|
||||||
*
|
*
|
||||||
* @param integer $page
|
* @param int $page
|
||||||
*/
|
*/
|
||||||
public function setPage($page)
|
public function setPage(int $page)
|
||||||
{
|
{
|
||||||
$this->page = max(1, intval($page));
|
$this->page = max(1, $page);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -132,7 +132,7 @@ class Pager
|
||||||
*
|
*
|
||||||
* @param string $queryString
|
* @param string $queryString
|
||||||
*/
|
*/
|
||||||
public function setQueryString($queryString)
|
public function setQueryString(string $queryString)
|
||||||
{
|
{
|
||||||
$stripped = preg_replace('/([&?]page=[0-9]*)/', '', $queryString);
|
$stripped = preg_replace('/([&?]page=[0-9]*)/', '', $queryString);
|
||||||
|
|
||||||
|
|
|
@ -39,10 +39,9 @@ class Smilies
|
||||||
* @param array $b Array of emoticons
|
* @param array $b Array of emoticons
|
||||||
* @param string $smiley The text smilie
|
* @param string $smiley The text smilie
|
||||||
* @param string $representation The replacement
|
* @param string $representation The replacement
|
||||||
*
|
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public static function add(&$b, $smiley, $representation)
|
public static function add(array &$b, string $smiley, string $representation)
|
||||||
{
|
{
|
||||||
$found = array_search($smiley, $b['texts']);
|
$found = array_search($smiley, $b['texts']);
|
||||||
|
|
||||||
|
@ -66,7 +65,7 @@ class Smilies
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
* @hook smilie ('texts' => smilies texts array, 'icons' => smilies html array)
|
* @hook smilie ('texts' => smilies texts array, 'icons' => smilies html array)
|
||||||
*/
|
*/
|
||||||
public static function getList()
|
public static function getList(): array
|
||||||
{
|
{
|
||||||
$texts = [
|
$texts = [
|
||||||
'<3',
|
'<3',
|
||||||
|
@ -169,7 +168,7 @@ class Smilies
|
||||||
*
|
*
|
||||||
* @return string $subject with all substrings in the $search array replaced by the values in the $replace array
|
* @return string $subject with all substrings in the $search array replaced by the values in the $replace array
|
||||||
*/
|
*/
|
||||||
private static function strOrigReplace($search, $replace, $subject)
|
private static function strOrigReplace(array $search, array $replace, string $subject): string
|
||||||
{
|
{
|
||||||
return strtr($subject, array_combine($search, $replace));
|
return strtr($subject, array_combine($search, $replace));
|
||||||
}
|
}
|
||||||
|
@ -191,7 +190,7 @@ class Smilies
|
||||||
* @return string HTML Output of the Smilie
|
* @return string HTML Output of the Smilie
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function replace($s, $no_images = false)
|
public static function replace(string $s, bool $no_images = false): string
|
||||||
{
|
{
|
||||||
$smilies = self::getList();
|
$smilies = self::getList();
|
||||||
|
|
||||||
|
@ -211,7 +210,7 @@ class Smilies
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function replaceFromArray($text, array $smilies, $no_images = false)
|
public static function replaceFromArray(string $text, array $smilies, bool $no_images = false): string
|
||||||
{
|
{
|
||||||
if (intval(DI::config()->get('system', 'no_smilies'))
|
if (intval(DI::config()->get('system', 'no_smilies'))
|
||||||
|| (local_user() && intval(DI::pConfig()->get(local_user(), 'system', 'no_smilies')))
|
|| (local_user() && intval(DI::pConfig()->get(local_user(), 'system', 'no_smilies')))
|
||||||
|
@ -244,22 +243,24 @@ class Smilies
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $m string
|
* Encodes smiley match array to BASE64 string
|
||||||
*
|
*
|
||||||
|
* @param array $m Match array
|
||||||
* @return string base64 encoded string
|
* @return string base64 encoded string
|
||||||
*/
|
*/
|
||||||
private static function encode($m)
|
private static function encode(array $m): string
|
||||||
{
|
{
|
||||||
return '<' . $m[1] . '>' . Strings::base64UrlEncode($m[2]) . '</' . $m[1] . '>';
|
return '<' . $m[1] . '>' . Strings::base64UrlEncode($m[2]) . '</' . $m[1] . '>';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $m string
|
* Decodes a previously BASE64-encoded match array to a string
|
||||||
*
|
*
|
||||||
|
* @param array $m Matches array
|
||||||
* @return string base64 decoded string
|
* @return string base64 decoded string
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
private static function decode($m)
|
private static function decode(array $m): string
|
||||||
{
|
{
|
||||||
return '<' . $m[1] . '>' . Strings::base64UrlDecode($m[2]) . '</' . $m[1] . '>';
|
return '<' . $m[1] . '>' . Strings::base64UrlDecode($m[2]) . '</' . $m[1] . '>';
|
||||||
}
|
}
|
||||||
|
@ -269,12 +270,10 @@ class Smilies
|
||||||
* expand <3333 to the correct number of hearts
|
* expand <3333 to the correct number of hearts
|
||||||
*
|
*
|
||||||
* @param string $x string
|
* @param string $x string
|
||||||
*
|
|
||||||
* @return string HTML Output
|
* @return string HTML Output
|
||||||
*
|
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
private static function pregHeart($x)
|
private static function pregHeart(string $x): string
|
||||||
{
|
{
|
||||||
if (strlen($x[1]) == 1) {
|
if (strlen($x[1]) == 1) {
|
||||||
return $x[0];
|
return $x[0];
|
||||||
|
|
|
@ -81,7 +81,7 @@ class BBCode
|
||||||
* 'description' -> Description of the attachment
|
* 'description' -> Description of the attachment
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
private static function getOldAttachmentData($body)
|
private static function getOldAttachmentData(string $body): array
|
||||||
{
|
{
|
||||||
$post = [];
|
$post = [];
|
||||||
|
|
||||||
|
@ -152,7 +152,7 @@ class BBCode
|
||||||
* 'description' -> Description of the attachment
|
* 'description' -> Description of the attachment
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function getAttachmentData($body)
|
public static function getAttachmentData(string $body): array
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
$data = [
|
$data = [
|
||||||
|
@ -187,26 +187,31 @@ class BBCode
|
||||||
case 'publisher_name':
|
case 'publisher_name':
|
||||||
$data['provider_name'] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
$data['provider_name'] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'publisher_url':
|
case 'publisher_url':
|
||||||
$data['provider_url'] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
$data['provider_url'] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'author_name':
|
case 'author_name':
|
||||||
$data['author_name'] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
$data['author_name'] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
||||||
if ($data['provider_name'] == $data['author_name']) {
|
if ($data['provider_name'] == $data['author_name']) {
|
||||||
$data['author_name'] = '';
|
$data['author_name'] = '';
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'author_url':
|
case 'author_url':
|
||||||
$data['author_url'] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
$data['author_url'] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
||||||
if ($data['provider_url'] == $data['author_url']) {
|
if ($data['provider_url'] == $data['author_url']) {
|
||||||
$data['author_url'] = '';
|
$data['author_url'] = '';
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'title':
|
case 'title':
|
||||||
$value = self::convert(html_entity_decode($value, ENT_QUOTES, 'UTF-8'), false, true);
|
$value = self::convert(html_entity_decode($value, ENT_QUOTES, 'UTF-8'), false, true);
|
||||||
$value = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
$value = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
||||||
$value = str_replace(['[', ']'], ['[', ']'], $value);
|
$value = str_replace(['[', ']'], ['[', ']'], $value);
|
||||||
$data['title'] = $value;
|
$data['title'] = $value;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
$data[$field] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
$data[$field] = html_entity_decode($value, ENT_QUOTES, 'UTF-8');
|
||||||
break;
|
break;
|
||||||
|
@ -241,7 +246,7 @@ class BBCode
|
||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function getAttachedData($body, $item = [])
|
public static function getAttachedData(string $body, array $item = []): array
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
- text:
|
- text:
|
||||||
|
@ -303,7 +308,7 @@ class BBCode
|
||||||
// Workaround:
|
// Workaround:
|
||||||
// Sometimes photo posts to the own album are not detected at the start.
|
// Sometimes photo posts to the own album are not detected at the start.
|
||||||
// So we seem to cannot use the cache for these cases. That's strange.
|
// So we seem to cannot use the cache for these cases. That's strange.
|
||||||
if (($data['type'] != 'photo') && strstr($pictures[0][1], "/photos/")) {
|
if (($data['type'] != 'photo') && strstr($pictures[0][1], '/photos/')) {
|
||||||
$data = ParseUrl::getSiteinfo($pictures[0][1]);
|
$data = ParseUrl::getSiteinfo($pictures[0][1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -390,7 +395,7 @@ class BBCode
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!isset($post['type'])) {
|
if (!isset($post['type'])) {
|
||||||
$post['type'] = "text";
|
$post['type'] = 'text';
|
||||||
$post['text'] = trim($body);
|
$post['text'] = trim($body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -422,7 +427,7 @@ class BBCode
|
||||||
*
|
*
|
||||||
* @return string with replaced body
|
* @return string with replaced body
|
||||||
*/
|
*/
|
||||||
public static function removeAttachment($body, $no_link_desc = false)
|
public static function removeAttachment(string $body, bool $no_link_desc = false): string
|
||||||
{
|
{
|
||||||
return preg_replace_callback("/\s*\[attachment (.*?)\](.*?)\[\/attachment\]\s*/ism",
|
return preg_replace_callback("/\s*\[attachment (.*?)\](.*?)\[\/attachment\]\s*/ism",
|
||||||
function ($match) use ($body, $no_link_desc) {
|
function ($match) use ($body, $no_link_desc) {
|
||||||
|
@ -442,12 +447,12 @@ class BBCode
|
||||||
/**
|
/**
|
||||||
* Converts a BBCode text into plaintext
|
* Converts a BBCode text into plaintext
|
||||||
*
|
*
|
||||||
* @param $text
|
* @param string $text
|
||||||
* @param bool $keep_urls Whether to keep URLs in the resulting plaintext
|
* @param bool $keep_urls Whether to keep URLs in the resulting plaintext
|
||||||
*
|
*
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function toPlaintext($text, $keep_urls = true)
|
public static function toPlaintext(string $text, bool $keep_urls = true): string
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
// Remove pictures in advance to avoid unneeded proxy calls
|
// Remove pictures in advance to avoid unneeded proxy calls
|
||||||
|
@ -463,7 +468,7 @@ class BBCode
|
||||||
return $naked_text;
|
return $naked_text;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function proxyUrl($image, $simplehtml = self::INTERNAL, $uriid = 0, $size = '')
|
private static function proxyUrl(string $image, int $simplehtml = self::INTERNAL, int $uriid = 0, string $size = ''): string
|
||||||
{
|
{
|
||||||
// Only send proxied pictures to API and for internal display
|
// Only send proxied pictures to API and for internal display
|
||||||
if (!in_array($simplehtml, [self::INTERNAL, self::API])) {
|
if (!in_array($simplehtml, [self::INTERNAL, self::API])) {
|
||||||
|
@ -483,7 +488,7 @@ class BBCode
|
||||||
* @param string $srctext The body with images
|
* @param string $srctext The body with images
|
||||||
* @return string The body with possibly scaled images
|
* @return string The body with possibly scaled images
|
||||||
*/
|
*/
|
||||||
public static function scaleExternalImages(string $srctext)
|
public static function scaleExternalImages(string $srctext): string
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
$s = $srctext;
|
$s = $srctext;
|
||||||
|
@ -551,7 +556,7 @@ class BBCode
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function limitBodySize($body)
|
public static function limitBodySize(string $body): string
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
$maxlen = DI::config()->get('config', 'max_import_size', 0);
|
$maxlen = DI::config()->get('config', 'max_import_size', 0);
|
||||||
|
@ -646,7 +651,7 @@ class BBCode
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function convertAttachment($text, $simplehtml = self::INTERNAL, $tryoembed = true, array $data = [], $uriid = 0)
|
public static function convertAttachment(string $text, int $simplehtml = self::INTERNAL, bool $tryoembed = true, array $data = [], int $uriid = 0): string
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
$data = $data ?: self::getAttachmentData($text);
|
$data = $data ?: self::getAttachmentData($text);
|
||||||
|
@ -659,10 +664,10 @@ class BBCode
|
||||||
$data['title'] = strip_tags($data['title']);
|
$data['title'] = strip_tags($data['title']);
|
||||||
$data['title'] = str_replace(['http://', 'https://'], '', $data['title']);
|
$data['title'] = str_replace(['http://', 'https://'], '', $data['title']);
|
||||||
} else {
|
} else {
|
||||||
$data['title'] = null;
|
$data['title'] = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
if (((strpos($data['text'], "[img=") !== false) || (strpos($data['text'], "[img]") !== false) || DI::config()->get('system', 'always_show_preview')) && !empty($data['image'])) {
|
if (((strpos($data['text'], '[img=') !== false) || (strpos($data['text'], '[img]') !== false) || DI::config()->get('system', 'always_show_preview')) && !empty($data['image'])) {
|
||||||
$data['preview'] = $data['image'];
|
$data['preview'] = $data['image'];
|
||||||
$data['image'] = '';
|
$data['image'] = '';
|
||||||
}
|
}
|
||||||
|
@ -716,14 +721,14 @@ class BBCode
|
||||||
return trim(($data['text'] ?? '') . ' ' . $return . ' ' . ($data['after'] ?? ''));
|
return trim(($data['text'] ?? '') . ' ' . $return . ' ' . ($data['after'] ?? ''));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function removeShareInformation($Text, $plaintext = false, $nolink = false)
|
public static function removeShareInformation(string $text, bool $plaintext = false, bool $nolink = false): string
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
$data = self::getAttachmentData($Text);
|
$data = self::getAttachmentData($text);
|
||||||
|
|
||||||
if (!$data) {
|
if (!$data) {
|
||||||
DI::profiler()->stopRecording();
|
DI::profiler()->stopRecording();
|
||||||
return $Text;
|
return $text;
|
||||||
} elseif ($nolink) {
|
} elseif ($nolink) {
|
||||||
DI::profiler()->stopRecording();
|
DI::profiler()->stopRecording();
|
||||||
return $data['text'] . ($data['after'] ?? '');
|
return $data['text'] . ($data['after'] ?? '');
|
||||||
|
@ -767,7 +772,7 @@ class BBCode
|
||||||
* @param array $match Array with the matching values
|
* @param array $match Array with the matching values
|
||||||
* @return string reformatted link including HTML codes
|
* @return string reformatted link including HTML codes
|
||||||
*/
|
*/
|
||||||
private static function convertUrlForActivityPubCallback($match)
|
private static function convertUrlForActivityPubCallback(array $match): string
|
||||||
{
|
{
|
||||||
$url = $match[1];
|
$url = $match[1];
|
||||||
|
|
||||||
|
@ -789,10 +794,9 @@ class BBCode
|
||||||
* @param string $url URL that is about to be reformatted
|
* @param string $url URL that is about to be reformatted
|
||||||
* @return string reformatted link including HTML codes
|
* @return string reformatted link including HTML codes
|
||||||
*/
|
*/
|
||||||
private static function convertUrlForActivityPub($url)
|
private static function convertUrlForActivityPub(string $url): string
|
||||||
{
|
{
|
||||||
$html = '<a href="%s" target="_blank" rel="noopener noreferrer">%s</a>';
|
return sprintf('<a href="%s" target="_blank" rel="noopener noreferrer">%s</a>', $url, self::getStyledURL($url));
|
||||||
return sprintf($html, $url, self::getStyledURL($url));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -801,7 +805,7 @@ class BBCode
|
||||||
* @param string $url URL that is about to be reformatted
|
* @param string $url URL that is about to be reformatted
|
||||||
* @return string reformatted link
|
* @return string reformatted link
|
||||||
*/
|
*/
|
||||||
private static function getStyledURL($url)
|
private static function getStyledURL(string $url): string
|
||||||
{
|
{
|
||||||
$parts = parse_url($url);
|
$parts = parse_url($url);
|
||||||
$scheme = $parts['scheme'] . '://';
|
$scheme = $parts['scheme'] . '://';
|
||||||
|
@ -818,8 +822,11 @@ class BBCode
|
||||||
* [noparse][i]italic[/i][/noparse] turns into
|
* [noparse][i]italic[/i][/noparse] turns into
|
||||||
* [noparse][ i ]italic[ /i ][/noparse],
|
* [noparse][ i ]italic[ /i ][/noparse],
|
||||||
* to hide them from parser.
|
* to hide them from parser.
|
||||||
|
*
|
||||||
|
* @param array $match
|
||||||
|
* @return string
|
||||||
*/
|
*/
|
||||||
private static function escapeNoparseCallback($match)
|
private static function escapeNoparseCallback(array $match): string
|
||||||
{
|
{
|
||||||
$whole_match = $match[0];
|
$whole_match = $match[0];
|
||||||
$captured = $match[1];
|
$captured = $match[1];
|
||||||
|
@ -832,8 +839,11 @@ class BBCode
|
||||||
* The previously spacefied [noparse][ i ]italic[ /i ][/noparse],
|
* The previously spacefied [noparse][ i ]italic[ /i ][/noparse],
|
||||||
* now turns back and the [noparse] tags are trimed
|
* now turns back and the [noparse] tags are trimed
|
||||||
* returning [i]italic[/i]
|
* returning [i]italic[/i]
|
||||||
|
*
|
||||||
|
* @param array $match
|
||||||
|
* @return string
|
||||||
*/
|
*/
|
||||||
private static function unescapeNoparseCallback($match)
|
private static function unescapeNoparseCallback(array $match): string
|
||||||
{
|
{
|
||||||
$captured = $match[1];
|
$captured = $match[1];
|
||||||
$unspacefied = preg_replace("/\[ (.*?)\ ]/", "[$1]", $captured);
|
$unspacefied = preg_replace("/\[ (.*?)\ ]/", "[$1]", $captured);
|
||||||
|
@ -849,7 +859,7 @@ class BBCode
|
||||||
* @param int $occurrences Number of first occurrences to skip
|
* @param int $occurrences Number of first occurrences to skip
|
||||||
* @return boolean|array
|
* @return boolean|array
|
||||||
*/
|
*/
|
||||||
public static function getTagPosition($text, $name, $occurrences = 0)
|
public static function getTagPosition(string $text, string $name, int $occurrences = 0)
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
if ($occurrences < 0) {
|
if ($occurrences < 0) {
|
||||||
|
@ -913,7 +923,7 @@ class BBCode
|
||||||
* @param string $text Text to search
|
* @param string $text Text to search
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function pregReplaceInTag($pattern, $replace, $name, $text)
|
public static function pregReplaceInTag(string $pattern, string $replace, string $name, string $text): string
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
$occurrences = 0;
|
$occurrences = 0;
|
||||||
|
@ -936,7 +946,7 @@ class BBCode
|
||||||
return $text;
|
return $text;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function extractImagesFromItemBody($body)
|
private static function extractImagesFromItemBody(string $body): array
|
||||||
{
|
{
|
||||||
$saved_image = [];
|
$saved_image = [];
|
||||||
$orig_body = $body;
|
$orig_body = $body;
|
||||||
|
@ -977,7 +987,7 @@ class BBCode
|
||||||
return ['body' => $new_body, 'images' => $saved_image];
|
return ['body' => $new_body, 'images' => $saved_image];
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function interpolateSavedImagesIntoItemBody($uriid, $body, array $images)
|
private static function interpolateSavedImagesIntoItemBody(int $uriid, string $body, array $images): string
|
||||||
{
|
{
|
||||||
$newbody = $body;
|
$newbody = $body;
|
||||||
|
|
||||||
|
@ -1062,7 +1072,7 @@ class BBCode
|
||||||
* @param callable $callback
|
* @param callable $callback
|
||||||
* @return string The BBCode string with all [share] blocks replaced
|
* @return string The BBCode string with all [share] blocks replaced
|
||||||
*/
|
*/
|
||||||
public static function convertShare($text, callable $callback, int $uriid = 0)
|
public static function convertShare(string $text, callable $callback, int $uriid = 0): string
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
$return = preg_replace_callback(
|
$return = preg_replace_callback(
|
||||||
|
@ -1146,7 +1156,7 @@ class BBCode
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
private static function convertShareCallback(array $attributes, array $author_contact, $content, $is_quote_share, $simplehtml)
|
private static function convertShareCallback(array $attributes, array $author_contact, string $content, bool $is_quote_share, int $simplehtml): string
|
||||||
{
|
{
|
||||||
DI::profiler()->startRecording('rendering');
|
DI::profiler()->startRecording('rendering');
|
||||||
$mention = $attributes['author'] . ' (' . ($author_contact['addr'] ?? '') . ')';
|
$mention = $attributes['author'] . ' (' . ($author_contact['addr'] ?? '') . ')';
|
||||||
|
@ -1215,7 +1225,7 @@ class BBCode
|
||||||
return $text;
|
return $text;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function removePictureLinksCallback($match)
|
private static function removePictureLinksCallback(array $match): string
|
||||||
{
|
{
|
||||||
$cache_key = 'remove:' . $match[1];
|
$cache_key = 'remove:' . $match[1];
|
||||||
$text = DI::cache()->get($cache_key);
|
$text = DI::cache()->get($cache_key);
|
||||||
|
@ -1229,9 +1239,9 @@ class BBCode
|
||||||
}
|
}
|
||||||
|
|
||||||
if (substr($mimetype, 0, 6) == 'image/') {
|
if (substr($mimetype, 0, 6) == 'image/') {
|
||||||
$text = "[url=" . $match[1] . ']' . $match[1] . "[/url]";
|
$text = '[url=' . $match[1] . ']' . $match[1] . '[/url]';
|
||||||
} else {
|
} else {
|
||||||
$text = "[url=" . $match[2] . ']' . $match[2] . "[/url]";
|
$text = '[url=' . $match[2] . ']' . $match[2] . '[/url]';
|
||||||
|
|
||||||
// if its not a picture then look if its a page that contains a picture link
|
// if its not a picture then look if its a page that contains a picture link
|
||||||
$body = DI::httpClient()->fetch($match[1], HttpClientAccept::HTML, 0);
|
$body = DI::httpClient()->fetch($match[1], HttpClientAccept::HTML, 0);
|
||||||
|
@ -1243,7 +1253,7 @@ class BBCode
|
||||||
$doc = new DOMDocument();
|
$doc = new DOMDocument();
|
||||||
@$doc->loadHTML($body);
|
@$doc->loadHTML($body);
|
||||||
$xpath = new DOMXPath($doc);
|
$xpath = new DOMXPath($doc);
|
||||||
$list = $xpath->query("//meta[@name]");
|
$list = $xpath->query('//meta[@name]');
|
||||||
foreach ($list as $node) {
|
foreach ($list as $node) {
|
||||||
$attr = [];
|
$attr = [];
|
||||||
|
|
||||||
|
@ -1331,7 +1341,7 @@ class BBCode
|
||||||
$doc = new DOMDocument();
|
$doc = new DOMDocument();
|
||||||
@$doc->loadHTML($body);
|
@$doc->loadHTML($body);
|
||||||
$xpath = new DOMXPath($doc);
|
$xpath = new DOMXPath($doc);
|
||||||
$list = $xpath->query("//meta[@name]");
|
$list = $xpath->query('//meta[@name]');
|
||||||
foreach ($list as $node) {
|
foreach ($list as $node) {
|
||||||
$attr = [];
|
$attr = [];
|
||||||
if ($node->attributes->length) {
|
if ($node->attributes->length) {
|
||||||
|
@ -1503,10 +1513,10 @@ class BBCode
|
||||||
* $match[1] = $url
|
* $match[1] = $url
|
||||||
* $match[2] = $title or absent
|
* $match[2] = $title or absent
|
||||||
*/
|
*/
|
||||||
$try_oembed_callback = function ($match)
|
$try_oembed_callback = function (array $match)
|
||||||
{
|
{
|
||||||
$url = $match[1];
|
$url = $match[1];
|
||||||
$title = $match[2] ?? null;
|
$title = $match[2] ?? '';
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$return = OEmbed::getHTML($url, $title);
|
$return = OEmbed::getHTML($url, $title);
|
||||||
|
@ -1829,7 +1839,7 @@ class BBCode
|
||||||
|
|
||||||
$text = preg_replace("/\[crypt\](.*?)\[\/crypt\]/ism", '<br><img src="' .DI::baseUrl() . '/images/lock_icon.gif" alt="' . DI::l10n()->t('Encrypted content') . '" title="' . DI::l10n()->t('Encrypted content') . '" /><br>', $text);
|
$text = preg_replace("/\[crypt\](.*?)\[\/crypt\]/ism", '<br><img src="' .DI::baseUrl() . '/images/lock_icon.gif" alt="' . DI::l10n()->t('Encrypted content') . '" title="' . DI::l10n()->t('Encrypted content') . '" /><br>', $text);
|
||||||
$text = preg_replace("/\[crypt(.*?)\](.*?)\[\/crypt\]/ism", '<br><img src="' .DI::baseUrl() . '/images/lock_icon.gif" alt="' . DI::l10n()->t('Encrypted content') . '" title="' . '$1' . ' ' . DI::l10n()->t('Encrypted content') . '" /><br>', $text);
|
$text = preg_replace("/\[crypt(.*?)\](.*?)\[\/crypt\]/ism", '<br><img src="' .DI::baseUrl() . '/images/lock_icon.gif" alt="' . DI::l10n()->t('Encrypted content') . '" title="' . '$1' . ' ' . DI::l10n()->t('Encrypted content') . '" /><br>', $text);
|
||||||
//$Text = preg_replace("/\[crypt=(.*?)\](.*?)\[\/crypt\]/ism", '<br><img src="' .DI::baseUrl() . '/images/lock_icon.gif" alt="' . DI::l10n()->t('Encrypted content') . '" title="' . '$1' . ' ' . DI::l10n()->t('Encrypted content') . '" /><br>', $Text);
|
//$text = preg_replace("/\[crypt=(.*?)\](.*?)\[\/crypt\]/ism", '<br><img src="' .DI::baseUrl() . '/images/lock_icon.gif" alt="' . DI::l10n()->t('Encrypted content') . '" title="' . '$1' . ' ' . DI::l10n()->t('Encrypted content') . '" /><br>', $text);
|
||||||
|
|
||||||
// Simplify "video" element
|
// Simplify "video" element
|
||||||
$text = preg_replace('(\[video[^\]]*?\ssrc\s?=\s?([^\s\]]+)[^\]]*?\].*?\[/video\])ism', '[video]$1[/video]', $text);
|
$text = preg_replace('(\[video[^\]]*?\ssrc\s?=\s?([^\s\]]+)[^\]]*?\].*?\[/video\])ism', '[video]$1[/video]', $text);
|
||||||
|
@ -1957,7 +1967,7 @@ class BBCode
|
||||||
|
|
||||||
if (in_array($simple_html, [self::OSTATUS, self::TWITTER])) {
|
if (in_array($simple_html, [self::OSTATUS, self::TWITTER])) {
|
||||||
$text = preg_replace_callback("/([^#@!])\[url\=([^\]]*)\](.*?)\[\/url\]/ism", "self::expandLinksCallback", $text);
|
$text = preg_replace_callback("/([^#@!])\[url\=([^\]]*)\](.*?)\[\/url\]/ism", "self::expandLinksCallback", $text);
|
||||||
//$Text = preg_replace("/[^#@!]\[url\=([^\]]*)\](.*?)\[\/url\]/ism", ' $2 [url]$1[/url]', $Text);
|
//$text = preg_replace("/[^#@!]\[url\=([^\]]*)\](.*?)\[\/url\]/ism", ' $2 [url]$1[/url]', $text);
|
||||||
$text = preg_replace("/\[bookmark\=([^\]]*)\](.*?)\[\/bookmark\]/ism", ' $2 [url]$1[/url]', $text);
|
$text = preg_replace("/\[bookmark\=([^\]]*)\](.*?)\[\/bookmark\]/ism", ' $2 [url]$1[/url]', $text);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2242,7 +2252,7 @@ class BBCode
|
||||||
$tagline .= '#' . $tag . ' ';
|
$tagline .= '#' . $tag . ' ';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$text = $text . " " . $tagline;
|
$text = $text . ' ' . $tagline;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$text = self::convert($text, false, self::CONNECTORS);
|
$text = self::convert($text, false, self::CONNECTORS);
|
||||||
|
@ -2287,7 +2297,6 @@ class BBCode
|
||||||
* Returns array of tags found, or empty array.
|
* Returns array of tags found, or empty array.
|
||||||
*
|
*
|
||||||
* @param string $string Post content
|
* @param string $string Post content
|
||||||
*
|
|
||||||
* @return array List of tag and person names
|
* @return array List of tag and person names
|
||||||
*/
|
*/
|
||||||
public static function getTags(string $string): array
|
public static function getTags(string $string): array
|
||||||
|
@ -2356,7 +2365,7 @@ class BBCode
|
||||||
public static function expandTags(string $body): string
|
public static function expandTags(string $body): string
|
||||||
{
|
{
|
||||||
return preg_replace_callback("/(?<=\W|^)([!#@])([^\^ \x0D\x0A,;:?'\"]*[^\^ \x0D\x0A,;:?!'\".])/",
|
return preg_replace_callback("/(?<=\W|^)([!#@])([^\^ \x0D\x0A,;:?'\"]*[^\^ \x0D\x0A,;:?!'\".])/",
|
||||||
function ($match) {
|
function (array $match) {
|
||||||
switch ($match[1]) {
|
switch ($match[1]) {
|
||||||
case '!':
|
case '!':
|
||||||
case '@':
|
case '@':
|
||||||
|
@ -2367,6 +2376,7 @@ class BBCode
|
||||||
return $match[1] . $match[2];
|
return $match[1] . $match[2];
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case '#':
|
case '#':
|
||||||
default:
|
default:
|
||||||
return $match[1] . '[url=' . DI::baseUrl() . '/search?tag=' . $match[2] . ']' . $match[2] . '[/url]';
|
return $match[1] . '[url=' . DI::baseUrl() . '/search?tag=' . $match[2] . ']' . $match[2] . '[/url]';
|
||||||
|
@ -2480,7 +2490,6 @@ class BBCode
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
* @see ParseUrl::getSiteinfoCached
|
* @see ParseUrl::getSiteinfoCached
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
public static function embedURL(string $url, bool $tryAttachment = true, string $title = null, string $description = null, string $tags = null): string
|
public static function embedURL(string $url, bool $tryAttachment = true, string $title = null, string $description = null, string $tags = null): string
|
||||||
{
|
{
|
||||||
|
|
|
@ -225,7 +225,7 @@ class Widget
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function contactRels($baseurl, $selected = '')
|
public static function contactRels(string $baseurl, string $selected = ''): string
|
||||||
{
|
{
|
||||||
if (!local_user()) {
|
if (!local_user()) {
|
||||||
return '';
|
return '';
|
||||||
|
@ -256,7 +256,7 @@ class Widget
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function networks($baseurl, $selected = '')
|
public static function networks(string $baseurl, string $selected = ''): string
|
||||||
{
|
{
|
||||||
if (!local_user()) {
|
if (!local_user()) {
|
||||||
return '';
|
return '';
|
||||||
|
@ -294,10 +294,10 @@ class Widget
|
||||||
*
|
*
|
||||||
* @param string $baseurl baseurl
|
* @param string $baseurl baseurl
|
||||||
* @param string $selected optional, default empty
|
* @param string $selected optional, default empty
|
||||||
* @return string|void
|
* @return string
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function fileAs($baseurl, $selected = '')
|
public static function fileAs(string $baseurl, string $selected = ''): string
|
||||||
{
|
{
|
||||||
if (!local_user()) {
|
if (!local_user()) {
|
||||||
return '';
|
return '';
|
||||||
|
@ -325,10 +325,10 @@ class Widget
|
||||||
* @param int $uid Id of the user owning the categories
|
* @param int $uid Id of the user owning the categories
|
||||||
* @param string $baseurl Base page URL
|
* @param string $baseurl Base page URL
|
||||||
* @param string $selected Selected category
|
* @param string $selected Selected category
|
||||||
* @return string|void
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function categories(int $uid, string $baseurl, string $selected = '')
|
public static function categories(int $uid, string $baseurl, string $selected = ''): string
|
||||||
{
|
{
|
||||||
if (!Feature::isEnabled($uid, 'categories')) {
|
if (!Feature::isEnabled($uid, 'categories')) {
|
||||||
return '';
|
return '';
|
||||||
|
@ -355,11 +355,11 @@ class Widget
|
||||||
*
|
*
|
||||||
* @param int $uid Viewed profile user ID
|
* @param int $uid Viewed profile user ID
|
||||||
* @param string $nickname Viewed profile user nickname
|
* @param string $nickname Viewed profile user nickname
|
||||||
* @return string|void
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
* @throws \ImagickException
|
* @throws \ImagickException
|
||||||
*/
|
*/
|
||||||
public static function commonFriendsVisitor(int $uid, string $nickname)
|
public static function commonFriendsVisitor(int $uid, string $nickname): string
|
||||||
{
|
{
|
||||||
if (local_user() == $uid) {
|
if (local_user() == $uid) {
|
||||||
return '';
|
return '';
|
||||||
|
@ -416,7 +416,7 @@ class Widget
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
* @throws \ImagickException
|
* @throws \ImagickException
|
||||||
*/
|
*/
|
||||||
public static function tagCloud(int $uid, int $limit = 50)
|
public static function tagCloud(int $uid, int $limit = 50): string
|
||||||
{
|
{
|
||||||
if (empty($uid)) {
|
if (empty($uid)) {
|
||||||
return '';
|
return '';
|
||||||
|
@ -441,7 +441,7 @@ class Widget
|
||||||
* @return string
|
* @return string
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function postedByYear(string $url, int $uid, bool $wall)
|
public static function postedByYear(string $url, int $uid, bool $wall): string
|
||||||
{
|
{
|
||||||
$o = '';
|
$o = '';
|
||||||
|
|
||||||
|
@ -512,10 +512,10 @@ class Widget
|
||||||
* The account type value is added as a parameter to the url
|
* The account type value is added as a parameter to the url
|
||||||
*
|
*
|
||||||
* @param string $base Basepath
|
* @param string $base Basepath
|
||||||
* @param int $accounttype Acount type
|
* @param string $accounttype Account type
|
||||||
* @return string
|
* @return string
|
||||||
*/
|
*/
|
||||||
public static function accounttypes(string $base, $accounttype)
|
public static function accountTypes(string $base, string $accounttype): string
|
||||||
{
|
{
|
||||||
$accounts = [
|
$accounts = [
|
||||||
['ref' => 'person', 'name' => DI::l10n()->t('Persons')],
|
['ref' => 'person', 'name' => DI::l10n()->t('Persons')],
|
||||||
|
|
|
@ -41,7 +41,7 @@ class Update
|
||||||
* @param string $basePath The base path of this application
|
* @param string $basePath The base path of this application
|
||||||
* @param boolean $via_worker Is the check run via the worker?
|
* @param boolean $via_worker Is the check run via the worker?
|
||||||
* @param App\Mode $mode The current app mode
|
* @param App\Mode $mode The current app mode
|
||||||
*
|
* @return void
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function check(string $basePath, bool $via_worker, App\Mode $mode)
|
public static function check(string $basePath, bool $via_worker, App\Mode $mode)
|
||||||
|
@ -73,7 +73,7 @@ class Update
|
||||||
}
|
}
|
||||||
|
|
||||||
// The postupdate has to completed version 1288 for the new post views to take over
|
// The postupdate has to completed version 1288 for the new post views to take over
|
||||||
$postupdate = DI::config()->get("system", "post_update_version", NEW_TABLE_STRUCTURE_VERSION);
|
$postupdate = DI::config()->get('system', 'post_update_version', NEW_TABLE_STRUCTURE_VERSION);
|
||||||
if ($postupdate < NEW_TABLE_STRUCTURE_VERSION) {
|
if ($postupdate < NEW_TABLE_STRUCTURE_VERSION) {
|
||||||
$error = DI::l10n()->t('Updates from postupdate version %s are not supported. Please update at least to version 2021.01 and wait until the postupdate finished version 1383.', $postupdate);
|
$error = DI::l10n()->t('Updates from postupdate version %s are not supported. Please update at least to version 2021.01 and wait until the postupdate finished version 1383.', $postupdate);
|
||||||
if (DI::mode()->getExecutor() == Mode::INDEX) {
|
if (DI::mode()->getExecutor() == Mode::INDEX) {
|
||||||
|
@ -85,9 +85,11 @@ class Update
|
||||||
|
|
||||||
if ($build < DB_UPDATE_VERSION) {
|
if ($build < DB_UPDATE_VERSION) {
|
||||||
if ($via_worker) {
|
if ($via_worker) {
|
||||||
// Calling the database update directly via the worker enables us to perform database changes to the workerqueue table itself.
|
/*
|
||||||
// This is a fallback, since normally the database update will be performed by a worker job.
|
* Calling the database update directly via the worker enables us to perform database changes to the workerqueue table itself.
|
||||||
// This worker job doesn't work for changes to the "workerqueue" table itself.
|
* This is a fallback, since normally the database update will be performed by a worker job.
|
||||||
|
* This worker job doesn't work for changes to the "workerqueue" table itself.
|
||||||
|
*/
|
||||||
self::run($basePath);
|
self::run($basePath);
|
||||||
} else {
|
} else {
|
||||||
Worker::add(PRIORITY_CRITICAL, 'DBUpdate');
|
Worker::add(PRIORITY_CRITICAL, 'DBUpdate');
|
||||||
|
@ -103,11 +105,10 @@ class Update
|
||||||
* @param bool $override Overrides any running/stuck updates
|
* @param bool $override Overrides any running/stuck updates
|
||||||
* @param bool $verbose Run the Update-Check verbose
|
* @param bool $verbose Run the Update-Check verbose
|
||||||
* @param bool $sendMail Sends a Mail to the administrator in case of success/failure
|
* @param bool $sendMail Sends a Mail to the administrator in case of success/failure
|
||||||
*
|
|
||||||
* @return string Empty string if the update is successful, error messages otherwise
|
* @return string Empty string if the update is successful, error messages otherwise
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function run(string $basePath, bool $force = false, bool $override = false, bool $verbose = false, bool $sendMail = true)
|
public static function run(string $basePath, bool $force = false, bool $override = false, bool $verbose = false, bool $sendMail = true): string
|
||||||
{
|
{
|
||||||
// In force mode, we release the dbupdate lock first
|
// In force mode, we release the dbupdate lock first
|
||||||
// Necessary in case of an stuck update
|
// Necessary in case of an stuck update
|
||||||
|
@ -228,11 +229,10 @@ class Update
|
||||||
* @param int $version the DB version number of the function
|
* @param int $version the DB version number of the function
|
||||||
* @param string $prefix the prefix of the function (update, pre_update)
|
* @param string $prefix the prefix of the function (update, pre_update)
|
||||||
* @param bool $sendMail whether to send emails on success/failure
|
* @param bool $sendMail whether to send emails on success/failure
|
||||||
|
|
||||||
* @return bool true, if the update function worked
|
* @return bool true, if the update function worked
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function runUpdateFunction(int $version, string $prefix, bool $sendMail = true)
|
public static function runUpdateFunction(int $version, string $prefix, bool $sendMail = true): bool
|
||||||
{
|
{
|
||||||
$funcname = $prefix . '_' . $version;
|
$funcname = $prefix . '_' . $version;
|
||||||
|
|
||||||
|
@ -284,6 +284,7 @@ class Update
|
||||||
*
|
*
|
||||||
* @param int $update_id number of failed update
|
* @param int $update_id number of failed update
|
||||||
* @param string $error_message error message
|
* @param string $error_message error message
|
||||||
|
* @return void
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
private static function updateFailed(int $update_id, string $error_message) {
|
private static function updateFailed(int $update_id, string $error_message) {
|
||||||
|
|
|
@ -73,7 +73,7 @@ class DBStructure
|
||||||
*/
|
*/
|
||||||
public static function dropTables(bool $execute)
|
public static function dropTables(bool $execute)
|
||||||
{
|
{
|
||||||
$postupdate = DI::config()->get("system", "post_update_version", PostUpdate::VERSION);
|
$postupdate = DI::config()->get('system', 'post_update_version', PostUpdate::VERSION);
|
||||||
if ($postupdate < PostUpdate::VERSION) {
|
if ($postupdate < PostUpdate::VERSION) {
|
||||||
echo DI::l10n()->t('The post update is at version %d, it has to be at %d to safely drop the tables.', $postupdate, PostUpdate::VERSION);
|
echo DI::l10n()->t('The post update is at version %d, it has to be at %d to safely drop the tables.', $postupdate, PostUpdate::VERSION);
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -538,7 +538,7 @@ class PostUpdate
|
||||||
private static function update1347()
|
private static function update1347()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1347) {
|
if (DI::config()->get('system', 'post_update_version') >= 1347) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -547,7 +547,7 @@ class PostUpdate
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
$id = DI::config()->get("system", "post_update_version_1347_id", 0);
|
$id = DI::config()->get('system', 'post_update_version_1347_id', 0);
|
||||||
|
|
||||||
Logger::info('Start', ['item' => $id]);
|
Logger::info('Start', ['item' => $id]);
|
||||||
|
|
||||||
|
@ -582,12 +582,12 @@ class PostUpdate
|
||||||
}
|
}
|
||||||
DBA::close($items);
|
DBA::close($items);
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version_1347_id", $id);
|
DI::config()->set('system', 'post_update_version_1347_id', $id);
|
||||||
|
|
||||||
Logger::info('Processed', ['rows' => $rows, 'last' => $id]);
|
Logger::info('Processed', ['rows' => $rows, 'last' => $id]);
|
||||||
|
|
||||||
if ($start_id == $id) {
|
if ($start_id == $id) {
|
||||||
DI::config()->set("system", "post_update_version", 1347);
|
DI::config()->set('system', 'post_update_version', 1347);
|
||||||
Logger::info('Done');
|
Logger::info('Done');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -605,11 +605,11 @@ class PostUpdate
|
||||||
private static function update1348()
|
private static function update1348()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1348) {
|
if (DI::config()->get('system', 'post_update_version') >= 1348) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
$id = DI::config()->get("system", "post_update_version_1348_id", 0);
|
$id = DI::config()->get('system', 'post_update_version_1348_id', 0);
|
||||||
|
|
||||||
Logger::info('Start', ['contact' => $id]);
|
Logger::info('Start', ['contact' => $id]);
|
||||||
|
|
||||||
|
@ -635,12 +635,12 @@ class PostUpdate
|
||||||
}
|
}
|
||||||
DBA::close($contacts);
|
DBA::close($contacts);
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version_1348_id", $id);
|
DI::config()->set('system', 'post_update_version_1348_id', $id);
|
||||||
|
|
||||||
Logger::info('Processed', ['rows' => $rows, 'last' => $id]);
|
Logger::info('Processed', ['rows' => $rows, 'last' => $id]);
|
||||||
|
|
||||||
if ($start_id == $id) {
|
if ($start_id == $id) {
|
||||||
DI::config()->set("system", "post_update_version", 1348);
|
DI::config()->set('system', 'post_update_version', 1348);
|
||||||
Logger::info('Done');
|
Logger::info('Done');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -658,11 +658,11 @@ class PostUpdate
|
||||||
private static function update1349()
|
private static function update1349()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1349) {
|
if (DI::config()->get('system', 'post_update_version') >= 1349) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
$id = DI::config()->get("system", "post_update_version_1349_id", '');
|
$id = DI::config()->get('system', 'post_update_version_1349_id', '');
|
||||||
|
|
||||||
Logger::info('Start', ['apcontact' => $id]);
|
Logger::info('Start', ['apcontact' => $id]);
|
||||||
|
|
||||||
|
@ -688,12 +688,12 @@ class PostUpdate
|
||||||
}
|
}
|
||||||
DBA::close($apcontacts);
|
DBA::close($apcontacts);
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version_1349_id", $id);
|
DI::config()->set('system', 'post_update_version_1349_id', $id);
|
||||||
|
|
||||||
Logger::info('Processed', ['rows' => $rows, 'last' => $id]);
|
Logger::info('Processed', ['rows' => $rows, 'last' => $id]);
|
||||||
|
|
||||||
if ($start_id == $id) {
|
if ($start_id == $id) {
|
||||||
DI::config()->set("system", "post_update_version", 1349);
|
DI::config()->set('system', 'post_update_version', 1349);
|
||||||
Logger::info('Done');
|
Logger::info('Done');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -711,7 +711,7 @@ class PostUpdate
|
||||||
private static function update1383()
|
private static function update1383()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1383) {
|
if (DI::config()->get('system', 'post_update_version') >= 1383) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -737,7 +737,7 @@ class PostUpdate
|
||||||
}
|
}
|
||||||
DBA::close($photos);
|
DBA::close($photos);
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version", 1383);
|
DI::config()->set('system', 'post_update_version', 1383);
|
||||||
Logger::info('Done', ['deleted' => $deleted]);
|
Logger::info('Done', ['deleted' => $deleted]);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -752,7 +752,7 @@ class PostUpdate
|
||||||
private static function update1384()
|
private static function update1384()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1384) {
|
if (DI::config()->get('system', 'post_update_version') >= 1384) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -782,7 +782,7 @@ class PostUpdate
|
||||||
Logger::info('Processed', ['rows' => $rows]);
|
Logger::info('Processed', ['rows' => $rows]);
|
||||||
|
|
||||||
if ($rows <= 100) {
|
if ($rows <= 100) {
|
||||||
DI::config()->set("system", "post_update_version", 1384);
|
DI::config()->set('system', 'post_update_version', 1384);
|
||||||
Logger::info('Done');
|
Logger::info('Done');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -800,12 +800,12 @@ class PostUpdate
|
||||||
private static function update1400()
|
private static function update1400()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1400) {
|
if (DI::config()->get('system', 'post_update_version') >= 1400) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!DBStructure::existsTable('item')) {
|
if (!DBStructure::existsTable('item')) {
|
||||||
DI::config()->set("system", "post_update_version", 1400);
|
DI::config()->set('system', 'post_update_version', 1400);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -829,7 +829,7 @@ class PostUpdate
|
||||||
Logger::info('Processed', ['rows' => $rows]);
|
Logger::info('Processed', ['rows' => $rows]);
|
||||||
|
|
||||||
if ($rows <= 100) {
|
if ($rows <= 100) {
|
||||||
DI::config()->set("system", "post_update_version", 1400);
|
DI::config()->set('system', 'post_update_version', 1400);
|
||||||
Logger::info('Done');
|
Logger::info('Done');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -847,7 +847,7 @@ class PostUpdate
|
||||||
private static function update1424()
|
private static function update1424()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1424) {
|
if (DI::config()->get('system', 'post_update_version') >= 1424) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -871,7 +871,7 @@ class PostUpdate
|
||||||
Logger::info('Processed', ['rows' => $rows]);
|
Logger::info('Processed', ['rows' => $rows]);
|
||||||
|
|
||||||
if ($rows <= 100) {
|
if ($rows <= 100) {
|
||||||
DI::config()->set("system", "post_update_version", 1424);
|
DI::config()->set('system', 'post_update_version', 1424);
|
||||||
Logger::info('Done');
|
Logger::info('Done');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -889,7 +889,7 @@ class PostUpdate
|
||||||
private static function update1425()
|
private static function update1425()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1425) {
|
if (DI::config()->get('system', 'post_update_version') >= 1425) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -918,7 +918,7 @@ class PostUpdate
|
||||||
Logger::info('Processed', ['rows' => $rows]);
|
Logger::info('Processed', ['rows' => $rows]);
|
||||||
|
|
||||||
if ($rows <= 100) {
|
if ($rows <= 100) {
|
||||||
DI::config()->set("system", "post_update_version", 1425);
|
DI::config()->set('system', 'post_update_version', 1425);
|
||||||
Logger::info('Done');
|
Logger::info('Done');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -936,7 +936,7 @@ class PostUpdate
|
||||||
private static function update1426()
|
private static function update1426()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1426) {
|
if (DI::config()->get('system', 'post_update_version') >= 1426) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -965,7 +965,7 @@ class PostUpdate
|
||||||
Logger::info('Processed', ['rows' => $rows]);
|
Logger::info('Processed', ['rows' => $rows]);
|
||||||
|
|
||||||
if ($rows <= 100) {
|
if ($rows <= 100) {
|
||||||
DI::config()->set("system", "post_update_version", 1426);
|
DI::config()->set('system', 'post_update_version', 1426);
|
||||||
Logger::info('Done');
|
Logger::info('Done');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -983,7 +983,7 @@ class PostUpdate
|
||||||
private static function update1427()
|
private static function update1427()
|
||||||
{
|
{
|
||||||
// Was the script completed?
|
// Was the script completed?
|
||||||
if (DI::config()->get("system", "post_update_version") >= 1427) {
|
if (DI::config()->get('system', 'post_update_version') >= 1427) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1012,7 +1012,7 @@ class PostUpdate
|
||||||
Logger::info('Processed', ['rows' => $rows]);
|
Logger::info('Processed', ['rows' => $rows]);
|
||||||
|
|
||||||
if ($rows <= 100) {
|
if ($rows <= 100) {
|
||||||
DI::config()->set("system", "post_update_version", 1427);
|
DI::config()->set('system', 'post_update_version', 1427);
|
||||||
Logger::info('Done');
|
Logger::info('Done');
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -474,7 +474,6 @@ class Contact
|
||||||
* Check if the given contact ID is on the same server
|
* Check if the given contact ID is on the same server
|
||||||
*
|
*
|
||||||
* @param string $url The contact link
|
* @param string $url The contact link
|
||||||
*
|
|
||||||
* @return boolean Is it the same server?
|
* @return boolean Is it the same server?
|
||||||
*/
|
*/
|
||||||
public static function isLocalById(int $cid): bool
|
public static function isLocalById(int $cid): bool
|
||||||
|
@ -556,7 +555,6 @@ class Contact
|
||||||
*
|
*
|
||||||
* @param int $cid Either public contact id or user's contact id
|
* @param int $cid Either public contact id or user's contact id
|
||||||
* @param int $uid User ID
|
* @param int $uid User ID
|
||||||
*
|
|
||||||
* @return array with public and user's contact id
|
* @return array with public and user's contact id
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
* @throws \ImagickException
|
* @throws \ImagickException
|
||||||
|
@ -597,12 +595,11 @@ class Contact
|
||||||
* @param int $cid A contact ID
|
* @param int $cid A contact ID
|
||||||
* @param int $uid The User ID
|
* @param int $uid The User ID
|
||||||
* @param array $fields The selected fields for the contact
|
* @param array $fields The selected fields for the contact
|
||||||
*
|
|
||||||
* @return array The contact details
|
* @return array The contact details
|
||||||
*
|
*
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function getContactForUser($cid, $uid, array $fields = [])
|
public static function getContactForUser(int $cid, int $uid, array $fields = []): array
|
||||||
{
|
{
|
||||||
$contact = DBA::selectFirst('contact', $fields, ['id' => $cid, 'uid' => $uid]);
|
$contact = DBA::selectFirst('contact', $fields, ['id' => $cid, 'uid' => $uid]);
|
||||||
|
|
||||||
|
@ -620,7 +617,7 @@ class Contact
|
||||||
* @return bool Operation success
|
* @return bool Operation success
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function createSelfFromUserId($uid)
|
public static function createSelfFromUserId(int $uid): bool
|
||||||
{
|
{
|
||||||
$user = DBA::selectFirst('user', ['uid', 'username', 'nickname', 'pubkey', 'prvkey'],
|
$user = DBA::selectFirst('user', ['uid', 'username', 'nickname', 'pubkey', 'prvkey'],
|
||||||
['uid' => $uid, 'account_expired' => false]);
|
['uid' => $uid, 'account_expired' => false]);
|
||||||
|
@ -678,11 +675,11 @@ class Contact
|
||||||
* Updates the self-contact for the provided user id
|
* Updates the self-contact for the provided user id
|
||||||
*
|
*
|
||||||
* @param int $uid
|
* @param int $uid
|
||||||
* @param boolean $update_avatar Force the avatar update
|
* @param bool $update_avatar Force the avatar update
|
||||||
* @return bool "true" if updated
|
* @return bool "true" if updated
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function updateSelfFromUserID($uid, $update_avatar = false)
|
public static function updateSelfFromUserID(int $uid, bool $update_avatar = false): bool
|
||||||
{
|
{
|
||||||
$fields = ['id', 'uri-id', 'name', 'nick', 'location', 'about', 'keywords', 'avatar', 'prvkey', 'pubkey', 'manually-approve',
|
$fields = ['id', 'uri-id', 'name', 'nick', 'location', 'about', 'keywords', 'avatar', 'prvkey', 'pubkey', 'manually-approve',
|
||||||
'xmpp', 'matrix', 'contact-type', 'forum', 'prv', 'avatar-date', 'url', 'nurl', 'unsearchable',
|
'xmpp', 'matrix', 'contact-type', 'forum', 'prv', 'avatar-date', 'url', 'nurl', 'unsearchable',
|
||||||
|
@ -795,9 +792,10 @@ class Contact
|
||||||
* Marks a contact for removal
|
* Marks a contact for removal
|
||||||
*
|
*
|
||||||
* @param int $id contact id
|
* @param int $id contact id
|
||||||
|
* @return void
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function remove($id)
|
public static function remove(int $id)
|
||||||
{
|
{
|
||||||
// We want just to make sure that we don't delete our "self" contact
|
// We want just to make sure that we don't delete our "self" contact
|
||||||
$contact = DBA::selectFirst('contact', ['uri-id', 'photo', 'thumb', 'micro', 'uid'], ['id' => $id, 'self' => false]);
|
$contact = DBA::selectFirst('contact', ['uri-id', 'photo', 'thumb', 'micro', 'uid'], ['id' => $id, 'self' => false]);
|
||||||
|
@ -822,6 +820,7 @@ class Contact
|
||||||
* Unfollow the remote contact
|
* Unfollow the remote contact
|
||||||
*
|
*
|
||||||
* @param array $contact Target user-specific contact (uid != 0) array
|
* @param array $contact Target user-specific contact (uid != 0) array
|
||||||
|
* @return void
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
* @throws \ImagickException
|
* @throws \ImagickException
|
||||||
*/
|
*/
|
||||||
|
@ -851,6 +850,7 @@ class Contact
|
||||||
* The local relationship is updated immediately, the eventual remote server is messaged in the background.
|
* The local relationship is updated immediately, the eventual remote server is messaged in the background.
|
||||||
*
|
*
|
||||||
* @param array $contact User-specific contact array (uid != 0) to revoke the follow from
|
* @param array $contact User-specific contact array (uid != 0) to revoke the follow from
|
||||||
|
* @return void
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
* @throws \ImagickException
|
* @throws \ImagickException
|
||||||
*/
|
*/
|
||||||
|
@ -878,6 +878,7 @@ class Contact
|
||||||
* Completely severs a relationship with a contact
|
* Completely severs a relationship with a contact
|
||||||
*
|
*
|
||||||
* @param array $contact User-specific contact (uid != 0) array
|
* @param array $contact User-specific contact (uid != 0) array
|
||||||
|
* @return void
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
* @throws \ImagickException
|
* @throws \ImagickException
|
||||||
*/
|
*/
|
||||||
|
@ -925,7 +926,7 @@ class Contact
|
||||||
* up or some other transient event and that there's a possibility we could recover from it.
|
* up or some other transient event and that there's a possibility we could recover from it.
|
||||||
*
|
*
|
||||||
* @param array $contact contact to mark for archival
|
* @param array $contact contact to mark for archival
|
||||||
* @return null
|
* @return void
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function markForArchival(array $contact)
|
public static function markForArchival(array $contact)
|
||||||
|
@ -978,7 +979,7 @@ class Contact
|
||||||
* @see Contact::markForArchival()
|
* @see Contact::markForArchival()
|
||||||
*
|
*
|
||||||
* @param array $contact contact to be unmarked for archival
|
* @param array $contact contact to be unmarked for archival
|
||||||
* @return null
|
* @return void
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function unmarkForArchival(array $contact)
|
public static function unmarkForArchival(array $contact)
|
||||||
|
@ -1025,7 +1026,7 @@ class Contact
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
* @throws \ImagickException
|
* @throws \ImagickException
|
||||||
*/
|
*/
|
||||||
public static function photoMenu(array $contact, $uid = 0)
|
public static function photoMenu(array $contact, int $uid = 0): array
|
||||||
{
|
{
|
||||||
$pm_url = '';
|
$pm_url = '';
|
||||||
$status_link = '';
|
$status_link = '';
|
||||||
|
@ -1168,7 +1169,7 @@ class Contact
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
* @throws \ImagickException
|
* @throws \ImagickException
|
||||||
*/
|
*/
|
||||||
public static function getIdForURL($url, $uid = 0, $update = null, $default = [])
|
public static function getIdForURL(string $url, int $uid = 0, $update = null, array $default = []): int
|
||||||
{
|
{
|
||||||
$contact_id = 0;
|
$contact_id = 0;
|
||||||
|
|
||||||
|
@ -1312,7 +1313,7 @@ class Contact
|
||||||
* @return boolean Is the contact archived?
|
* @return boolean Is the contact archived?
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function isArchived(int $cid)
|
public static function isArchived(int $cid): bool
|
||||||
{
|
{
|
||||||
if ($cid == 0) {
|
if ($cid == 0) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -1352,11 +1353,10 @@ class Contact
|
||||||
* Checks if the contact is blocked
|
* Checks if the contact is blocked
|
||||||
*
|
*
|
||||||
* @param int $cid contact id
|
* @param int $cid contact id
|
||||||
*
|
|
||||||
* @return boolean Is the contact blocked?
|
* @return boolean Is the contact blocked?
|
||||||
* @throws HTTPException\InternalServerErrorException
|
* @throws HTTPException\InternalServerErrorException
|
||||||
*/
|
*/
|
||||||
public static function isBlocked($cid)
|
public static function isBlocked(int $cid): bool
|
||||||
{
|
{
|
||||||
if ($cid == 0) {
|
if ($cid == 0) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -1378,11 +1378,10 @@ class Contact
|
||||||
* Checks if the contact is hidden
|
* Checks if the contact is hidden
|
||||||
*
|
*
|
||||||
* @param int $cid contact id
|
* @param int $cid contact id
|
||||||
*
|
|
||||||
* @return boolean Is the contact hidden?
|
* @return boolean Is the contact hidden?
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function isHidden($cid)
|
public static function isHidden(int $cid): bool
|
||||||
{
|
{
|
||||||
if ($cid == 0) {
|
if ($cid == 0) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -1406,7 +1405,7 @@ class Contact
|
||||||
* @return string posts in HTML
|
* @return string posts in HTML
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function getPostsFromUrl($contact_url, $thread_mode = false, $update = 0, $parent = 0, bool $only_media = false)
|
public static function getPostsFromUrl(string $contact_url, bool $thread_mode = false, int $update = 0, int $parent = 0, bool $only_media = false): string
|
||||||
{
|
{
|
||||||
return self::getPostsFromId(self::getIdForURL($contact_url), $thread_mode, $update, $parent, $only_media);
|
return self::getPostsFromId(self::getIdForURL($contact_url), $thread_mode, $update, $parent, $only_media);
|
||||||
}
|
}
|
||||||
|
@ -1422,7 +1421,7 @@ class Contact
|
||||||
* @return string posts in HTML
|
* @return string posts in HTML
|
||||||
* @throws \Exception
|
* @throws \Exception
|
||||||
*/
|
*/
|
||||||
public static function getPostsFromId($cid, $thread_mode = false, $update = 0, $parent = 0, bool $only_media = false)
|
public static function getPostsFromId(int $cid, bool $thread_mode = false, int $update = 0, int $parent = 0, bool $only_media = false): string
|
||||||
{
|
{
|
||||||
$contact = DBA::selectFirst('contact', ['contact-type', 'network'], ['id' => $cid]);
|
$contact = DBA::selectFirst('contact', ['contact-type', 'network'], ['id' => $cid]);
|
||||||
if (!DBA::isResult($contact)) {
|
if (!DBA::isResult($contact)) {
|
||||||
|
|
|
@ -586,6 +586,8 @@ class Photo
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Returns a float that represents the GPS coordinate from EXIF data
|
||||||
|
*
|
||||||
* @param array $exifCoord coordinate
|
* @param array $exifCoord coordinate
|
||||||
* @param string $hemi hemi
|
* @param string $hemi hemi
|
||||||
* @return float
|
* @return float
|
||||||
|
|
|
@ -186,7 +186,7 @@ class Contact extends BaseModule
|
||||||
$follow_widget = Widget::follow();
|
$follow_widget = Widget::follow();
|
||||||
}
|
}
|
||||||
|
|
||||||
$account_widget = Widget::accounttypes($_SERVER['REQUEST_URI'], $accounttype);
|
$account_widget = Widget::accountTypes($_SERVER['REQUEST_URI'], $accounttype);
|
||||||
$networks_widget = Widget::networks($_SERVER['REQUEST_URI'], $nets);
|
$networks_widget = Widget::networks($_SERVER['REQUEST_URI'], $nets);
|
||||||
$rel_widget = Widget::contactRels($_SERVER['REQUEST_URI'], $rel);
|
$rel_widget = Widget::contactRels($_SERVER['REQUEST_URI'], $rel);
|
||||||
$groups_widget = Widget::groups($_SERVER['REQUEST_URI'], $group);
|
$groups_widget = Widget::groups($_SERVER['REQUEST_URI'], $group);
|
||||||
|
|
|
@ -141,7 +141,7 @@ class Contacts extends BaseModule
|
||||||
'$paginate' => $pager->renderFull($total),
|
'$paginate' => $pager->renderFull($total),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
DI::page()['aside'] .= Widget::accounttypes($_SERVER['REQUEST_URI'], $accounttype);
|
DI::page()['aside'] .= Widget::accountTypes($_SERVER['REQUEST_URI'], $accounttype);
|
||||||
|
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,7 +90,7 @@ class Community extends BaseModule
|
||||||
|
|
||||||
Nav::setSelected('community');
|
Nav::setSelected('community');
|
||||||
|
|
||||||
DI::page()['aside'] .= Widget::accounttypes('community/' . self::$content, self::$accountTypeString);
|
DI::page()['aside'] .= Widget::accountTypes('community/' . self::$content, self::$accountTypeString);
|
||||||
|
|
||||||
if (local_user() && DI::config()->get('system', 'community_no_sharer')) {
|
if (local_user() && DI::config()->get('system', 'community_no_sharer')) {
|
||||||
$path = self::$content;
|
$path = self::$content;
|
||||||
|
|
|
@ -86,13 +86,13 @@ class Network extends BaseModule
|
||||||
|
|
||||||
$module = 'network';
|
$module = 'network';
|
||||||
|
|
||||||
DI::page()['aside'] .= Widget::accounttypes($module, self::$accountTypeString);
|
DI::page()['aside'] .= Widget::accountTypes($module, self::$accountTypeString);
|
||||||
DI::page()['aside'] .= Group::sidebarWidget($module, $module . '/group', 'standard', self::$groupId);
|
DI::page()['aside'] .= Group::sidebarWidget($module, $module . '/group', 'standard', self::$groupId);
|
||||||
DI::page()['aside'] .= ForumManager::widget($module . '/forum', local_user(), self::$forumContactId);
|
DI::page()['aside'] .= ForumManager::widget($module . '/forum', local_user(), self::$forumContactId);
|
||||||
DI::page()['aside'] .= Widget::postedByYear($module . '/archive', local_user(), false);
|
DI::page()['aside'] .= Widget::postedByYear($module . '/archive', local_user(), false);
|
||||||
DI::page()['aside'] .= Widget::networks($module, !self::$forumContactId ? self::$network : '');
|
DI::page()['aside'] .= Widget::networks($module, !self::$forumContactId ? self::$network : '');
|
||||||
DI::page()['aside'] .= Widget\SavedSearches::getHTML(DI::args()->getQueryString());
|
DI::page()['aside'] .= Widget\SavedSearches::getHTML(DI::args()->getQueryString());
|
||||||
DI::page()['aside'] .= Widget::fileAs('filed', null);
|
DI::page()['aside'] .= Widget::fileAs('filed', '');
|
||||||
|
|
||||||
$arr = ['query' => DI::args()->getQueryString()];
|
$arr = ['query' => DI::args()->getQueryString()];
|
||||||
Hook::callAll('network_content_init', $arr);
|
Hook::callAll('network_content_init', $arr);
|
||||||
|
|
|
@ -258,7 +258,7 @@ class Photo extends BaseModule
|
||||||
return MPhoto::getPhoto($matches[1], $matches[2]);
|
return MPhoto::getPhoto($matches[1], $matches[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return MPhoto::createPhotoForExternalResource($url, (int)local_user(), $media['mimetype']);
|
return MPhoto::createPhotoForExternalResource($url, (int)local_user(), $media['mimetype'] ?? '');
|
||||||
case 'media':
|
case 'media':
|
||||||
$media = DBA::selectFirst('post-media', ['url', 'mimetype', 'uri-id'], ['id' => $id, 'type' => Post\Media::IMAGE]);
|
$media = DBA::selectFirst('post-media', ['url', 'mimetype', 'uri-id'], ['id' => $id, 'type' => Post\Media::IMAGE]);
|
||||||
if (empty($media)) {
|
if (empty($media)) {
|
||||||
|
@ -276,7 +276,7 @@ class Photo extends BaseModule
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return MPhoto::createPhotoForExternalResource($link['url'], (int)local_user(), $link['mimetype']);
|
return MPhoto::createPhotoForExternalResource($link['url'], (int)local_user(), $link['mimetype'] ?? '');
|
||||||
case 'contact':
|
case 'contact':
|
||||||
$fields = ['uid', 'uri-id', 'url', 'nurl', 'avatar', 'photo', 'xmpp', 'addr', 'network', 'failed', 'updated'];
|
$fields = ['uid', 'uri-id', 'url', 'nurl', 'avatar', 'photo', 'xmpp', 'addr', 'network', 'failed', 'updated'];
|
||||||
$contact = Contact::getById($id, $fields);
|
$contact = Contact::getById($id, $fields);
|
||||||
|
|
|
@ -106,7 +106,7 @@ class Post
|
||||||
// Only add will be displayed
|
// Only add will be displayed
|
||||||
if ($item['network'] === Protocol::MAIL && local_user() != $item['uid']) {
|
if ($item['network'] === Protocol::MAIL && local_user() != $item['uid']) {
|
||||||
continue;
|
continue;
|
||||||
} elseif (!DI::contentItem()->visibleActivity($item)) {
|
} elseif (!DI::contentItem()->isVisibleActivity($item)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -981,7 +981,7 @@ function update_1429()
|
||||||
return Update::FAILED;
|
return Update::FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
DI::config()->set("system", "post_update_version", 1423);
|
DI::config()->set('system', 'post_update_version', 1423);
|
||||||
|
|
||||||
return Update::SUCCESS;
|
return Update::SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue