]> git.mxchange.org Git - friendica.git/blobdiff - src/Module/Manifest.php
Merge pull request #13110 from anubis2814/develop
[friendica.git] / src / Module / Manifest.php
index c0af708fa8877e21749bf4aeb0ea7ee84484d1ab..e98c83a6136b79147d2e772479ee7ae5382fdfd1 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2023, the Friendica project
  *
  * @license GNU AGPL version 3 or any later version
  *
 namespace Friendica\Module;
 
 use Friendica\BaseModule;
-use Friendica\Core\Renderer;
+use Friendica\Core;
 use Friendica\DI;
 
 class Manifest extends BaseModule
 {
-       public static function rawContent(array $parameters = [])
+       protected function rawContent(array $request = [])
        {
                $config = DI::config();
 
-               $tpl = Renderer::getMarkupTemplate('manifest.tpl');
+               $theme = DI::config()->get('system', 'theme');
 
-               header('Content-type: application/manifest+json');
+               $manifest = [
+                       'name'          => $config->get('config', 'sitename', 'Friendica'),
+                       'start_url'     => DI::baseUrl(),
+                       'display'       => 'standalone',
+                       'description'   => $config->get('config', 'info', DI::l10n()->t('A Decentralized Social Network')),
+                       'short_name'    => 'Friendica',
+                       'lang'          => $config->get('system', 'language'),
+                       'dir'           => 'auto',
+                       'categories'    => ['social network', 'internet'],
+                       'shortcuts'     => [
+                               [
+                                       'name'  => 'Latest posts',
+                                       'url'   => '/network'
+                               ],
+                               [
+                                       'name'  => 'Messages',
+                                       'url'   => '/message'
+                               ],
+                               [
+                                       'name'  => 'Notifications',
+                                       'url'   => '/notifications/system'
+                               ],
+                               [
+                                       'name'  => 'Contacts',
+                                       'url'   => '/contact'
+                               ],
+                               [
+                                       'name'  => 'Calendar',
+                                       'url'   => '/calendar'
+                               ]
+                       ]
+               ];
 
-               $touch_icon = $config->get('system', 'touch_icon', 'images/friendica-128.png');
-               if ($touch_icon == '') {
-                       $touch_icon = 'images/friendica-128.png';
+               /// @TODO If the admin provides their own touch icon, the manifest will regress
+               /// to a smaller set of icons that do not follow the web app manifest spec.
+               /// There should be a mechanism to allow the admin to provide all of the 6
+               /// different images that are required for a fully valid web app manifest.
+               $touch_icon = $config->get('system', 'touch_icon');
+               if($touch_icon){
+                       $manifest['icons'] = [
+                               [
+                                       'src'   => DI::baseUrl() . '/' . $touch_icon,
+                                       'sizes' => '192x192',
+                                       'type'  => 'image/png',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/' . $touch_icon,
+                                       'sizes' => '512x512',
+                                       'type'  => 'image/png',
+                               ],
+                       ];
+               } else {
+                       $manifest['icons'] = [
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica.svg',
+                                       'sizes' => 'any',
+                                       'type'  => 'image/svg+xml',
+                                       'purpose' => 'any',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-192.png',
+                                       'sizes' => '192x192',
+                                       'type'  => 'image/png',
+                                       'purpose' => 'any',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-512.png',
+                                       'sizes' => '512x512',
+                                       'type'  => 'image/png',
+                                       'purpose' => 'any',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-maskable.svg',
+                                       'sizes' => 'any',
+                                       'type'  => 'image/svg+xml',
+                                       'purpose' => 'maskable',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-maskable-192.png',
+                                       'sizes' => '192x192',
+                                       'type'  => 'image/png',
+                                       'purpose' => 'maskable',
+                               ],
+                               [
+                                       'src'   => DI::baseUrl() . '/images/friendica-maskable-512.png',
+                                       'sizes' => '512x512',
+                                       'type'  => 'image/png',
+                                       'purpose' => 'maskable',
+                               ],
+                       ];
                }
 
-               $output = Renderer::replaceMacros($tpl, [
-                       '$touch_icon' => $touch_icon,
-                       '$title' => $config->get('config', 'sitename', 'Friendica'),
-               ]);
+               if ($background_color = Core\Theme::getBackgroundColor($theme)) {
+                       $manifest['background_color'] = $background_color;
+               }
 
-               echo $output;
+               if ($theme_color = Core\Theme::getThemeColor($theme)) {
+                       $manifest['theme_color'] = $theme_color;
+               }
 
-               exit();
+               Core\System::jsonExit($manifest, 'application/manifest+json');
        }
 }