1 package NDWeb::Controller::Members;
5 use parent 'Catalyst::Controller';
9 NDWeb::Controller::Members - Catalyst Controller
25 my ( $self, $c, $order ) = @_;
28 if ($order =~ /^((?:defense|attack|total|humor|scan|raid)_points)$/){
31 $order = 'total_points DESC';
34 my $limit = 'LIMIT 10';
35 $limit = '' if $c->check_user_roles(qw/members_points_nolimit/);
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});
47 while (my $member = $query->fetchrow_hashref){
48 push @members,$member;
50 $c->stash(members => \@members);
53 sub addintel : Local {
54 my ( $self, $c, $order ) = @_;
56 $c->stash(intel => $c->flash->{intel});
57 $c->stash(scans => $c->flash->{scans});
58 $c->stash(intelmessage => $c->flash->{intelmessage});
61 sub postintel : Local {
62 my ( $self, $c, $order ) = @_;
64 $c->forward('insertintel');
66 $c->res->redirect($c->uri_for('addintel'));
69 sub postintelmessage : Local {
70 my ( $self, $c, $order ) = @_;
72 unless ($c->req->param('subject')){
73 if ($c->req->param('message') =~ /(.*\w.*)/){
74 $c->req->param(subject => $1);
78 $c->forward('/forum/insertThread',[12]);
79 $c->forward('/forum/insertPost',[$c->stash->{thread}]);
80 $c->flash(intelmessage => 1);
82 $c->forward('insertintel');
84 $c->res->redirect($c->uri_for('addintel'));
87 sub insertintel : Private {
88 my ( $self, $c, $order ) = @_;
92 my $findscan = $dbh->prepare(q{SELECT scan_id FROM scans
93 WHERE scan_id = ? AND tick >= tick() - 168 AND groupscan = ?
95 my $addscan = $dbh->prepare(q{INSERT INTO scans (scan_id,tick,uid,groupscan)
98 my $addpoint = $dbh->prepare(q{UPDATE users SET scan_points = scan_points + 1
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;
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;
115 $scan{message} = 'already exists';
119 my $tick = $c->req->param('tick');
120 unless ($tick =~ /^(\d+)$/){
121 $tick = $c->stash->{game}->{tick};
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)
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);
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 $&";
141 push @intel,"Couldn't add $&: ".$dbh->errstr;
145 $c->flash(intel => \@intel);
146 $c->flash(scans => \@scans);
151 Michael Andreen (harv@ruin.nu)