]> git.mxchange.org Git - friendica.git/blobdiff - src/Module/Admin/Addons/Details.php
Merge branch 'friendica:develop' into doc_faq_client-clean-up
[friendica.git] / src / Module / Admin / Addons / Details.php
index 9ef2035dec2bb8808df0e9e20d6725c00647c993..bab52fb0de5edc3a49fdd259dd162e7cc2cdee7b 100644 (file)
-<?php\r
-\r
-namespace Friendica\Module\Admin\Addons;\r
-\r
-use Friendica\Content\Text\Markdown;\r
-use Friendica\Core\Addon;\r
-use Friendica\Core\L10n;\r
-use Friendica\Core\Renderer;\r
-use Friendica\Database\DBA;\r
-use Friendica\Module\BaseAdminModule;\r
-use Friendica\Util\Strings;\r
-\r
-class Details extends BaseAdminModule\r
-{\r
-       public static function post()\r
-       {\r
-               parent::post();\r
-\r
-               $a = self::getApp();\r
-\r
-               if ($a->argc > 2) {\r
-                       // @TODO: Replace with parameter from router\r
-                       $addon = $a->argv[2];\r
-                       $addon = Strings::sanitizeFilePathItem($addon);\r
-                       if (is_file('addon/' . $addon . '/' . $addon . '.php')) {\r
-                               include_once 'addon/' . $addon . '/' . $addon . '.php';\r
-                               if (function_exists($addon . '_addon_admin_post')) {\r
-                                       $func = $addon . '_addon_admin_post';\r
-                                       $func($a);\r
-                               }\r
-\r
-                               $a->internalRedirect('admin/addons/' . $addon);\r
-                       }\r
-               }\r
-\r
-               $a->internalRedirect('admin/addons');\r
-       }\r
-\r
-       public static function content()\r
-       {\r
-               parent::content();\r
-\r
-               $a = self::getApp();\r
-\r
-               $addons_admin = [];\r
-               $addonsAdminStmt = DBA::select('addon', ['name'], ['plugin_admin' => 1], ['order' => ['name']]);\r
-               foreach (DBA::toArray($addonsAdminStmt) as $addon) {\r
-                       $addonName = $addon['name'];\r
-                       // temp addons with admin\r
-                       $addons_admin[] = $addonName;\r
-               }\r
-\r
-               if ($a->argc > 2) {\r
-                       // @TODO: Replace with parameter from router\r
-                       $addon = $a->argv[2];\r
-                       $addon = Strings::sanitizeFilePathItem($addon);\r
-                       if (!is_file("addon/$addon/$addon.php")) {\r
-                               notice(L10n::t('Item not found.'));\r
-                               $a->internalRedirect('admin/addons');\r
-                       }\r
-\r
-                       if (defaults($_GET, 'action', '') == 'toggle') {\r
-                               parent::checkFormSecurityTokenRedirectOnError('/admin/addons', 'admin_themes', 't');\r
-\r
-                               // Toggle addon status\r
-                               if (Addon::isEnabled($addon)) {\r
-                                       Addon::uninstall($addon);\r
-                                       info(L10n::t('Addon %s disabled.', $addon));\r
-                               } else {\r
-                                       Addon::install($addon);\r
-                                       info(L10n::t('Addon %s enabled.', $addon));\r
-                               }\r
-\r
-                               Addon::saveEnabledList();\r
-\r
-                               $a->internalRedirect('admin/addons/' . $addon);\r
-                       }\r
-\r
-                       // display addon details\r
-                       if (Addon::isEnabled($addon)) {\r
-                               $status = 'on';\r
-                               $action = L10n::t('Disable');\r
-                       } else {\r
-                               $status = 'off';\r
-                               $action = L10n::t('Enable');\r
-                       }\r
-\r
-                       $readme = null;\r
-                       if (is_file("addon/$addon/README.md")) {\r
-                               $readme = Markdown::convert(file_get_contents("addon/$addon/README.md"), false);\r
-                       } elseif (is_file("addon/$addon/README")) {\r
-                               $readme = '<pre>' . file_get_contents("addon/$addon/README") . '</pre>';\r
-                       }\r
-\r
-                       $admin_form = '';\r
-                       if (in_array($addon, $addons_admin)) {\r
-                               require_once "addon/$addon/$addon.php";\r
-                               $func = $addon . '_addon_admin';\r
-                               $func($a, $admin_form);\r
-                       }\r
-\r
-                       $t = Renderer::getMarkupTemplate('admin/addons/details.tpl');\r
-\r
-                       return Renderer::replaceMacros($t, [\r
-                               '$title' => L10n::t('Administration'),\r
-                               '$page' => L10n::t('Addons'),\r
-                               '$toggle' => L10n::t('Toggle'),\r
-                               '$settings' => L10n::t('Settings'),\r
-                               '$baseurl' => $a->getBaseURL(true),\r
-\r
-                               '$addon' => $addon,\r
-                               '$status' => $status,\r
-                               '$action' => $action,\r
-                               '$info' => Addon::getInfo($addon),\r
-                               '$str_author' => L10n::t('Author: '),\r
-                               '$str_maintainer' => L10n::t('Maintainer: '),\r
-\r
-                               '$admin_form' => $admin_form,\r
-                               '$function' => 'addons',\r
-                               '$screenshot' => '',\r
-                               '$readme' => $readme,\r
-\r
-                               '$form_security_token' => parent::getFormSecurityToken('admin_themes'),\r
-                       ]);\r
-               }\r
-\r
-               $a->internalRedirect('admin/addons');\r
-       }\r
-}
\ No newline at end of file
+<?php
+/**
+ * @copyright Copyright (C) 2010-2021, the Friendica project
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program.  If not, see <https://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace Friendica\Module\Admin\Addons;
+
+use Friendica\Content\Text\Markdown;
+use Friendica\Core\Addon;
+use Friendica\Core\Renderer;
+use Friendica\DI;
+use Friendica\Module\BaseAdmin;
+use Friendica\Util\Strings;
+
+class Details extends BaseAdmin
+{
+       public function post()
+       {
+               self::checkAdminAccess();
+
+               $addon = Strings::sanitizeFilePathItem($this->parameters['addon']);
+
+               $redirect = 'admin/addons/' . $addon;
+
+               if (is_file('addon/' . $addon . '/' . $addon . '.php')) {
+                       include_once 'addon/' . $addon . '/' . $addon . '.php';
+
+                       if (function_exists($addon . '_addon_admin_post')) {
+                               self::checkFormSecurityTokenRedirectOnError($redirect, 'admin_addons_details');
+
+                               $func = $addon . '_addon_admin_post';
+                               $func(DI::app());
+                       }
+               }
+
+               DI::baseUrl()->redirect($redirect);
+       }
+
+       public function content(): string
+       {
+               parent::content();
+
+               $a = DI::app();
+
+               $addons_admin = Addon::getAdminList();
+
+               $addon = Strings::sanitizeFilePathItem($this->parameters['addon']);
+               if (!is_file("addon/$addon/$addon.php")) {
+                       notice(DI::l10n()->t('Addon not found.'));
+                       Addon::uninstall($addon);
+                       DI::baseUrl()->redirect('admin/addons');
+               }
+
+               if (($_GET['action'] ?? '') == 'toggle') {
+                       self::checkFormSecurityTokenRedirectOnError('/admin/addons', 'admin_addons_details', 't');
+
+                       // Toggle addon status
+                       if (Addon::isEnabled($addon)) {
+                               Addon::uninstall($addon);
+                               info(DI::l10n()->t('Addon %s disabled.', $addon));
+                       } else {
+                               Addon::install($addon);
+                               info(DI::l10n()->t('Addon %s enabled.', $addon));
+                       }
+
+                       DI::baseUrl()->redirect('admin/addons/' . $addon);
+               }
+
+               // display addon details
+               if (Addon::isEnabled($addon)) {
+                       $status = 'on';
+                       $action = DI::l10n()->t('Disable');
+               } else {
+                       $status = 'off';
+                       $action = DI::l10n()->t('Enable');
+               }
+
+               $readme = null;
+               if (is_file("addon/$addon/README.md")) {
+                       $readme = Markdown::convert(file_get_contents("addon/$addon/README.md"), false);
+               } elseif (is_file("addon/$addon/README")) {
+                       $readme = '<pre>' . file_get_contents("addon/$addon/README") . '</pre>';
+               }
+
+               $admin_form = '';
+               if (array_key_exists($addon, $addons_admin)) {
+                       require_once "addon/$addon/$addon.php";
+                       $func = $addon . '_addon_admin';
+                       $func($a, $admin_form);
+               }
+
+               $t = Renderer::getMarkupTemplate('admin/addons/details.tpl');
+
+               return Renderer::replaceMacros($t, [
+                       '$title' => DI::l10n()->t('Administration'),
+                       '$page' => DI::l10n()->t('Addons'),
+                       '$toggle' => DI::l10n()->t('Toggle'),
+                       '$settings' => DI::l10n()->t('Settings'),
+                       '$baseurl' => DI::baseUrl()->get(true),
+
+                       '$addon' => $addon,
+                       '$status' => $status,
+                       '$action' => $action,
+                       '$info' => Addon::getInfo($addon),
+                       '$str_author' => DI::l10n()->t('Author: '),
+                       '$str_maintainer' => DI::l10n()->t('Maintainer: '),
+
+                       '$admin_form' => $admin_form,
+                       '$function' => 'addons',
+                       '$screenshot' => '',
+                       '$readme' => $readme,
+
+                       '$form_security_token' => self::getFormSecurityToken('admin_addons_details'),
+               ]);
+       }
+}