mirror of
https://github.com/acanas/swad-core.git
synced 2024-09-23 00:00:50 +02:00
128 lines
5.7 KiB
C
128 lines
5.7 KiB
C
// swad_group_database.h: types of groups and groups operations with database
|
|
|
|
#ifndef _SWAD_GRP_DB
|
|
#define _SWAD_GRP_DB
|
|
/*
|
|
SWAD (Shared Workspace At a Distance in Spanish),
|
|
is a web platform developed at the University of Granada (Spain),
|
|
and used to support university teaching.
|
|
|
|
This file is part of SWAD core.
|
|
Copyright (C) 1999-2024 Antonio Cañas Vargas
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License as
|
|
published by the Free Software Foundation, either version 3 of the
|
|
License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
/*****************************************************************************/
|
|
/********************************* Headers ***********************************/
|
|
/*****************************************************************************/
|
|
|
|
#include "swad_group.h"
|
|
#include "swad_parameter.h"
|
|
|
|
/*****************************************************************************/
|
|
/**************************** Public prototypes ******************************/
|
|
/*****************************************************************************/
|
|
|
|
void Grp_DB_LockTables (void);
|
|
|
|
long Grp_DB_CreateGroupType (const struct GroupType *GrpTyp);
|
|
void Grp_DB_CreateGroup (const struct Grp_Groups *Grps);
|
|
|
|
unsigned Grp_DB_GetGroupTypeDataByCod (MYSQL_RES **mysql_res,long GrpTypCod);
|
|
unsigned Grp_DB_GetMultipleEnrolmentOfAGroupType (MYSQL_RES **mysql_res,long GrpTypCod);
|
|
unsigned Grp_DB_GetGroupDataByCod (MYSQL_RES **mysql_res,long GrpCod);
|
|
|
|
bool Grp_DB_CheckIfGrpExists (long GrpCod);
|
|
bool Grp_DB_CheckIfGrpBelongsToCrs (long GrpCod,long CrsCod);
|
|
|
|
bool Grp_DB_CheckIfGrpTypNameExistsInCurrentCrs (const char *GrpTypName,long GrpTypCod);
|
|
bool Grp_DB_CheckIfGrpNameExistsForGrpTyp (long GrpTypCod,const char *GrpName,long GrpCod);
|
|
|
|
unsigned Grp_DB_CountNumUsrsInGrp (Rol_Role_t Role,long GrpCod);
|
|
unsigned Grp_DB_CountNumUsrsInNoGrpsOfType (Rol_Role_t Role,long GrpTypCod);
|
|
long Grp_DB_GetRamdomStdFromGrp (long GrpCod);
|
|
unsigned Grp_DB_GetUsrsFromCurrentGrpExceptMe (MYSQL_RES **mysql_res);
|
|
unsigned Grp_DB_GetTchsFromCurrentGrpExceptMe (MYSQL_RES **mysql_res);
|
|
|
|
bool Grp_DB_CheckIfIBelongToGrpsOfType (long GrpTypCod);
|
|
bool Grp_DB_CheckIfIBelongToGrp (long GrpCod);
|
|
bool Grp_DB_CheckIfUsrSharesAnyOfMyGrpsInCurrentCrs (long UsrCod);
|
|
|
|
unsigned Grp_DB_GetGrpTypesWithGrpsInCrs (MYSQL_RES **mysql_res,long CrsCod);
|
|
unsigned Grp_DB_GetAllGrpTypesInCrs (MYSQL_RES **mysql_res,long CrsCod);
|
|
|
|
unsigned Grp_DB_GetGrpTypesInCurrentCrsToBeOpened (MYSQL_RES **mysql_res);
|
|
|
|
unsigned Grp_DB_CountNumGrpsInCurrentCrs (void);
|
|
unsigned Grp_DB_CountNumGrpsInThisCrsOfType (long GrpTypCod);
|
|
unsigned Grp_DB_GetGrpsInCrs (MYSQL_RES **mysql_res,long CrsCod);
|
|
unsigned Grp_DB_GetGrpsOfType (MYSQL_RES **mysql_res,long GrpTypCod);
|
|
|
|
unsigned Grp_DB_GetLstCodGrpsInAllCrssUsrBelongs (MYSQL_RES **mysql_res,long UsrCod);
|
|
unsigned Grp_DB_GetLstCodGrpsOfAnyTypeInCurrentCrsUsrBelongs (MYSQL_RES **mysql_res,long UsrCod);
|
|
unsigned Grp_DB_GetLstCodGrpsOfATypeInCurrentCrsUsrBelongs (MYSQL_RES **mysql_res,long UsrCod,long GrpTypCod);
|
|
unsigned Grp_DB_GetLstCodGrpsWithFileZonesInCurrentCrsIBelong (MYSQL_RES **mysql_res);
|
|
unsigned Grp_DB_GetNamesGrpsUsrBelongsTo (MYSQL_RES **mysql_res,
|
|
long UsrCod,long GrpTypCod);
|
|
|
|
long Grp_DB_GetGrpTypeFromGrp (long GrpCod);
|
|
|
|
bool Grp_DB_CheckIfAssociatedToGrp (const char *Table,const char *Field,
|
|
long Cod,long GrpCod);
|
|
bool Grp_DB_CheckIfAssociatedToGrps (const char *Table,const char *Field,long Cod);
|
|
|
|
void Grp_DB_ChangeMandatoryEnrolmentOfAGrpTyp (long GrpTypCod,
|
|
bool NewMandatoryEnrolment);
|
|
void Grp_DB_ChangeMultipleEnrolmentOfAGrpTyp (long GrpTypCod,
|
|
bool NewMultipleEnrolment);
|
|
void Grp_DB_ChangeOpeningTimeOfAGrpTyp (long GrpTypCod,
|
|
bool MustBeOpened,time_t OpenTimeUTC);
|
|
void Grp_DB_ClearMustBeOpened (long GrpTypCod);
|
|
void Grp_DB_OpenGrpsOfType (long GrpTypCod);
|
|
|
|
void Grp_DB_OpenGrp (long GrpCod);
|
|
void Grp_DB_CloseGrp (long GrpCod);
|
|
void Grp_DB_EnableFileZonesGrp (long GrpCod);
|
|
void Grp_DB_DisableFileZonesGrp (long GrpCod);
|
|
void Grp_DB_ChangeGrpTypOfGrp (long GrpCod,long NewGrpTypCod);
|
|
void Grp_DB_ChangeRoomOfGrp (long GrpCod,long NewRooCod);
|
|
void Grp_DB_ResetRoomInGrps (long RooCod);
|
|
void Grp_DB_ChangeMaxStdsOfGrp (long GrpCod,unsigned NewMaxStds);
|
|
|
|
bool Grp_DB_CheckIfAvailableGrpTyp (long GrpTypCod);
|
|
|
|
void Grp_DB_RenameGrpTyp (long GrpTypCod,
|
|
const char NewNameGrpTyp[Grp_MAX_BYTES_GROUP_TYPE_NAME + 1]);
|
|
void Grp_DB_RenameGrp (long GrpCod,
|
|
const char NewNameGrp[Grp_MAX_BYTES_GROUP_NAME + 1]);
|
|
|
|
void Grp_DB_AddUsrToGrp (long UsrCod,long GrpCod);
|
|
|
|
void Grp_DB_RemoveUsrFromGrp (long UsrCod,long GrpCod);
|
|
void Grp_DB_RemUsrFromAllGrpsInCrs (long UsrCod,long CrsCod);
|
|
void Grp_DB_RemUsrFromAllGrps (long UsrCod);
|
|
|
|
void Grp_DB_RemoveUsrsFromGrpsOfCrs (long HieCod);
|
|
void Grp_DB_RemoveUsrsFromGrpsOfType (long GrpTypCod);
|
|
void Grp_DB_RemoveUsrsFromGrp (long GrpCod);
|
|
|
|
void Grp_DB_RemoveGrpTypesInCrs (long HieCod);
|
|
void Grp_DB_RemoveGrpType (long GrpTypCod);
|
|
|
|
void Grp_DB_RemoveGrpsInCrs (long CrsCod);
|
|
void Grp_DB_RemoveGrpsOfType (long GrpTypCod);
|
|
void Grp_DB_RemoveGrp (long GrpCod);
|
|
|
|
#endif
|