]> ruin.nu Git - ndwebbie.git/blob - lib/NDWeb/Controller/Members.pm
Converted addintel
[ndwebbie.git] / lib / NDWeb / Controller / Members.pm
1 package NDWeb::Controller::Members;
2
3 use strict;
4 use warnings;
5 use parent 'Catalyst::Controller';
6
7 =head1 NAME
8
9 NDWeb::Controller::Members - Catalyst Controller
10
11 =head1 DESCRIPTION
12
13 Catalyst Controller.
14
15 =head1 METHODS
16
17 =cut
18
19
20 =head2 index 
21
22 =cut
23
24 sub points : Local {
25         my ( $self, $c, $order ) = @_;
26         my $dbh = $c->model;
27
28         if ($order =~ /^((?:defense|attack|total|humor|scan|raid)_points)$/){
29                 $order = "$1 DESC";
30         }else{
31                 $order = 'total_points DESC';
32         }
33
34         my $limit = 'LIMIT 10';
35         $limit = '' if $c->check_user_roles(qw/members_points_nolimit/);
36
37         my $query = $dbh->prepare(qq{SELECT username,defense_points,attack_points
38                 ,scan_points,humor_points
39                 ,(attack_points+defense_points+scan_points/20) as total_points
40                 , count(NULLIF(rc.launched,FALSE)) AS raid_points
41                 FROM users u LEFT OUTER JOIN raid_claims rc USING (uid)
42                 WHERE uid IN (SELECT uid FROM groupmembers WHERE gid = 2)
43                 GROUP BY username,defense_points,attack_points,scan_points,humor_points,rank
44                 ORDER BY $order $limit});
45         $query->execute;
46         my @members;
47         while (my $member = $query->fetchrow_hashref){
48                 push @members,$member;
49         }
50         $c->stash(members => \@members);
51 }
52
53 sub addintel : Local {
54         my ( $self, $c, $order ) = @_;
55
56         $c->stash(intel => $c->flash->{intel});
57         $c->stash(scans => $c->flash->{scans});
58         $c->stash(intelmessage => $c->flash->{intelmessage});
59 }
60
61 sub postintel : Local {
62         my ( $self, $c, $order ) = @_;
63
64         $c->forward('insertintel');
65
66         $c->res->redirect($c->uri_for('addintel'));
67 }
68
69 sub postintelmessage : Local {
70         my ( $self, $c, $order ) = @_;
71
72         unless ($c->req->param('subject')){
73                 if ($c->req->param('message') =~ /(.*\w.*)/){
74                         $c->req->param(subject => $1);
75                 }
76         }
77
78         $c->forward('/forum/insertThread',[12]);
79         $c->forward('/forum/insertPost',[$c->stash->{thread}]);
80         $c->flash(intelmessage => 1);
81
82         $c->forward('insertintel');
83
84         $c->res->redirect($c->uri_for('addintel'));
85 }
86
87 sub insertintel : Private {
88         my ( $self, $c, $order ) = @_;
89         my $dbh = $c->model;
90
91         $dbh->begin_work;
92         my $findscan = $dbh->prepare(q{SELECT scan_id FROM scans
93                 WHERE scan_id = ? AND tick >= tick() - 168 AND groupscan = ?
94                 });
95         my $addscan = $dbh->prepare(q{INSERT INTO scans (scan_id,tick,uid,groupscan)
96                 VALUES (?,tick(),?,?)
97                 });
98         my $addpoint = $dbh->prepare(q{UPDATE users SET scan_points = scan_points + 1
99                 WHERE uid = ?
100                 });
101         my @scans;
102         my $intel = $c->req->param('message');
103         while ($intel =~ m{http://[\w.]+/.+?scan(_id|_grp)?=(\d+)}g){
104                 my $groupscan = (defined $1 && $1 eq '_grp') || 0;
105                 my %scan;
106                 $scan{id} = $2;
107                 $scan{group} = $groupscan;
108                 $findscan->execute($2,$groupscan);
109                 if ($findscan->rows == 0){
110                         if ($addscan->execute($2,$c->user->id,$groupscan)){
111                                 $addpoint->execute($c->user->id) unless $groupscan;
112                                 $scan{added} = 1;
113                         }
114                 }else{
115                         $scan{message} = 'already exists';
116                 }
117                 push @scans,\%scan;
118         }
119         my $tick = $c->req->param('tick');
120         unless ($tick =~ /^(\d+)$/){
121                 $tick = $c->stash->{game}->{tick};
122         }
123         my $addintel = $dbh->prepare(q{INSERT INTO fleets 
124                 (name,mission,tick,target,sender,eta,amount,ingal,back,uid)
125                 VALUES($1,$2,$3,planetid($4,$5,$6,$10),planetid($7,$8,$9,$10)
126                         ,$11,$12,$13,$14,$15)
127         });
128         my @intel;
129         while ($intel =~ m/(\d+):(\d+):(\d+)\*?\s+(\d+):(\d+):(\d+)
130                 \*?\s+(.+)(?:Ter|Cat|Xan|Zik|Etd)?
131                 \s+(\d+)\s+(Attack|Defend)\s+(\d+)/gx){
132                 my $ingal = ($1 == $4 && $2 == $5) || 0;
133                 my $lt = $tick + $10;
134                 my $back = ($ingal ? $lt + 4 : undef);
135                 eval {
136                         $addintel->execute($7,$9,$lt,$1,$2,$3,$4,$5,$6,$tick,$10,$8
137                                 ,$ingal,$back, $c->user->id);
138                         push @intel,"Added $&";
139                 };
140                 if ($@){
141                         push @intel,"Couldn't add $&: ".$dbh->errstr;
142                 }
143         }
144         $dbh->commit;
145         $c->flash(intel => \@intel);
146         $c->flash(scans => \@scans);
147 }
148
149 =head1 AUTHOR
150
151 Michael Andreen (harv@ruin.nu)
152
153 =head1 LICENSE
154
155 GPL 2.0, or later.
156
157 =cut
158
159 1;