[Bio] / WebApplication / scripts / org_count.pl Repository:
ViewVC logotype

View of /WebApplication/scripts/org_count.pl

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.2 - (download) (as text) (annotate)
Mon Feb 23 15:57:40 2009 UTC (10 years, 11 months ago) by paczian
Branch: MAIN
CVS Tags: mgrast_dev_08112011, rast_rel_2009_05_18, mgrast_dev_08022011, rast_rel_2014_0912, mgrast_dev_03052011, mobedac_release_05302012, mgrast_dev_05262011, mgrast_dev_04082011, rast_rel_2010_0928, mgrast_version_3_2, mgrast_dev_12152011, mgrast_dev_06072011, rast_rel_2009_0925, rast_rel_2010_0526, rast_rel_2014_0729, mgrast_dev_02212011, rast_rel_2010_1206, mgrast_release_3_0, mgrast_dev_03252011, rast_rel_2010_0118, rast_rel_2011_0119, mgrast_release_3_0_4, mgrast_release_3_0_2, mgrast_release_3_0_3, mgrast_release_3_0_1, mgrast_dev_03312011, mgrast_release_3_1_2, mgrast_release_3_1_1, mgrast_release_3_1_0, mgrast_dev_04132011, mgrast_dev_04012011, rast_rel_2009_07_09, rast_rel_2010_0827, myrast_33, rast_rel_2011_0928, mgrast_dev_04052011, mgrast_dev_02222011, rast_rel_2009_03_26, mgrast_dev_10262011, HEAD
Changes since 1.1: +8 -5 lines
now using WebApplicationDBHandle

#!/usr/bin/env perl

use strict;
use warnings;

use WebApplicationDBHandle;

use Getopt::Long;

sub usage {
  print "org_count.pl >>> counts the number of organizations for a list of users\n";
  print "org_count.pl -input <input_file>\n";
}

# read in parameters
my $input       = '';

GetOptions ( 'input=s' => \$input );


unless ($input) {
  &usage();
  exit 0;
}

# initialize db-master
my ($dbmaster, $error) = WebApplicationDBHandle->new();

# check if we got a dbmaster
if ($error) {
  print $error."\n";
  exit 0;
}

# open the user file
my @users;
open(FH, $input) or die "Could not open user file $input";
while (<FH>) {
  chomp;
  push(@users, $_);
}
close FH;

my $organizations = {};

foreach my $login (@users) {
  # get user
  my $user = $dbmaster->User->init( { 'login' => $login } );
  unless (ref $user) {
    print "User $login not found in database.\n";
  }
  my $uos = $dbmaster->OrganizationUsers->get_objects( { user => $user } );
  foreach my $uo (@$uos) {
    if (exists($organizations->{$uo->organization->name})) {
      $organizations->{$uo->organization->name} ++;
    } else {
      $organizations->{$uo->organization->name} = 1;
    }
  }
}

print "Oranization\tNo. Members\n";
foreach my $key (keys(%$organizations)) {
  print $key."\t".$organizations->{$key}."\n";
}

exit 1;

MCS Webmaster
ViewVC Help
Powered by ViewVC 1.0.3