#!/usr/pkg/bin/perl

# VERSION : RELEASE 1.1

 #####     #    ######  ####### #     # ####### #######     #####         #        #     #
#     #   # #   #     # #       ##    # #          #       #     #       # #       #     #
#        #   #  #     # #       # #   # #          #       #            #   #      #     #
 #####  #     # ######  #####   #  #  # #####      #        #####      #     #     #     #
      # ####### #   #   #       #   # # #          #             # ### ####### ### #     #
#     # #     # #    #  #       #    ## #          #       #     # ### #     # ### #     #
 #####  #     # #     # ####### #     # #######    #        #####  ### #     # ###  #####


############################# LICENSE #############################
#
# Davical interface for command line is a software developed by
# Egoitz Aurrekoetxea at Sarenet S.A.U (http://www.sarenet.es/).
#
# It is under BSD license and is distributed as is without any
# other warranty. You can contact with me in the following
# email address : egoitz(at)sarenet.es
#
# Enjoy!
#
# Copyright (c) Sarenet S.A.U (http://www.sarenet.es/).
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
#    notice, this list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright
#    notice, this list of conditions and the following disclaimer in the
#    documentation and/or other materials provided with the distribution.
# 3. Neither the name of Sarenet S.A.U nor the names of its contributors
#    may be used to endorse or promote products derived from this software
#    without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY SARENET S.A.U AND CONTRIBUTORS ``AS IS'' AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED.  IN NO EVENT SHALL SARENET S.A.U OR CONTRIBUTORS BE LIABLE
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
# SUCH DAMAGE.
#
######################### IMPORTANT NOTES #########################
#
# SEE ALSO: https://wiki.davical.org/index.php/DAViCal-cli
#
# This code has been created for and used in a FreeBSD machine with Davical
# installed from the own ports (at the beginning). This means that in this
# version the hardcoded paths and checks will have some customization for that
# environment. Even they have been hardcoded in this version (which probably
# will be improved in the following releases of this tool) they can be easily
# customed for your env.
#
# About hardcoded important notes:
#
# * This program does not hardcoded any admin of database for managing
#   different Davical domain instances. It fetches from the config file
#   credentials for each of the Davical database it manages. This way we make
#   more difficult for an attacker to try to do a massive change. It fetches
#   config files the way described in the next point.
#
# * Function obtener_conexion_a_bbdd --> Line 1971 --> my $fichero =
#   "/usr/local/etc/davical/".$dominioloc.".organizer.sarenet.es-conf.php";
#
#   This tool is being used in production env in a mail hosting service where
#   each domain contains it's own Davical instance and the config of each
#   instance is located under /usr/local/etc/davical.
#
# * This script assumes default collections, calendar and addresses should
#   never be removed for the fact of being the default ones... and for keeping a
#   default same content in all accounts.
#
# * It logs to syslog by default to the local2 facility and info priority. Can
#   easily be changed in ## SYSLOG STAFF section.
#
# * At present time it does only contemplate read only or read write
#   permissions. It allows too by default seeing if an account is busy or free in
#   the calendar.
#
#   Even being bynarily defined the rest of permissions and not being used at
#   this moment at least... as said. Everyone who needs to make use of them, the
#   code is pretty ordered for being to achieve some modifications which could
#   allow anyone use different permission types.
#
# * I wanted to excuse myself for being all syslogged comments, vars,
#   functions, etc in Spanish. This code had been done in some "free" and other
#   non free times I had at work but the coding having to be compatible with
#   other tasks I do as Sarenet sysadmin/postmaster, etc…. So the more
#   significant errors, var names, function names and so where for me... the most
#   easily I could get all job finished. So excuse me but at least in the first
#   times of this code (where I didn't know If I was going to be able to make it
#   open  even) was important to be in my native language.
#
# * The URL this code manages are basically :
#   https://the-customer-domain-without-dots-or-dash.organizer.sarenet.es/caldav.php/_______.
#   So for instance for a domain like acme-comp.com.es the URL would be :
#   https://acmecompcomes.organizer.sarenet.es/caldav.php/_______. When in the
#   code you see $dominioloc var is referring to the domain after this
#   transformation.
#
# * Lines containing the string "organizer.sarenet.es/caldav.php". The product
#   name at Sarenet is Organizer. And the URL always called is :
#   https://____________.organizer.sarenet.es/caldav.php/____ so it's too
#   hardcoded in the code.
#
# * 9987982389 is nothing but an invented error code which is pretty dificult
#   to any time be owned by any valid id.
#
# * Of course you can, have to... must... whatever any line you need to adapt
#   for your env. Mainly talking about literals. Specially literals like :
#
#   "Fallo en acceso a BBDD. CONTACTE CON SARENET."
#
#   As said previously this code was written for easily being understood in
#   literal terms and so... by anyone at Sarenet.
#
# * It has too some very light security meassures in function
#   comprobar_permiso_ejecutar. It does some checks that could help you at least
#   delaying slihtly an attack. Obviously you have to properly configure the
#   function for your env in order to use this code. You could too remove all
#   code inside this function if you prefer it.
#
# * The code reads database access credentials from a file in which the
#   pg_connect line has the format : $c->pg_connect[] = "host=XX.XX.XX.XX
#   port=5432 dbname=whatever user=whatever password=whatever”;
#
#
# In case of suffering issues or having doubts of it's working mode, please
# contact me at egoitz@sarenet.es email address and I'll help you happily :)
#
###################################################################

## REQUIRED PERL MODULES
use DBI;
use strict;
use warnings;
use Getopt::Long;
use Switch;
use Sys::Syslog qw(:DEFAULT setlogsock);


## SYSLOG STAFF
our $syslog_socktype = 'unix'; # inet, unix, stream, console
our $syslog_facility="local2";
our $syslog_options="pid";
our $syslog_priority="info";

openlog $0, $syslog_options, $syslog_facility;

## DATABASE CONNECTION VARIABLES
our $driver = "Pg";
our $host = "";
our $database = "";
our $dsn = "";
our $userid = "";
our $password = "";
our $dbh = "";

our $error_general = '9987982389';
our $mensaje_fallo_gen = "";
our $colec_default_calendar = 'calendar';
our $colec_default_addresses = 'addresses';
our $permisos_defecto_nada = 'NONE';

## GENERAL PURPOSE VARIABLES
our $usuario = "";
our $usudest = "";
our $grupo = "";
our $principal = "";
our $permisos = "";
our $coleccion = "";
our $tipocol = "";
our $email = "";
our $dominio = "";
our $coldispname = "";
our $idoperacion = 99;
our $dequien = "";

our $usercorriendo = "";

our $verbose = 0;

## DAVICAL PERMISSIONS
our $perm_all              = '000000001111111111111111';
our $perm_readwrite        = '000000001111111011100111';
our $perm_read             = '000000000001001000100001';
our $perm_readsched        = '000000001111111000100001';
our $perm_freebusy         = '000000000001001000000000';
our $perm_schedliv         = '000000000001110000000000';
our $perm_schedsend        = '000000001110000000000000';
our $perm_none             = '000000000000000000000000';
our $perm_resetprinc       = '000000001111111000100000';

#### POSSIBLE OPERATIONS
#
### 1  - CREATE COLLECTION
### 2  - REMOVE COLLECTION
### 3  - APPEND USER TO A GROUP OF AN OWNER (OWNERS ARE THE WAY OF UNIQUELY IDENTIFY A GROUP FROM A CONCRETE PRINCIPAL OR USER)
### 4  - REMOVE USER TO A GROUP OF AN OWNER (OWNERS ARE THE WAY OF UNIQUELY IDENTIFY A GROUP FROM A CONCRETE PRINCIPAL OR USER)
### 5  - GRANT CONCRETE PERMISSIONS TO A PRINCIPAL IN ANOTHER PRINCIPAL (PRINCIPALS ARE FINALLY JUST USERS)
### 6  - REVOKE PERMISSIONS TO A PRINCIPAL IN PRINCIPAL (PRINCIPALS ARE FINALLY JUST USERS)
### 7  - GRANT PERMISSIONS TO A PRINCIPAL (A USER FINALLY) IN A COLLECTION OF ANOTHER PRINCIPAL (ANOTHER USER FINALLY)
### 8  - REVOKE PERMISSIONS TO A PRINCIPAL (A USER FINALLY) IN A COLLECTION OF ANOTHER PRINCIPAL (ANOTHER USER FINALLY)
### 9  - CREATE GROUP OWNED BY USER (BY A PRINCIPAL FINALLY)
### 10 - REMOVE GROUP OWNED BY USER (BY A PRINCIPAL FINALLY)
### 11 - REMOVE PRINCIPAL/USER (AN ACCOUNT FINALLY WITH ALL THE COLLECTIONS)
### 12 - SET DEFAULT PERMISSIONS IN A COLLECTION OF A PRINCIPAL
### 13 - UNSET DEFAULT PERMISSIONS IN A COLLECTION OF A PRINCIPAL
### 14 - SET DEFAULT PERMISSIONS IN A PRINCIPAL
### 15 - UNSET DEFAULT PERMISSIONS IN A PRINCIPAL
### 16 - OBTAIN PRINCIPAL GRANTS FOR DISPLAYING THEM FOR EXAMPLE IN THE WEBMAIL....
### 17 - OBTAIN GROUP MEMBERS FROM A GROUP OWNED BY AN USER (A PRINCIPAL)
### 18 - OBTAIN GROUPS OWNED BY AN USER (OR PRINCIPAL)
### 19 - SET A COLLECTION'S (FROM A PRINCIPAL) DISPLAY NAME
### 20 - OBTAIN PERMISSIONS GRANTED TO OTHER USERS IN MY COLLECTIONS
### 21 - OBTAIN A LIST OF ALL CREATED USERS IN THE DAVICAL INSTANCE
### 22 - OBTAIN A LISTING WHICH DISPLAYS FROM A CONCRETE OWNER, GROUP:MEMBERS
### 23 - COMBINED LISTING OF 16,20,21,22
#
##########################

#### FUNCIONES BASICAS PARA SER COMBINADAS EN OTRAS FUNCIONES MAS COMPLEJAS QUE HAGAN LAS TAREAS

sub comprobar_error_variable {
	if (($_[0] == '9987982389') && ($_[1] eq ""))
	{
		syslog $syslog_priority, "Error general en rutina de comprobacion general, al comprobar valor de variable. CONTACTE CON SARENET.";
		$dbh->disconnect();
		closelog();
		die "Error general en rutina de comprobacion general, al comprobar valor de variable. CONTACTE CON SARENET.";
	}
	elsif (($_[0] == '9987982389') && ($_[1] ne ""))
	{
		syslog $syslog_priority, $_[1];
		$dbh->disconnect();
		closelog();
		die "Error general en rutina de comprobacion general, al comprobar valor de variable. CONTACTE CON SARENET.";
	}
}

sub comprobar_error_variable_texto {
	if (($_[0] eq '9987982389') && ($_[1] eq ""))
	{
		syslog $syslog_priority, "Error general en rutina de comprobacion general, al comprobar valor de variable. CONTACTE CON SARENET.";
		$dbh->disconnect();
		closelog();
		die "Error general en rutina de comprobacion general, al comprobar valor de variable. CONTACTE CON SARENET.";
	}
	elsif (($_[0] eq '9987982389') && ($_[1] ne ""))
	{
		syslog $syslog_priority, $_[1];
		$dbh->disconnect();
		closelog();
		die "Error general en rutina de comprobacion general, al comprobar valor de variable. CONTACTE CON SARENET.";
	}
}

sub comprobar_error_array {
	if (grep(/^$9987982389$/, @{$_[0]}) && ($_[1] eq ""))
	{
		syslog $syslog_priority, "Error general en rutina de comprobacion general, al comprobar valor de array. CONTACTE CON SARENET.";
		$dbh->disconnect();
		closelog();
		die "Error general en rutina de comprobacion general, al comprobar valor de array. CONTACTE CON SARENET.";
	}
	elsif (grep(/^$9987982389$/, @{$_[0]}) && ($_[1] ne ""))
	{
		syslog $syslog_priority, $_[1];
		$dbh->disconnect();
		closelog();
		die "Error general en rutina de comprobacion general, al comprobar valor de array. CONTACTE CON SARENET.";
	}
}

sub func_remplazo_die {
	$dbh->disconnect();
	closelog();
	syslog $syslog_priority, $_[0];
	die $_[0];
}

sub comprobar_version {
	my $stmt = qq(SELECT schema_major||'.'||schema_minor FROM awl_db_revision ORDER BY schema_id DESC LIMIT 1;);
	my $sth = $dbh->prepare( $stmt );
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my $i = 0;
	my $version = "";
	if($rv < 0){
		print $DBI::errstr;
	}
	@row = $sth->fetchrow_array();
	$version = $row[0];

	if ($version != '1.2')
	{
		func_remplazo_die("Version de esquema incompatible. CONTACTE CON SARENET.");
	}
}

sub sacar_userid {
	syslog $syslog_priority, "Obteniendo userid de usuario : ----$_[0]----" if ($verbose==1);
	## Se quotea el valor del nombre de usuario del que obtener el id. Nos lo pasan al llamar a la funcion
	my $entfuncq = $dbh->quote($_[0]);
	my $stmt = "SELECT user_no FROM usr WHERE username = "."$entfuncq"." LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	$entfuncq = $dbh->quote($_[0]);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	if($rv < 0){
		print $DBI::errstr;
	}
	@row = $sth->fetchrow_array();
	my $usuarioid = $row[0];

	if (scalar(@row) > 0)
	{
		syslog $syslog_priority, "Para userid de usuario ----$_[0]---- devolvemos id de usuario ----$usuarioid----" if ($verbose==1);
	return($usuarioid);
	}
	else
	{
		syslog $syslog_priority, "Para userid de usuario ----$_[0]---- devolvemos id de usuario ----ERROR 9987982389----" if ($verbose==1);
		return($error_general);
	}
}

sub sacar_principalid {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de usuario del que obtener el id. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT principal_id FROM principal WHERE user_no = "."$entfuncq"." LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my $principalid = "";
	if($rv < 0){
		print $DBI::errstr;
	}
	@row = $sth->fetchrow_array();
	$principalid = $row[0];

	if (scalar(@row) > 0)
	{
		syslog $syslog_priority, "El valor que devolvemos para ID de principal del usuario con usuario id ---$_[0]--- es ---$principalid---" if ($verbose==1);
		return($principalid);
	}
	else
	{
		syslog $syslog_priority, "El valor que devolvemos para ID de principal del usuario con usuario id ---$_[0]--- es ---ERROR 9987982389---" if ($verbose==1);
		return($error_general);
	}
}

sub sacar_userid_principal {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de principal de usuario del que obtener el id de usuario. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT user_no FROM principal WHERE principal_id = "."$entfuncq"." LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my $userno = "";
	if($rv < 0){
		print $DBI::errstr;
	}
	@row = $sth->fetchrow_array();
	$userno = $row[0];

	if (scalar(@row) > 0)
	{
		syslog $syslog_priority, "El ID del usuario del ID del principal ----$_[0]---- es ---$userno---" if ($verbose==1);
		return($userno);
	}
	else
	{
		syslog $syslog_priority, "El ID del usuario del ID del principal ----$_[0]---- es ---ERROR 9987982389---" if ($verbose==1);
		return($error_general);
	}
}

sub sacar_username_deidusu {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de usuario del que obtener el nombre de usuario. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT username FROM usr WHERE user_no = "."$entfuncq"." LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my $username = "";
	if($rv < 0){
		print $DBI::errstr;
	}
	@row = $sth->fetchrow_array();
	$username = $row[0];

	if (scalar(@row) > 0)
	{
		syslog $syslog_priority, "El username obtenido de userid : ----$_[0]---- es ---$username---" if ($verbose==1);
		return($username);
	}
	else
	{
		syslog $syslog_priority, "El username obtenido de userid : ----$_[0]---- es ---ERROR 9987982389---" if ($verbose==1);
		return($error_general);
	}
}

sub sacar_tipo_principal {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de usuario del que obtener el tipo de principal que es. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT principal_type_desc FROM ((usr LEFT JOIN principal USING (user_no)) LEFT JOIN role_member USING (user_no)) LEFT JOIN principal_type ON (principal_type_id = type_id) WHERE user_no = "."$entfuncq"." AND active = 't' and role_no IS DISTINCT FROM '1' LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my $principaltype = "";
	if($rv < 0){
		print $DBI::errstr;
	}
	@row = $sth->fetchrow_array();
	$principaltype = $row[0];

	if (scalar(@row) > 0)
	{
		syslog $syslog_priority, "El tipo de principal obtenido al consultarlo para el id de usuario ----$_[0]---- es ----$principaltype-----" if ($verbose==1);
		return($principaltype);
	}
	else
	{
		syslog $syslog_priority, "El tipo de principal obtenido al consultarlo para el id de usuario ----$_[0]---- es ----ERROR 9987982389-----" if ($verbose==1);
		return($error_general);
	}
}

sub tipo_principal_es_persona {
	my $tipo_principal = sacar_tipo_principal($_[0]);

	if ($tipo_principal eq $error_general)
	{
		syslog $syslog_priority, "Al consultar si el tipo de principal del usuario ID ---$_[0]--- es Persona decimos NO y devolvemos 1" if ($verbose==1);
		return(1);
	}

	if ($tipo_principal eq "Person")
	{
		syslog $syslog_priority, "Al consultar si el tipo de principal del usuario ID ---$_[0]--- es Persona decimos SI y devolvemos 0" if ($verbose==1);
		return(0);
	}
	else
	{
		syslog $syslog_priority, "Al consultar si el tipo de principal del usuario ID ---$_[0]--- es Persona decimos NO y devolvemos 1" if ($verbose==1);
		return(1);
	}
}

sub tipo_principal_es_grupo {
	my $tipo_principal = sacar_tipo_principal($_[0]);

	if ($tipo_principal eq $error_general)
	{
		syslog $syslog_priority, "Al consultar si el tipo de principal del usuario ID ---$_[0]--- es Grupo decimos NO y devolvemos 1" if ($verbose==1);
		return(1);
	}

	if ($tipo_principal eq "Group")
	{
		syslog $syslog_priority, "Al consultar si el tipo de principal del usuario ID ---$_[0]--- es Grupo decimos SI y devolvemos 0" if ($verbose==1);
		return(0);
	}
	else
	{
		syslog $syslog_priority, "Al consultar si el tipo de principal del usuario ID ---$_[0]--- es Grupo decimos NO y devolvemos 1" if ($verbose==1);
		return(1);
	}
}

