Add feature to account_manager to look up posters by posting-hash when necessary.
This commit is contained in:
parent
bb14360d1e
commit
626d810527
|
@ -534,6 +534,14 @@ function message_post($subject, $from, $newsgroups, $ref, $body, $encryptthis =
|
|||
if ($userconfig) {
|
||||
set_user_config($authname, 'posting-user', $posting_user);
|
||||
}
|
||||
$posthashfile = $spooldir . '/posthash.dat';
|
||||
if(file_exists($posthashfile)) {
|
||||
$posthash = unserialize(file_get_contents($posthashfile));
|
||||
} else {
|
||||
$posthash = array();
|
||||
}
|
||||
$posthash[$posting_user] = $authname;
|
||||
file_put_contents($posthashfile, serialize($posthash));
|
||||
}
|
||||
|
||||
if (isset($encryptthis)) {
|
||||
|
|
|
@ -36,6 +36,13 @@ if ($argv[1][0] == '-') {
|
|||
echo "Creating User: " . $argv[2] . "\n";
|
||||
create_new($argv[2], $argv[3], $argv[4]);
|
||||
break;
|
||||
case "-getuserbyhash":
|
||||
if (! isset($argv[2])) {
|
||||
echo "Usage: -getuserbyhash posting_hash\n";
|
||||
exit();
|
||||
}
|
||||
get_user_by_hash($argv[2]);
|
||||
break;
|
||||
case "-newpass":
|
||||
if (! isset($argv[2]) || ! isset($argv[3])) {
|
||||
echo "Usage: -newpass username password\n";
|
||||
|
@ -94,6 +101,7 @@ if ($argv[1][0] == '-') {
|
|||
echo "-help: This help page\n";
|
||||
echo "-version: Display version\n";
|
||||
echo "-create: Create user account '-create username password email'\n";
|
||||
echo "-getuserbyhash: Find username by Posting-User hash\n";
|
||||
echo "-newpass: Change user password '-newpass username newpassword'\n";
|
||||
echo "-newemail: Change user email '-newemail username emailaddress'\n";
|
||||
echo " Email address will remain listed as 'verified'\n";
|
||||
|
@ -110,7 +118,26 @@ if ($argv[1][0] == '-') {
|
|||
exit();
|
||||
}
|
||||
|
||||
function ban_user($username) {
|
||||
function get_user_by_hash($postinghash)
|
||||
{
|
||||
global $spooldir;
|
||||
$posthashfile = $spooldir . '/posthash.dat';
|
||||
if (file_exists($posthashfile)) {
|
||||
$posthash = unserialize(file_get_contents($posthashfile));
|
||||
} else {
|
||||
echo "Hash file not found\n";
|
||||
return;
|
||||
}
|
||||
if(isset($posthash[$postinghash])) {
|
||||
echo $posthash[$postinghash] . ' : ' . $postinghash . "\n";
|
||||
} else {
|
||||
echo "$postinghash not found in database\n";
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
function ban_user($username)
|
||||
{
|
||||
global $config_dir;
|
||||
$banfile = $config_dir . '/banned_users.conf';
|
||||
$username = strtolower($username);
|
||||
|
@ -135,7 +162,8 @@ function ban_user($username) {
|
|||
}
|
||||
}
|
||||
|
||||
function change_user_email($username, $email) {
|
||||
function change_user_email($username, $email)
|
||||
{
|
||||
global $config_dir;
|
||||
$username = strtolower($username);
|
||||
$userfile = $config_dir . '/users/' . $username;
|
||||
|
@ -147,7 +175,8 @@ function change_user_email($username, $email) {
|
|||
}
|
||||
}
|
||||
|
||||
function change_user_password($username, $password) {
|
||||
function change_user_password($username, $password)
|
||||
{
|
||||
global $config_dir;
|
||||
$username = strtolower($username);
|
||||
$userfile = $config_dir . '/users/' . $username;
|
||||
|
@ -199,4 +228,3 @@ function make_key($username)
|
|||
$key = openssl_random_pseudo_bytes(44);
|
||||
return base64_encode($key);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue