Merge pull request #14322 from annando/link-length

Configurable maximum link length
This commit is contained in:
Tobias Diekershoff 2024-07-26 20:40:54 +02:00 committed by GitHub
commit 4f928b6fae
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 21 additions and 10 deletions

View file

@ -2090,7 +2090,7 @@ class BBCode
$text = preg_replace("/\[zrl\=(.*?)\](.*?)\[\/zrl\]/ism", '[url=$1]$2[/url]', $text); $text = preg_replace("/\[zrl\=(.*?)\](.*?)\[\/zrl\]/ism", '[url=$1]$2[/url]', $text);
if (in_array($simple_html, [self::INTERNAL, self::EXTERNAL, self::DIASPORA, self::OSTATUS, self::MASTODON_API, self::TWITTER_API, self::ACTIVITYPUB])) { if (in_array($simple_html, [self::INTERNAL, self::EXTERNAL, self::DIASPORA, self::OSTATUS, self::MASTODON_API, self::TWITTER_API, self::ACTIVITYPUB])) {
$text = self::shortenLinkDescription($text); $text = self::shortenLinkDescription($text, $simple_html);
} else { } else {
$text = self::unifyLinks($text); $text = self::unifyLinks($text);
} }
@ -2143,20 +2143,26 @@ class BBCode
); );
} }
private static function shortenLinkDescription(string $text): string private static function shortenLinkDescription(string $text, int $simple_html): string
{ {
if ($simple_html == self::INTERNAL) {
$max_length = DI::config()->get('system', 'display_link_length');
} else {
$max_length = 30;
}
$text = preg_replace_callback( $text = preg_replace_callback(
"/\[url\](.*?)\[\/url\]/ism", "/\[url\](.*?)\[\/url\]/ism",
function ($match) { function ($match) use ($max_length) {
return "[url=" . self::escapeUrl($match[1]) . "]" . Strings::getStyledURL($match[1]) . "[/url]"; return "[url=" . self::escapeUrl($match[1]) . "]" . Strings::getStyledURL($match[1], $max_length) . "[/url]";
}, },
$text $text
); );
$text = preg_replace_callback( $text = preg_replace_callback(
"/\[url\=(.*?)\](.*?)\[\/url\]/ism", "/\[url\=(.*?)\](.*?)\[\/url\]/ism",
function ($match) { function ($match) use ($max_length) {
if ($match[1] == $match[2]) { if ($match[1] == $match[2]) {
return "[url=" . self::escapeUrl($match[1]) . "]" . Strings::getStyledURL($match[2]) . "[/url]"; return "[url=" . self::escapeUrl($match[1]) . "]" . Strings::getStyledURL($match[2], $max_length) . "[/url]";
} else { } else {
return "[url=" . self::escapeUrl($match[1]) . "]" . $match[2] . "[/url]"; return "[url=" . self::escapeUrl($match[1]) . "]" . $match[2] . "[/url]";
} }

View file

@ -565,10 +565,11 @@ class Strings
/** /**
* Converts an URL in a nicer format (without the scheme and possibly shortened) * Converts an URL in a nicer format (without the scheme and possibly shortened)
* *
* @param string $url URL that is about to be reformatted * @param string $url URL that is about to be reformatted
* @param int $max_length Maximum length of an url before it is shortened
* @return string reformatted link * @return string reformatted link
*/ */
public static function getStyledURL(string $url): string public static function getStyledURL(string $url, int $max_length = 30): string
{ {
$parts = parse_url($url); $parts = parse_url($url);
if (empty($parts['scheme'])) { if (empty($parts['scheme'])) {
@ -578,8 +579,8 @@ class Strings
$scheme = [$parts['scheme'] . '://www.', $parts['scheme'] . '://']; $scheme = [$parts['scheme'] . '://www.', $parts['scheme'] . '://'];
$styled_url = str_replace($scheme, '', $url); $styled_url = str_replace($scheme, '', $url);
if (strlen($styled_url) > 30) { if (!empty($max_length) && strlen($styled_url) > $max_length) {
$styled_url = substr($styled_url, 0, 30) . ""; $styled_url = substr($styled_url, 0, $max_length) . "";
} }
return $styled_url; return $styled_url;

View file

@ -259,6 +259,10 @@ return [
// Display the first resharer as icon and text on a reshared item. // Display the first resharer as icon and text on a reshared item.
'display_resharer' => false, 'display_resharer' => false,
// display_link_length (integer)
// Maximum length of displayed links. Default value is 30, 0 deactivates the functionality.
'display_link_length' => 30,
// dlogfile (Path) // dlogfile (Path)
// location of the developer log file. // location of the developer log file.
'dlogfile' => '', 'dlogfile' => '',