3
0
mirror of https://github.com/pragma-/pbot.git synced 2024-11-22 20:09:43 +01:00

Plugin/Quotegrabs: rq now "shuffles" through quotes without repeats

This commit is contained in:
Pragmatic Software 2023-04-10 08:06:35 -07:00
parent d8b19eff68
commit 8bf243a9fd
3 changed files with 63 additions and 9 deletions

View File

@ -45,6 +45,7 @@ sub unload {
$self->{pbot}->{commands}->unregister('getq'); $self->{pbot}->{commands}->unregister('getq');
$self->{pbot}->{commands}->unregister('delq'); $self->{pbot}->{commands}->unregister('delq');
$self->{pbot}->{commands}->unregister('rq'); $self->{pbot}->{commands}->unregister('rq');
$self->{database}->end();
} }
sub uniq { my %seen; grep !$seen{$_}++, @_ } sub uniq { my %seen; grep !$seen{$_}++, @_ }

View File

@ -46,6 +46,12 @@ CREATE TABLE IF NOT EXISTS Quotegrabs (
text TEXT, text TEXT,
timestamp NUMERIC timestamp NUMERIC
) )
SQL
$self->{dbh}->do(<< 'SQL');
CREATE TABLE IF NOT EXISTS Seen (
id INTEGER UNIQUE
)
SQL SQL
}; };
@ -117,7 +123,7 @@ sub get_random_quotegrab {
# multi-grabs have the nick separated by +'s so we must test for # multi-grabs have the nick separated by +'s so we must test for
# nick, nick+*, *+nick, and *+nick+* to match each of these cases # nick, nick+*, *+nick, and *+nick+* to match each of these cases
if (defined $nick) { if (defined $nick) {
$sql .= $where . 'nick LIKE ? OR nick LIKE ? OR nick LIKE ? OR nick LIKE ?'; $sql .= $where . '(nick LIKE ? OR nick LIKE ? OR nick LIKE ? OR nick LIKE ?) ';
push @params, "$nick"; push @params, "$nick";
push @params, "$nick+%"; push @params, "$nick+%";
push @params, "%+$nick"; push @params, "%+$nick";
@ -138,17 +144,62 @@ sub get_random_quotegrab {
push @params, "%$text%"; push @params, "%$text%";
} }
$sql .= 'ORDER BY RANDOM() LIMIT 1'; my $sth = $self->{dbh}->prepare($sql . $where . $and . 'id NOT IN Seen ORDER BY RANDOM() LIMIT 1');
my $sth = $self->{dbh}->prepare($sql);
$sth->execute(@params); $sth->execute(@params);
return $sth->fetchrow_hashref(); my $quotegrab = $sth->fetchrow_hashref();
# no unseen quote found, remove queried quotes from Seen table and try again
if (not defined $quotegrab) {
my $count = $self->remove_seen($sql, \@params);
# no matching quotes in Seen table, ergo no quote found
if ($count == 0) {
return undef;
}
# try again
$sth->execute(@params);
$quotegrab = $sth->fetchrow_hashref();
}
# mark quote as seen
if (defined $quotegrab) {
$self->add_seen($quotegrab->{id});
}
return $quotegrab;
}; };
$self->{pbot}->{logger}->log($@) if $@; $self->{pbot}->{logger}->log($@) if $@;
return $quotegrab; return $quotegrab;
} }
sub remove_seen {
my ($self, $sql, $params) = @_;
$sql =~ s/^SELECT \*/SELECT id/;
my $count = eval {
my $sth = $self->{dbh}->prepare("DELETE from Seen WHERE id IN ($sql)");
$sth->execute(@$params);
return $sth->rows;
};
$self->{pbot}->{logger}->log($@) if $@;
return $count;
}
sub add_seen {
my ($self, $id) = @_;
eval {
my $sth = $self->{dbh}->prepare('INSERT INTO Seen VALUES (?)');
$sth->execute($id);
};
$self->{pbot}->{logger}->log($@) if $@;
}
sub get_all_quotegrabs { sub get_all_quotegrabs {
my $self = shift; my $self = shift;
@ -167,8 +218,10 @@ sub delete_quotegrab {
eval { eval {
my $sth = $self->{dbh}->prepare('DELETE FROM Quotegrabs WHERE id == ?'); my $sth = $self->{dbh}->prepare('DELETE FROM Quotegrabs WHERE id == ?');
$sth->bind_param(1, $id); $sth->execute($id);
$sth->execute();
$sth = $self->{dbh}->prepare('DELETE FROM Seen WHERE id == ?');
$sth->execute($id);
}; };
$self->{pbot}->{logger}->log($@) if $@; $self->{pbot}->{logger}->log($@) if $@;

View File

@ -25,8 +25,8 @@ use PBot::Imports;
# These are set by the /misc/update_version script # These are set by the /misc/update_version script
use constant { use constant {
BUILD_NAME => "PBot", BUILD_NAME => "PBot",
BUILD_REVISION => 4641, BUILD_REVISION => 4642,
BUILD_DATE => "2023-03-30", BUILD_DATE => "2023-04-10",
}; };
sub initialize {} sub initialize {}