mirror of
https://gitea.msk.dinamika-avia.ru/Constanta-Design/RRJServer.git
synced 2026-03-28 19:55:48 +03:00
481 lines
13 KiB
C++
481 lines
13 KiB
C++
#include <QMessageBox>
|
|
#include <QCoreApplication>
|
|
#include <QSqlError>
|
|
#include <QDateTime>
|
|
#include <QTime>
|
|
#include "interfacedatabaselms.h"
|
|
|
|
InterfaceDataBaseLMS::InterfaceDataBaseLMS(QWidget *ownerWidget, QObject *parent):
|
|
QObject(parent),
|
|
DataBaseLMS(ownerWidget),
|
|
ownerWidget(ownerWidget)
|
|
{
|
|
|
|
}
|
|
|
|
void InterfaceDataBaseLMS::slot_LanguageChanged(QString language)
|
|
{
|
|
qtLanguageTranslator.load(QString(QStringLiteral("translations/DataBaseLMS_")) + language, QStringLiteral("."));
|
|
QCoreApplication::installTranslator(&qtLanguageTranslator);
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::ConnectionToDB()
|
|
{
|
|
if(!createConnection())
|
|
{
|
|
QMessageBox::critical(ownerWidget, dbSettings.dbName, tr("Connection error: ") + db->lastError().text());
|
|
return false;
|
|
}
|
|
else
|
|
{
|
|
//QMessageBox::information(ownerWidget, dbName, tr("Connection is successful!"));
|
|
return true;
|
|
}
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::DisConnectionFromDB()
|
|
{
|
|
deleteConnection();
|
|
//QMessageBox::information(ownerWidget, dbName, tr("Disconnection is successful!"));
|
|
return true;
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::DBisConnected()
|
|
{
|
|
return isConnected();
|
|
}
|
|
|
|
|
|
//Инструкторы
|
|
|
|
bool InterfaceDataBaseLMS::AuthorizationInstructor(QString login, QString password)
|
|
{
|
|
if(! transactionBegin())
|
|
return false;
|
|
|
|
if(int id = selectUserID(DataBaseLMS::TypeUserDBInstructor, login, password))
|
|
{
|
|
if(isArchivedInstructor(id) || isLoggedInInstructor(id))
|
|
{
|
|
transactionEnd();
|
|
return false;
|
|
}
|
|
if(updateUserLoggedIn(DataBaseLMS::TypeUserDBInstructor, id, true))
|
|
return transactionEnd();
|
|
}
|
|
|
|
transactionEnd();
|
|
return false;
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::deAuthorizationInstructor(QString login)
|
|
{
|
|
if(! transactionBegin())
|
|
return false;
|
|
|
|
if(int id = selectUserID(DataBaseLMS::TypeUserDBInstructor, login))
|
|
{
|
|
if(updateUserLoggedIn(DataBaseLMS::TypeUserDBInstructor, id, false))
|
|
return transactionEnd();
|
|
}
|
|
|
|
transactionEnd();
|
|
return false;
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::deAuthorizationAllInstructors()
|
|
{
|
|
return updateAllUsersLoggedIn(DataBaseLMS::TypeUserDBInstructor,false);
|
|
}
|
|
|
|
QString InterfaceDataBaseLMS::getNameInstructorByLogin(QString login)
|
|
{
|
|
return selectUserNameByLogin(DataBaseLMS::TypeUserDBInstructor, login);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::getIdInstructorByLogin(QString login)
|
|
{
|
|
return selectUserID(DataBaseLMS::TypeUserDBInstructor, login);
|
|
}
|
|
|
|
QList<Instructor> InterfaceDataBaseLMS::getListInstructors()
|
|
{
|
|
return selectAllInstructors();
|
|
}
|
|
|
|
Instructor InterfaceDataBaseLMS::getInstructor(int id)
|
|
{
|
|
return selectInstructor(id);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::newInstructor()
|
|
{
|
|
return insertInstructor();
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::delInstructor(int id)
|
|
{
|
|
return deleteInstructor(id);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::editInstructor(Instructor instructor)
|
|
{
|
|
//Проверка корректности логина, имени, пароля
|
|
QList<Instructor> listInstructors = selectAllInstructors();
|
|
for(Instructor exist_instructor : listInstructors)
|
|
{
|
|
if(instructor.getName() == QStringLiteral("<instructor>"))
|
|
{//Имя не корректно!
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("Unacceptable instructor name has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
|
|
if(instructor.getLogin() == QStringLiteral("<login>"))
|
|
{//Логин не корректен!
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("Unacceptable instructor login has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
|
|
if(instructor.getPassword() == QStringLiteral("<password>"))
|
|
{//Пароль не корректный!
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("Unacceptable instructor password has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
|
|
if(instructor.getName() == exist_instructor.getName() && instructor.getID() != exist_instructor.getID())
|
|
{//Имя уже существует
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("An existing instructor name has been entered."));
|
|
return 0;
|
|
}
|
|
|
|
if(instructor.getLogin() == exist_instructor.getLogin() && instructor.getID() != exist_instructor.getID())
|
|
{//Логин уже существует!
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("An existing instructor login has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
return updateInstructor(instructor);
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::isAdminInstructor(int id)
|
|
{
|
|
return selectInstructorIsAdmin(id);
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::isArchivedInstructor(int id)
|
|
{
|
|
return selectUserArchived(DataBaseLMS::TypeUserDBInstructor, id);
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::isLoggedInInstructor(int id)
|
|
{
|
|
return selectUserLoggedIn(DataBaseLMS::TypeUserDBInstructor, id);
|
|
}
|
|
|
|
|
|
//Инструкторы
|
|
|
|
bool InterfaceDataBaseLMS::AuthorizationTrainee(QString login, QString password, QString classroom_name, QString computer_name)
|
|
{
|
|
if(! transactionBegin())
|
|
return false;
|
|
|
|
if(int id = selectUserID(DataBaseLMS::TypeUserDBTrainee, login, password))
|
|
{
|
|
if(isArchivedTrainee(id) || isLoggedInTrainee(id))
|
|
{
|
|
transactionEnd();
|
|
return false;
|
|
}
|
|
if(updateUserLoggedIn(DataBaseLMS::TypeUserDBTrainee, id, true))
|
|
return transactionEnd();
|
|
}
|
|
|
|
transactionEnd();
|
|
return false;
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::deAuthorizationTrainee(QString login)
|
|
{
|
|
if(! transactionBegin())
|
|
return false;
|
|
|
|
if(int id = selectUserID(DataBaseLMS::TypeUserDBTrainee, login))
|
|
{
|
|
if(updateUserLoggedIn(DataBaseLMS::TypeUserDBTrainee, id, false))
|
|
return transactionEnd();
|
|
}
|
|
|
|
transactionEnd();
|
|
return false;
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::deAuthorizationAllTrainees()
|
|
{
|
|
return updateAllUsersLoggedIn(DataBaseLMS::TypeUserDBTrainee, false);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::entryTraineeOnSimulator(int id_trainee)
|
|
{
|
|
TimingOfTrainee timing(id_trainee);
|
|
|
|
timing = selectTimingTrainee(id_trainee);
|
|
|
|
if(!timing.getID())
|
|
{//Еще нет записи
|
|
int timing_id = insertTimingTrainee(id_trainee);
|
|
timing.setID(timing_id);
|
|
|
|
if(!timing_id)
|
|
return 0;
|
|
}
|
|
|
|
timing.fixEntry();
|
|
|
|
return updateTimingTrainee(id_trainee, timing);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::exitTraineeFromSimulator(int id_trainee)
|
|
{
|
|
TimingOfTrainee timing(id_trainee);
|
|
|
|
timing = selectTimingTrainee(id_trainee);
|
|
|
|
if(!timing.getID())
|
|
{//Еще нет записи
|
|
int timing_id = insertTimingTrainee(id_trainee);
|
|
timing.setID(timing_id);
|
|
|
|
if(!timing_id)
|
|
return 0;
|
|
}
|
|
|
|
timing.fixExit();
|
|
|
|
return updateTimingTrainee(id_trainee, timing);
|
|
}
|
|
|
|
QString InterfaceDataBaseLMS::getNameTraineeOnComputer(QString computer_name)
|
|
{
|
|
return selectTraineeNameOnComputer(computer_name);
|
|
}
|
|
|
|
Trainee InterfaceDataBaseLMS::getTraineeOnComputer(QString computer_name)
|
|
{
|
|
return selectTraineeOnComputer(computer_name);
|
|
}
|
|
|
|
QString InterfaceDataBaseLMS::getNameTraineeByLogin(QString login)
|
|
{
|
|
return selectUserNameByLogin(DataBaseLMS::TypeUserDBTrainee, login);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::getIdTraineeByLogin(QString login)
|
|
{
|
|
return selectUserID(DataBaseLMS::TypeUserDBTrainee, login);
|
|
}
|
|
|
|
QList<Trainee> InterfaceDataBaseLMS::getListTraineesInGroup(int id)
|
|
{
|
|
return selectAllTraineesInGroup(id);
|
|
}
|
|
|
|
QList<Group> InterfaceDataBaseLMS::getListGroups()
|
|
{
|
|
return selectAllGroups();
|
|
}
|
|
|
|
QList<Trainee> InterfaceDataBaseLMS::getListTrainees()
|
|
{
|
|
return selectAllTrainees();
|
|
}
|
|
|
|
Trainee InterfaceDataBaseLMS::getTrainee(int id)
|
|
{
|
|
return selectTrainee(id);
|
|
}
|
|
|
|
Group InterfaceDataBaseLMS::getGroup(int id)
|
|
{
|
|
return selectGroup(id);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::newGroup()
|
|
{
|
|
return insertGroup();
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::delGroup(int id)
|
|
{
|
|
return deleteGroup(id);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::editGroup(Group group)
|
|
{
|
|
//Проверка корректности имени
|
|
QList<Group> listGroups = selectAllGroups();
|
|
for(Group exist_group : listGroups)
|
|
{
|
|
if(group.getName() == QStringLiteral("<group>"))
|
|
{//Имя не корректно!
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("Unacceptable group name has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
|
|
if(group.getName() == exist_group.getName() && group.getID() != exist_group.getID())
|
|
{//Имя уже существует
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("An existing group name has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
return updateGroup(group);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::newTaskAMM(TaskAmmFim task, int id_trainee)
|
|
{
|
|
return insertTaskAMM(task, id_trainee);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::delTaskAMM(int id)
|
|
{
|
|
return deleteTaskAMM(id);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::editTaskAMM(TaskAmmFim task)
|
|
{
|
|
return updateTaskAMM(task);
|
|
}
|
|
|
|
QList<TaskAmmFim> InterfaceDataBaseLMS::getListTasksAMMofTrainee(int id_trainee)
|
|
{
|
|
return selectTasksAMMofTrainee(id_trainee);
|
|
}
|
|
|
|
QList<TaskAmmFim> InterfaceDataBaseLMS::getListTasksFIMofTrainee(int id_trainee)
|
|
{
|
|
return selectTasksFIMofTrainee(id_trainee);
|
|
}
|
|
|
|
TaskAmmFim InterfaceDataBaseLMS::getTaskAMMbyID(int id_task)
|
|
{
|
|
return selectTaskAMMbyID(id_task);
|
|
}
|
|
|
|
TaskAmmFim InterfaceDataBaseLMS::getTaskFIMbyID(int id_task)
|
|
{
|
|
return selectTaskFIMbyID(id_task);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::newTaskFIM(TaskAmmFim task, int id_trainee)
|
|
{
|
|
return insertTaskFIM(task, id_trainee);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::delTaskFIM(int id)
|
|
{
|
|
deleteReportFIM(id);
|
|
return deleteTaskFIM(id);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::editTaskFIM(TaskAmmFim task)
|
|
{
|
|
return updateTaskFIM(task);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::replaceReportFIM(TaskAmmFim task)
|
|
{
|
|
deleteReportFIM(task.getID());
|
|
|
|
if(int report_id = insertReportFIM(task))
|
|
{
|
|
updateStatusTaskFIM(task.getID(), "checkup");
|
|
return report_id;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::changeStatusTaskFIM(int id_task, QString status)
|
|
{
|
|
return updateStatusTaskFIM(id_task, status);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::changeStatusTaskAMM(int id_task, QString status)
|
|
{
|
|
return updateStatusTaskAMM(id_task, status);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::newTrainee(int id_group)
|
|
{
|
|
return insertTrainee(id_group);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::delTrainee(int id)
|
|
{
|
|
return deleteTrainee(id);
|
|
}
|
|
|
|
int InterfaceDataBaseLMS::editTrainee(Trainee trainee)
|
|
{
|
|
//Проверка корректности логина, имени, пароля
|
|
QList<Trainee> listTrainees = selectAllTrainees();
|
|
for(Trainee exist_trainee : listTrainees)
|
|
{
|
|
if(trainee.getName() == QStringLiteral("<trainee>"))
|
|
{//Имя не корректно!
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("Unacceptable trainee name has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
|
|
if(trainee.getLogin() == QStringLiteral("<login>"))
|
|
{//Логин не корректен!
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("Unacceptable trainee login has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
|
|
if(trainee.getPassword() == QStringLiteral("<password>"))
|
|
{//Пароль не корректный!
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("Unacceptable trainee password has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
|
|
if(trainee.getName() == exist_trainee.getName() && trainee.getID() != exist_trainee.getID())
|
|
{//Имя уже существует
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("An existing trainee name has been entered."));
|
|
return 0;
|
|
}
|
|
|
|
if(trainee.getLogin() == exist_trainee.getLogin() && trainee.getID() != exist_trainee.getID())
|
|
{//Логин уже существует!
|
|
QMessageBox::critical(ownerWidget, tr("Editing error!"),
|
|
tr("An existing trainee login has been entered.\nThe changes will not be accepted."));
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
return updateTrainee(trainee);
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::isArchivedTrainee(int id)
|
|
{
|
|
return selectUserArchived(DataBaseLMS::TypeUserDBTrainee, id);
|
|
}
|
|
|
|
bool InterfaceDataBaseLMS::isLoggedInTrainee(int id)
|
|
{
|
|
return selectUserLoggedIn(DataBaseLMS::TypeUserDBTrainee, id);
|
|
}
|