Merge pull request #3951 from tobiasd/20171125-blockaccount
Script to block an account from the node
This commit is contained in:
commit
f54faf1363
1 changed files with 65 additions and 0 deletions
65
util/global_community_block.php
Executable file
65
util/global_community_block.php
Executable file
|
@ -0,0 +1,65 @@
|
||||||
|
#!/usr/bin/env php
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief tool to block an account from the node
|
||||||
|
*
|
||||||
|
* With this tool, you can block an account in such a way, that no postings
|
||||||
|
* or comments this account writes are accepted to the node.
|
||||||
|
*
|
||||||
|
* Usage: pass the URL of the to be blocked account as only parameter
|
||||||
|
* at the command line when running this tool. E.g.
|
||||||
|
*
|
||||||
|
* $> util/global_community_block.php http://example.com/profile/bob
|
||||||
|
*
|
||||||
|
* will block bob@example.com.
|
||||||
|
*
|
||||||
|
* Author: Tobias Diekershoff
|
||||||
|
*
|
||||||
|
* License: AGPLv3 or later, same as Friendica
|
||||||
|
**/
|
||||||
|
|
||||||
|
if ($argc != 2 || $argv[1] == "-h" || $argv[1] == "--help" || $argv[1] == "-?") {
|
||||||
|
echo "Usage: ".$argv[0]." [-h|profile_url]\r\n";
|
||||||
|
echo " -h, -?, --help ... show this help\r\n";
|
||||||
|
echo " profile_url ...... The URL of the profile you want to silence\r\n";
|
||||||
|
echo "\r\n";
|
||||||
|
echo "Example: block bob@example.com\r\n";
|
||||||
|
echo "$> ".$argv[0]." https://example.com/profiles/bob\r\n";
|
||||||
|
echo "\r\n";
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
use Friendica\Database\DBM;
|
||||||
|
use Friendica\Network\Probe;
|
||||||
|
|
||||||
|
require_once 'boot.php';
|
||||||
|
require_once 'include/dba.php';
|
||||||
|
require_once 'include/text.php';
|
||||||
|
$a = get_app();
|
||||||
|
require_once '.htconfig.php';
|
||||||
|
|
||||||
|
dba::connect($db_host, $db_user, $db_pass, $db_data);
|
||||||
|
unset($db_host, $db_user, $db_pass, $db_data);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1. make nurl from last parameter
|
||||||
|
* 2. check DB (contact) if there is a contact with uid=0 and that nurl, get the ID
|
||||||
|
* 3. set the flag hidden=1 for the contact entry with the found ID
|
||||||
|
**/
|
||||||
|
$net = Probe::uri($argv[1]);
|
||||||
|
if (in_array($net['network'], array(NETWORK_PHANTOM, NETWORK_MAIL))) {
|
||||||
|
echo 'This account seems not to exist.';
|
||||||
|
echo "\r\n";
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
$nurl = normalise_link($net['url']);
|
||||||
|
$r = dba::select('contact', array('id'), array('nurl' => $nurl, 'uid' => 0), array('limit' => 1));
|
||||||
|
if (DBM::is_result($r)) {
|
||||||
|
dba::update('contact', array('blocked' => true), array('id' => $r['id']));
|
||||||
|
echo "NOTICE: The account should be blocked from the node now\r\n";
|
||||||
|
} else {
|
||||||
|
echo "NOTICE: Could not find any entry for this URL (".$nurl.")\r\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
Loading…
Reference in a new issue