Move admin/blocklist/server to src/Module
- Add Module\Admin\Blocklist\Server class - Add route for admin/blocklist/server - Add server blocklist admin aside menu entry - Move templates/admin/blocklist.tpl to templates/admin/blocklist/server.tpl - Remove admin_page_blocklist and admin_page_blocklist_post from mod/admin.php
This commit is contained in:
parent
cf885841c8
commit
5750623b48
|
@ -114,9 +114,6 @@ function admin_post(App $a)
|
||||||
case 'logs':
|
case 'logs':
|
||||||
admin_page_logs_post($a);
|
admin_page_logs_post($a);
|
||||||
break;
|
break;
|
||||||
case 'blocklist':
|
|
||||||
admin_page_blocklist_post($a);
|
|
||||||
break;
|
|
||||||
case 'deleteitem':
|
case 'deleteitem':
|
||||||
admin_page_deleteitem_post($a);
|
admin_page_deleteitem_post($a);
|
||||||
break;
|
break;
|
||||||
|
@ -237,9 +234,6 @@ function admin_content(App $a)
|
||||||
case 'workerqueue':
|
case 'workerqueue':
|
||||||
$o = admin_page_workerqueue($a, false);
|
$o = admin_page_workerqueue($a, false);
|
||||||
break;
|
break;
|
||||||
case 'blocklist':
|
|
||||||
$o = admin_page_blocklist($a);
|
|
||||||
break;
|
|
||||||
case 'deleteitem':
|
case 'deleteitem':
|
||||||
$o = admin_page_deleteitem($a);
|
$o = admin_page_deleteitem($a);
|
||||||
break;
|
break;
|
||||||
|
@ -256,98 +250,6 @@ function admin_content(App $a)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Subpage to modify the server wide block list via the admin panel.
|
|
||||||
*
|
|
||||||
* This function generates the subpage of the admin panel to allow the
|
|
||||||
* modification of the node wide block/black list to block entire
|
|
||||||
* remote servers from communication with this node. The page allows
|
|
||||||
* adding, removing and editing of entries from the blocklist.
|
|
||||||
*
|
|
||||||
* @param App $a
|
|
||||||
* @return string
|
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
|
||||||
*/
|
|
||||||
function admin_page_blocklist(App $a)
|
|
||||||
{
|
|
||||||
$blocklist = Config::get('system', 'blocklist');
|
|
||||||
$blocklistform = [];
|
|
||||||
if (is_array($blocklist)) {
|
|
||||||
foreach ($blocklist as $id => $b) {
|
|
||||||
$blocklistform[] = [
|
|
||||||
'domain' => ["domain[$id]", L10n::t('Blocked domain'), $b['domain'], '', L10n::t('The blocked domain'), 'required', '', ''],
|
|
||||||
'reason' => ["reason[$id]", L10n::t("Reason for the block"), $b['reason'], L10n::t('The reason why you blocked this domain.') . '(' . $b['domain'] . ')', 'required', '', ''],
|
|
||||||
'delete' => ["delete[$id]", L10n::t("Delete domain") . ' (' . $b['domain'] . ')', false, L10n::t("Check to delete this entry from the blocklist")]
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$t = Renderer::getMarkupTemplate('admin/blocklist.tpl');
|
|
||||||
return Renderer::replaceMacros($t, [
|
|
||||||
'$title' => L10n::t('Administration'),
|
|
||||||
'$page' => L10n::t('Server Blocklist'),
|
|
||||||
'$intro' => L10n::t('This page can be used to define a black list of servers from the federated network that are not allowed to interact with your node. For all entered domains you should also give a reason why you have blocked the remote server.'),
|
|
||||||
'$public' => L10n::t('The list of blocked servers will be made publically available on the /friendica page so that your users and people investigating communication problems can find the reason easily.'),
|
|
||||||
'$addtitle' => L10n::t('Add new entry to block list'),
|
|
||||||
'$newdomain' => ['newentry_domain', L10n::t('Server Domain'), '', L10n::t('The domain of the new server to add to the block list. Do not include the protocol.'), 'required', '', ''],
|
|
||||||
'$newreason' => ['newentry_reason', L10n::t('Block reason'), '', L10n::t('The reason why you blocked this domain.'), 'required', '', ''],
|
|
||||||
'$submit' => L10n::t('Add Entry'),
|
|
||||||
'$savechanges' => L10n::t('Save changes to the blocklist'),
|
|
||||||
'$currenttitle' => L10n::t('Current Entries in the Blocklist'),
|
|
||||||
'$thurl' => L10n::t('Blocked domain'),
|
|
||||||
'$threason' => L10n::t('Reason for the block'),
|
|
||||||
'$delentry' => L10n::t('Delete entry from blocklist'),
|
|
||||||
'$entries' => $blocklistform,
|
|
||||||
'$baseurl' => System::baseUrl(true),
|
|
||||||
'$confirm_delete' => L10n::t('Delete entry from blocklist?'),
|
|
||||||
'$form_security_token' => BaseModule::getFormSecurityToken("admin_blocklist")
|
|
||||||
]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Process send data from Admin Blocklist Page
|
|
||||||
*
|
|
||||||
* @param App $a
|
|
||||||
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
|
||||||
*/
|
|
||||||
function admin_page_blocklist_post(App $a)
|
|
||||||
{
|
|
||||||
if (empty($_POST['page_blocklist_save']) && empty($_POST['page_blocklist_edit'])) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
BaseModule::checkFormSecurityTokenRedirectOnError('/admin/blocklist', 'admin_blocklist');
|
|
||||||
|
|
||||||
if (!empty($_POST['page_blocklist_save'])) {
|
|
||||||
// Add new item to blocklist
|
|
||||||
$blocklist = Config::get('system', 'blocklist');
|
|
||||||
$blocklist[] = [
|
|
||||||
'domain' => Strings::escapeTags(trim($_POST['newentry_domain'])),
|
|
||||||
'reason' => Strings::escapeTags(trim($_POST['newentry_reason']))
|
|
||||||
];
|
|
||||||
Config::set('system', 'blocklist', $blocklist);
|
|
||||||
info(L10n::t('Server added to blocklist.') . EOL);
|
|
||||||
} else {
|
|
||||||
// Edit the entries from blocklist
|
|
||||||
$blocklist = [];
|
|
||||||
foreach ($_POST['domain'] as $id => $domain) {
|
|
||||||
// Trimming whitespaces as well as any lingering slashes
|
|
||||||
$domain = Strings::escapeTags(trim($domain, "\x00..\x1F/"));
|
|
||||||
$reason = Strings::escapeTags(trim($_POST['reason'][$id]));
|
|
||||||
if (empty($_POST['delete'][$id])) {
|
|
||||||
$blocklist[] = [
|
|
||||||
'domain' => $domain,
|
|
||||||
'reason' => $reason
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Config::set('system', 'blocklist', $blocklist);
|
|
||||||
info(L10n::t('Site blocklist updated.') . EOL);
|
|
||||||
}
|
|
||||||
$a->internalRedirect('admin/blocklist');
|
|
||||||
|
|
||||||
return; // NOTREACHED
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Subpage where the admin can delete an item from their node given the GUID
|
* @brief Subpage where the admin can delete an item from their node given the GUID
|
||||||
*
|
*
|
||||||
|
|
|
@ -125,6 +125,8 @@ class Router
|
||||||
$collector->addRoute(['GET', 'POST'], '/addons/{addon}' , Module\Admin\Addons\Details::class);
|
$collector->addRoute(['GET', 'POST'], '/addons/{addon}' , Module\Admin\Addons\Details::class);
|
||||||
|
|
||||||
$collector->addRoute(['GET', 'POST'], '/blocklist/contact' , Module\Admin\Blocklist\Contact::class);
|
$collector->addRoute(['GET', 'POST'], '/blocklist/contact' , Module\Admin\Blocklist\Contact::class);
|
||||||
|
$collector->addRoute(['GET', 'POST'], '/blocklist/server' , Module\Admin\Blocklist\Server::class);
|
||||||
|
|
||||||
$collector->addRoute(['GET', 'POST'], '/features' , Module\Admin\Features::class);
|
$collector->addRoute(['GET', 'POST'], '/features' , Module\Admin\Features::class);
|
||||||
$collector->addRoute(['GET'] , '/federation' , Module\Admin\Federation::class);
|
$collector->addRoute(['GET'] , '/federation' , Module\Admin\Federation::class);
|
||||||
|
|
||||||
|
|
91
src/Module/Admin/Blocklist/Server.php
Normal file
91
src/Module/Admin/Blocklist/Server.php
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Friendica\Module\Admin\Blocklist;
|
||||||
|
|
||||||
|
use Friendica\Core\Config;
|
||||||
|
use Friendica\Core\L10n;
|
||||||
|
use Friendica\Core\Renderer;
|
||||||
|
use Friendica\Core\System;
|
||||||
|
use Friendica\Module\BaseAdminModule;
|
||||||
|
use Friendica\Util\Strings;
|
||||||
|
|
||||||
|
class Server extends BaseAdminModule
|
||||||
|
{
|
||||||
|
public static function post()
|
||||||
|
{
|
||||||
|
parent::post();
|
||||||
|
|
||||||
|
if (empty($_POST['page_blocklist_save']) && empty($_POST['page_blocklist_edit'])) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
parent::checkFormSecurityTokenRedirectOnError('/admin/blocklist/server', 'admin_blocklist');
|
||||||
|
|
||||||
|
if (!empty($_POST['page_blocklist_save'])) {
|
||||||
|
// Add new item to blocklist
|
||||||
|
$blocklist = Config::get('system', 'blocklist');
|
||||||
|
$blocklist[] = [
|
||||||
|
'domain' => Strings::escapeTags(trim($_POST['newentry_domain'])),
|
||||||
|
'reason' => Strings::escapeTags(trim($_POST['newentry_reason']))
|
||||||
|
];
|
||||||
|
Config::set('system', 'blocklist', $blocklist);
|
||||||
|
info(L10n::t('Server added to blocklist.') . EOL);
|
||||||
|
} else {
|
||||||
|
// Edit the entries from blocklist
|
||||||
|
$blocklist = [];
|
||||||
|
foreach ($_POST['domain'] as $id => $domain) {
|
||||||
|
// Trimming whitespaces as well as any lingering slashes
|
||||||
|
$domain = Strings::escapeTags(trim($domain, "\x00..\x1F/"));
|
||||||
|
$reason = Strings::escapeTags(trim($_POST['reason'][$id]));
|
||||||
|
if (empty($_POST['delete'][$id])) {
|
||||||
|
$blocklist[] = [
|
||||||
|
'domain' => $domain,
|
||||||
|
'reason' => $reason
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Config::set('system', 'blocklist', $blocklist);
|
||||||
|
info(L10n::t('Site blocklist updated.') . EOL);
|
||||||
|
}
|
||||||
|
|
||||||
|
self::getApp()->internalRedirect('admin/blocklist/server');
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function content()
|
||||||
|
{
|
||||||
|
parent::content();
|
||||||
|
|
||||||
|
$blocklist = Config::get('system', 'blocklist');
|
||||||
|
$blocklistform = [];
|
||||||
|
if (is_array($blocklist)) {
|
||||||
|
foreach ($blocklist as $id => $b) {
|
||||||
|
$blocklistform[] = [
|
||||||
|
'domain' => ["domain[$id]", L10n::t('Blocked domain'), $b['domain'], '', L10n::t('The blocked domain'), 'required', '', ''],
|
||||||
|
'reason' => ["reason[$id]", L10n::t("Reason for the block"), $b['reason'], L10n::t('The reason why you blocked this domain.') . '(' . $b['domain'] . ')', 'required', '', ''],
|
||||||
|
'delete' => ["delete[$id]", L10n::t("Delete domain") . ' (' . $b['domain'] . ')', false, L10n::t("Check to delete this entry from the blocklist")]
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$t = Renderer::getMarkupTemplate('admin/blocklist/server.tpl');
|
||||||
|
return Renderer::replaceMacros($t, [
|
||||||
|
'$title' => L10n::t('Administration'),
|
||||||
|
'$page' => L10n::t('Server Blocklist'),
|
||||||
|
'$intro' => L10n::t('This page can be used to define a black list of servers from the federated network that are not allowed to interact with your node. For all entered domains you should also give a reason why you have blocked the remote server.'),
|
||||||
|
'$public' => L10n::t('The list of blocked servers will be made publically available on the /friendica page so that your users and people investigating communication problems can find the reason easily.'),
|
||||||
|
'$addtitle' => L10n::t('Add new entry to block list'),
|
||||||
|
'$newdomain' => ['newentry_domain', L10n::t('Server Domain'), '', L10n::t('The domain of the new server to add to the block list. Do not include the protocol.'), 'required', '', ''],
|
||||||
|
'$newreason' => ['newentry_reason', L10n::t('Block reason'), '', L10n::t('The reason why you blocked this domain.'), 'required', '', ''],
|
||||||
|
'$submit' => L10n::t('Add Entry'),
|
||||||
|
'$savechanges' => L10n::t('Save changes to the blocklist'),
|
||||||
|
'$currenttitle' => L10n::t('Current Entries in the Blocklist'),
|
||||||
|
'$thurl' => L10n::t('Blocked domain'),
|
||||||
|
'$threason' => L10n::t('Reason for the block'),
|
||||||
|
'$delentry' => L10n::t('Delete entry from blocklist'),
|
||||||
|
'$entries' => $blocklistform,
|
||||||
|
'$baseurl' => System::baseUrl(true),
|
||||||
|
'$confirm_delete' => L10n::t('Delete entry from blocklist?'),
|
||||||
|
'$form_security_token' => parent::getFormSecurityToken("admin_blocklist")
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
|
@ -61,6 +61,7 @@ abstract class BaseAdminModule extends BaseModule
|
||||||
]],
|
]],
|
||||||
'tools' => [L10n::t('Tools'), [
|
'tools' => [L10n::t('Tools'), [
|
||||||
'contactblock' => ['admin/blocklist/contact', L10n::t('Contact Blocklist') , 'contactblock'],
|
'contactblock' => ['admin/blocklist/contact', L10n::t('Contact Blocklist') , 'contactblock'],
|
||||||
|
'blocklist' => ['admin/blocklist/server' , L10n::t('Server Blocklist') , 'blocklist'],
|
||||||
]],
|
]],
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
<p>{{$public}}</p>
|
<p>{{$public}}</p>
|
||||||
|
|
||||||
<h2>{{$addtitle}}</h2>
|
<h2>{{$addtitle}}</h2>
|
||||||
<form action="{{$baseurl}}/admin/blocklist" method="post">
|
<form action="{{$baseurl}}/admin/blocklist/server" method="post">
|
||||||
<input type="hidden" name="form_security_token" value="{{$form_security_token}}">
|
<input type="hidden" name="form_security_token" value="{{$form_security_token}}">
|
||||||
{{include file="field_input.tpl" field=$newdomain}}
|
{{include file="field_input.tpl" field=$newdomain}}
|
||||||
{{include file="field_input.tpl" field=$newreason}}
|
{{include file="field_input.tpl" field=$newreason}}
|
||||||
|
@ -19,7 +19,7 @@
|
||||||
{{if $entries}}
|
{{if $entries}}
|
||||||
<h2>{{$currenttitle}}</h2>
|
<h2>{{$currenttitle}}</h2>
|
||||||
<p>{{$currentintro}}</p>
|
<p>{{$currentintro}}</p>
|
||||||
<form action="{{$baseurl}}/admin/blocklist" method="post">
|
<form action="{{$baseurl}}/admin/blocklist/server" method="post">
|
||||||
<input type="hidden" name="form_security_token" value="{{$form_security_token}}">
|
<input type="hidden" name="form_security_token" value="{{$form_security_token}}">
|
||||||
{{foreach $entries as $e}}
|
{{foreach $entries as $e}}
|
||||||
{{include file="field_input.tpl" field=$e.domain}}
|
{{include file="field_input.tpl" field=$e.domain}}
|
Loading…
Reference in a new issue