#!/usr/bin/perl -w # -- # otrs.addUser2Role - Assign users to Roles from CLI # Copyright (C) 2001-2009 OTRS AG, http://otrs.org/ # -- # $Id: otrs.addUser2Role,v 1.5 2009/09/01 14:42:39 jb Exp $ # -- # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU AFFERO General Public License as published by # the Free Software Foundation; either version 3 of the License, or # any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # or see http://www.gnu.org/licenses/agpl.txt. # -- use strict; use warnings; # use ../ as lib location use File::Basename; use FindBin qw($RealBin); use lib dirname($RealBin); use lib dirname($RealBin) . "/Kernel/cpan-lib"; use vars qw($VERSION); $VERSION = qw($Revision: 1.5 $) [1]; use Getopt::Std; use Kernel::Config; use Kernel::System::Encode; use Kernel::System::Time; use Kernel::System::DB; use Kernel::System::Log; use Kernel::System::Queue; use Kernel::System::Group; use Kernel::System::Main; use Kernel::System::User; # get options my %Opts = (); getopts( 'hr:u:', \%Opts ); if ( $Opts{h} ) { print "otrs.addUser2Role - assign Users to Roles\n"; print "Copyright (C) 2001-2009 OTRS AG, http://otrs.org/\n"; print "usage: otrs.addUsers2Role -u -r \n"; exit 1; } if ( !$Opts{r} ) { print STDERR "ERROR: Need -r \n"; exit 1; } if ( !$Opts{u} ) { print STDERR "ERROR: Need -u \n"; exit 1; } # create common objects my %CommonObject = (); $CommonObject{ConfigObject} = Kernel::Config->new(%CommonObject); $CommonObject{EncodeObject} = Kernel::System::Encode->new(%CommonObject); $CommonObject{LogObject} = Kernel::System::Log->new( %CommonObject, LogPrefix => 'otrs.addUser2Role', ); $CommonObject{MainObject} = Kernel::System::Main->new(%CommonObject); $CommonObject{DBObject} = Kernel::System::DB->new(%CommonObject); $CommonObject{TimeObject} = Kernel::System::Time->new(%CommonObject); $CommonObject{GroupObject} = Kernel::System::Group->new(%CommonObject); $CommonObject{UserObject} = Kernel::System::User->new(%CommonObject); # check user my $UserID = $CommonObject{UserObject}->UserLookup( UserLogin => $Opts{u} ); if ( !$UserID ) { print STDERR "ERROR: Found no UserID for $Opts{u}\n"; exit 1; } my $RoleID = $CommonObject{GroupObject}->RoleLookup( Role => $Opts{r} ); if ( !$RoleID ) { print STDERR "ERROR: Found no RoleID for $Opts{r}\n"; exit 1; } # add user 2 role if ( !$CommonObject{GroupObject}->GroupUserRoleMemberAdd( UID => $UserID, RID => $RoleID, Active => 1, UserID => 1, ) ) { print STDERR "ERROR: Can't set permissions!\n"; exit 1; } else { print "Rolle '$Opts{r}' permissions set for User '$Opts{u}'\n"; exit(0); }