mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-12 04:52:37 +01:00
Plugins/RemindMe: fix -c option
This commit is contained in:
parent
7dbfd03c10
commit
8ea3fab219
@ -14,8 +14,8 @@ use PBot::Imports;
|
|||||||
|
|
||||||
use DBI;
|
use DBI;
|
||||||
use Time::Duration qw/concise duration/;
|
use Time::Duration qw/concise duration/;
|
||||||
use Time::HiRes qw/time/;
|
use Time::HiRes qw/time/;
|
||||||
use Getopt::Long qw(GetOptionsFromArray);
|
use Getopt::Long qw/GetOptionsFromArray/;
|
||||||
|
|
||||||
sub initialize {
|
sub initialize {
|
||||||
my ($self, %conf) = @_;
|
my ($self, %conf) = @_;
|
||||||
@ -194,7 +194,7 @@ sub cmd_remindme {
|
|||||||
|
|
||||||
my $admininfo = $self->{pbot}->{users}->loggedin_admin($channel ? $channel : $context->{from}, $context->{hostmask});
|
my $admininfo = $self->{pbot}->{users}->loggedin_admin($channel ? $channel : $context->{from}, $context->{hostmask});
|
||||||
|
|
||||||
# option -c was provided; ensure user is an admin and bot is in targeted channel
|
# option -c was provided; ensure user is an admin and bot is in channel
|
||||||
if ($channel) {
|
if ($channel) {
|
||||||
if (not defined $admininfo) {
|
if (not defined $admininfo) {
|
||||||
return "Only admins can create channel reminders.";
|
return "Only admins can create channel reminders.";
|
||||||
@ -272,25 +272,19 @@ sub do_reminder {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
# nick of person being reminded
|
# ensures we get the current nick of the person being reminded
|
||||||
my $nick;
|
my $hostmask = $self->{pbot}->{messagehistory}->{database}->find_most_recent_hostmask($reminder->{account});
|
||||||
|
my ($nick) = $hostmask =~ /^([^!]+)!/;
|
||||||
|
|
||||||
# ensure person is available to receive reminder
|
# try again in 30 seconds if the person isn't around yet
|
||||||
if (not defined $reminder->{target}) {
|
if (not $self->{pbot}->{nicklist}->is_present_any_channel($nick)) {
|
||||||
# ensures we get the current nick of the person
|
$event->{interval} = 30;
|
||||||
my $hostmask = $self->{pbot}->{messagehistory}->{database}->find_most_recent_hostmask($reminder->{account});
|
$event->{repeating} = 1;
|
||||||
($nick) = $hostmask =~ /^([^!]+)!/;
|
return;
|
||||||
|
|
||||||
# try again in 30 seconds if the person isn't around yet
|
|
||||||
if (not $self->{pbot}->{nicklist}->is_present_any_channel($nick)) {
|
|
||||||
$event->{interval} = 30;
|
|
||||||
$event->{repeating} = 1;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# send reminder text to person
|
# send reminder text to person
|
||||||
my $target = $reminder->{target} // $nick;
|
my $target = $reminder->{channel} // $nick;
|
||||||
my $text = $reminder->{text};
|
my $text = $reminder->{text};
|
||||||
|
|
||||||
# if sending reminder to channel, highlight person being reminded
|
# if sending reminder to channel, highlight person being reminded
|
||||||
@ -298,10 +292,10 @@ sub do_reminder {
|
|||||||
$text = "$nick: $text";
|
$text = "$nick: $text";
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{pbot}->{conn}->privmsg($target, $reminder->{text});
|
$self->{pbot}->{conn}->privmsg($target, $text);
|
||||||
|
|
||||||
# log event
|
# log event
|
||||||
$self->{pbot}->{logger}->log("Reminded $target about \"$reminder->{text}\"\n");
|
$self->{pbot}->{logger}->log("Reminded $target about \"$text\"\n");
|
||||||
|
|
||||||
# update repeats or delete reminder
|
# update repeats or delete reminder
|
||||||
if ($reminder->{repeats} > 0) {
|
if ($reminder->{repeats} > 0) {
|
||||||
@ -371,7 +365,7 @@ sub create_database {
|
|||||||
CREATE TABLE IF NOT EXISTS Reminders (
|
CREATE TABLE IF NOT EXISTS Reminders (
|
||||||
id INTEGER PRIMARY KEY,
|
id INTEGER PRIMARY KEY,
|
||||||
account TEXT,
|
account TEXT,
|
||||||
target TEXT,
|
channel TEXT,
|
||||||
text TEXT,
|
text TEXT,
|
||||||
alarm NUMERIC,
|
alarm NUMERIC,
|
||||||
repeats INTEGER,
|
repeats INTEGER,
|
||||||
@ -413,11 +407,11 @@ sub add_reminder {
|
|||||||
my ($self, %args) = @_;
|
my ($self, %args) = @_;
|
||||||
|
|
||||||
my $id = eval {
|
my $id = eval {
|
||||||
my $sth = $self->{dbh}->prepare('INSERT INTO Reminders (account, target, text, alarm, interval, repeats, created_on, created_by) VALUES (?, ?, ?, ?, ?, ?, ?, ?)');
|
my $sth = $self->{dbh}->prepare('INSERT INTO Reminders (account, channel, text, alarm, interval, repeats, created_on, created_by) VALUES (?, ?, ?, ?, ?, ?, ?, ?)');
|
||||||
|
|
||||||
$sth->execute(
|
$sth->execute(
|
||||||
$args{account},
|
$args{account},
|
||||||
$args{target},
|
$args{channel},
|
||||||
$args{text},
|
$args{text},
|
||||||
$args{alarm},
|
$args{alarm},
|
||||||
$args{interval},
|
$args{interval},
|
||||||
|
Loading…
Reference in New Issue
Block a user