sub sacar_colecciones_usuario {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de usuario del que obtener que colecciones tiene. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT dav_name,is_addressbook,collection_id FROM collection WHERE user_no = "."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @parte_collection = ();
	my @nombres_id_tipo_collections = ();
	my $contador = 0;
	if($rv < 0){
		print $DBI::errstr;
	}

	while(@row = $sth->fetchrow_array()) {
		@parte_collection = split(/\//, $row[0]);
		$nombres_id_tipo_collections[$contador][0] = $parte_collection[2];
		$nombres_id_tipo_collections[$contador][1] = $row[1];
		$nombres_id_tipo_collections[$contador][2] = $row[2];

		$contador = $contador + 1;
	}

	if (scalar(@nombres_id_tipo_collections) > 0)
	{
		return(@nombres_id_tipo_collections);
	}
	else
	{
	syslog $syslog_priority, "Del id de usuario ---$_[0]--- sacamos que tiene las colecciones ----ERROR 9987982389----" if ($verbose==1);
		@nombres_id_tipo_collections = ('9987982389');
		return(@nombres_id_tipo_collections);
	}
}

sub comprobar_existencia_permisos {
	my $en_princ_o_col = $_[0];
	my $permisos_supuestos_no_existen = $_[1];
	my $id_princ_origen = $_[2];
	my $id_princ_col_destino = $_[3];
	my $ok_adelante = '0';
	my $permisos_nombre_que_existen = "";

	if ($en_princ_o_col == '0')
	{
		my $entfuncq = $dbh->quote($id_princ_origen);
		my $entfuncq2 = $dbh->quote($id_princ_col_destino);
		## Se quotea el valor del ID de principal para el que sacar permisos externos en otras colecciones. Nos lo pasan al llamar a la funcion
		my $stmt = "SELECT privileges FROM grants WHERE to_principal = "."$entfuncq"." AND by_principal = "."$entfuncq2"." LIMIT 1;";
		syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
		my $sth = $dbh->prepare($stmt);
		my $rv = $sth->execute() or die $DBI::errstr;
		my @row = ();
		my @array_coles_permisos = ();
		my $contador = 0;
		if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
		}

		@row = $sth->fetchrow_array();
		my $permisos_que_existen = $row[0];
		$permisos_nombre_que_existen = permisosbin_a_nombre($permisos_que_existen);
		syslog $syslog_priority, "Para el principal ID origen ---$id_princ_origen--- en principal ID destino ---$id_princ_col_destino--- existen permisos de ---$permisos_nombre_que_existen---" if ($verbose==1);
	}
	elsif ($en_princ_o_col == '1')
	{
		my $entfuncq = $dbh->quote($id_princ_origen);
		my $entfuncq2 = $dbh->quote($id_princ_col_destino);
		## Se quotea el valor del ID de principal para el que sacar permisos externos en otras colecciones. Nos lo pasan al llamar a la funcion
		my $stmt = "SELECT privileges FROM grants WHERE to_principal = "."$entfuncq"." AND by_collection = "."$entfuncq2"." LIMIT 1;";
		syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
		my $sth = $dbh->prepare($stmt);
		my $rv = $sth->execute() or die $DBI::errstr;
		my @row = ();
		my @array_coles_permisos = ();
		my $contador = 0;
		if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
		}

		@row = $sth->fetchrow_array();
		my $permisos_que_existen = $row[0];
		$permisos_nombre_que_existen = permisosbin_a_nombre($permisos_que_existen);
		syslog $syslog_priority, "Para el principal ID origen ---$id_princ_origen--- en collection ID destino ---$id_princ_col_destino--- existen permisos de ---$permisos_nombre_que_existen---" if ($verbose==1);
	}

	if ($permisos_supuestos_no_existen ne $permisos_nombre_que_existen)
	{
		syslog $syslog_priority, "Adelante en aplicar esos permisos" if ($verbose==1);
		return($ok_adelante);
	}
	else
	{
		syslog $syslog_priority, "Los permisos ya estan aplicados y no se tiene que volver a aplicar" if ($verbose==1);
		return($error_general);
	}
}

sub sacar_id_colecc_usuario_nombre {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	## Se quotea el valor del id de usuario y nombre completo de la coleccion para obtener un id de coleccion. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT collection_id FROM collection WHERE user_no = "."$entfuncq"." AND dav_name = "."$entfuncq2"." LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my $id_col = 998798238;
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	if($rv < 0){
		print $DBI::errstr;
	}

	@row = $sth->fetchrow_array();
	$id_col = $row[0];

	if (scalar(@row) > 0)
	{
		syslog $syslog_priority, "Para el ID de usuario ---$_[0]--- y nombre de coleccion ---$_[1]--- el id de coleccion vale ---$id_col---" if ($verbose==1);
		return($id_col);
	}
	else
	{
		syslog $syslog_priority, "Para el ID de usuario ---$_[0]--- y nombre de coleccion ---$_[1]--- el id de coleccion vale ---ERROR 9987982389---" if ($verbose==1);
		return($error_general);
	}
}

sub sacar_nombre_id_colecc {
	## Se quotea el valor del id de coleccion para obtener el nombre completo de coleccion. Nos lo pasan al llamar a la funcion
	my $entfuncq = $dbh->quote($_[0]);
	my $stmt = "SELECT dav_name FROM collection WHERE collection_id = "."$entfuncq"." LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my $dav_name = 998798238;
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	if($rv < 0){
		print $DBI::errstr;
	}

	@row = $sth->fetchrow_array();
	$dav_name = $row[0];

	if (scalar(@row) > 0)
	{
		syslog $syslog_priority, "El valor que devolvemos de nombre de coleccion para id de coleccion ----$_[0]--- vale ---$dav_name---" if ($verbose==1);
		return($dav_name);
	}
	else
	{
		syslog $syslog_priority, "El valor que devolvemos de nombre de coleccion para id de coleccion ----$_[0]--- vale ---ERROR 9987982389---" if ($verbose==1);
		return($error_general);
	}
}


sub sacar_permisos_acceso_autorizados_defecto {

	## Se quotea el valor del id de coleccion para obtener el nombre completo de coleccion. Nos lo pasan al llamar a la funcion

	### PRIMERO SACO LAS COLECCIONES QUE TIENEN PERMISOS POR DEFECTO DE LECTURA
	my $colec_usu_opquetoca = "";
	my $stmt = "SELECT parent_container,dav_name,user_no,collection_id FROM collection WHERE default_privileges = "."'$perm_read'".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @array_coles_permisos_defecto_lectura = ();
	my @array_coles_permisos_defecto_lecturaescritura = ();
	my @resultado_devolver = ();
	my $contador = 0;
	my $dominioloc = $dominio;
	$dominioloc =~ s/\.//g;
	$dominioloc =~ s/-//g;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$array_coles_permisos_defecto_lectura[$contador][0] = $row[0];
		$array_coles_permisos_defecto_lectura[$contador][1] = $row[1];
		$array_coles_permisos_defecto_lectura[$contador][2] = $row[2];
		$array_coles_permisos_defecto_lectura[$contador][3] = $row[3];
		$contador = $contador + 1;
	}

	### LUEGO SACO LAS COLECCIONES QUE TIENEN PERMISOS POR DEFECTO DE LECTURA-ESCRITURA
	$contador = 0;
	$stmt = "SELECT parent_container,dav_name,user_no,collection_id FROM collection WHERE default_privileges = "."'$perm_readwrite'".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	$sth = $dbh->prepare($stmt);
	$rv = $sth->execute() or die $DBI::errstr;
	@row = ();
	$contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$array_coles_permisos_defecto_lecturaescritura[$contador][0] = $row[0];
		$array_coles_permisos_defecto_lecturaescritura[$contador][1] = $row[1];
		$array_coles_permisos_defecto_lecturaescritura[$contador][2] = $row[2];
		$array_coles_permisos_defecto_lecturaescritura[$contador][3] = $row[3];
		$contador = $contador + 1;
	}

	### AHORA SACO QUE PRINCIPALS TIENEN PERMISO DE LECTURA --- NOOO TIENE QUE HABER PRINCIPALS CON PERMISOS EN LECTURA-ESCRITURA
	$contador = 0;
	$stmt = "SELECT principal_id FROM principal WHERE (default_privileges = '".$perm_read."' OR default_privileges = '".$perm_readwrite."');";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	$sth = $dbh->prepare($stmt);
	$rv = $sth->execute() or die $DBI::errstr;
	@row = ();
	my @array_principal_permisos_defecto_lectura = ();
	$contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$array_principal_permisos_defecto_lectura[$contador] = $row[0];
		$contador = $contador + 1;
	}

	### AHORA CRUZAMOS LOS ARRAYS PARA VER QUE COLECCIONES PUEDEN SER ACCEDIDAS POR SUS PERMISOS POR DEFECTO POR TENERLOS TAMBIEN SUS RESPECTIVOS PRINCIPALS
	$contador = 0;
	my $principal_revisar = 0;
	my $princ_que_toca = 0;
	foreach $colec_usu_opquetoca (@array_coles_permisos_defecto_lectura) {
		$principal_revisar = sacar_principalid(@$colec_usu_opquetoca[2]);
		foreach $princ_que_toca (@array_principal_permisos_defecto_lectura)
		{
			if ($princ_que_toca == $principal_revisar)
			{
				$resultado_devolver[$contador][0] = 'https://'.$dominioloc.'.organizer.sarenet.es/caldav.php'.@$colec_usu_opquetoca[1].'';
				$resultado_devolver[$contador][1] = 'READ';
				$resultado_devolver[$contador][2] = coleccion_es_libreta_o_agenda(@$colec_usu_opquetoca[3]);
				$contador = $contador + 1;
				next;
			}
		}
	}

	foreach $colec_usu_opquetoca (@array_coles_permisos_defecto_lecturaescritura) {
		$principal_revisar = sacar_principalid(@$colec_usu_opquetoca[2]);
		foreach $princ_que_toca (@array_principal_permisos_defecto_lectura)
		{
			if ($princ_que_toca == $principal_revisar)
			{
				$resultado_devolver[$contador][0] = 'https://'.$dominioloc.'.organizer.sarenet.es/caldav.php'.@$colec_usu_opquetoca[1].'';
				$resultado_devolver[$contador][1] = 'READWRITE';
				$resultado_devolver[$contador][2] = coleccion_es_libreta_o_agenda(@$colec_usu_opquetoca[3]);
				$contador = $contador + 1;
				next;
			}
		}
	}

	return(@resultado_devolver);
}

sub colecc_tiene_permisos_por_defecto {
	my $colec_usu_opquetoca = "";
	my $stmt = "SELECT user_no FROM collection WHERE (default_privileges = '".$perm_read."' OR default_privileges = '".$perm_readwrite."') AND collection_id = '".$_[0]."' LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @array_coles_permisos_defecto_lectura = ();
	my @array_coles_permisos_defecto_lecturaescritura = ();
	my @resultado_devolver = ();
	my $contador = 0;
	my $dominioloc = $dominio;
	my $userid_para_comp_principal = '0';
	$dominioloc =~ s/\.//g;
	$dominioloc =~ s/-//g;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	@row = $sth->fetchrow_array();
	$userid_para_comp_principal = $row[0];
	if ((defined($userid_para_comp_principal)) && ($userid_para_comp_principal =~ /^[+-]?\d+$/))
	{
		if ($userid_para_comp_principal != '0')
		{
			syslog $syslog_priority, "El userid que miro vale ----$userid_para_comp_principal----" if ($verbose==1);

			my $stmt = "SELECT principal_id FROM principal WHERE (default_privileges = '".$perm_read."' OR default_privileges = '".$perm_readwrite."') AND user_no = '".$userid_para_comp_principal."';";
			syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
			$sth = $dbh->prepare($stmt);
			$rv = $sth->execute() or die $DBI::errstr;
			if($rv < 0){
				print $DBI::errstr;
				die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
			}

			@row = $sth->fetchrow_array();
			if (scalar(@row) > 0)
			{
				syslog $syslog_priority, "El tipo de coleccion para el ID de coleccion ---$_[0]--- tiene permisos por defecto" if ($verbose==1);
				my $devolvemos = 0;
				return($devolvemos);
			}
		}
		else
		{
			syslog $syslog_priority, "Nos ha salido userid 0... algo raro ocurre...." if ($verbose==1);
			my $devolvemos = 1;
			return($devolvemos);
		}
	}
	else
	{
		syslog $syslog_priority, "El tipo de coleccion para el ID de coleccion ---$_[0]--- NO tiene permisos por defecto---" if ($verbose==1);
		my $devolvemos = 1;
		return($devolvemos);
	}
}

sub ver_permisos_defecto_colecc {
	my $stmt = "SELECT default_privileges FROM collection WHERE (default_privileges = '".$perm_read."' OR default_privileges = '".$perm_readwrite."') AND collection_id = '".$_[0]."' LIMIT 1;";
	syslog $syslog_priority, "  Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my $default_privileges_collection = '9987982389';
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	@row = $sth->fetchrow_array();
	$default_privileges_collection = $row[0];

	if (defined($default_privileges_collection))
	{
		if (($default_privileges_collection ne '9987982389') && ($default_privileges_collection ne ''))
		{
			syslog $syslog_priority, (" Los permisos binarios que obtengo para colec id ----$_[0]---- valen ----$default_privileges_collection----");
			my $nombre_permisos_defecto = permisosbin_a_nombre($default_privileges_collection);
			return($nombre_permisos_defecto);
		}
	}
	else
	{
		syslog $syslog_priority, " La colecc ----$_[0]---- no tiene permisos por defecto de lectura o lectura-escritura" if ($verbose==1);
		return($error_general);
	}
}

sub sacar_permisos_de_principalconcreto_en_colecciones {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	## Se quotea el valor del ID de principal para el que sacar permisos externos en otras principals. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT to_principal,privileges FROM grants WHERE by_collection = "."$entfuncq"." AND to_principal = "."$entfuncq2".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @array_coles_permisos = ();
	my $contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$array_coles_permisos[$contador][0] = $row[0];
		$array_coles_permisos[$contador][1] = $row[1];
		$contador = $contador + 1;
	}

	syslog $syslog_priority, "El ID de principal ---$_[0]--- tiene los siguientes permisos de array_coles_permisos--- en coleccion ---$_[0]--" if ($verbose==1);
	return(@array_coles_permisos);
}

sub existen_perm_defecto_princ {
	my $stmt = "SELECT default_privileges FROM dav_principal WHERE (default_privileges = '".$perm_read."' OR default_privileges = '".$perm_readwrite."') AND principal_id = '".$_[0]."' LIMIT 1;";
	syslog $syslog_priority, "  Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my $default_privileges_principal = '9987982389';
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	@row = $sth->fetchrow_array();
	$default_privileges_principal = $row[0];

	if (defined($default_privileges_principal))
	{
		if (($default_privileges_principal != '9987982389') && ($default_privileges_principal ne ''))
		{
			syslog $syslog_priority, (" Los permisos binarios que obtengo para principal id ----$_[0]---- valen ----$default_privileges_principal----");
			my $nombre_permisos_defecto = permisosbin_a_nombre($default_privileges_principal);
			return($nombre_permisos_defecto);
		}
	}
	else
	{
		syslog $syslog_priority, " El principal ----$_[0]---- NO tiene permisos por defecto de lectura o lectura-escritura" if ($verbose==1);
		return($error_general);
	}
}

sub sacar_permisos_externos_principal_en_coleccion {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de principal para el que sacar permisos externos en otras colecciones. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT by_collection,privileges FROM grants WHERE to_principal = "."$entfuncq"." AND by_collection IS NOT NULL;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @array_coles_permisos = ();
	my $contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$array_coles_permisos[$contador][0] = $row[0];
		$array_coles_permisos[$contador][1] = $row[1];
		$contador = $contador + 1;
	}

	return(@array_coles_permisos);
}

sub sacar_permisos_de_NOprincipal_en_colecciones {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	## Se quotea el valor del ID de principal para el que sacar permisos externos en otras principals. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT to_principal,privileges FROM grants WHERE by_collection = "."$entfuncq"." AND to_principal != "."$entfuncq2".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @array_coles_permisos = ();
	my $contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$array_coles_permisos[$contador][0] = $row[0];
		$array_coles_permisos[$contador][1] = $row[1];
		$contador = $contador + 1;
	}

	syslog $syslog_priority, "El ID de principal ---$_[0]--- tiene los siguientes permisos en otras colecciones ---@array_coles_permisos---" if ($verbose==1);
	return(@array_coles_permisos);
}

sub sacar_permisos_de_principal_en_colecciones {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de principal para el que sacar permisos externos en otras principals. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT to_principal,privileges FROM grants WHERE by_collection = "."$entfuncq"." AND to_principal IS NOT NULL;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @array_coles_permisos = ();
	my $contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$array_coles_permisos[$contador][0] = $row[0];
		$array_coles_permisos[$contador][1] = $row[1];
		$contador = $contador + 1;
	}

	syslog $syslog_priority, "El ID de principal ---$_[0]--- tiene los siguientes permisos en otras colecciones ---@array_coles_permisos---" if ($verbose==1);
	return(@array_coles_permisos);
}

sub sacar_permisos_de_principals_en_principal {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	## Se quotea el valor del ID de principal para el que sacar permisos externos en otras principals. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT to_principal,privileges FROM grants WHERE by_principal = "."$entfuncq"." AND privileges != '000000000000000000000000';";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @array_princs_permisos = ();
	my $contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$array_princs_permisos[$contador][0] = $row[0];
		$array_princs_permisos[$contador][1] = $row[1];
		$contador = $contador + 1;
	}

	syslog $syslog_priority, "Devolvemos si hay mas principals con permisos sobre otro principal" if ($verbose==1);
	return(@array_princs_permisos);
}

sub sacar_grupos_de_propietario {
	my $entfuncqtemp = $_[0].'%';
	## Se quotea el valor del ID de usuario propietario del que saber que grupos tiene. Todos los grupos empiezan con ID de usuario propietario + nombre de grupo. Nos pasan ID de propietario al llamar a la funcion
	my $entfuncq = $dbh->quote($entfuncqtemp);
	my $stmt = "SELECT username FROM dav_principal WHERE username like "."$entfuncq"." AND type_id = 3;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @array_grupos_prop = ();
	my $contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$array_grupos_prop[$contador] = $row[0];
		$contador = $contador + 1;
	}

	syslog $syslog_priority, "El usuario ID ---$_[0]--- es propietario de los grupos ---@array_grupos_prop---" if ($verbose==1);
	return(@array_grupos_prop);
}

sub sacar_listado_usuarios_davical {
	## Se quotea el valor del ID de usuario propietario del que saber que grupos tiene. Todos los grupos empiezan con ID de usuario propietario + nombre de grupo. Nos pasan ID de propietario al llamar a la funcion
	my $stmt = "SELECT username FROM dav_principal WHERE type_id = 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @listado_usuarios_davical = ();
	my $contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$listado_usuarios_davical[$contador] = $row[0];
		$contador = $contador + 1;
	}

	return(@listado_usuarios_davical);
}

sub grupo_conpermisos_asignados {
	## MIRAMOS SI EL ID DE PRINCIPAL DEL GRUPO TIENE MAS PERMISOS ASOCIADOS PARA SABER SI UN GRUPO SE PUEDE BORRAR O NO.....
	my $entfuncq = $dbh->quote($_[0]);
	my $stmt = "SELECT to_principal FROM grants WHERE to_principal = "."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare($stmt);
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	my @listado_usuarios_davical = ();
	my $contador = 0;
	if($rv < 0){
		print $DBI::errstr;
		die("Fallo en acceso a BBDD. CONTACTE CON SARENET.");
	}

	while(@row = $sth->fetchrow_array()) {
		$listado_usuarios_davical[$contador] = $row[0];
		$contador = $contador + 1;
	}

	return(@listado_usuarios_davical);
}

sub coleccion_es_libreta_o_agenda {
	my $tipocole = 0;
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de la coleccion de la que saber de QUE tipo es. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT is_addressbook FROM collection WHERE collection_id = "."$entfuncq"." LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	if($rv < 0){
		print $DBI::errstr;
	}
	@row = $sth->fetchrow_array();
	$tipocole = $row[0];

	if (scalar(@row) > 0)
	{
		syslog $syslog_priority, "El tipo de coleccion para el ID de coleccion ---$_[0]--- es ---$tipocole---" if ($verbose==1);
		return($tipocole);
	}
	else
	{
		syslog $syslog_priority, "El tipo de coleccion para el ID de coleccion ---$_[0]--- es ---ERROR 9987982389---" if ($verbose==1);
		return($error_general);
	}
}

