+
+sub getShips {
+ my ($ship,$command) = @_;
+
+ unless (defined $ship){
+ $ND::server->command("notice $ND::nick Usage: .$command ship | % can be used as wildcard, e.g. beet%");
+ return;
+ }
+ if (officer() || dc()){
+ my $f = $ND::DBH->prepare(qq{SELECT username,SUM(fs.amount) AS amount
+ FROM users u
+ JOIN (SELECT DISTINCT ON (planet) planet,fid FROM fleets
+ WHERE mission = 'Full fleet' AND name <> 'Unit'
+ ORDER BY planet,tick DESC,fid DESC) f USING (planet)
+ JOIN fleet_ships fs USING (fid)
+ WHERE ship ILIKE ? AND uid IN (SELECT uid FROM groupmembers WHERE gid = 2)
+ GROUP BY username ORDER BY amount DESC
+ });
+ if ($command eq 'shipshome'){
+ $f = $ND::DBH->prepare(q{
+SELECT username,SUM(amount) AS amount
+FROM available_ships
+WHERE ship ILIKE ? AND uid IN (SELECT uid FROM groupmembers WHERE gid = 2)
+GROUP BY username ORDER BY amount DESC
+ });
+ }
+ $f->execute($ship);
+ my $text;
+ my $i = 0;
+ my $total = 0;
+ while (my $user = $f->fetchrow_hashref){
+ $user->{last} = '?' unless defined $user->{last};
+ $text .= "$user->{username}: $user->{amount} ";
+ $i++;
+ $total += $user->{amount};
+ }
+ if ($text){
+ $ND::server->command("notice $ND::nick $ND::B$i$ND::B Users with $ND::B$total $ship$ND::B: $text");
+ }else{
+ $ND::server->command("msg $ND::target $ND::B$i$ND::B Couldn't find any user with $ND::B$ship$ND::B:");
+ }
+ }
+}
+
+sub getFleet {
+ my ($nick,$command) = @_;
+
+ unless (defined $nick){
+ $ND::server->command("notice $ND::nick Usage: $command nick | % can be used as wildcard, e.g. barr%");
+ return;
+ }
+ if (officer() || dc()){
+ my $f = $ND::DBH->prepare(q{SELECT fs.ship, fs.amount, username
+ FROM fleet_ships fs
+ JOIN (SELECT fid,username
+ FROM fleets f
+ JOIN users u USING (planet)
+ WHERE mission = 'Full fleet' AND name <> 'Unit'
+ AND username ILIKE $1
+ ORDER BY planet,tick DESC,fid DESC
+ LIMIT 1
+ ) f USING (fid)
+ ORDER BY num
+ });
+ $f->execute($nick);
+ my $text;
+ my $username;
+ while (my $ship = $f->fetchrow_hashref){
+ unless (defined $username) {
+ $username = $ship->{username};
+ $text = "$ND::B$username$ND::O has: "
+ }
+ $text .= "$ship->{ship} $ship->{amount} ";
+ }
+ if ($text){
+ $ND::server->command("notice $ND::nick $text");
+ }else{
+ $ND::server->command("notice $ND::nick Couldn't find any fleet for $nick");
+ }
+ }
+}
+