diff options
author | Lukas Reschke <lukas@owncloud.com> | 2015-01-17 01:03:41 +0100 |
---|---|---|
committer | Lukas Reschke <lukas@owncloud.com> | 2015-01-17 01:03:41 +0100 |
commit | 744cf713f7d6fff80f79465086a522f35d263ff5 (patch) | |
tree | 5b01004e362e86b79f33362b1931ee1b91634ed0 /lib/private | |
parent | 08d118eab794ee33c60dcb0fa13d1de495a12dfd (diff) | |
parent | 520d8ec53b672e768e59eaf0409559bbecc6c042 (diff) | |
download | nextcloud-server-744cf713f7d6fff80f79465086a522f35d263ff5.tar.gz nextcloud-server-744cf713f7d6fff80f79465086a522f35d263ff5.zip |
Merge pull request #13319 from owncloud/replace-line-breaks-in-app-description
replace line breaks in the app description by spaces - fixes #13315
Diffstat (limited to 'lib/private')
-rw-r--r-- | lib/private/app.php | 39 |
1 files changed, 38 insertions, 1 deletions
diff --git a/lib/private/app.php b/lib/private/app.php index e75202eec23..3a1f731d621 100644 --- a/lib/private/app.php +++ b/lib/private/app.php @@ -642,6 +642,10 @@ class OC_App { $parser = new \OC\App\InfoParser(\OC::$server->getHTTPHelper(), \OC::$server->getURLGenerator()); $data = $parser->parse($file); + if(is_array($data)) { + $data = OC_App::parseAppInfo($data); + } + self::$appInfo[$appId] = $data; return $data; @@ -914,7 +918,8 @@ class OC_App { $i = 0; $l = \OC::$server->getL10N('core'); foreach ($remoteApps as $app) { - $app1[$i] = $app; + // enhance app info (for example the description) + $app1[$i] = OC_App::parseAppInfo($app); $app1[$i]['author'] = $app['personid']; $app1[$i]['ocs_id'] = $app['id']; $app1[$i]['internal'] = $app1[$i]['active'] = 0; @@ -1199,4 +1204,36 @@ class OC_App { return false; } } + + /** + * parses the app data array and enhanced the 'description' value + * + * @param array $data the app data + * @return array improved app data + */ + public static function parseAppInfo(array $data) { + + // just modify the description if it is available + // otherwise this will create a $data element with an empty 'description' + if(isset($data['description'])) { + // sometimes the description contains line breaks and they are then also + // shown in this way in the app management which isn't wanted as HTML + // manages line breaks itself + + // first of all we split on empty lines + $paragraphs = preg_split("!\n[[:space:]]*\n!m", $data['description']); + + $result = []; + foreach ($paragraphs as $value) { + // replace multiple whitespace (tabs, space, newlines) inside a paragraph + // with a single space - also trims whitespace + $result[] = trim(preg_replace('![[:space:]]+!m', ' ', $value)); + } + + // join the single paragraphs with a empty line in between + $data['description'] = implode("\n\n", $result); + } + + return $data; + } } |