sub permisosbin_a_nombre{
	my $permnombre = 'NONE';
	switch ($_[0]) {
			case '000000001111111111111111'	{ $permnombre = 'ALL'; }
			case '000000001111111011100111'	{ $permnombre = 'READWRITE' }
			case '000000000001001000100001'	{ $permnombre = 'READ' }
			case '000000001111111000100001'	{ $permnombre = 'READSCHED' }
			case '000000000001001000000000'	{ $permnombre = 'FREEBUSY' }
			case '000000000001110000000000'	{ $permnombre = 'SCHEDLIV' }
			case '000000001110000000000000'	{ $permnombre = 'SCHEDSEND' }
			case '000000000000000000000000'	{ $permnombre = 'NONE' }
			else { $permnombre = '9987982389' }
		}
	return($permnombre);
}

sub permnombre_a_permbin{
	my $permbin = '000000000000000000000000';
	switch ($_[0]) {
			case 'ALL'		{ $permbin = $perm_all }
			case 'READWRITE'	{ $permbin = $perm_readwrite }
			case 'READ'		{ $permbin = $perm_read }
			case 'READSCHED'	{ $permbin = $perm_readsched }
			case 'FREEBUSY'		{ $permbin = $perm_freebusy }
			case 'SCHEDLIV'		{ $permbin = $perm_schedliv }
			case 'SCHEDSEND'	{ $permbin = $perm_schedsend }
			case 'NONE'		{ $permbin = $perm_none }
			else { $permbin = '9987982389' }
		}
	return($permbin);
}

sub sacar_colecc_permisos_usuario {
	my $userid = sacar_userid($_[0]);
	my $mensaje_fallo_gen = 'ERROR GRAVE : Intento de sacar permisos en colecciones para usuario --$_[0]-- inexistente';
	comprobar_error_variable($userid, $mensaje_fallo_gen);
	my $usuario_poner = "";
	my $grupoquetoca = "";
	my @permisosgrupoquetoca = ();
	my $colecquetoca = ();
	my @array_url_tipo_permisos = ();
	my $linea_array_url_tipo_permisos = "";
	my $contador = 0;
	my $dominioloc = $dominio;
	$dominioloc =~ s/\.//g;
	$dominioloc =~ s/-//g;
	my $idcolecc = 0;
	my $colec_nombre = "";
	my $colec_perm = "";
	my $tipo_colecc = 0;
	my $useridcolecc = 0;

	my @colec_prop_usuario = sacar_colecciones_usuario($userid);
	comprobar_existencia_colecciones_por_defecto($userid);

	my $principalid = sacar_principalid($userid);
	$mensaje_fallo_gen = 'ERROR GRAVE: Hemos obtenido un usuario --$_[0]-- por valido que no tiene ID de principal';
	comprobar_error_variable($principalid, $mensaje_fallo_gen);

	## SACAR ACCESOS POR PERMISO POR DEFECTO
	my @permisos_usuario_privilegios_defecto = sacar_permisos_acceso_autorizados_defecto();

	## SACAR PERMISOS POR SI MISMO
	my @permisos_usuario_comotal = sacar_permisos_externos_principal_en_coleccion($principalid);

	my @permisos_usuario_comogrupos = ();
	my @grupos_usuario = saca_grupos_usuario($principalid);

	## SACAR PERMISOS DE LOS GRUPOS
	foreach $grupoquetoca (@grupos_usuario) {
		@permisosgrupoquetoca = sacar_permisos_externos_principal_en_coleccion($grupoquetoca);
		push(@permisos_usuario_comogrupos, @permisosgrupoquetoca);
		@permisosgrupoquetoca = ();
	}

	## PINTAR POSIBILIDADES ACCESO POR PRINCIPAL LOCAL
	$usuario_poner = sacar_username_deidusu($userid);

	foreach $colecquetoca (@colec_prop_usuario) {
		$array_url_tipo_permisos[$contador][0] = 'https://'.$dominioloc.'.organizer.sarenet.es/caldav.php/'.$usuario_poner.'/'.@$colecquetoca[0].'/';
		$array_url_tipo_permisos[$contador][1] = 'READWRITE';
		$tipo_colecc = coleccion_es_libreta_o_agenda(@$colecquetoca[2]);
		$mensaje_fallo_gen = 'ERROR GRAVE : La coleccion --$colecquetoca-- no es calendario o libreta de direcciones';
		comprobar_error_variable($tipo_colecc, $mensaje_fallo_gen);
		$array_url_tipo_permisos[$contador][2] = $tipo_colecc;
		$contador = $contador + 1;
	}

	$colecquetoca = ();

	## PINTAR POSIBILIDADES ACCESO EXTERNOS SIN ESTAR EN GRUPO
	foreach $colecquetoca (@permisos_usuario_comotal) {
		$colec_nombre = sacar_nombre_id_colecc(@$colecquetoca[0]);
		$mensaje_fallo_gen = 'ERROR GRAVE : No puedo obtener el nombre de coleccion a partir del id ---@$colecquetoca[0]---';
		comprobar_error_variable_texto($colec_nombre, $mensaje_fallo_gen);
		$mensaje_fallo_gen = 'ERROR GRAVE : No puedo obtener el nombre de usuario para la URL de la coleccion ---$colec_nombre---';
		comprobar_error_variable_texto($usuario_poner, $mensaje_fallo_gen);
		$array_url_tipo_permisos[$contador][0] = 'https://'.$dominioloc.'.organizer.sarenet.es/caldav.php'.$colec_nombre;
		$colec_perm = permisosbin_a_nombre(@$colecquetoca[1]);
		$mensaje_fallo_gen = 'ERROR GRAVE : Para la coleccion --$colecquetoca-- no hemos obtenido un valor normal de nombre de permisos';
		comprobar_error_variable_texto($colec_perm, $mensaje_fallo_gen);
		$tipo_colecc = coleccion_es_libreta_o_agenda(@$colecquetoca[0]);
		$mensaje_fallo_gen = 'ERROR GRAVE : La coleccion --$colecquetoca-- no es calendario o libreta de direcciones';
		comprobar_error_variable($tipo_colecc, $mensaje_fallo_gen);
		$array_url_tipo_permisos[$contador][1] = $colec_perm;
		$array_url_tipo_permisos[$contador][2] = $tipo_colecc;
		$contador = $contador + 1;
	}

	$colecquetoca = ();

	## PINTAR POSIBILIDADES ACCESO POR GRUPO
	foreach $colecquetoca (@permisos_usuario_comogrupos) {
		$colec_nombre = sacar_nombre_id_colecc(@$colecquetoca[0]);
		$mensaje_fallo_gen = 'ERROR GRAVE : No puedo obtener el nombre de coleccion a partir del id ---@$colecquetoca[0]---';
		comprobar_error_variable_texto($colec_nombre, $mensaje_fallo_gen);
		$mensaje_fallo_gen = 'ERROR GRAVE : No puedo obtener el nombre de usuario para la URL de la coleccion ---$colec_nombre---';
		comprobar_error_variable_texto($usuario_poner, $mensaje_fallo_gen);
		$array_url_tipo_permisos[$contador][0] = 'https://'.$dominioloc.'.organizer.sarenet.es/caldav.php'.$colec_nombre;
		$colec_perm = permisosbin_a_nombre(@$colecquetoca[1]);
		$mensaje_fallo_gen = 'ERROR GRAVE : Para la coleccion --$colecquetoca-- no hemos obtenido un valor normal de nombre de permisos';
		comprobar_error_variable_texto($colec_perm, $mensaje_fallo_gen);
		$tipo_colecc = coleccion_es_libreta_o_agenda(@$colecquetoca[0]);
		$mensaje_fallo_gen = 'ERROR GRAVE : La coleccion --$colecquetoca-- no es calendario o libreta de direcciones';
		comprobar_error_variable($tipo_colecc, $mensaje_fallo_gen);
		$array_url_tipo_permisos[$contador][1] = $colec_perm;
		$array_url_tipo_permisos[$contador][2] = $tipo_colecc;
		$contador = $contador + 1;
	}

	$contador = 0;

	## ANADO PERMISOS CONCEDIDOS POR PRIVILEGIOS POR DEFECTO
	push(@array_url_tipo_permisos,@permisos_usuario_privilegios_defecto);

	## POR ULTIMO COMPRUEBO NO DAR RESULTADOS DUPLICADOS Y POR ELLO POSIBLE QUE CON DIFERENTES PERMISOS
	my $linea_array_url_tipo_permisos_resumen = "";
	my $cuenta_repeticiones = '0';
	my $permisos_escritura = '0';
	my $permisos_lectura = '0';
	my @array_cuentas_repetidas = ();
	foreach $linea_array_url_tipo_permisos (@array_url_tipo_permisos)
	{
		$cuenta_repeticiones = 0;
		$permisos_escritura = 0;
		$permisos_lectura = 0;

		foreach $linea_array_url_tipo_permisos_resumen (@array_url_tipo_permisos)
		{
			if (@$linea_array_url_tipo_permisos[0] eq @$linea_array_url_tipo_permisos_resumen[0])
			{
				$cuenta_repeticiones = $cuenta_repeticiones + 1;
				if (@$linea_array_url_tipo_permisos[1] eq "READWRITE")
				{
					$permisos_escritura = '1';
				}
				elsif (@$linea_array_url_tipo_permisos[1] eq "READ")
				{
					$permisos_lectura = '1';
				}

			}
		}

		if ($cuenta_repeticiones > '1')
		{
			if (!grep { @$linea_array_url_tipo_permisos[0] eq $_ } @array_cuentas_repetidas)
			{
				syslog $syslog_priority, "AAAA";
				push(@array_cuentas_repetidas,@$linea_array_url_tipo_permisos[0]);
				if ($permisos_escritura eq '1')
				{
					syslog $syslog_priority, "Para el usuario ---$_[0]--- sacamos que tiene acceso a : @$linea_array_url_tipo_permisos[0]|@$linea_array_url_tipo_permisos[1]|@$linea_array_url_tipo_permisos[2]|" if ($verbose==1);
					print ("@$linea_array_url_tipo_permisos[0]|READWRITE|@$linea_array_url_tipo_permisos[2]|\n");
				}
				elsif ($permisos_lectura eq '1')
				{
					syslog $syslog_priority, "Para el usuario ---$_[0]--- sacamos que tiene acceso a : @$linea_array_url_tipo_permisos[0]|@$linea_array_url_tipo_permisos[1]|@$linea_array_url_tipo_permisos[2]|" if ($verbose==1);
					print ("@$linea_array_url_tipo_permisos[0]|READ|@$linea_array_url_tipo_permisos[2]|\n");
				}
			}
			else
			{
				syslog $syslog_priority, "Evitando repetir ---@$linea_array_url_tipo_permisos[0]--- al citar colecciones con permisos" if ($verbose==1);
				next;
			}
		}
		elsif ($cuenta_repeticiones eq '1')
		{
			syslog $syslog_priority, "Para el usuario ---$_[0]--- sacamos que tiene acceso a : @$linea_array_url_tipo_permisos[0]|@$linea_array_url_tipo_permisos[1]|@$linea_array_url_tipo_permisos[2]|" if ($verbose==1);
			print ("@$linea_array_url_tipo_permisos[0]|@$linea_array_url_tipo_permisos[1]|@$linea_array_url_tipo_permisos[2]|\n");
		}
	}
}

sub sacar_ids_colecc_usuario {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de usuario del que obtener los ID de coleccion. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT collection_id FROM collection WHERE user_no = "."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my @id_col = ();
	my $contador = 0;
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	if($rv < 0){
		print $DBI::errstr;
	}

	while(@row = $sth->fetchrow_array()) {
	$id_col[$contador] = $row[0];
	$contador = $contador + 1;
	}

	if (scalar(@id_col) > 0)
	{
		syslog $syslog_priority, "El ID de usuario ---$_[0]--- tiene las colecciones ---@id_col---" if ($verbose==1);
		return(@id_col);
	}
	else
	{
		syslog $syslog_priority, "El ID de usuario ---$_[0]--- tiene las colecciones ---ERROR 9987982389---" if ($verbose==1);
		@id_col = ('9987982389');
		return(@id_col);
	}
}

sub sacar_id_coledavname {
	my $coleasacarid = '/'.$_[0].'/'.$_[1].'/';
	my $entfuncq = $dbh->quote($coleasacarid);
	## Se quotea el valor del ID de usuario del que obtener los ID de coleccion. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT collection_id FROM collection WHERE dav_name = "."$entfuncq"." LIMIT 1;";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my @id_col = ();
	my $contador = 0;
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	if($rv < 0){
		print $DBI::errstr;
	}

	if (@row = $sth->fetchrow_array())
	{
		$id_col[$contador] = $row[0];
	}

	if (scalar(@id_col) > 0)
	{
		syslog $syslog_priority, "El ID de cole que tiene el DAV_NAME ---$_[0]--- es ---$row[0]---" if ($verbose==1);
		return($row[0]);
	}
	else
	{
		syslog $syslog_priority, "FALLO -- El ID de cole que tiene el DAV_NAME ---$coleasacarid--- es ---$row[0]---" if ($verbose==1);
		@id_col = ('9987982389');
		return($error_general);
	}
}

sub usuario_ya_tiene_coleccion {
	my @colecciones_usuario = @{$_[0]};
	my $coleccion_comprobar = $_[1];

	if (grep(/^$coleccion_comprobar$/, @colecciones_usuario))
	{
		return 1;
	}
	else
	{
		return 0;
	}
}

sub crear_coleccion {
	## Se quotea el valor de username, descripcion, tipo de coleccion para dar de alta una nueva. Nos lo pasan al llamar a la funcion
	my $usuarioid = sacar_userid($_[0]);
	comprobar_error_variable($usuarioid, 'ERROR GRAVE : Pidiendo crear coleccion para un ---$usuario--- inexistente.');
	my $entfuncq = $dbh->quote($usuarioid);
	my $entfuncq3 = $dbh->quote($_[2]);
	my $entfuncq4 = $dbh->quote($_[3]);
	my $tempentfunc5 = '/'.$_[0].'/';
	my $tempentfunc52 = '/'.$_[0].'/'.$_[1].'/';
	my $entfuncq52 = $dbh->quote($tempentfunc52);
	my $entfuncq5 = $dbh->quote($tempentfunc5);
	my $escaloag = $_[3];
	my $stmt = "";

	if ($escaloag == 0)
	{
	$stmt = "INSERT INTO collection (user_no, parent_container, dav_name, dav_displayname, is_calendar, publicly_readable, default_privileges, is_addressbook, resourcetypes, schedule_transp, description) VALUES( "."$entfuncq".", "."$entfuncq5".","."$entfuncq52".", "."$entfuncq3".", TRUE, FALSE, NULL, FALSE, '<DAV::collection/><urn:ietf:params:xml:ns:caldav:calendar/>', 'opaque', '' )";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	}
	else
	{
	$stmt = "INSERT INTO collection (user_no, parent_container, dav_name, dav_displayname, is_calendar, publicly_readable, default_privileges, is_addressbook, resourcetypes, schedule_transp, description) VALUES( "."$entfuncq".", "."$entfuncq5".","."$entfuncq52".", "."$entfuncq3".", FALSE, FALSE, NULL, TRUE, '<DAV::collection/><urn:ietf:params:xml:ns:carddav:addressbook/>', 'opaque', '' )";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	}
	my $rv = $dbh->do($stmt) or die $DBI::errstr;
}

sub borrar_coleccion {
	my $coleaborrar = '/'.$_[0].'/'.$_[1].'/';
	## Se quotea el valor del username propietario de la coleccion y la coleccion a borrar. Vamos, el nombre completo de la coleccion. Nos lo pasan al llamar a la funcion
	my $entfuncq = $dbh->quote($coleaborrar);
	my $stmt = "";

	$stmt = "DELETE FROM collection WHERE dav_name="."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $rv = $dbh->do($stmt) or die $DBI::errstr;
	if( $rv < 0 ) {
		print $DBI::errstr;
	} else {
		syslog $syslog_priority, "La consulta ---$stmt---- devuelve ----Total number of rows deleted : $rv-----" if ($verbose==1);
	}
}

sub borrar_de_grupo {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	my $stmt = "";
	## Se quotea el valor del ID de grupo y ID de miembro que borrar del grupo del ID. Nos lo pasan al llamar a la funcion
	$stmt = "DELETE FROM group_member WHERE group_id="."$entfuncq"." AND member_id="."$entfuncq2".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $rv = $dbh->do($stmt) or die $DBI::errstr;
	if( $rv < 0 ){
		print $DBI::errstr;
	} else {
		syslog $syslog_priority, "La consulta ---$stmt---- devuelve ----Total number of rows deleted : $rv-----" if ($verbose==1);
	}
}

sub anadir_a_grupo {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	## Se quotea el valor del ID de grupo y ID de miembro que anadir al grupo del ID. Nos lo pasan al llamar a la funcion
	my $stmt = "INSERT INTO group_member (group_id, member_id) VALUES ("."$entfuncq".", "."$entfuncq2".");";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $rv = $dbh->do($stmt) or die $DBI::errstr;
}

sub crear_grupo {
	## Se quotea el valor de username, Nombre completo y email del grupo que se va a crear. Ademas los valores del nombre de grupo se forman con IDusuariopropietario + grupo. Nos lo pasan al llamar a la funcion
	my $tempentfuncq = $_[1].$_[0];
	my $entfuncq = $dbh->quote($tempentfuncq);

	my $tempentfuncq2 = $_[1].$_[0].'@'.$_[2];
	my $entfuncq2 = $dbh->quote($tempentfuncq2);

	my $stmt = "INSERT INTO dav_principal (user_active, username, password, fullname, email, date_format_type, locale, type_id, displayname, default_privileges) VALUES( TRUE, "."$entfuncq".", \'\', "."$entfuncq2".", "."$entfuncq2".", 'E', '', 3, "."$entfuncq".", '000000001111111000100000' );";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);

	my $rv = $dbh->do($stmt) or die $DBI::errstr;
}

sub elimina_principal{
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de principal que dar de baja. Nos lo pasan al llamar a la funcion
	my $stmt = "DELETE FROM dav_principal WHERE principal_id="."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $rv = $dbh->do($stmt) or die $DBI::errstr;
}

sub elimina_grupo{
	my $id_principal = $_[0];
	## Se quota el valor del id de principal del grupo a eliminar. Nos lo pasan al llamar a la funcion.
	syslog $syslog_priority, "Dando de baja grupo que tiene por ID de principal ---$_[0]---" if ($verbose==1);
	elimina_principal($id_principal);
}

sub elimina_usuario{
	my $id_principal = $_[0];
	## Se quota el valor del id de principal del usuario a eliminar. Nos lo pasan al llamar a la funcion.
	syslog $syslog_priority, "Dando de baja usuario que tiene por ID de principal ---$_[0]---" if ($verbose==1);
	elimina_principal($id_principal);
}

sub sacaid_princ_grupo {
	my $id_usuario = 0;
	my $id_principal = 0;
	my $tipo_principal = "9987982389";

	## Se quotea el valor del username del principal tipo grupo del que queremos sacar el principal ID. Nos lo pasan al llamar a la funcion.

	$id_usuario = sacar_userid($_[0]);
	$mensaje_fallo_gen = 'ERROR GRAVE : Intentando obtener id de principal para grupo ---$_[0]--- inexistente';
	comprobar_error_variable($id_usuario, $mensaje_fallo_gen);

	if ($id_usuario != 0)
	{
		$tipo_principal = sacar_tipo_principal($id_usuario);
		$mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener tipo de principal para ---$_[0]--- con ID Usuario --$id_usuario-- inexistente';
		comprobar_error_variable_texto($tipo_principal, $mensaje_fallo_gen);

		if ($tipo_principal eq "Group")
		{
				$id_principal = sacar_principalid($id_usuario);
				syslog $syslog_priority, "El grupo que tiene por usuario ---$_[0]--- tiene por id de principal ---$id_principal---" if ($verbose==1);
				return($id_principal);
		}
		else
		{
				syslog $syslog_priority, "El grupo que tiene por usuario ---$_[0]--- tiene por id de principal ---ERROR 9987982389---" if ($verbose==1);
				return($error_general);
		}
	}
	else
	{
		syslog $syslog_priority, "Fallo al obtener id de principal para el grupo que tiene por usuario ---$_[0]--- por no poderse sacar id de usuario ---ERROR 9987982389---" if ($verbose==1);
		return($error_general);
	}
}

