2021-05-11 18:22:00 +02:00
|
|
|
|
// swad_assignment_database.h: assignments operations with database
|
|
|
|
|
|
|
|
|
|
#ifndef _SWAD_ASG_DB
|
|
|
|
|
#define _SWAD_ASG_DB
|
|
|
|
|
/*
|
|
|
|
|
SWAD (Shared Workspace At a Distance),
|
|
|
|
|
is a web platform developed at the University of Granada (Spain),
|
|
|
|
|
and used to support university teaching.
|
|
|
|
|
|
|
|
|
|
This file is part of SWAD core.
|
2022-09-21 10:46:14 +02:00
|
|
|
|
Copyright (C) 1999-2022 Antonio Ca<EFBFBD>as Vargas
|
2021-05-11 18:22:00 +02:00
|
|
|
|
|
|
|
|
|
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 ***********************************/
|
|
|
|
|
/*****************************************************************************/
|
|
|
|
|
|
2021-05-18 14:40:18 +02:00
|
|
|
|
#include <mysql/mysql.h> // To access MySQL databases
|
|
|
|
|
|
2021-05-11 18:22:00 +02:00
|
|
|
|
#include "swad_assignment.h"
|
2021-09-13 23:55:28 +02:00
|
|
|
|
#include "swad_browser.h"
|
2021-05-13 12:50:36 +02:00
|
|
|
|
#include "swad_group.h"
|
2021-05-11 18:22:00 +02:00
|
|
|
|
|
|
|
|
|
/*****************************************************************************/
|
|
|
|
|
/***************************** Public prototypes *****************************/
|
|
|
|
|
/*****************************************************************************/
|
|
|
|
|
|
|
|
|
|
unsigned Asg_DB_GetListAssignmentsMyGrps (MYSQL_RES **mysql_res,
|
|
|
|
|
Dat_StartEndTime_t SelectedOrder);
|
|
|
|
|
unsigned Asg_DB_GetListAssignmentsAllGrps (MYSQL_RES **mysql_res,
|
|
|
|
|
Dat_StartEndTime_t SelectedOrder);
|
|
|
|
|
|
|
|
|
|
unsigned Asg_DB_GetDataOfAssignmentByCod (MYSQL_RES **mysql_res,long AsgCod);
|
|
|
|
|
unsigned Asg_DB_GetDataOfAssignmentByFolder (MYSQL_RES **mysql_res,
|
|
|
|
|
const char Folder[Brw_MAX_BYTES_FOLDER + 1]);
|
|
|
|
|
unsigned Asg_DB_GetAssignmentTitleAndTxtByCod (MYSQL_RES **mysql_res,long AsgCod);
|
2022-09-21 02:33:40 +02:00
|
|
|
|
void Asg_DB_GetAssignmentTitleByCod (long AsgCod,char Title[Asg_MAX_BYTES_ASSIGNMENT_TITLE + 1]);
|
2021-05-11 18:22:00 +02:00
|
|
|
|
void Asg_DB_GetAssignmentTxtByCod (long AsgCod,char Txt[Cns_MAX_BYTES_TEXT + 1]);
|
|
|
|
|
|
|
|
|
|
bool Asg_DB_CheckIfSimilarAssignmentExists (const char *Field,const char *Value,
|
|
|
|
|
long AsgCod);
|
|
|
|
|
|
|
|
|
|
long Asg_DB_CreateAssignment (const struct Asg_Assignment *Asg,const char *Txt);
|
|
|
|
|
void Asg_DB_UpdateAssignment (const struct Asg_Assignment *Asg,const char *Txt);
|
2021-10-24 16:55:47 +02:00
|
|
|
|
void Asg_DB_HideOrUnhideAssignment (long AsgCod,bool Hide);
|
2021-05-11 18:22:00 +02:00
|
|
|
|
|
|
|
|
|
void Asg_DB_RemoveAssignment (long AsgCod);
|
|
|
|
|
|
|
|
|
|
bool Asg_DB_CheckIfICanDoAssignment (long AsgCod);
|
|
|
|
|
|
|
|
|
|
unsigned Asg_DB_GetGrps (MYSQL_RES **mysql_res,long AsgCod);
|
2021-05-13 12:50:36 +02:00
|
|
|
|
void Asg_DB_CreateGroup (long AsgCod,long GrpCod);
|
2021-05-11 18:22:00 +02:00
|
|
|
|
void Asg_DB_RemoveGroup (long GrpCod);
|
|
|
|
|
void Asg_DB_RemoveGroupsOfType (long GrpTypCod);
|
2021-05-13 12:50:36 +02:00
|
|
|
|
void Asg_DB_RemoveGrpsAssociatedToAnAssignment (long AsgCod);
|
2021-05-11 18:22:00 +02:00
|
|
|
|
|
|
|
|
|
void Asg_DB_RemoveGrpsAssociatedToAsgsInCrs (long CrsCod);
|
|
|
|
|
void Asg_DB_RemoveCrsAssignments (long CrsCod);
|
|
|
|
|
|
|
|
|
|
void Asg_DB_UpdateNumUsrsNotifiedByEMailAboutAssignment (long AsgCod,
|
|
|
|
|
unsigned NumUsrsToBeNotifiedByEMail);
|
2021-10-04 14:36:35 +02:00
|
|
|
|
unsigned Asg_DB_GetUsrsFromAssignmentExceptMe (MYSQL_RES **mysql_res,long AsgCod);
|
2021-05-11 18:22:00 +02:00
|
|
|
|
|
2021-05-27 23:30:16 +02:00
|
|
|
|
unsigned Asg_DB_GetNumCoursesWithAssignments (HieLvl_Level_t Scope);
|
2021-05-11 18:22:00 +02:00
|
|
|
|
|
2021-05-27 23:30:16 +02:00
|
|
|
|
unsigned Asg_DB_GetNumAssignments (MYSQL_RES **mysql_res,HieLvl_Level_t Scope);
|
2021-05-11 18:22:00 +02:00
|
|
|
|
|
|
|
|
|
unsigned Asg_DB_GetNumAssignmentsInCrs (long CrsCod);
|
|
|
|
|
|
|
|
|
|
#endif
|