X-Git-Url: https://ruin.nu/git/%3CTMPL_VAR%20NAME=PAGE%3E?a=blobdiff_plain;f=Context.pm;h=5810ca4e97dc9cc369b2d6327e716d50ea67fd02;hb=fc37239d5f764e9f0f7c113a03fc52d264699725;hp=124da62e5ca301a33da1a18534b24ac6737c51c6;hpb=9e077e0aeb51cfd1eeeb12f2362fc11ac6d6b38a;p=NDIRC.git
diff --git a/Context.pm b/Context.pm
index 124da62..5810ca4 100644
--- a/Context.pm
+++ b/Context.pm
@@ -50,6 +50,12 @@ has roles => (
lazy_build => 1
);
+has uid => (
+ is => 'ro',
+ isa => 'Int',
+ lazy_build => 1
+);
+
has disp => (
is => 'ro',
isa => 'Object',
@@ -97,37 +103,64 @@ sub check_user_roles {
sub reply {
my ($self,$msg) = @_;
- $self->message($self->reply_string , $msg);
+ my @command = split / /, $self->reply_string;
+ $self->message(@command, $msg);
}
sub message {
- my ($self,$command,$msg) = @_;
+ my ($self,$command, $target, $msg) = @_;
$msg =~ s`(.*?)`${\(chr(2))}$1${\(chr(15))}`gi;
$msg =~ s`(.*?)`${\(chr(3))}$1$2${\(chr(15))}`gi;
- $self->server->command("$command $msg");
+ #Split the message, using the, slightly modified, algorithm from splitlong.pl in the irssi distribution.
+ if ($command eq 'privmsg'){
+ my $lend = ' ...';
+ my $lstart = '... ';
+ my $maxlength = $self->server->{msg_length} - bytes::length("privmsg $target :" . $self->server->nick_name());
+ my $maxlength2 = $maxlength - bytes::length($lend);
+
+ if (bytes::length($msg) > ($maxlength)) {
+ my @spltarr;
+
+ while (bytes::length($msg) > ($maxlength)) {
+ my $pos = rindex($msg, " ", $maxlength2);
+ push @spltarr, substr($msg, 0, ($pos < ($maxlength/10 + 4)) ? $maxlength2 : $pos) . $lend;
+ $msg = $lstart . substr($msg, ($pos < ($maxlength/10 + 4)) ? $maxlength2 : $pos+1);
+ }
+
+ push @spltarr, $msg;
+ for (@spltarr) {
+ $self->command($command, $target, $_);
+ }
+ return;
+ }
+ }
+ $self->command($command, $target, $msg);
+}
+
+sub command {
+ my ($self,@command) = @_;
+
+ $self->server->yield(@command);
}
sub intel_log {
my ($c,$planet, $message) = @_;
my $log = $c->model->prepare_cached(q{
INSERT INTO forum_posts (ftid,uid,message) VALUES(
- (SELECT ftid FROM planets WHERE id = $3)
- ,(SELECT uid FROM users WHERE hostmask ILIKE $1)
- ,$2)
+ (SELECT ftid FROM planets WHERE pid = $3),$1,$2)
});
- $log->execute($c->host,$message,$planet);
+ $log->execute($c->uid,$message,$planet);
}
sub def_log {
my ($c,$call, $message) = @_;
my $log = $c->model->prepare(q{
INSERT INTO forum_posts (ftid,uid,message) VALUES(
- (SELECT ftid FROM calls WHERE id = $3)
- ,(SELECT uid FROM users WHERE hostmask ILIKE $1),$2)
+ (SELECT ftid FROM calls WHERE call = $3),$1,$2)
});
- $log->execute($c->host,$message,$call);
+ $log->execute($c->uid,$message,$call);
}
sub _build_roles {
@@ -136,7 +169,7 @@ sub _build_roles {
my $query = $self->model->prepare(q{
SELECT role FROM group_roles
WHERE gid IN (SELECT gid FROM groupmembers JOIN users USING (uid)
- WHERE hostmask ILIKE $1)
+ WHERE hostmask = $1)
});
$query->execute($self->host);
@@ -147,5 +180,32 @@ WHERE gid IN (SELECT gid FROM groupmembers JOIN users USING (uid)
return Set::Object->new(@roles);
}
+sub _build_uid {
+ my ($self) = @_;
+
+ my $query = $self->model->prepare(q{
+SELECT uid FROM users
+WHERE hostmask = $1
+ });
+ $query->execute($self->host);
+
+ if (my ($uid) = $query->fetchrow_array){
+ $query->finish;
+ return $uid;
+ }
+ return -4;
+}
+
+sub valuecolor {
+ shift @_;
+ my $s = $_;
+ $s = $_[1] if $#_ >= 1;
+ $s = "" unless defined $s;
+ return "$s" if $s eq 'Hostile';
+ return "$s" if $s eq 'Friendly';
+ return "$s" if $s eq 'Nap' or $s eq 'NAP';
+ return "$s" if $_[0];
+ return $s;
+}
1;