sub saca_grupos_usuario {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quota el valor del id de usuario del que queremos sacar que grupos tiene o de los que el usuario que nos pasan es propietario. Nos lo pasan al llamar a la funcion.

	my $stmt = "SELECT group_id FROM group_member WHERE member_id = "."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my @id_grupos = ();
	my $contador = 0;
	my $ids_grupos_sacados = "";
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	if($rv < 0){
		print $DBI::errstr;
		die ("Error de acceso a BBDD");
	}

	while(@row = $sth->fetchrow_array()) {
	$id_grupos[$contador] = $row[0];
	$contador = $contador + 1;
	$ids_grupos_sacados = $ids_grupos_sacados." $row[0]";
	}

	syslog $syslog_priority, "El ID de usuario ---$_[0]--- tiene los grupos ---$ids_grupos_sacados---" if ($verbose==1);
	return(@id_grupos);
}

sub saca_usuarios_grupo {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de grupo del que obtener que miembros tiene. Nos lo pasan al llamar a la funcion
	my $stmt = "SELECT member_id FROM group_member WHERE group_id = "."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $sth = $dbh->prepare( $stmt );
	my @id_usu = ();
	my $contador = 0;
	my $rv = $sth->execute() or die $DBI::errstr;
	my @row = ();
	if($rv < 0){
		print $DBI::errstr;
		die ("Error de acceso a BBDD");
	}

	while(@row = $sth->fetchrow_array()) {
	$id_usu[$contador] = $row[0];
	$contador = $contador + 1;
	}

	syslog $syslog_priority, "El ID de grupo ---$_[0]--- tiene los id de miembros ---@id_usu---" if ($verbose==1);
	return(@id_usu);
}

sub existe_usuario_en_grupo {
	my $id_usuario = 0;
	my $id_grupo = 0;
	my $id_principal = 0;
	my $respuesta = 0;
	my $respuesta2 = 0;
	$respuesta = existe_usuario($usuario);
	$respuesta2 = existe_usuario($grupo);
	if (($respuesta != 1) || ($respuesta2 != 1))
	{
		func_remplazo_die("No existe el usuario o grupo");
	}

	$id_usuario = sacar_userid($usuario);
	$mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener id de usuario para ---$usuario---';
	comprobar_error_variable($id_usuario, $mensaje_fallo_gen);
	$id_grupo = sacar_userid($grupo);
	$mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener id de grupo para ---$grupo---';
	comprobar_error_variable($id_grupo, $mensaje_fallo_gen);

	syslog $syslog_priority, "El id_usuario vale ---$id_usuario---. El id_usuario que nos pasan a la func vale ---$_[1]---" if ($verbose==1);
	syslog $syslog_priority, "El id_grupo vale ---$id_grupo---. El id_grupo que nos pasan a la func vale ---$_[0]---" if ($verbose==1);

	my $id_principal_origen = sacar_principalid($id_usuario);
	$mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener id de principal para ---$usuario--- con id de usuario ---$id_usuario---';
	comprobar_error_variable($id_principal_origen, $mensaje_fallo_gen);
	my $id_principal_grupo = sacaid_princ_grupo($grupo);
	my $mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener id de principal para ---$grupo--- con id de grupo ---$id_grupo---';
	comprobar_error_variable($id_principal_grupo, $mensaje_fallo_gen);
	my $entfuncq = $dbh->quote($id_principal_origen);
	my $entfuncq2 = $dbh->quote($id_principal_grupo);

	if (($id_principal_grupo != 0) && ($id_principal_origen != 0))
	{

		my $stmt = "SELECT group_id,member_id from group_member where group_id="."$entfuncq2"." and member_id="."$entfuncq"." LIMIT 1;";
		syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
		my $sth = $dbh->prepare( $stmt );
		my $rv = $sth->execute() or die $DBI::errstr;
		my @row = ();
		if($rv < 0){
			print $DBI::errstr;
		}
		if (@row = $sth->fetchrow_array())
		{
			syslog $syslog_priority, "El usuario $usuario existe en grupo $grupo. Devolvemos 1." if ($verbose==1);
			return (1);
		}
		else
		{
			syslog $syslog_priority, "El usuario $usuario NO existe en grupo $grupo. Devolvemos 0." if ($verbose==1);
			return (0);
		}
	}
	else
	{
		syslog $syslog_priority, "El usuario $usuario o grupo $grupo no existen. Devolvemos ERROR 9987982389." if ($verbose==1);
		return($error_general);
	}
}

sub existe_usuario {
	my $id_usuario = 0;
	my $id_principal = 0;
	$id_usuario = sacar_userid($_[0]);
	## Se quota el valor del username de quien comprobar su existencia. Nos lo pasan al llamar a la funcion.

	if ($id_usuario != '9987982389')
	{
		syslog $syslog_priority, "El usuario ---$_[0]--- existe. El ID de usuario es ---$id_usuario----" if ($verbose==1);
		return(1);
	}
	else
	{
		syslog $syslog_priority, "El usuario ---$_[0]--- NO existe. El ID de usuario es ---ERROR 9987982389----" if ($verbose==1);
		return(0);
	}
}

sub fijar_permisos_defect_col {
	my $entfuncq = $dbh->quote($_[0]);
	## Se quotea el valor del ID de coleccion sobre la que aplicar los permisos que nos digan. Nos pasan ambas cosas al llamar la funcion.

	my $stmt = "";
	my $permbin = $perm_none;

	if ($_[1] eq "defecto")
	{
		$stmt = "UPDATE collection SET default_privileges = NULL WHERE collection_id="."$entfuncq".";";
		syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	}
	else
	{
		my $perm = $_[1];
		my $permbin = permnombre_a_permbin($perm);
		$mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener permisos binarios para nombre ---$perm---';
		comprobar_error_variable_texto($permbin, $mensaje_fallo_gen);
		my $entfuncq2 = $dbh->quote($permbin);
		$stmt = "UPDATE collection SET default_privileges = "."$entfuncq2"." WHERE collection_id="."$entfuncq".";";
		syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	}

	my $rv = $dbh->do($stmt) or die $DBI::errstr;
	if ($rv < 0) {
		print $DBI::errstr;
		die ("Error de acceso a BBDD");
	} else {
		syslog $syslog_priority, "La consulta ---$stmt---- devuelve ----Total number of rows modified : $rv-----" if ($verbose==1);
	}
}

sub fijar_permisos_defect_princ {
	my $principal_id = $_[0];
	my $perm = $_[1];
	my $entfuncq = $dbh->quote($_[0]);
	## Se quota el valor del id de principal al que aplicar los permisos que nos digan. Nos los pasan al llamar a la funcion.

	my $stmt = "";
	my $permbin = $perm_none;

	if ($_[1] eq "defecto")
	{
		$stmt = "UPDATE dav_principal SET default_privileges = '000000001111111000100000' WHERE principal_id="."$entfuncq".";";
		syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	}
	else
	{
		$permbin = permnombre_a_permbin($perm);
		my $entfuncq2 = $dbh->quote($permbin);
		$mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener permisos binarios para nombre ---$perm---';
		comprobar_error_variable_texto($permbin, $mensaje_fallo_gen);
		$stmt = "UPDATE dav_principal SET default_privileges = "."$entfuncq2"." WHERE principal_id="."$entfuncq".";";
		syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	}

	my $rv = $dbh->do($stmt) or die $DBI::errstr;
	if ($rv < 0) {
		print $DBI::errstr;
		die ("Error de acceso a BBDD");
	} else {
		syslog $syslog_priority, "La consulta ---$stmt---- devuelve ----Total number of rows modified : $rv-----" if ($verbose==1);
	}
}


sub anadir_permisos_principal_a_principal {
	## Se quota el valor del id de principal al que darle permisos en el principal X. Ademas nos dicen que permisos. Nos lo pasan al llamar a la funcion.
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	my $perm = $_[2];
	## AHORA COMPRUEBO SI YA ESTA ASI
	my $existencia_permisos_ya = comprobar_existencia_permisos(0,$_[2],$_[0],$_[1]);

	if ($existencia_permisos_ya != $error_general)
	{
		my $permbin = $perm_none;
		$permbin = permnombre_a_permbin($perm);
		$mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener permisos binarios para nombre ---$perm---';
		comprobar_error_variable_texto($permbin, $mensaje_fallo_gen);
		my $entfuncq3 = $dbh->quote($permbin);

		my $stmt = "INSERT INTO grants (by_principal, to_principal, privileges) VALUES( "."$entfuncq2".", "."$entfuncq".", "."$entfuncq3".");";
		syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
		my $rv = $dbh->do($stmt) or die $DBI::errstr;

	}
	else
	{
		syslog $syslog_priority, "No aplicando permisos ya aplicados." if ($verbose==1);
	}
}

sub eliminar_permisos_principal_a_principal {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	## Se quota el valor del id de principal al que quitarle permisos en el principal X. Nos lo pasan al llamar a la funcion.

	my $stmt = "DELETE FROM grants WHERE by_principal="."$entfuncq2"." AND to_principal="."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $rv = $dbh->do($stmt) or die $DBI::errstr;
}

sub anadir_permisos_principal_a_collection {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	my $perm = $_[2];
	my $permbin = permnombre_a_permbin($perm);
	$mensaje_fallo_gen = 'ERROR GRAVE : El valor binario de los permisos no es valido';
	comprobar_error_variable_texto($permbin, $mensaje_fallo_gen);

	## AHORA COMPRUEBO SI YA ESTA ASI
	my $existencia_permisos_ya = comprobar_existencia_permisos(1,$_[2],$_[0],$_[1]);
	if ($existencia_permisos_ya != $error_general)
	{
		my $entfuncq3 = $dbh->quote($permbin);
		## Se quota el valor del id de principal al que darle permisos en la coleccion X. Ademas nos dicen que permisos. Nos lo pasan al llamar a la funcion.
		my $stmt = "INSERT INTO grants (by_collection, to_principal, privileges) VALUES("."$entfuncq2".", "."$entfuncq".", "."$entfuncq3".");";
		my $rv = $dbh->do($stmt) or die $DBI::errstr;
		syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	}
	else
	{
		syslog $syslog_priority, "No aplicando permisos ya aplicados." if ($verbose==1);
	}
}

sub sacar_nombre_real_grupo {
	### PONEMOS EL NOMBRE DEL GRUPO REAL CON EL QUE TRABAJAMOS
	syslog $syslog_priority, "Recibimos por la llamada a la funcion el nombre de grupo ---$_[0]--- perteneciente al id de usuario ---$_[1]---" if ($verbose==1);
	my $existe_propietario = existe_usuario($_[1]);
	## NO HAGO COMPROBACION DE ERR CON NUMEROS RAROS PORQUE ESTOY TANTEANDO POSIBILIDADES PARA TIPO DE USUARIO ORIGEN ETC.... GRUPO NO GRUPO....
	my $dominioponeres = sacar_dominio_para_email($_[1]);
	$mensaje_fallo_gen = 'ERROR GRAVE : El dominio de email de ---$_[1]--- no es valido';
	comprobar_error_variable_texto($dominioponeres, $mensaje_fallo_gen);
	my $idusuariodequien = 9987982389;
	my $gruporesultante = "";
	if ($existe_propietario == 1)
	{
		$idusuariodequien = sacar_userid($_[1]);
		$mensaje_fallo_gen = 'ERROR GRAVE : Me sale que no existe el usuario ---$_[1]--- propietario del posible grupo ---$_[0]';
		comprobar_error_variable($idusuariodequien, $mensaje_fallo_gen);
		syslog $syslog_priority, "El propietario solicitado para el grupo existe y tiene por id de usuario ---$idusuariodequien---" if ($verbose==1);
		my $espersona = tipo_principal_es_persona($idusuariodequien);

		if ($espersona == 0)
		{
			$gruporesultante = $idusuariodequien.$_[0];
			syslog $syslog_priority, "El propietario solicitado para el grupo existe y tiene por id de usuario ---$idusuariodequien---. Ademas es persona y grupo resultante vale ---$gruporesultante---" if ($verbose==1);
		}
		else
		{
			syslog $syslog_priority, "El propietario solicitado para el grupo existe y tiene por id de usuario ---$idusuariodequien--- pero NO ES PERSONA" if ($verbose==1);
			func_remplazo_die("El supuesto propietario del grupo indicado ---$_[1]--- no puede serlo porque no es persona");
		}
	}
	else
	{
		syslog $syslog_priority, "No podemos formar nombre real de grupo porque no existe el propietario del mismo." if ($verbose==1);
		func_remplazo_die("No puedo formar el nombre real del grupo");
	}
	return($gruporesultante);
}

sub comprobar_si_pers_o_grupo_y_poner_nombre_grupo_bien {
	my $id_usuario_op = sacar_userid($_[0]);
	my $existe_como_usuario = existe_usuario($_[0]);
	my $espersona = tipo_principal_es_persona($id_usuario_op);

	if (($espersona != 0) && ($existe_como_usuario == 0) && ($dequien eq ""))
	{
		syslog $syslog_priority, "Pidiendo trabajar con algo que no es persona ----$usuario---- y sin poder formar grupo" if ($verbose==1);
		func_remplazo_die("Pidiendo trabajar con algo que no es persona ----$usuario---- y sin poder formar grupo");
	}

	if (($espersona == 0) && ($existe_como_usuario == 1) && ($dequien eq ""))
	{
		syslog $syslog_priority, "Devolviendo el username ---$usuario--- recibido porque es persona. No le doy mas vueltas." if ($verbose==1);
		return($_[0]);
	}


	if ($dequien ne "")
	{
		my $usuario_resultante = sacar_nombre_real_grupo($usuario,$dequien);
		my $existe_como_grupo = existe_usuario($usuario_resultante);
		if ($existe_como_grupo == 1)
		{
			syslog $syslog_priority, "Devolviendo el username ---$usuario_resultante--- despues de procesar y sacar el nombre del grupo." if ($verbose==1);
			return($usuario_resultante);
		}
		else
		{
			syslog $syslog_priority, "El ---$usuario_resultante--- despues de procesar y sacar el nombre del grupo tampoco existe." if ($verbose==1);
			func_remplazo_die("Tampoco existe como grupo....");
		}
	}
	else
	{
		syslog $syslog_priority, "No nos han pasado el propietario del grupo..." if ($verbose==1);
		func_remplazo_die("No tenemos propietario para grupo...");
	}
}

sub eliminar_permisos_principal_a_collection {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	## Se quota el valor del id de principal y coleccion sobre la que quitar permisos... Nos lo pasan al llamar a la funcion.
	my $stmt = "DELETE FROM grants WHERE by_collection="."$entfuncq2"." AND to_principal = "."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $rv = $dbh->do($stmt) or die $DBI::errstr;
}

sub actualiza_display_name {
	my $entfuncq = $dbh->quote($_[0]);
	my $entfuncq2 = $dbh->quote($_[1]);
	## Se quota el valor del id de principal y coleccion sobre la que quitar permisos... Nos lo pasan al llamar a la funcion.
	my $stmt = "UPDATE collection SET dav_displayname="."$entfuncq2"." WHERE collection_id="."$entfuncq".";";
	syslog $syslog_priority, "Logueando consulta para instancia Davical para dominio $dominio : ---$stmt----" if ($verbose==1);
	my $rv = $dbh->do($stmt) or die $DBI::errstr;
}

sub sacar_dominio_para_email {
	my @array_correo = split(/\@/,$_[0]);
	my $dominio = $array_correo[1];

	if ($dominio =~ /^((\w)+\.{1})+(\w)+$/)
	{
		syslog $syslog_priority, "Sacamos el ---$dominio--- del propietario ---$_[0]---" if ($verbose==1);
		return($dominio);
	}
	else
	{
		syslog $syslog_priority, "Rechazamos el ---$dominio--- del propietario ---$_[0]--- que tiene formato NO valido" if ($verbose==1);
		return($error_general);
	}
}

sub comprobar_existencia_colecciones_por_defecto {
	my @colec_usuario_op = sacar_colecciones_usuario($_[0]);

	my $colec_usu_opquetoca = "";
	my @colec_usu_pasar = ();

	foreach $colec_usu_opquetoca (@colec_usuario_op) {
		push(@colec_usu_pasar,@$colec_usu_opquetoca[0]);
	}

	my $comprobar_que_tiene_calendar = usuario_ya_tiene_coleccion(\@colec_usu_pasar,$colec_default_calendar);
	my $comprobar_que_tiene_addresses = usuario_ya_tiene_coleccion(\@colec_usu_pasar,$colec_default_addresses);

	if (($comprobar_que_tiene_calendar == 0) || ($comprobar_que_tiene_addresses == 0))
	{
		syslog $syslog_priority, "Para el usuario ---$usuario--- no existen las colecciones por defecto calendar o addresses";
	}
}

sub sacar_nombre_grupo_sin_userid {
	my $nombre_grupo_completo = $_[0];
	my $id_usuario_quitar = $_[1];
	$nombre_grupo_completo =~ s/$id_usuario_quitar//g;
	return($nombre_grupo_completo);
}

sub comprobar_permiso_ejecutar {
	my $pidpadre = getppid();
	$usercorriendo = `/usr/bin/whoami | /usr/bin/tr -d '\n'`;
	my $lineappid = `/bin/ps auxwww | grep '$usercorriendo' | grep '$pidpadre' | grep -v 'grep'`;
	syslog $syslog_priority, "La linea lineappid vale ----$lineappid------";
	my ($ppidname) = $lineappid =~ m/[0-9]+:{1}[0-9]+\.[0-9]+\s+(.*)\n$/;
	my ($ppidnameusernam) = $lineappid =~ m/^([a-zA-Z0-9]+)\s+[0-9]+\s+[0-9]+(\.{1}[0-9]+)*\s+/;
	syslog $syslog_priority, "El PID name del parent es ---$ppidname---- que corre como ----$ppidnameusernam---";

	if ($usercorriendo eq "root")
	{
		if (($usercorriendo eq $ppidnameusernam) && (($ppidname =~ m/gestiona_altasbajas\.pl/) || ($ppidname =~ m/csh/) || ($ppidname =~ m/gestiones-organizer-webmail-v011\.pl/)))
		{
			syslog $syslog_priority, "Adelante con la ejecucion con ---$usercorriendo--- llamado desde el usuario ---$ppidnameusernam--- y siendo el proceso padre ---$ppidname---";
		}
		else
		{
			die "UNEXPECTED GENERAL FAILURE";
			syslog $syslog_priority, "Abortamos ejecucion con ---$usercorriendo--- llamado desde el ---$ppidnameusernam--- y siendo el proceso padre ---$ppidname---";
		}
	}
	elsif ($usercorriendo eq "www")
	{
		if (($usercorriendo eq $ppidnameusernam) && ($ppidname =~ m/gestiones-organizer-webmail-v011\.pl/))
		{
			syslog $syslog_priority, "Adelante con la ejecucion con ---$usercorriendo--- llamado desde el usuario ---$ppidnameusernam--- y siendo el proceso padre ---$ppidname---";
		}
		else
		{
			die "UNEXPECTED GENERAL FAILURE";
			syslog $syslog_priority, "Abortamos ejecucion con ---$usercorriendo--- llamado desde el usuario ---$ppidnameusernam--- y siendo el proceso padre ---$ppidname---";
		}
	}
	else
	{
		die "UNEXPECTED GENERAL FAILURE";
		syslog $syslog_priority, "Abortamos ejecucion con ---$usercorriendo--- llamado desde el ---$ppidnameusernam--- y siendo el proceso padre ---$ppidname---";
	}
}

