+ exit;
+ }
+};
+
+# Obtiene las observaciones de un permiso para un sistema.
+#
+# @param int $perm Obtiene las observaciones de un permiso para un sistema.
+# @param int $sistema Sistema al cual pertenecen los permisos.
+#
+# @return array
+$SAMURAI_Perm->{getObservaciones} = sub
+{
+ $perm = @_[0];
+ if (scalar(@_[1])) {
+ $sistema = @_[1];
+ }
+ else {
+ $sistema = $udat{SAMURAI_Perm_vars}{id_sistema};
+ }
+ if (!$udat{SAMURAI_Perm_vars}{observaciones}{$sistema}{$perm}) {
+ $udat{SAMURAI_Perm_vars}{observaciones} = '';
+ $sql = 'SELECT ps.observaciones AS observaciones FROM samurai.perm_sist AS ps WHERE ps.id_permiso = ? AND ps.id_sistema = ?';
+ #TODO cambiar los parametros de conexion segun corresponda
+ my $dbh = DBI->connect('dbi:mysql:dbname=samurai;host=localhost',"intranet","intranet");
+ $re = $dbh->prepare($sql);
+ $re->execute($perm, $sistema);
+ while ($r = $re->fetchrow_hashref()) {
+ push (@{$obser{$sistema}{$perm}}, $r->{observaciones});
+ }
+ $re->finish();
+ #Desconexion con la base
+ $dbh->disconnect;
+ $udat{SAMURAI_Perm_vars}{observaciones} = \%obser;
+ return $udat{SAMURAI_Perm_vars}{observaciones};
+ }
+};
+
+# MANAZAR: Funcion para dar un perfil a un usuario en un sistema
+#
+# @return void
+$SAMURAI_Perm->{asignarPerfil} = sub
+{
+ $id_perfil = @_[0];
+ my $login=$udat{SAMURAI_Perm_vars}{login};
+ my $id_sistema=$udat{SAMURAI_Perm_vars}{id_sistema};
+ my $resp=$udat{'user'};
+ my $sql = "REPLACE INTO perfil_sist_usuario (login,id_perfil,id_sistema,responsable) VALUES ('$login',$id_perfil,$id_sistema,'$resp')";
+ ##Conexion con la base
+ #TODO Cambiar los parametros de conexion segun corresponda.
+ my $dbh = DBI->connect('dbi:mysql:dbname=samurai;host=localhost',"intranet","intranet");
+ my $result=$dbh->do($sql);
+ #Desconexion con la base
+ $dbh->disconnect;
+};
+
+# MANAZAR: Funcion para quitar perfil a un usuario en un sistema
+#
+# @return void
+$SAMURAI_Perm->{quitarPerfil} = sub
+{
+ $id_perfil = @_[0];
+ my $login=$udat{SAMURAI_Perm_vars}{login};
+ my $id_sistema=$udat{SAMURAI_Perm_vars}{id_sistema};
+ my $resp=$udat{'user'};
+ my $sql = "DELETE FROM perfil_sist_usuario where (login='$login') AND (id_perfil=$id_perfil) AND (id_sistema=$id_sistema)";
+ ##Conexion con la base
+ #TODO Cambiar los parametros de conexion segun corresponda.
+ my $dbh = DBI->connect('dbi:mysql:dbname=samurai;host=localhost',"intranet","intranet");
+ my $result=$dbh->do($sql);
+ #Desconexion con la base
+ $dbh->disconnect;
+};