diff options
author | Arthur Schiwon <blizzz@arthur-schiwon.de> | 2021-11-26 16:21:40 +0100 |
---|---|---|
committer | Arthur Schiwon <blizzz@arthur-schiwon.de> | 2021-11-26 16:21:40 +0100 |
commit | d384edc9c6bbf708e621c50315c81f02400ff9a6 (patch) | |
tree | c90e1e587d926a091555726bdab1e5e776ee7d2e /lib/public | |
parent | aee3bb42aeb716ff6c60401cd60ec7d6d7a36bec (diff) | |
download | nextcloud-server-d384edc9c6bbf708e621c50315c81f02400ff9a6.tar.gz nextcloud-server-d384edc9c6bbf708e621c50315c81f02400ff9a6.zip |
add method to shorten a string to given byte size to Utils
Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
Diffstat (limited to 'lib/public')
-rw-r--r-- | lib/public/Util.php | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/public/Util.php b/lib/public/Util.php index 5165846707a..103b65fe874 100644 --- a/lib/public/Util.php +++ b/lib/public/Util.php @@ -513,4 +513,28 @@ class Util { } return self::$needUpgradeCache; } + + /** + * Sometimes a string has to be shortened to fit within a certain maximum + * data length in bytes. substr() you may break multibyte characters, + * because it operates on single byte level. mb_substr() operates on + * characters, so does not ensure that the shortend string satisfies the + * max length in bytes. + * + * For example, json_encode is messing with multibyte characters a lot, + * replacing them with something along "\u1234". + * + * This function shortens the string with by $accurancy (-5) from + * $dataLength characters, until it fits within $dataLength bytes. + * + * @since 23.0.0 + */ + public static function shortenMultibyteString(string $subject, int $dataLength, int $accuracy = 5): string { + $temp = mb_substr($subject, 0, $dataLength); + // json encodes encapsulates the string in double quotes, they need to be substracted + while ((strlen(json_encode($temp)) - 2) > $dataLength) { + $temp = mb_substr($temp, 0, -$accuracy); + } + return $temp; + } } |