sub obtener_conexion_a_bbdd {
	syslog $syslog_priority, "El dominio vale --$dominio--";
	my $dominioloc = $dominio;
	$dominioloc =~ s/\.//g;
	$dominioloc =~ s/-//g;
	my $fichero = "/usr/local/etc/davical/".$dominioloc.".organizer.sarenet.es-conf.php";
	my $linea_conexion = "";
	my $linea_conexion_trabajo = "";
	if ($verbose == 1) { syslog $syslog_priority, ("El fichero vale ----$fichero-----"); }
	open FILE, "<", $fichero or die "No existe fichero $fichero";
	while (<FILE>) {
		if($_ =~ m/^\$c->pg_connect\[\] = \"host=([0-9]{1,3}\.{1}){3}([0-9]{1,3}){1} port=5432 dbname=[\w]+ user=[\w]+ password=[\w]+\";/i)
		{
		if ($verbose == 1) { syslog $syslog_priority, ("La linea de conexion vale ---$_----"); }
		$linea_conexion = $_;
		$linea_conexion =~ s/\s+$//;
		$linea_conexion_trabajo = $linea_conexion;
		$linea_conexion_trabajo =~ m/(\w+)=(\w+\.{1}\w+\.{1}\w+\.{1}\w+ )(\w+)=(\w+ )(\w+)=(\w+ )(\w+)=(\w+ )(\w+)=(\w+)/;
		if ($verbose == 1) { syslog $syslog_priority, "La linea de conexion trabajo vale ---$1--- ---$2--- ---$3--- ---$4--- ---$5--- ---$6--- ---$7--- ---$8--- ---$9--- ---$10---; El host vale : ---$2---; El port vale : ---$4---; La BBDD vale : ---$6---; El usuario vale : ---$8--- "};
		$host = $2;
		$database = $6;
		$dsn = "DBI:$driver:dbname=$database;host=$host;port=5432";
		$userid = $8;
		$password = $10;
		$host =~ s/^\s+|\s+$//g;
		$database =~ s/^\s+|\s+$//g;
		$userid =~ s/^\s+|\s+$//g;
		$password =~ s/^\s+|\s+$//g;
		last;
		}
	}
	close FILE;
	## VARIABLES DE CONEXION
	$dbh = DBI->connect($dsn, $userid, $password, { RaiseError => 1 })
		or die $DBI::errstr;
}

sub funcion_case_22 {
	my $princ_id_grupo_revisar = "";
	my @array_usuarios_grupo = ();
	my $id_princ_usuario = 998798238;
	my $id_usu_princ = 998798238;
	my $nombre_id_usu = "";
	my @array_nombres_grupo_mostrar = ();
	my $nombre_que_toca = "";
	my $contador = 0;
	my $useridgrupo = 0;

	my $id_usuario_prop_grupo = sacar_userid($dequien);
	$mensaje_fallo_gen = 'ERROR GRAVE : Queriendo sacar los grupos de un propietario no podemos sacar el id de usuario de ---$dequien---';
	comprobar_error_variable($id_usuario_prop_grupo, $mensaje_fallo_gen);
	my $espersona = tipo_principal_es_persona($id_usuario_prop_grupo);
	if ($espersona != 0)
	{
		syslog $syslog_priority, "Intentando sacar grupos pertenecientes a ---$dequien--- pero que no es persona este principal...";
		func_remplazo_die("Intentando sacar grupos pertenecientes a ---$dequien--- pero que no es persona este principal...");
	}

	my @array_grupos_propietario = sacar_grupos_de_propietario($id_usuario_prop_grupo);
	my $grupo_propietario_quetoca = "";
	my $grupo_sin_id_usuario = "";
	syslog $syslog_priority, "El propietario --$dequien-- tiene los grupos : @array_grupos_propietario";
	foreach $grupo_propietario_quetoca (@array_grupos_propietario) {
		$grupo_sin_id_usuario = sacar_nombre_grupo_sin_userid($grupo_propietario_quetoca,$id_usuario_prop_grupo);
		print ("$grupo_sin_id_usuario:");
		$princ_id_grupo_revisar = sacaid_princ_grupo($grupo_propietario_quetoca);
		$mensaje_fallo_gen = 'ERROR GRAVE : Nos piden sacar miembros de un grupo ---$grupo--- que pertenece a un usuario ---$usuario---. No podemos sacar principal del grupo resultante.';
		comprobar_error_variable($useridgrupo, $mensaje_fallo_gen);
		@array_usuarios_grupo = saca_usuarios_grupo($princ_id_grupo_revisar);
		$nombre_id_usu = "";

		syslog $syslog_priority, "El grupo $grupo tiene los siguientes miembros : @array_usuarios_grupo\n";
		@array_nombres_grupo_mostrar = ();

		foreach $id_princ_usuario (@array_usuarios_grupo) {
			$id_usu_princ = sacar_userid_principal($id_princ_usuario);
			$mensaje_fallo_gen = 'ERROR GRAVE : Al rellenar array de nombres de usuarios de un grupo a mostrar no podemos sacar el id de usuario del principal --$id_princ_usuario--';
			comprobar_error_variable($id_usu_princ, $mensaje_fallo_gen);
			$nombre_id_usu = sacar_username_deidusu($id_usu_princ);
			$mensaje_fallo_gen = 'ERROR GRAVE : Al rellenar array de nombres de usuarios de un grupo a mostrar no podemos sacar el nombre de usuario del userid --$id_usu_princ--';
			comprobar_error_variable_texto($nombre_id_usu, $mensaje_fallo_gen);
			push(@array_nombres_grupo_mostrar, $nombre_id_usu);
		}

		foreach $nombre_que_toca (@array_nombres_grupo_mostrar) {
			if ($contador eq '0')
			{
				print "$nombre_que_toca";
			}
			else
			{
				print ",$nombre_que_toca";
			}
			$contador = $contador + 1;
		}
	$contador = 0;
	print "\n";
	}
}

sub funcion_case_21 {
	my @listado_usuarios_davical = sacar_listado_usuarios_davical();
	my $usu_que_toca = "";
	foreach $usu_que_toca (@listado_usuarios_davical) {
		if ($usu_que_toca ne "admin")
		{
			print "$usu_que_toca\n";
		}
	}
}

sub funcion_case_20 {
	if ($usuario ne "")
	{
		my $id_usu_modif = sacar_userid($usuario);
		my $espersona = tipo_principal_es_persona($id_usu_modif);

		if (($espersona == 1) || ($id_usu_modif == '9987982389'))
		{
			syslog $syslog_priority, "El usuario ----$usuario----- del que obtener libretas no existe o no es persona.";
			func_remplazo_die("El usuario ----$usuario----- del que obtener libretas no existe o no es persona.");
		}

		my $id_principal_propio = sacar_principalid($id_usu_modif);
		$mensaje_fallo_gen="ERROR GRAVE : Problemas para sacar el principalID de ---$usuario---";
		comprobar_error_variable($id_principal_propio, $mensaje_fallo_gen);
		my @array_colecciones_usuario = sacar_colecciones_usuario($id_usu_modif);
		my $filas_array = scalar(@array_colecciones_usuario);
		if ($filas_array < '2')
		{
			syslog $syslog_priority, "El usuario ----$usuario----- tiene demasiadas pocas colecciones. Que lo revisen.";
			func_remplazo_die("El usuario ----$usuario----- tiene demasiadas pocas colecciones. Que lo revisen.");
		}

		my $nombre_coleccion = "";
		my $useridtemp = "";
		my $usernametemp = "";
		my $usernametemp2 = "";
		my $linea_array_coleccniones_disponibles_usuario = "";
		my $linea2_array_coleccniones_disponibles_usuario = "";
		my $linea3_array_coleccniones_disponibles_usuario = "";
		my @array_propios_permisos_coleccion = ();
		my @array_externos_permisos_coleccion = ();
		my @array_permisos_defecto_cole = ();
		my @array_principal_permisos_coleccion = ();
		my @permisos_totales_en_colecciones_de_usuario = ();
		my $nombre_permisos = "";
		my $id_colec_temp = "";
		my $permisos_bin_temp = "";
		my $principal_temp = "";
		my $tiene_permisos_defecto_rw_ro = '9987982389';
		my $nombre_permisos_defecto = 'NONE';

		foreach $linea_array_coleccniones_disponibles_usuario (@array_colecciones_usuario) {
			$id_colec_temp = @$linea_array_coleccniones_disponibles_usuario[2];
			$mensaje_fallo_gen="ERROR GRAVE : Id de coleccion erroneo ---$id_colec_temp---";
			comprobar_error_variable($id_colec_temp, $mensaje_fallo_gen);
			syslog $syslog_priority, "Comprobando permisos por defecto para ----$id_colec_temp-----." if ($verbose==1);
			$tiene_permisos_defecto_rw_ro = colecc_tiene_permisos_por_defecto($id_colec_temp);
			if ($tiene_permisos_defecto_rw_ro == 0)
			{
				$nombre_permisos_defecto = ver_permisos_defecto_colecc($id_colec_temp);
				syslog $syslog_priority, "La id de coleccion ----$id_colec_temp----- tiene permisos por defecto de lectura o lectura-escritura ----$nombre_permisos_defecto---." if ($verbose==1);
				if (($nombre_permisos_defecto eq "READ") || ($nombre_permisos_defecto eq "READWRITE"))
				{
					$nombre_coleccion = sacar_nombre_id_colecc($id_colec_temp);
					syslog $syslog_priority, "La id de coleccion ----$id_colec_temp----- tiene permisos por defecto de ----$nombre_permisos_defecto----." if ($verbose==1);
					@array_permisos_defecto_cole = ($nombre_coleccion,'T0D0S_AUTENTICAD0S_D4VICAL',$nombre_permisos_defecto);
					push(@permisos_totales_en_colecciones_de_usuario,@array_permisos_defecto_cole);
				}
			}

			$nombre_coleccion = sacar_nombre_id_colecc($id_colec_temp);
			$mensaje_fallo_gen="ERROR GRAVE : Problemas obteniendo nombre de coleccion de id ---$nombre_coleccion---";
			comprobar_error_variable_texto($nombre_coleccion, $mensaje_fallo_gen);
			@array_propios_permisos_coleccion = ("$nombre_coleccion","$usuario","READWRITE");
			push(@permisos_totales_en_colecciones_de_usuario,@array_propios_permisos_coleccion);
			@array_principal_permisos_coleccion = sacar_permisos_de_principal_en_colecciones($id_colec_temp);
			foreach $linea2_array_coleccniones_disponibles_usuario(@array_principal_permisos_coleccion) {
				$permisos_bin_temp = @$linea2_array_coleccniones_disponibles_usuario[1];
				$principal_temp = @$linea2_array_coleccniones_disponibles_usuario[0];
				if (($permisos_bin_temp ne '000000000001001000100001') && ($permisos_bin_temp ne '000000001111111011100111'))
				{
					syslog $syslog_priority, "Estos permisos ---$permisos_bin_temp--- no son los permisos que usamos en provision y seran NONE";
					next;
				}
				$nombre_permisos = permisosbin_a_nombre($permisos_bin_temp);
				$mensaje_fallo_gen="ERROR GRAVE : Problemas para sacar el nombre de los permisos binarios ---$permisos_bin_temp---";
				comprobar_error_variable_texto($nombre_permisos, $mensaje_fallo_gen);
				$useridtemp = sacar_userid_principal($principal_temp);
				$mensaje_fallo_gen="ERROR GRAVE : Problemas para sacar el userid del principalID ---$principal_temp---";
				comprobar_error_variable($useridtemp, $mensaje_fallo_gen);
				$usernametemp = sacar_username_deidusu($useridtemp);
				$mensaje_fallo_gen="ERROR GRAVE : Problemas para sacar el username del userid ---$useridtemp---";
				comprobar_error_variable($usernametemp, $mensaje_fallo_gen);
				$usernametemp2 = sacar_nombre_grupo_sin_userid($usernametemp,$id_usu_modif);
				@array_externos_permisos_coleccion = ($nombre_coleccion,$usernametemp2,$nombre_permisos);
				push(@permisos_totales_en_colecciones_de_usuario,@array_externos_permisos_coleccion);
			}
		}

		my $contador = 0;
		foreach (@permisos_totales_en_colecciones_de_usuario) {
			if ($contador > 1)
			{
				print "$_";
				print "|";
				print "\n";
				$contador = 0;
				next;
			}
			print "$_";
			print "|";
			$contador = $contador + 1;
		}
	}
	else
	{
		syslog $syslog_priority, "Faltan argumentos para sacar permisos de colection de un usuario ---$usuario---";
		print "Faltan argumentos para sacar permisos de colection de un usuario ---$usuario---";
	}
}

sub funcion_case_16 {
	if ($usuario ne "")
	{
		sacar_colecc_permisos_usuario($usuario);
	}
	else
	{
		syslog $syslog_priority, "No puedo pasar al webmail (case 16) las url de las collection para ---$usuario--- porque faltan argumentos.";
		print "No puedo pasar al webmail (case 16) las url de las collection para ---$usuario--- porque faltan argumentos.";
	}
}
#### FIN FUNCIONES BASICAS PARA SER COMBINADAS EN OTRAS FUNCIONES MAS COMPLEJAS QUE HAGAN LAS TAREAS

## COMIENZA LA FIESTA!!! FUNCION MAIN()

GetOptions ("usuario=s" => \$usuario,
		"grupo=s" => \$grupo,
		"permisos=s" => \$permisos,
		"coleccion=s" => \$coleccion,
		"tipocol=s" => \$tipocol,
		"displaynamecoleccion=s" => \$coldispname,
		"operacion=i" => \$idoperacion,
		"wdestusu=s" => \$usudest,
		"femailgr=s" => \$email,
		"rdomprinc=s" => \$dominio,
		"zdequien=s" => \$dequien,
		"verbose" => \$verbose)
or die("Error in command line arguments\n");

## if ($verbose == 1)
## {
##	print "En modo verboso";
## }

comprobar_permiso_ejecutar();
obtener_conexion_a_bbdd();
comprobar_version();

## SWITCH PARA LA FUNCION PRINCIPAL A REALIZAR

switch ($idoperacion) {
case 1	{
	if (($usuario ne "") && ($tipocol ne "") && ($coleccion ne ""))
	{
		syslog $syslog_priority, "ACCION 1 : Se solicita crear la coleccion ---$coleccion--- solicitada porque el usuario ---$usuario---." if ($verbose==1);
		my $usuario_existe = existe_usuario($usuario);

		if ($usuario_existe != 1)
		{
			syslog $syslog_priority, "No podemos crear la coleccion ---$coleccion--- solicitada porque el usuario ---$usuario--- sobre el que crearlo no existe." if ($verbose==1);
			func_remplazo_die("El usuario ---$usuario--- no existe");
		}
		my $id_usuario_op = sacar_userid($usuario);
		my $id_usuario_op_princ = sacar_principalid($id_usuario_op);
		$mensaje_fallo_gen = 'ERROR GRAVE : Despues de ver que --$usuario-- existe no podemos obtener su user id';
		comprobar_error_variable($id_usuario_op, $mensaje_fallo_gen);
		my $espersona = tipo_principal_es_persona($id_usuario_op);

		if ($espersona != 0)
		{
			syslog $syslog_priority, "No podemos crear la coleccion ---$coleccion--- solicitada porque el usuario ---$usuario--- porque usuario no es de tipo persona." if ($verbose==1);
			func_remplazo_die("Pidiendo crear coleccion para usuario ----$usuario---- que no es de tipo persona.");
		}

		if ($coldispname eq "")
		{
			if ($tipocol == 0)
			{
				$coldispname = "Calendario llamado ".$coleccion;
			}
			elsif ($tipocol == 1)
			{
				$coldispname = "Agenda de contactos llamada ".$coleccion;
			}
			else
			{
				syslog $syslog_priority, "No podemos crear la coleccion ---$coleccion--- solicitada porque el usuario ---$usuario--- porque la coleccion no es de tipo libreta o agenda." if ($verbose==1);
				func_remplazo_die("La coleccion no es de tipo agenda o libreta...");
			}
		}

		my @colec_usuario_op = sacar_colecciones_usuario($id_usuario_op);

		my $colec_usu_opquetoca = "";
		my @colec_usu_pasar = ();

		foreach $colec_usu_opquetoca (@colec_usuario_op) {
			push(@colec_usu_pasar,@$colec_usu_opquetoca[0]);
		}
		my $colec_exist_usu_op = usuario_ya_tiene_coleccion(\@colec_usu_pasar,$coleccion);


		if ($colec_exist_usu_op == 0)
		{
			my $principal_con_permisos_todos_usu_autenticados_fijados = existen_perm_defecto_princ($id_usuario_op_princ);
			my @permisos_externos_sobre_principal = sacar_permisos_de_principals_en_principal($id_usuario_op_princ);
			my $n_permisos_externos_sobre_principal = scalar(@permisos_externos_sobre_principal);
			crear_coleccion($usuario,$coleccion,$coldispname,$tipocol);
			if (($principal_con_permisos_todos_usu_autenticados_fijados != '9987982389') || ($n_permisos_externos_sobre_principal > '0'))
			{
				syslog $syslog_priority, "Ajustando permisos sobre coleccion ---$coleccion--- a permisos defecto nada para prevenir accesos no autorizados";
				my $id_colec_creada = sacar_id_colecc_usuario_nombre($id_usuario_op,'/'.$usuario.'/'.$coleccion.'/');
				fijar_permisos_defect_col($id_colec_creada,$permisos_defecto_nada);
			}
			print "OK";
		}
		else
		{
			print ("No se puede crear la coleccion porque ya existe.");
			syslog $syslog_priority, "No podemos crear la coleccion ---$coleccion--- solicitada porque el usuario ---$usuario--- porque la coleccion ya existe." if ($verbose==1);
		}
		comprobar_existencia_colecciones_por_defecto($id_usuario_op);
	}
	else
	{
		print "Para el case 1 faltan argumentos. Usuario vale --$usuario-- Tipo de colecc vale --$tipocol-- y Coleccion vale --$coleccion--";
		syslog $syslog_priority, "Solicitud de crear coleccion (case 1) erronea porque faltan argumentos. Usuario vale --$usuario-- Tipo de colecc vale --$tipocol-- y Coleccion vale --$coleccion--";
	}
}
case 2	{
	if (($usuario ne "") && ($coleccion ne ""))
	{
		syslog $syslog_priority, "ACCION 2 : Se solicita eliminar la coleccion ---$coleccion--- para el usuario ---$usuario---." if ($verbose==1);
		my $usuario_existe = existe_usuario($usuario);
		if ($usuario_existe != 1)
		{
			syslog $syslog_priority, "No se puede eliminar la coleccion ---$coleccion--- del usuario ---$usuario--- porque el usuario no existe" if ($verbose==1);
			func_remplazo_die("No se puede eliminar la coleccion ---$coleccion--- del usuario ---$usuario--- porque el usuario no existe");
		}

		my $id_usuario_op = sacar_userid($usuario);
		my $id_principal_usuario = sacar_principalid($id_usuario_op);
		$mensaje_fallo_gen = 'ERROR GRAVE : Despues de ver que --$usuario-- existe no podemos obtener su user id';
		comprobar_error_variable($id_usuario_op, $mensaje_fallo_gen);
		my $espersona = tipo_principal_es_persona($id_usuario_op);
		my $colec_usu_opquetoca = "";
		my @colec_usu_pasar = ();

		if ($espersona != 0)
		{
			syslog $syslog_priority, "Pidiendo borrar coleccion para usuario ----$usuario---- que no es de tipo persona." if ($verbose==1);
			func_remplazo_die("Pidiendo borrar coleccion para usuario ----$usuario---- que no es de tipo persona.");
		}

		my @colec_usuario_op = sacar_colecciones_usuario($id_usuario_op);

		foreach $colec_usu_opquetoca (@colec_usuario_op) {
			push(@colec_usu_pasar,@$colec_usu_opquetoca[0]);
		}

		my $colec_exist_usu_op = usuario_ya_tiene_coleccion(\@colec_usu_pasar,$coleccion);

		### COMPRUEBO QUE LA COLECCION SE PUEDE BORRAR PORQUE NADIE TIENE PERMISOS SOBRE ELLA O NO TIENE PERMISOS DEFECTO
		my $imposibilidad_borrar = '0';
		my $id_de_cole = sacar_id_coledavname($usuario,$coleccion);
		my @permisos_deotros_que_hay_sobre_colecc = sacar_permisos_de_NOprincipal_en_colecciones($id_de_cole,$id_principal_usuario);
		my $n_permisos_deotros_que_hay_sobre_colecc = scalar(@permisos_deotros_que_hay_sobre_colecc);
		if ($n_permisos_deotros_que_hay_sobre_colecc > 0)
		{
			$imposibilidad_borrar = '1';
		}
		my $lacole_tiene_permisos_defecto = colecc_tiene_permisos_por_defecto($id_de_cole);
		if ($lacole_tiene_permisos_defecto == '0')
		{
			$imposibilidad_borrar = '1';
		}
		### FIN COMPRUEBO QUE LA COLECCION SE PUEDE BORRAR PORQUE NADIE TIENE PERMISOS SOBRE ELLA O NO TIENE PERMISOS DEFECTO

		if (($colec_exist_usu_op == '1') && (($coleccion ne "calendar") && ($coleccion ne "addresses")) && ($imposibilidad_borrar == '0'))
		{
			borrar_coleccion($usuario,$coleccion);
			print "OK";
		}
		else
		{
			syslog $syslog_priority, "Imposible borrar coleccion ---$coleccion--- para usuario ----$usuario---- porque NO existe o si son las de por defecto no se permite." if ($verbose==1);
			print ("Imposible borrar coleccion ---$coleccion--- para usuario ----$usuario---- porque NO existe o si son las de por defecto no se permite.");
		}
		comprobar_existencia_colecciones_por_defecto($id_usuario_op);
	}
	else
	{
		syslog $syslog_priority, "Para el case 2 faltan argumentos. Usuario vale --$usuario-- y Coleccion vale --$coleccion--";
		print "Para el case 2 faltan argumentos. Usuario vale --$usuario-- y Coleccion vale --$coleccion--";
	}
}
case 3	{
	if (($usuario ne "") && ($grupo ne "") && ($dequien ne ""))
	{
		syslog $syslog_priority, "ACCION 3 : Se solicita anadir el usuario ---$usuario--- al grupo ---$grupo--- perteneciente a ---$dequien---" if ($verbose==1);
		my $id_usuario_op = sacar_userid($usuario);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden anadir usuario ---$usuario--- que no se puede sacar el user id al grupo ---$grupo---";
		comprobar_error_variable($id_usuario_op, $mensaje_fallo_gen);
		my $id_usuario_prop_grupo = sacar_userid($dequien);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden anadir usuario ---$usuario--- al grupo ---$grupo--- de cuyo propietario no podemos sacar user id";
		comprobar_error_variable($id_usuario_prop_grupo, $mensaje_fallo_gen);
		my $nombregrupousar = sacar_nombre_real_grupo($grupo,$dequien);
		my $id_grupocomp = sacar_userid($nombregrupousar);
		$mensaje_fallo_gen = "ERROR GRAVE : No podemos obtener id de usuario del grupo resultante ---$nombregrupousar---";
		comprobar_error_variable($id_grupocomp, $mensaje_fallo_gen);
		my $grupo_existe = existe_usuario($nombregrupousar);
		if ($grupo_existe != 1)
		{
			syslog $syslog_priority, "El grupo --$grupo-- no es valido para el propietario --$dequien--";
			func_remplazo_die("El grupo --$grupo-- no es valido para el propietario --$dequien--");
		}

		my $id_grupo_op = 998798238;
		my $id_princ_memb = 998798238;

		my $espersona = tipo_principal_es_persona($id_usuario_op);
		my $esgrupo = tipo_principal_es_grupo($id_grupocomp);
		my $espersona2 = tipo_principal_es_persona($id_usuario_prop_grupo);

		if (($espersona != 0) || ($espersona2 != 0))
		{
			syslog $syslog_priority, "El usuario ---$usuario---, grupo ---$grupo--- no son del tipo que deben ser para la accion solicitada o alguno no existe.";
			func_remplazo_die("El usuario ---$usuario---, grupo ---$grupo--- no son del tipo que deben ser para la accion solicitada o alguno no existe.");
		}

		my $grupo_resultante = $nombregrupousar;
		$grupo = $grupo_resultante;

		$id_princ_memb = sacar_principalid($id_usuario_op);
		$id_grupo_op = sacaid_princ_grupo($grupo_resultante);

		if (($id_princ_memb == 998798238) || ($id_grupo_op == 998798238))
		{
			syslog $syslog_priority, "No existe el usuario ---$usuario--- o grupo indicados ---$grupo----";
			func_remplazo_die("No existe el usuario ---$usuario--- o grupo indicados ---$grupo----");
		}
		my $usu_yaexiste_grupo = existe_usuario_en_grupo($id_grupo_op,$id_princ_memb);
		$mensaje_fallo_gen = 'ERROR GRAVE : Error extrano al intentar ver si el usuario ---$usuario--- con principal id ---$id_princ_memb--- pertenece al grupo ---$grupo--- con principal id ---$id_grupo_op---';
		comprobar_error_variable($usu_yaexiste_grupo, $mensaje_fallo_gen);
		if ($usu_yaexiste_grupo == 0)
		{
			anadir_a_grupo($id_grupo_op,$id_princ_memb);
			print "OK";
		}
		else
		{
			syslog $syslog_priority, "Es imposible anadir usuario ---$usuario--- a grupo ---$grupo--- porque ya pertenece a grupo";
			print ("Es imposible anadir usuario ---$usuario--- a grupo ---$grupo--- porque ya pertenece a grupo");
		}
	}
	else
	{
		syslog $syslog_priority, "No se puede anadir usuario a grupo. Usuario vale --$usuario-- y Grupo vale --$grupo-- perteneciendo a --$dequien--";
		print "No se puede anadir usuario a grupo. Usuario vale --$usuario-- y Grupo vale --$grupo-- perteneciendo a --$dequien--";
	}
}
case 4	{
	if (($usuario ne "") && ($grupo ne "") && ($dequien ne ""))
	{
		syslog $syslog_priority, "ACCION 4 : Se solicita eliminar el usuario ---$usuario--- del grupo ---$grupo--- perteneciente a ---$dequien---" if ($verbose==1);
		my $id_usuario_op = sacar_userid($usuario);
		$mensaje_fallo_gen = 'ERROR GRAVE : Nos piden eliminar usuario ---$usuario--- que no se puede sacar el user id al grupo ---$grupo---';
		comprobar_error_variable($id_usuario_op, $mensaje_fallo_gen);
		my $id_usuario_prop_grupo = sacar_userid($dequien);
		$mensaje_fallo_gen = 'ERROR GRAVE : Nos piden eliminar usuario ---$usuario--- al grupo ---$grupo--- de cuyo propietario no podemos sacar user id';
		comprobar_error_variable($id_usuario_prop_grupo,$mensaje_fallo_gen);
		my $id_grupocomp = sacar_userid($id_usuario_prop_grupo.$grupo);
		my $grupo_existe = existe_usuario($id_usuario_prop_grupo.$grupo);
		if ($grupo_existe != 1)
		{
			syslog $syslog_priority, "El grupo --$grupo-- no es valido para el propietario --$dequien--";
			func_remplazo_die("El grupo --$grupo-- no es valido para el propietario --$dequien--");
		}

		my $id_grupo_op = 998798238;
		my $id_princ_memb = 998798238;

		my $espersona = tipo_principal_es_persona($id_usuario_op);
		my $espersona2 = tipo_principal_es_persona($id_usuario_prop_grupo);

		if (($espersona != 0) || ($espersona2 != 0))
		{
			syslog $syslog_priority, "El usuario ---$usuario---, grupo ---$grupo--- no son del tipo que deben ser para la accion solicitada o alguno no existe.";
			func_remplazo_die("El usuario ---$usuario---, grupo ---$grupo--- no son del tipo que deben ser para la accion solicitada o alguno no existe.");
		}

		my $esgrupo = tipo_principal_es_grupo($id_grupocomp);

		if ($esgrupo != 0)
		{
			syslog $syslog_priority, "El destino --$grupo-- no es un grupo....";
			func_remplazo_die("El destino --$grupo-- no es un grupo....");
		}

		$id_princ_memb = sacar_principalid($id_usuario_op);

		my $grupo_resultante = sacar_nombre_real_grupo($grupo,$dequien);
		$grupo = $grupo_resultante;

		$id_grupo_op = sacaid_princ_grupo($grupo);

		if (($id_princ_memb == 9987982389) || ($id_grupo_op == 9987982389))
		{
			syslog $syslog_priority, "No existe el usuario ---$usuario--- o grupo ---$grupo--- indicados";
			func_remplazo_die("No existe el usuario ---$usuario--- o grupo ---$grupo--- indicados");
		}
		my $usu_yaexiste_grupo = existe_usuario_en_grupo($id_grupo_op,$id_princ_memb);
		if ($usu_yaexiste_grupo == 1)
		{
			borrar_de_grupo($id_grupo_op,$id_princ_memb);
			print "OK";
		}
		else
		{
			syslog $syslog_priority, "Imposible borrar usuario ---$usuario--- de grupo ---$grupo--- porque NO pertenece a grupo";
			func_remplazo_die("Imposible borrar usuario ---$usuario--- de grupo ---$grupo--- porque NO pertenece a grupo");
		}
	}
	else
	{
		print "No se puede (case 4) borrar usuario ---$usuario--- de grupo ---$grupo--- porque faltan argumentos....";
		syslog $syslog_priority, "No se puede (case 4) borrar usuario ---$usuario--- de grupo ---$grupo--- porque faltan argumentos....";
	}
}
case 5	{
	if (($usuario ne "") && ($usudest ne "") && ($permisos ne ""))
	{
		syslog $syslog_priority, "ACCION 5 : Se solicita dar permisos de principal ---$permisos--- al usuario ---$usuario--- en el principal ---$usudest---" if ($verbose==1);
		my $id_princ_usuario = 0;
		my $id_princ_destino = 0;
		my $resultado_usu_grupo_orig = "";
		my $colec_usu_opquetoca = "";
		my @colec_usu_pasar = ();

		## TENGO QUE TENER CLARO CON QUE TRABAJO
		$resultado_usu_grupo_orig = comprobar_si_pers_o_grupo_y_poner_nombre_grupo_bien($usuario,$dequien);

		my $id_usuario_op = sacar_userid($usudest);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden dar permisos a ---$usuario--- en ---$usudest--- pero no ponemos obtener el id de usuario destino";
		comprobar_error_variable($id_usuario_op, $mensaje_fallo_gen);
		my $espersona = tipo_principal_es_persona($id_usuario_op);
		if ($espersona != 0)
		{
			syslog $syslog_priority, "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA";
			syslog $syslog_priority, "Pidiendo dar permisos a ---$usuario--- sobre ---$usudest--- que no es una persona... NO VALE";
			func_remplazo_die("Pidiendo dar permisos a ---$usuario--- sobre ---$usudest--- que no es una persona... NO VALE");
		}

		my $id_usuario_origen = sacar_userid($resultado_usu_grupo_orig);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden dar permisos a ---$resultado_usu_grupo_orig--- en ---$usudest--- pero no ponemos obtener el id de usuario origen";
		comprobar_error_variable($id_usuario_origen, $mensaje_fallo_gen);
		my $id_usuario_destino = $id_usuario_op;
		my @id_col_poner_defpriv_a_0 = sacar_ids_colecc_usuario($id_usuario_destino);
		comprobar_existencia_colecciones_por_defecto($id_usuario_op);

		my $toca_col = "";

		$id_princ_usuario = sacar_principalid($id_usuario_origen);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden dar permisos a ---$usuario--- en ---$usudest--- pero no ponemos obtener el id de principal del id de usuario origen ---$id_usuario_origen---";
		comprobar_error_variable($id_princ_usuario, $mensaje_fallo_gen);
		$id_princ_destino = sacar_principalid($id_usuario_destino);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden dar permisos a ---$usuario--- en ---$usudest--- pero no ponemos obtener el id de principal del id de usuario destino ---$id_usuario_destino---";
		comprobar_error_variable($id_princ_destino, $mensaje_fallo_gen);

		my $colec_tiene_perm_defecto = 1;

		anadir_permisos_principal_a_principal($id_princ_usuario,$id_princ_destino,$permisos);

		my $colpuntoin = sacar_id_colecc_usuario_nombre($id_usuario_destino,'/'.$usudest.'/.in/');
		my $colpuntoout = sacar_id_colecc_usuario_nombre($id_usuario_destino,'/'.$usudest.'/.out/');

		foreach $toca_col (@id_col_poner_defpriv_a_0) {

			$colec_tiene_perm_defecto = colecc_tiene_permisos_por_defecto($toca_col);
			$mensaje_fallo_gen = "Imposible saber si la coleccion con id ---$toca_col--- tiene permisos por defecto";
			comprobar_error_variable($colec_tiene_perm_defecto, $mensaje_fallo_gen);
			if ($colec_tiene_perm_defecto == 1)
			{
				if (($toca_col != $colpuntoin) && ($toca_col != $colpuntoout))
				{
					fijar_permisos_defect_col($toca_col,$permisos_defecto_nada);
					syslog $syslog_priority, "Reseteando permisos para colid --$toca_col-- de usuario ---$usudest--- para para principalid ---$id_princ_usuario--- y usuario origen ---$usuario--- evitar accesos no deseados" if ($verbose==1);
				}
				else
				{
					syslog $syslog_priority, "Evitando tocar coleccion con id ----$toca_col--- porque es una .in o .out" if ($verbose==1);
				}
			}
			else
			{
				syslog $syslog_priority, "No reseteamos permisos para colid --$toca_col-- de usuario ---$usudest--- para evitar accesos no deseados porque esa cole tiene permisos por defecto" if ($verbose==1);
			}
		}
		print "OK";
	}
	else
	{
		syslog $syslog_priority, "No podemos aplicar permisos sobre el principal ---$usudest--- a ---$usuario--- con permisos ---$permisos--- porque faltan argumentos";
		print "No podemos aplicar permisos sobre el principal ---$usudest--- a ---$usuario--- con permisos ---$permisos--- porque faltan argumentos";
	}
}
case 6	{
	if (($usuario ne "") && ($usudest ne ""))
	{
		syslog $syslog_priority, "ACCION 6 : Se solicita quitar permisos de principal al usuario ---$usuario--- en el principal ---$usudest---" if ($verbose==1);
		my $id_princ_usuario = 0;
		my $id_princ_destino = 0;

		my $resultado_usu_grupo_orig = comprobar_si_pers_o_grupo_y_poner_nombre_grupo_bien($usuario);

		my $id_usuario_op = sacar_userid($usudest);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden eliminar permisos a ---$usuario--- en ---$usudest--- pero no ponemos obtener el id de usuario destino";
		comprobar_error_variable($id_usuario_op, $mensaje_fallo_gen);
		my $espersona = tipo_principal_es_persona($id_usuario_op);
		if ($espersona != 0)
		{
			syslog $syslog_priority, "Pidiendo quitar permisos a ---$usuario--- sobre principal ---$usudest--- que no es una persona... NO VALE";
			func_remplazo_die("Pidiendo quitar permisos a ---$usuario--- sobre principal ---$usudest--- que no es una persona... NO VALE");
		}

		my $id_usuario_origen = sacar_userid($resultado_usu_grupo_orig);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden eliminar permisos a ---$resultado_usu_grupo_orig--- en ---$usudest--- pero no ponemos obtener el id de usuario origen";
		comprobar_error_variable($id_usuario_origen, $mensaje_fallo_gen);
		my $id_usuario_destino = $id_usuario_op;
		my @id_col_poner_defpriv_a_0 = sacar_ids_colecc_usuario($id_usuario_destino);
		comprobar_existencia_colecciones_por_defecto($id_usuario_op);

		my $toca_col = "";

		$id_princ_usuario = sacar_principalid($id_usuario_origen);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden eliminar permisos a ---$usuario--- en ---$usudest--- pero no ponemos obtener el id de principal del id de usuario origen ---$id_usuario_origen---";
		comprobar_error_variable($id_princ_usuario, $mensaje_fallo_gen);
		$id_princ_destino = sacar_principalid($id_usuario_destino);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden eliminar permisos a ---$usuario--- en ---$usudest--- pero no ponemos obtener el id de principal del id de usuario destino ---$id_usuario_destino---";
		comprobar_error_variable($id_princ_destino, $mensaje_fallo_gen);
		foreach $toca_col (@id_col_poner_defpriv_a_0) {
			eliminar_permisos_principal_a_collection($id_princ_usuario, $toca_col);
			syslog $syslog_priority, "Eliminando los permisos que se dieron a ---$usuario--- en principal ---$usudest---" if ($verbose == 1);
		}

		eliminar_permisos_principal_a_principal($id_princ_usuario,$id_princ_destino);
		print "OK";
	}
	else
	{
		syslog $syslog_priority, "Imposible eliminar permisos en principal ---$usudest--- para usuario ---$usuario---. Faltan argumentos (Case 6).";
	}
}
case 7	{
	if (($usuario ne "") && ($coleccion ne "") && ($usudest ne "") && ($permisos ne ""))
	{
		syslog $syslog_priority, "ACCION 7 : Se solicita dar permisos sobre coleccion ---$coleccion--- de tipo ---$permisos--- al usuario ---$usuario--- en el principal ---$usudest---" if ($verbose==1);

		my $id_princ_usuario = 0;
		my $id_princ_destino = 0;

		my $resultado_usu_grupo_orig = comprobar_si_pers_o_grupo_y_poner_nombre_grupo_bien($usuario);

		syslog $syslog_priority, "Nombre de usuario implicado con el que trabajaremos es -----$resultado_usu_grupo_orig----------";

		## TENGO QUE TENER CLARO CON QUE TRABAJO
		my $id_usudest = sacar_userid($usudest);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden dar permisos a ---$usuario--- en ---$usudest--- en coleccion --$coleccion-- pero no podemos determinar el ID de usuario destino.";
		comprobar_error_variable($id_usudest, $mensaje_fallo_gen);
		my $tipo_principal = sacar_tipo_principal($id_usudest);
		if ($tipo_principal != "Person")
		{
			syslog $syslog_priority, "Pidiendo dar permisos a ---$usuario--- sobre usuario ---$usudest--- en coleccion ---$coleccion--- que no es una persona... NO VALE";
			func_remplazo_die("Pidiendo dar permisos a ---$usuario--- sobre usuario ---$usudest--- en coleccion ---$coleccion--- que no es una persona... NO VALE");
		}

		my $id_usuario_origen = sacar_userid($resultado_usu_grupo_orig);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden dar permisos a ---$usuario--- en ---$usudest--- en coleccion --$coleccion-- pero no podemos determinar el ID de usuario origen.";
		comprobar_error_variable($id_usuario_origen, $mensaje_fallo_gen);
		my $id_usuario_destino = $id_usudest;
		$id_princ_usuario = sacar_principalid($id_usuario_origen);
		$id_princ_destino = sacar_principalid($id_usuario_destino);
		my $cole_existe = sacar_id_colecc_usuario_nombre($id_usuario_destino,'/'.$usudest.'/'.$coleccion.'/');

		if (($cole_existe == 9987982389) || ($id_princ_usuario == 9987982389) || ($id_princ_destino == 9987982389))
		{
			syslog $syslog_priority, "Al dar permisos de usuario en coleccion no existe usuario origen $usuario --$id_usuario_origen-- o usuario destino $usudest --$id_usuario_destino-- o coleccion $coleccion --$cole_existe--";
			func_remplazo_die("Al dar permisos de usuario en coleccion no existe usuario origen $usuario --$id_usuario_origen-- o usuario destino $usudest --$id_usuario_destino-- o coleccion $coleccion --$cole_existe--");
		}
		my $id_colec_destino = $cole_existe;
		anadir_permisos_principal_a_collection($id_princ_usuario, $id_colec_destino, $permisos);
		print "OK";
	}
	else
	{
		syslog $syslog_priority, "Me faltan argumentos para dar permisos a ---$usuario--- en ---$usudest--- coleccion ---$coleccion--- los permisos de ---$permisos---. Faltan argumentos (Case 7)";
		print "Me faltan argumentos para dar permisos a ---$usuario--- en ---$usudest--- coleccion ---$coleccion--- los permisos de ---$permisos---. Faltan argumentos (Case 7)";
	}
}
case 8	{
	if (($usuario ne "") && ($coleccion ne "") && ($usudest ne ""))
	{
		syslog $syslog_priority, "ACCION 8 : Se solicita quitar permisos sobre coleccion ---$coleccion--- al usuario ---$usuario--- en el principal ---$usudest---" if ($verbose==1);
		my $id_princ_usuario = 0;
		my $id_princ_destino = 0;

		my $resultado_usu_grupo_orig = comprobar_si_pers_o_grupo_y_poner_nombre_grupo_bien($usuario);

		## TENGO QUE TENER CLARO CON QUE TRABAJO
		my $id_usudest = sacar_userid($usudest);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden eliminar permisos a ---$usuario--- en ---$usudest--- en coleccion --$coleccion-- pero no podemos determinar el ID de usuario destino.";
		comprobar_error_variable($id_usudest, $mensaje_fallo_gen);
		my $tipo_principal = sacar_tipo_principal($id_usudest);
		if ($tipo_principal != "Person")
		{
			syslog $syslog_priority, "Pidiendo quitar permisos a ---$usuario--- sobre usuario ---$usudest--- en coleccion ---$coleccion--- que no es una persona... NO VALE";
			func_remplazo_die("Pidiendo quitar permisos a ---$usuario--- sobre usuario ---$usudest--- en coleccion ---$coleccion--- que no es una persona... NO VALE");
		}

		my $id_usuario_origen = sacar_userid($resultado_usu_grupo_orig);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden eliminar permisos a ---$usuario--- en ---$usudest--- en coleccion --$coleccion-- pero no podemos determinar el ID de usuario origen.";
		comprobar_error_variable($id_usuario_origen, $mensaje_fallo_gen);
		my $id_usuario_destino = $id_usudest;
		my $cole_existe = sacar_id_colecc_usuario_nombre($id_usuario_destino,'/'.$usudest.'/'.$coleccion.'/');
		$id_princ_usuario = sacar_principalid($id_usuario_origen);
		$id_princ_destino = sacar_principalid($id_usuario_destino);
		if (($cole_existe == 9987982389) || ($id_princ_usuario == 9987982389) || ($id_princ_destino == 9987982389))
		{
			syslog $syslog_priority, "No puedo quitar permisos en coleccion de usuario origen $usuario --$id_usuario_origen-- en usuario destino $usudest --$id_usuario_destino-- en coleccion $coleccion --$cole_existe--";
			func_remplazo_die("No puedo quitar permisos en coleccion de usuario origen $usuario --$id_usuario_origen-- en usuario destino $usudest --$id_usuario_destino-- en coleccion $coleccion --$cole_existe--");
		}
		my $id_colec_destino = $cole_existe;
		eliminar_permisos_principal_a_collection($id_princ_usuario, $id_colec_destino);

		my @colecs_usuario_destino = sacar_ids_colecc_usuario($id_usudest);
		my @colecs_usuario_destino_permisos = ();
		my $toca_col = "";
		my $elementos_array = '0';
		my $testigo = '0';

		foreach $toca_col (@colecs_usuario_destino) {
			@colecs_usuario_destino_permisos = sacar_permisos_de_principalconcreto_en_colecciones($toca_col,$id_princ_usuario);
			$elementos_array = scalar(@colecs_usuario_destino_permisos);
			if ($elementos_array > '0')
			{
				$testigo = '1';
				print "OK";
			}
		}

		if ($testigo eq '0')
		{
				syslog $syslog_priority, "HACIENDO LIMPIEZAAAAAAA";
				eliminar_permisos_principal_a_principal($id_princ_usuario,$id_princ_destino);
				syslog $syslog_priority, "Como el principal origen --$id_princ_usuario-- no tiene mas permisos en --$id_princ_destino-- podemos eliminar del principal el permiso de ---$id_princ_usuario---";
				my @princ_con_perm_sobre_princ_pend = sacar_permisos_de_principals_en_principal($id_princ_destino);
				$elementos_array = scalar(@princ_con_perm_sobre_princ_pend);
				if ($elementos_array == '0')
				{
					my $perm_def_en_principal = existen_perm_defecto_princ($id_princ_destino);
					if ($perm_def_en_principal == '9987982389')
					{
						foreach $toca_col (@colecs_usuario_destino) {
								fijar_permisos_defect_col($toca_col,"defecto");
						}

					}
				}
				print "OK";
		}
	}
	else
	{
		print "Me faltan argumentos (case 8) para quitar permisos en coleccion para : usuario origen $usuario en usuario destino $usudest en coleccion $coleccion";
		syslog $syslog_priority, "Me faltan argumentos (case 8) para quitar permisos en coleccion para : usuario origen $usuario en usuario destino $usudest en coleccion $coleccion";
	}
}
case 9	{
	if (($grupo ne "") && ($dequien ne ""))
	{
		syslog $syslog_priority, "ACCION 9 : El usuario ---$dequien--- solicita crear el grupo ---$grupo--- a su nombre" if ($verbose==1);
		my $existe_usuario = existe_usuario($dequien);
		my $dominiomail = sacar_dominio_para_email($dequien);
		$mensaje_fallo_gen = 'ERROR GRAVE : Nos hemos podido obtener un dominio bueno para poner al email del grupo.';
		comprobar_error_variable_texto($dominiomail, $mensaje_fallo_gen);
		my $idusuarioprop = 998798238;
		my $idusuariogrupo = 998798238;
		if ($existe_usuario == 1)
		{
			$idusuarioprop = sacar_userid($dequien);
			$mensaje_fallo_gen = 'ERROR GRAVE : Intentando crear el grupo ---$grupo--- del propietario ---$dequien--- del que no podemos sacar el id de usuario.';
			comprobar_error_variable($idusuarioprop, $mensaje_fallo_gen);
			my $espersona = tipo_principal_es_persona($idusuarioprop);
			if ($espersona != 0)
			{
				syslog $syslog_priority, "Pidiendo crear grupo ---$grupo--- sin que propietario ---$dequien---- sea persona.... No vale....";
				func_remplazo_die("Pidiendo crear grupo ---$grupo--- sin que propietario ---$dequien---- sea persona.... No vale....");
			}

			my $grupo_resultante = sacar_nombre_real_grupo($grupo,$dequien);
			my $grupo_existe = existe_usuario($grupo_resultante);

			if ($grupo_existe == 0)
			{
				if ($grupo !~ m/\@/)
				{
					syslog $syslog_priority, "Paso a crear grupo como grupo ----$grupo--- y como propietario -----$idusuarioprop-----" if ($verbose==1);
					crear_grupo($grupo, $idusuarioprop, $dominiomail);
					print "OK";
				}
				else
				{
					print "Caracter ARROBA no permitido para nombre de grupo";
					syslog $syslog_priority, "Caracter ARROBA no permitido para nombre de grupo";
				}
			}
			else
			{
				syslog $syslog_priority, "No puedo crear un grupo --$grupo_resultante-- que viene de --$grupo-- y es de --$dequien-- que ya existe";
				func_remplazo_die("No puedo crear un grupo --$grupo_resultante-- que viene de --$grupo-- y es de --$dequien-- que ya existe");
			}
		}
		else
		{
			syslog $syslog_priority, "El usuario $usuario (propietario) para el que se quiere crear el grupo $grupo no existe";
			func_remplazo_die("El usuario $usuario (propietario) para el que se quiere crear el grupo $grupo no existe");
		}
	}
	else
	{
		syslog $syslog_priority, "No puedo crear grupo (case 9) porque me faltan argumentos. Grupo vale --$grupo-- El dominio vale --$email--";
		print("No puedo crear grupo (case 9) porque me faltan argumentos. Grupo vale --$grupo-- El dominio vale --$email--");
	}
}
case 10 {
	if (($grupo ne "") && ($dequien ne ""))
	{
		syslog $syslog_priority, "ACCION 10 : El usuario ---$dequien--- solicita eliminar el grupo ---$grupo--- de su nombre" if ($verbose==1);
		my $existe_usuario = existe_usuario($dequien);
		my $idusuarioprop = 998798238;
		my $idusuariogrupo = 998798238;
		if ($existe_usuario == 1)
		{
			$idusuarioprop = sacar_userid($dequien);
			$mensaje_fallo_gen = "ERROR GRAVE : Intentando eliminar el grupo ---$grupo--- del propietario ---$dequien--- del que no podemos sacar el id de usuario.";
			comprobar_error_variable($idusuarioprop, $mensaje_fallo_gen);
			my $espersona = tipo_principal_es_persona($idusuarioprop);
			if ($espersona != 0)
			{
				syslog $syslog_priority, "Pidiendo eliminar grupo ---$grupo--- sin que propietario ---$dequien---- sea persona.... No vale....";
				func_remplazo_die("Pidiendo eliminar grupo ---$grupo--- sin que propietario ---$dequien---- sea persona.... No vale....");
			}
			my $grupo_resultante = sacar_nombre_real_grupo($grupo,$dequien);
			my $grupo_existe = existe_usuario($grupo_resultante);
			if ($grupo_existe == 1)
			{
				my $userid_gruporesult = sacar_userid($grupo_resultante);
				my $principalgruporesult = sacar_principalid($userid_gruporesult);
				my @registros_implicado_en_permisos = grupo_conpermisos_asignados($principalgruporesult);
				my $n_registros_implicado_en_permisos = scalar(@registros_implicado_en_permisos);
				if ($n_registros_implicado_en_permisos == 0)
				{
					elimina_grupo($principalgruporesult);
					syslog $syslog_priority, "El grupo no tiene cuentas con mas permisos pendientes... si se quiere... se puede borrar....";
					print "OK";
				}
				else
				{
					syslog $syslog_priority, "El grupo TIENE cuentas con mas permisos pendientes... NO se puede borrar....";
					print "KO";
				}

			}
			else
			{
				syslog $syslog_priority, "No existe grupo ---$grupo--- a eliminar";
				print "No existe grupo ---$grupo--- a eliminar";
			}
		}
		else
		{
			syslog $syslog_priority, "El usuario $usuario para el que se quiere eliminar el grupo $grupo no existe";
			print "El usuario $usuario para el que se quiere eliminar el grupo $grupo no existe";
		}
	}
	else
	{
		syslog $syslog_priority, "Imposible eliminar (case 10) grupo --$grupo-- de propietario --$dequien--  porque faltan argumentos";
		print "Imposible eliminar (case 10) grupo --$grupo-- de propietario --$dequien--  porque faltan argumentos";
	}
}
case 11 {
	if (($usuario ne "") && ($usercorriendo eq "root"))
	{
		syslog $syslog_priority, "ACCION 11 : Se solicita eliminar el usuario/principal con nombre ---$usuario--- del sistema" if ($verbose==1);
		my $id_princ_usuario = $error_general;
		my $existe_userid_resultado_usu_grupo_orig = $error_general;
		my $resultado_usu_grupo_orig = comprobar_si_pers_o_grupo_y_poner_nombre_grupo_bien($usuario);
		my $existe_resultado_usu_grupo_orig = existe_usuario($resultado_usu_grupo_orig);
		if ($existe_resultado_usu_grupo_orig == 1)
		{
			my $userid_resultado_usu_grupo_orig = sacar_userid($resultado_usu_grupo_orig);
			my $cosa_baja_es_pers_o_grupo = tipo_principal_es_persona($userid_resultado_usu_grupo_orig);
			if ($cosa_baja_es_pers_o_grupo == 0)
			{
				my @grupos_es_prop_usuario_de_baja = sacar_grupos_de_propietario($userid_resultado_usu_grupo_orig);
				my $grupo_que_toca = "";
				my $id_usu_grupo_que_toca = 0;
				my $id_princ_usu_grupo_que_toca = 0;

				###	ELIMINANDO GRUPOS DE USUARIO PARA EVITAR GRUPOS HUERFANOS....
				foreach $grupo_que_toca (@grupos_es_prop_usuario_de_baja) {
					$id_usu_grupo_que_toca = sacar_userid($grupo_que_toca);
					$id_princ_usu_grupo_que_toca = sacar_principalid($id_usu_grupo_que_toca);
					elimina_usuario($id_princ_usu_grupo_que_toca);
				}

				### AHORA SI ELIMINANDO EL PRINCIPAL DEL USUARIO
				$id_princ_usuario = sacar_principalid($userid_resultado_usu_grupo_orig);
				comprobar_error_variable($id_princ_usuario);
				elimina_usuario($id_princ_usuario);
				print "OK";
			}
			elsif ($cosa_baja_es_pers_o_grupo == 1)
			{
				$id_princ_usuario = sacar_principalid($userid_resultado_usu_grupo_orig);
				elimina_usuario($id_princ_usuario);
				print "OK";
			}
		}
		elsif ($existe_userid_resultado_usu_grupo_orig == 0)
		{
			syslog $syslog_priority, "Intentando dar de baja el (principal) usuario ---$usuario--- pero es imposible porque no existe";
			func_remplazo_die("Intentando dar de baja el (principal) usuario ---$usuario--- pero es imposible porque no existe");
		}
	}
	else
	{
		syslog $syslog_priority, "Imposible dar de baja el usuario (case 11) faltan argumentos. Usuario vale --$usuario--";
		print "Imposible dar de baja el usuario (case 11) faltan argumentos. Usuario vale --$usuario--";
	}
}
case 12 {
	if (($usuario ne "") && ($coleccion ne "") && ($permisos ne ""))
	{
		syslog $syslog_priority, "ACCION 12 : Se solicita dar permisos por defecto ---$permisos--- sobre coleccion ---$coleccion--- de usuario ---$usuario---" if ($verbose==1);
		my $id_usuario_destino = sacar_userid($usuario);
		$mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener usuario id de usuario destino de colec ---$coleccion--- de usuario ---$usuario--- para fijar perm por defec en cole.';
		comprobar_error_variable($id_usuario_destino, $mensaje_fallo_gen);
		my $espersona = tipo_principal_es_persona($id_usuario_destino);
		if ($espersona != 0)
		{
			syslog $syslog_priority, "Pidiendo fijar permisos ---$permisos--- por defecto sobre una coleccion ---$coleccion--- de un principal ---$usuario--- que no es persona... No vale...";
			print "Pidiendo fijar permisos ---$permisos--- por defecto sobre una coleccion ---$coleccion--- de un principal ---$usuario--- que no es persona... No vale...";
		}

		my $id_colec = sacar_id_colecc_usuario_nombre($id_usuario_destino,'/'.$usuario.'/'.$coleccion.'/');

		if ($id_colec != 9987982389)
		{
			fijar_permisos_defect_col($id_colec,$permisos);
			print "OK";
		}
		else
		{
			syslog $syslog_priority, "No existe la coleccion ---$coleccion--- para fijar los permisos ---$permisos--- por defecto";
			print "No existe la coleccion ---$coleccion--- para fijar los permisos ---$permisos--- por defecto";
		}
	}
	else
	{
		syslog $syslog_priority, "Imposible fijar permisos por defecto en coleccion (case 12). Faltan argumentos. Usuario vale --$usuario--, coleccion --$coleccion-- y permisos por defecto vale --$permisos--";
		print "Imposible fijar permisos por defecto en coleccion (case 12). Faltan argumentos. Usuario vale --$usuario--, coleccion --$coleccion-- y permisos por defecto vale --$permisos--";
	}
}
case 13 {
	if (($usudest ne "") && ($coleccion ne ""))
	{
		syslog $syslog_priority, "ACCION 13 : Se solicita quitar permisos por defecto ---$permisos--- sobre coleccion ---$coleccion--- de usuario ---$usuario---" if ($verbose==1);
		my $id_colec = 0;
		my $id_usuario_destino = sacar_userid($usudest);
		my $id_princ = sacar_principalid($id_usuario_destino);
		$mensaje_fallo_gen = 'ERROR GRAVE : Imposible obtener usuario id de usuario destino de colec ---$coleccion--- de usuario ---$usudest--- para eliminar perm por defec en cole.';
		comprobar_error_variable($id_usuario_destino, $mensaje_fallo_gen);
		my $espersona = tipo_principal_es_persona($id_usuario_destino);

		if ($espersona != 0)
		{
			syslog $syslog_priority, "Pidiendo eliminar permisos ---$permisos--- por defecto sobre una coleccion ---$coleccion--- de un principal ---$usudest--- que no es persona... No vale...";
			func_remplazo_die("Pidiendo eliminar permisos ---$permisos--- por defecto sobre una coleccion ---$coleccion--- de un principal ---$usudest--- que no es persona... No vale...");
		}

		$id_colec = sacar_id_colecc_usuario_nombre($id_usuario_destino,'/'.$usudest.'/'.$coleccion.'/');

		if ($id_colec != 9987982389)
		{
			fijar_permisos_defect_col($id_colec,$permisos_defecto_nada);
			my @colecc_usuario_a_comp_si_perm_defecto = sacar_ids_colecc_usuario($id_usuario_destino);
			my $toca_col = "";
			my $permisos_defecto = "";
			my $testigo_a_fab = '0';
			foreach $toca_col (@colecc_usuario_a_comp_si_perm_defecto) {
				$permisos_defecto = ver_permisos_defecto_colecc($toca_col);
				if ($permisos_defecto ne "9987982389")
				{
					$testigo_a_fab = '1';
				}
			}

			if ($testigo_a_fab eq '0')
			{
				my @princs_con_perms_sobre_princ = sacar_permisos_de_principals_en_principal($id_princ);
				my $nprincs_con_perms_sobre_princ = scalar(@princs_con_perms_sobre_princ);
				if ($nprincs_con_perms_sobre_princ == '0')
				{
					foreach $toca_col (@colecc_usuario_a_comp_si_perm_defecto) {
						fijar_permisos_defect_col($toca_col,"defecto");
					}
				}
				my $id_princ = sacar_principalid($id_usuario_destino);
				fijar_permisos_defect_princ($id_princ,"defecto");
				syslog $syslog_priority, "Como era la unica coleccion con permisos por defecto reseteo toda la cuenta a permisos de fabrica" if ($verbose==1);

			}
			print "OK";
		}
		else
		{
			syslog $syslog_priority, "No existe la coleccion ---$coleccion--- para fijar los permisos ---$permisos--- por defecto";
			print "No existe la coleccion ---$coleccion--- para fijar los permisos ---$permisos--- por defecto";
		}
	}
	else
	{
		syslog $syslog_priority, "Imposible eliminar permisos por defecto en coleccion (case 13) faltan argumentos. Usuario vale --$usudest--, coleccion --$coleccion--";
		print "Imposible eliminar permisos por defecto en coleccion (case 13) faltan argumentos. Usuario vale --$usudest--, coleccion --$coleccion--";
	}
}
case 14 {
	if (($usudest ne "") && ($permisos ne ""))
	{
		syslog $syslog_priority, "ACCION 14 : Se solicita dar permisos por defecto ---$permisos--- sobre principal de usuario ---$usudest---" if ($verbose==1);
		my $id_princ = 0;
		my $id_usuario_destino = sacar_userid($usudest);
		$mensaje_fallo_gen = "ERROR GRAVE : Imposible obtener usuario id de usuario destino ---$usudest--- para fijar perm por defec en su principal.";
		comprobar_error_variable($id_usuario_destino, $mensaje_fallo_gen);
		my $toca_col = "";

		my $espersona = tipo_principal_es_persona($id_usuario_destino);
		if ($espersona != 0)
		{
			syslog $syslog_priority, "Pidiendo fijar permisos ---$permisos--- por defecto sobre un principal ---$usudest--- que no es persona... No vale...";
			func_remplazo_die("Pidiendo fijar permisos ---$permisos--- por defecto sobre un principal que no es persona... No vale...");
		}

		$id_princ = sacar_principalid($id_usuario_destino);

		if ($id_princ != 9987982389)
		{
			fijar_permisos_defect_princ($id_princ,$permisos);
			my $colpuntoin = sacar_id_colecc_usuario_nombre($id_usuario_destino,'/'.$usudest.'/.in/');
			my $colpuntoout = sacar_id_colecc_usuario_nombre($id_usuario_destino,'/'.$usudest.'/.out/');
			my @id_col_poner_defpriv_a_0 = sacar_ids_colecc_usuario($id_usuario_destino);
			foreach $toca_col (@id_col_poner_defpriv_a_0) {
				my $cole_tiene_perm_defecto = colecc_tiene_permisos_por_defecto($toca_col);
				if (($toca_col != $colpuntoin) && ($toca_col != $colpuntoout) && ($cole_tiene_perm_defecto == '1'))
				{
					fijar_permisos_defect_col($toca_col,$permisos_defecto_nada);
					syslog $syslog_priority, "Reseteando permisos para colid --$toca_col-- de usuario ---$usudest--- para evitar accesos no deseados" if ($verbose==1);

				}
				else
				{
					syslog $syslog_priority, "Evitando tocar coleccion con id ----$toca_col--- porque es una .in o .out" if ($verbose==1);
				}
			}
			print "OK";
		}
		else
		{
			syslog $syslog_priority, "El principal --$id_princ-- del usuario --$usudest-- no existe para poder fijar permisos por defecto";
			print "El principal --$id_princ-- del usuario --$usudest-- no existe para poder fijar permisos por defecto";
		}
	}
	else
	{
		syslog $syslog_priority, "Faltan argumentos para fijar permisos por defecto en principal (case 14) del usuario --$usudest--";
		print "Faltan argumentos para fijar permisos por defecto en principal (case 14) del usuario --$usudest--";
	}
}
case 15 {
	if ($usudest ne "")
	{
		syslog $syslog_priority, "ACCION 15 : Se solicita quitar permisos por defecto existentes sobre principal de usuario ---$usudest---" if ($verbose==1);
		my $id_princ = 0;
		my $id_usuario_destino = sacar_userid($usudest);
		$mensaje_fallo_gen = "ERROR GRAVE : Imposible obtener usuario id de usuario destino ---$usudest--- para quitar perm por defec en su principal.";
		comprobar_error_variable($id_usuario_destino, $mensaje_fallo_gen);
		my $toca_col = "";
		my $espersona = tipo_principal_es_persona($id_usuario_destino);
		if ($espersona != 0)
		{
			syslog $syslog_priority, "Pidiendo resetear permisos por defecto sobre un principal ---$usudest--- que no es persona... No vale...";
			func_remplazo_die("Pidiendo resetear permisos por defecto sobre un principal ---$usudest--- que no es persona... No vale...");
		}

		$id_princ = sacar_principalid($id_usuario_destino);

		my @id_col_poner_defpriv_a_def = sacar_ids_colecc_usuario($id_usuario_destino);

		if ($id_princ != 9987982389)
		{
			foreach $toca_col (@id_col_poner_defpriv_a_def) {
				fijar_permisos_defect_col($toca_col,"defecto");
				syslog $syslog_priority, "Poniendo a defecto permisos en colleciones como salva guardia en principal ---$usudest---" if ($verbose == 1);
			}
			fijar_permisos_defect_princ($id_princ,"defecto");
			print "OK";
		}
		else
		{
			syslog $syslog_priority, "El principal --$id_princ-- del usuario --$usudest-- no existe para poder resetear permisos por defecto sobre principal";
			print "El principal --$id_princ-- del usuario --$usudest-- no existe para poder resetear permisos por defecto sobre principal";
		}
	}
	else
	{
		print "Faltan argumentos para resetear permisos (case 15) por defecto en principal de ---$usudest---";
	}
}
case 16 {
	funcion_case_16();
}
case 17 {
	if (($grupo ne "") && ($dequien ne ""))
	{
		my $id_usuario_prop_grupo = sacar_userid($dequien);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden sacar miembros de un grupo ---$grupo--- de un usuario ---$usuario--- del que no podemos obtener su id.";
		comprobar_error_variable($id_usuario_prop_grupo, $mensaje_fallo_gen);
		my $espersona = tipo_principal_es_persona($id_usuario_prop_grupo);
		if ($espersona != 0)
		{
			syslog $syslog_priority, "No podemos sacar miembros de grupo ---$grupo--- de un usuario ---$dequien--- que no es persona....";
		}


		my $existe_grupo = existe_usuario($id_usuario_prop_grupo.$grupo);
		my $useridgrupo = sacar_userid($id_usuario_prop_grupo.$grupo);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden sacar miembros de un grupo ---$grupo--- que pertenece a un usuario ---$usuario---. No podemos sacar userid del grupo resultante.";
		comprobar_error_variable($useridgrupo, $mensaje_fallo_gen);
		my $esgrupo = tipo_principal_es_grupo($useridgrupo);

		if (($existe_grupo != 1) || ($esgrupo != 0))
		{
			syslog $syslog_priority, "No existe el grupo $id_usuario_prop_grupo.$grupo para el que sacar los usuarios (case 17)";
			func_remplazo_die("No existe el grupo $id_usuario_prop_grupo.$grupo para el que sacar los usuarios (case 17)");
		}

		my $princ_id_grupo_revisar = sacaid_princ_grupo($id_usuario_prop_grupo.$grupo);
		$mensaje_fallo_gen = "ERROR GRAVE : Nos piden sacar miembros de un grupo ---$grupo--- que pertenece a un usuario ---$usuario---. No podemos sacar principal del grupo resultante.";
		comprobar_error_variable($useridgrupo, $mensaje_fallo_gen);
		my @array_usuarios_grupo = saca_usuarios_grupo($princ_id_grupo_revisar);
		my $id_princ_usuario = 998798238;
		my $id_usu_princ = 998798238;
		my $nombre_id_usu = "";

		syslog $syslog_priority, "El grupo $grupo tiene los siguientes miembros : @array_usuarios_grupo\n";
		print ("El grupo $grupo tiene los siguientes miembros :\n");
		my @array_nombres_grupo_mostrar = ();

		foreach $id_princ_usuario (@array_usuarios_grupo) {
			$id_usu_princ = sacar_userid_principal($id_princ_usuario);
			$mensaje_fallo_gen = "ERROR GRAVE : Al rellenar array de nombres de usuarios de un grupo a mostrar no podemos sacar el id de usuario del principal --$id_princ_usuario--";
			comprobar_error_variable($id_usu_princ, $mensaje_fallo_gen);
			$nombre_id_usu = sacar_username_deidusu($id_usu_princ);
			$mensaje_fallo_gen = "ERROR GRAVE : Al rellenar array de nombres de usuarios de un grupo a mostrar no podemos sacar el nombre de usuario del userid --$id_usu_princ--";
			comprobar_error_variable_texto($nombre_id_usu, $mensaje_fallo_gen);
			push(@array_nombres_grupo_mostrar, $nombre_id_usu);
		}

		## SI TODO HA IDO BIEN IMPRIMIMOS
		my $nombre_que_toca = "";
		foreach $nombre_que_toca (@array_nombres_grupo_mostrar) {
			print "$nombre_que_toca\n";
		}
	}
	else
	{
		syslog $syslog_priority, "Para sacar miembros de grupo (case 17) de un usuario faltan argumentos. Propietario vale --$dequien-- y --$grupo--";
		print "Para sacar miembros de grupo (case 17) de un usuario faltan argumentos. Propietario vale --$dequien-- y --$grupo--";
	}
}
case 18 {
	if ($dequien ne "")
	{
		my $id_usuario_prop_grupo = sacar_userid($dequien);
		$mensaje_fallo_gen = 'ERROR GRAVE : Queriendo sacar los grupos de un propietario no podemos sacar el id de usuario de ---$dequien---';
		comprobar_error_variable($id_usuario_prop_grupo, $mensaje_fallo_gen);
		my $espersona = tipo_principal_es_persona($id_usuario_prop_grupo);
		if ($espersona != 0)
		{
			syslog $syslog_priority, "Intentando sacar grupos pertenecientes a ---$dequien--- pero que no es persona este principal...";
			func_remplazo_die("Intentando sacar grupos pertenecientes a ---$dequien--- pero que no es persona este principal...");
		}


		my @array_grupos_propietario = sacar_grupos_de_propietario($id_usuario_prop_grupo);
		my $grupo_propietario_quetoca = "";
		my $grupo_sin_id_usuario = "";
		syslog $syslog_priority, "El propietario --$dequien-- tiene los grupos : @array_grupos_propietario";
		print "El propietario --$dequien-- tiene los grupos : \n";
		foreach $grupo_propietario_quetoca (@array_grupos_propietario) {
			$grupo_sin_id_usuario = sacar_nombre_grupo_sin_userid($grupo_propietario_quetoca,$id_usuario_prop_grupo);
			print ("----$grupo_sin_id_usuario-----\n");
		}
	}
	else
	{
		syslog $syslog_priority, "Para sacar grupos de propietario (case 18) ---$dequien--- tenemos problemas porque faltan argumentos.";
		print "Para sacar grupos de propietario (case 18) ---$dequien--- tenemos problemas porque faltan argumentos.";
	}
}
case 19 {
	if (($usuario ne "") && ($coleccion ne "") && ($coldispname ne ""))
	{
		syslog $syslog_priority, "ACCION 19 : Se solicita cambiar display name de coleccion ---$coleccion--- del usuario ---$usuario--- pasando a ser el disp name ---$coldispname---" if ($verbose==1);
		my $id_usu_modif = sacar_userid($usuario);
		$mensaje_fallo_gen="ERROR GRAVE : Queriendo cambiar el display name de la coleccion ---$coleccion--- a ---$coldispname--- no podemos sacar el user id de ---$usuario--- de principal de coleccion";
		comprobar_error_variable($id_usu_modif, $mensaje_fallo_gen);
		my $espersona = tipo_principal_es_persona($id_usu_modif);
		my $id_colec_modif = 0;
		if ($espersona != 0)
		{
			syslog $syslog_priority, "No podemos actualizar display name de coleccion ---$coleccion--- poniendo ---$coldispname--- de usuario ---$usuario--- que no es persona....";
			func_remplazo_die("No podemos actualizar display name de coleccion ---$coleccion--- poniendo ---$coldispname--- de usuario ---$usuario--- que no es persona....");
		}

		$coleccion = '/'.$usuario.'/'.$coleccion.'/';
		$id_colec_modif = sacar_id_colecc_usuario_nombre($id_usu_modif,$coleccion);
		if ($id_colec_modif != 9987982389)
		{
			actualiza_display_name($id_colec_modif,$coldispname);
			syslog $syslog_priority, "El nuevo display name es ---$coldispname--- de la coleccion ---$coleccion--- del usuario ----$usuario-----";
			print "OK";
		}
		else
		{
			syslog $syslog_priority, "No existe la coleccion --$coleccion-- para el usuario --$usuario-- a la que poner el display name ---$coldispname---";
			func_remplazo_die("No existe la coleccion --$coleccion-- para el usuario --$usuario-- a la que poner el display name ---$coldispname---");
		}
	}
	else
	{
		syslog $syslog_priority, "Faltan argumentos para actualizar al display name ---$coldispname--- de la coleccion ---$coleccion--- del usuario ---$usuario---";
		print "Faltan argumentos para actualizar al display name ---$coldispname--- de la coleccion ---$coleccion--- del usuario ---$usuario---";
	}
}
case 20 {
	funcion_case_20();
}
case 21 {
	funcion_case_21();
}
case 22 {
	funcion_case_22();
}
case 23 {
	$dequien = $usuario;
	print "-----------------------------------------------------------------------------------------------------------------------------\n";
	funcion_case_16();
	print "-----------------------------------------------------------------------------------------------------------------------------\n";
	funcion_case_22();
	print "-----------------------------------------------------------------------------------------------------------------------------\n";
	funcion_case_20();
	print "-----------------------------------------------------------------------------------------------------------------------------\n";
	funcion_case_21();
	print "-----------------------------------------------------------------------------------------------------------------------------\n";
}
else	{
	print " \n";
	print " \n";
	print " \n";
	print "**********************************************************************************************************************************\n";
	print "**********************************************************************************************************************************\n";
	print "**********************************************************************************************************************************\n";
	print " \n";
	print "Please enter with -o the number of the request you need to carry out by looking at the example requests below.\n";
	print " \n";
	print " 1  -> CREATE COLLECTION. \n";
	print " 2  -> REMOVE COLLECTION. Syntax : $0 -r domain -o 2 -c collection_name -u user_principal_to_create_inside -v\n";
	print " 3  -> APPEND USER TO A GROUP OF AN OWNER (OWNERS ARE THE WAY OF UNIQUELY IDENTIFY A GROUP FROM A CONCRETE PRINCIPAL OR USER)\n";
	print " 4  -> REMOVE USER TO A GROUP OF AN OWNER (OWNERS ARE THE WAY OF UNIQUELY IDENTIFY A GROUP FROM A CONCRETE PRINCIPAL OR USER)\n";
	print " 5  -> GRANT CONCRETE PERMISSIONS TO A PRINCIPAL IN ANOTHER PRINCIPAL (PRINCIPALS ARE FINALLY JUST USERS)\n";
	print " 6  -> REVOKE PERMISSIONS TO A PRINCIPAL IN PRINCIPAL (PRINCIPALS ARE FINALLY JUST USERS)\n";
	print " 7  -> GRANT PERMISSIONS TO A PRINCIPAL (A USER FINALLY) IN A COLLECTION OF ANOTHER PRINCIPAL (ANOTHER USER FINALLY)\n";
	print " 8  -> REVOKE PERMISSIONS TO A PRINCIPAL (A USER FINALLY) IN A COLLECTION OF ANOTHER PRINCIPAL (ANOTHER USER FINALLY)\n";
	print " 9  -> CREATE GROUP OWNED BY USER (BY A PRINCIPAL FINALLY)\n";
	print " 10 -> REMOVE GROUP OWNED BY USER (BY A PRINCIPAL FINALLY)\n";
	print " 11 -> REMOVE PRINCIPAL/USER (AN ACCOUNT FINALLY WITH ALL THE COLLECTIONS)\n";
	print " 12 -> SET DEFAULT PERMISSIONS IN A COLLECTION OF A PRINCIPAL\n";
	print " 13 -> UNSET DEFAULT PERMISSIONS IN A COLLECTION OF A PRINCIPAL\n";
	print " 14 -> SET DEFAULT PERMISSIONS IN A PRINCIPAL \n";
	print " 15 -> UNSET DEFAULT PERMISSIONS IN A PRINCIPAL \n";
	print " 16 -> OBTAIN PRINCIPAL GRANTS FOR DISPLAYING THEM FOR EXAMPLE IN THE WEBMAIL....\n";
	print " 17 -> OBTAIN GROUP MEMBERS FROM A GROUP OWNED BY AN USER (A PRINCIPAL)\n";
	print " 18 -> OBTAIN GROUPS OWNED BY AN USER (OR PRINCIPAL)\n";
	print " 19 -> SET A COLLECTION'S (FROM A PRINCIPAL) DISPLAY NAME\n";
	print " 20 -> OBTAIN PERMISSIONS GRANTED TO OTHER USERS IN MY COLLECTIONS\n";
	print " 21 -> OBTAIN A LIST OF ALL CREATED USERS IN THE DAVICAL INSTANCE\n";
	print " 22 -> OBTAIN A LISTING WHICH DISPLAYS FROM A CONCRETE OWNER, GROUP:MEMBERS\n";
	print " 23 -> COMBINED LISTING OF 16,20,21,22\n";
	print " \n";
	print "**********************************************************************************************************************************\n";
	print " \n";
	print " Example syntax for all operations :\n";
	print " \n";
	print " 1  -> $0 -r domain -o 1 -c collection_name -u user_principal_to_create_inside -t 0 for calendar or 1 for addressbook -v\n";
	print " 2  -> $0 -r domain -o 2 -c collection_name -u user_principal_to_create_inside -v\n";
	print " 3  -> $0 -r domain -o 3 -u user_to_add -z owner_of_the_group_of_this_request -g groupname -v\n";
	print " 4  -> $0 -r domain -o 4 -u user_to_add -z owner_of_the_group_of_this_request -g groupname -v\n";
	print " 5  -> $0 -r domain -o 5 -u permissions_granted_to_user -w permissions_granted_in_principal -p READ OR READWRITE -v\n";
	print " 6  -> $0 -r domain -o 6 -u permissions_revoked_to_user -w permissions_revoked_in_principal -v\n";
	print " 7  -> $0 -r domain -o 7 -u permissions_granted_to_user -w permissions_granted_in_collection_of_principal -c collection -p READ or READWRITE -v\n";
	print " 8  -> $0 -r domain -o 8 -u permissions_granted_to_user -w permissions_granted_in_collection_of_principal -c collection -v\n";
	print " 9  -> $0 -r domain -o 9 -z user_owner_of_group -g groupname -v\n";
	print " 10 -> $0 -r domain -o 10 -z user_owner_of_group -g groupname -v\n";
	print " 11 -> $0 -r domain -o 11 -u user_principal_to_be_removed -v\n";
	print " 12 -> $0 -r domain -o 12 -u user_owning_the_collection_overwhich -p READ or READWRITE -c collection -v\n";
	print " 13 -> $0 -r domain -o 13 -w user_owning_the_collection_overwhich -c collection -v\n";
	print " 14 -> $0 -r domain -o 14 -w destination_principal -p READ OR READWRITE -v\n";
	print " 15 -> $0 -r domain -o 15 -w destination_principal -v\n";
	print " 16 -> $0 -r domain -o 16 -u user_principal_to_answer_for -v\n";
	print " 17 -> $0 -r domain -o 17 -z principal_user_owner_of_the_group -g the_own_group_of_the_query_for_obtain_members -v\n";
	print " 18 -> $0 -r domain -o 18 -z principal_user_owner_of_the_groups -v\n";
	print " 19 -> $0 -r domain -o 19 -u principal_with_collection_inside -c collection_name -d \"NEW DISPLAY NAME\" -v\n";
	print " 20 -> $0 -r domain -o 20 -u user_principal_to_query_for -v\n";
	print " 21 -> $0 -r domain -o 21 -v\n";
	print " 22 -> $0 -r domain -o 22 -z owner_to_query_for_the_listing -v\n";
	print " 22 -> $0 -r domain -o 23 -v\n";
	print " \n";
	print "**********************************************************************************************************************************\n";
	print "**********************************************************************************************************************************\n";
	print "**********************************************************************************************************************************\n";
	print " \n";
	print " \n";
	print " \n";
	syslog $syslog_priority, "No operation requested with -o modifier";
	}
}

$dbh->disconnect();
closelog();
