<?php
+/**
+ * @copyright Copyright (C) 2020, Friendica
+ *
+ * @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\L10n;
use Friendica\Core\Renderer;
-use Friendica\Module\BaseAdminModule;
+use Friendica\DI;
+use Friendica\Module\BaseAdmin;
use Friendica\Util\Strings;
-class Details extends BaseAdminModule
+class Details extends BaseAdmin
{
- public static function post()
+ public static function post(array $parameters = [])
{
- parent::post();
-
- $a = self::getApp();
-
- if ($a->argc > 2) {
- // @TODO: Replace with parameter from router
- $addon = $a->argv[2];
- $addon = Strings::sanitizeFilePathItem($addon);
- if (is_file('addon/' . $addon . '/' . $addon . '.php')) {
- include_once 'addon/' . $addon . '/' . $addon . '.php';
- if (function_exists($addon . '_addon_admin_post')) {
- $func = $addon . '_addon_admin_post';
- $func($a);
- }
-
- $a->internalRedirect('admin/addons/' . $addon);
+ self::checkAdminAccess();
+
+ $addon = Strings::sanitizeFilePathItem($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());
}
}
- $a->internalRedirect('admin/addons');
+ DI::baseUrl()->redirect($redirect);
}
- public static function content()
+ public static function content(array $parameters = [])
{
- parent::content();
+ parent::content($parameters);
- $a = self::getApp();
+ $a = DI::app();
$addons_admin = Addon::getAdminList();
- if ($a->argc > 2) {
- // @TODO: Replace with parameter from router
- $addon = $a->argv[2];
- $addon = Strings::sanitizeFilePathItem($addon);
- if (!is_file("addon/$addon/$addon.php")) {
- notice(L10n::t('Addon not found.'));
- Addon::uninstall($addon);
- $a->internalRedirect('admin/addons');
- }
-
- if (defaults($_GET, 'action', '') == 'toggle') {
- parent::checkFormSecurityTokenRedirectOnError('/admin/addons', 'admin_themes', 't');
-
- // Toggle addon status
- if (Addon::isEnabled($addon)) {
- Addon::uninstall($addon);
- info(L10n::t('Addon %s disabled.', $addon));
- } else {
- Addon::install($addon);
- info(L10n::t('Addon %s enabled.', $addon));
- }
-
- Addon::saveEnabledList();
+ $addon = Strings::sanitizeFilePathItem($parameters['addon']);
+ if (!is_file("addon/$addon/$addon.php")) {
+ notice(DI::l10n()->t('Addon not found.'));
+ Addon::uninstall($addon);
+ DI::baseUrl()->redirect('admin/addons');
+ }
- $a->internalRedirect('admin/addons/' . $addon);
- }
+ if (($_GET['action'] ?? '') == 'toggle') {
+ self::checkFormSecurityTokenRedirectOnError('/admin/addons', 'admin_addons_details', 't');
- // display addon details
+ // Toggle addon status
if (Addon::isEnabled($addon)) {
- $status = 'on';
- $action = L10n::t('Disable');
+ Addon::uninstall($addon);
+ info(DI::l10n()->t('Addon %s disabled.', $addon));
} else {
- $status = 'off';
- $action = L10n::t('Enable');
+ Addon::install($addon);
+ info(DI::l10n()->t('Addon %s enabled.', $addon));
}
- $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>';
- }
+ DI::baseUrl()->redirect('admin/addons/' . $addon);
+ }
- $admin_form = '';
- if (array_key_exists($addon, $addons_admin)) {
- require_once "addon/$addon/$addon.php";
- $func = $addon . '_addon_admin';
- $func($a, $admin_form);
- }
+ // 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>';
+ }
- $t = Renderer::getMarkupTemplate('admin/addons/details.tpl');
-
- return Renderer::replaceMacros($t, [
- '$title' => L10n::t('Administration'),
- '$page' => L10n::t('Addons'),
- '$toggle' => L10n::t('Toggle'),
- '$settings' => L10n::t('Settings'),
- '$baseurl' => $a->getBaseURL(true),
-
- '$addon' => $addon,
- '$status' => $status,
- '$action' => $action,
- '$info' => Addon::getInfo($addon),
- '$str_author' => L10n::t('Author: '),
- '$str_maintainer' => L10n::t('Maintainer: '),
-
- '$admin_form' => $admin_form,
- '$function' => 'addons',
- '$screenshot' => '',
- '$readme' => $readme,
-
- '$form_security_token' => parent::getFormSecurityToken('admin_themes'),
- ]);
+ $admin_form = '';
+ if (array_key_exists($addon, $addons_admin)) {
+ require_once "addon/$addon/$addon.php";
+ $func = $addon . '_addon_admin';
+ $func($a, $admin_form);
}
- $a->internalRedirect('admin/addons');
+ $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'),
+ ]);
}
}