6 GrantStockPermissions.pm
10 mx-run ThisPackageName [options] -H hostname -D dbname -u username [-F]
12 this is a subclass of L<CXGN::Metadata::Dbpatch>
13 see the perldoc of parent class for more details.
17 Take care of web_usr permissions for the Chado Stock module
18 This subclass uses L<Moose>. The parent class uses L<MooseX::Runnable>
22 Naama Menda<nm249@cornell.edu>
24 =head1 COPYRIGHT & LICENSE
26 Copyright 2010 Boyce Thompson Institute for Plant Research
28 This program is free software; you can redistribute it and/or modify
29 it under the same terms as Perl itself.
34 package GrantStockPermissions
;
37 extends
'CXGN::Metadata::Dbpatch';
42 my $name = __PACKAGE__
;
43 print "dbpatch name is :'" . $name . "'\n\n";
44 my $description = 'Granting permissions to web_usr on the chado stock module';
45 my @previous_requested_patches = ('LoadChadoStock'); #ADD HERE
48 $self->description($description);
49 $self->prereq(\
@previous_requested_patches);
50 print STDOUT
"\nChecking if this db_patch was executed before or if previous db_patches have been executed.\n";
57 print STDOUT
"Executing the patch:\n " . $self->name . ".\n\nDescription:\n ". $self->description . ".\n\nExecuted by:\n " . $self->username . " .";
59 print STDOUT
"\nExecuting the SQL commands.\n";
67 stock_relationship_pub
76 foreach my $t (@tables) {
77 my $seq = $t . "_" . $t . "_id_seq";
78 print "Granting permissions to web_user on table $t and sequence $seq\n";
80 $self->dbh->do( 'SET SEARCH_PATH TO public' );
81 $self->dbh->do( "GRANT SELECT, UPDATE, INSERT ON $t TO web_usr" );
82 $self->dbh->do( "GRANT USAGE ON $seq TO web_usr" );
84 print "You're done!\n";