2023-04-05 14:43:27 +02:00
|
|
|
#include <QCoreApplication>
|
|
|
|
#include <QApplication>
|
|
|
|
#include <QDebug>
|
|
|
|
#include <QTimer>
|
2023-04-13 11:22:32 +02:00
|
|
|
#include <QFileInfo>
|
2023-04-05 14:43:27 +02:00
|
|
|
|
2023-06-19 15:59:17 +02:00
|
|
|
#ifdef __linux__
|
|
|
|
#include <stdlib.h> // system()
|
|
|
|
#endif
|
|
|
|
|
2023-04-05 14:43:27 +02:00
|
|
|
#include "message_handler.h"
|
2024-03-15 12:07:15 +01:00
|
|
|
#include <DeviceController/interfaces.h>
|
2023-11-16 14:16:31 +01:00
|
|
|
#include "commandline_parser.h"
|
2023-04-11 15:38:04 +02:00
|
|
|
|
2023-04-05 14:43:27 +02:00
|
|
|
#include <unistd.h>
|
2023-04-11 15:38:04 +02:00
|
|
|
#include <memory>
|
2023-04-14 09:06:45 +02:00
|
|
|
#include <QSharedMemory>
|
2023-05-19 15:33:40 +02:00
|
|
|
#include <QRunnable>
|
|
|
|
#include <QThreadPool>
|
2023-05-26 13:02:45 +02:00
|
|
|
#include <QDir>
|
2023-06-19 15:59:17 +02:00
|
|
|
#include <QProcess>
|
|
|
|
#include <QCommandLineParser>
|
|
|
|
#include <QStandardPaths>
|
2023-08-02 15:40:44 +02:00
|
|
|
#include <QMainWindow>
|
2023-11-16 14:16:31 +01:00
|
|
|
#include <QSettings>
|
2023-05-19 15:33:40 +02:00
|
|
|
|
2023-05-22 16:04:50 +02:00
|
|
|
#include "update.h"
|
2023-07-14 13:29:52 +02:00
|
|
|
#include "git/git_client.h"
|
|
|
|
#include "ismas/ismas_client.h"
|
2023-06-16 16:48:58 +02:00
|
|
|
#include "worker_thread.h"
|
|
|
|
#include "worker.h"
|
2023-08-02 15:40:44 +02:00
|
|
|
#include "mainwindow.h"
|
|
|
|
#include "utils.h"
|
2023-06-16 16:48:58 +02:00
|
|
|
|
2023-07-14 13:29:52 +02:00
|
|
|
#include <QThread>
|
2023-08-18 11:39:00 +02:00
|
|
|
#include <QtWidgets>
|
2023-09-09 14:30:53 +02:00
|
|
|
#include <QScopedPointer>
|
|
|
|
|
|
|
|
#if defined (Q_OS_UNIX) || defined (Q_OS_LINUX)
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#endif
|
2023-04-11 15:38:04 +02:00
|
|
|
|
2023-04-13 14:03:25 +02:00
|
|
|
#ifdef PTU5
|
|
|
|
#define SERIAL_PORT "ttymxc2"
|
|
|
|
#else
|
|
|
|
#define SERIAL_PORT "ttyUSB0"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// argv[1]: file to send to dc
|
2023-04-11 15:38:04 +02:00
|
|
|
int main(int argc, char *argv[]) {
|
2023-07-14 13:29:52 +02:00
|
|
|
QByteArray const value = qgetenv("LC_ALL");
|
2024-06-28 12:52:48 +02:00
|
|
|
if (value.isEmpty() || value != "C") {
|
2023-07-14 13:29:52 +02:00
|
|
|
qputenv("LC_ALL", "C");
|
2023-06-19 15:59:17 +02:00
|
|
|
}
|
2024-06-28 12:52:48 +02:00
|
|
|
|
|
|
|
|
2023-11-16 14:16:31 +01:00
|
|
|
// qputenv("XDG_RUNTIME_DIR", "/var/run/user/0");
|
2023-06-19 15:59:17 +02:00
|
|
|
|
2023-08-06 07:34:17 +02:00
|
|
|
openlog("ATB-UPDATE", LOG_PERROR | LOG_PID | LOG_CONS, LOG_USER);
|
|
|
|
|
2023-04-05 14:43:27 +02:00
|
|
|
QApplication a(argc, argv);
|
2023-06-19 15:59:17 +02:00
|
|
|
QApplication::setApplicationName("ATBUpdateTool");
|
2023-07-06 14:12:41 +02:00
|
|
|
QApplication::setApplicationVersion(APP_VERSION);
|
2023-04-05 14:43:27 +02:00
|
|
|
|
|
|
|
if (!messageHandlerInstalled()) { // change internal qt-QDebug-handling
|
2024-05-15 15:05:49 +02:00
|
|
|
atbInstallMessageHandler(nullptr);
|
|
|
|
//atbInstallMessageHandler(atbDebugOutput);
|
2023-08-06 07:34:17 +02:00
|
|
|
setDebugLevel(LOG_NOTICE);
|
2023-04-05 14:43:27 +02:00
|
|
|
}
|
|
|
|
|
2023-11-16 14:16:31 +01:00
|
|
|
CommandLineParser parser;
|
2023-06-19 15:59:17 +02:00
|
|
|
parser.process(a);
|
2023-11-16 14:16:31 +01:00
|
|
|
parser.readSettings();
|
|
|
|
|
|
|
|
QString repositoryUrl = parser.repositoryUrl();
|
2024-07-17 14:50:32 +02:00
|
|
|
|
|
|
|
if (repositoryUrl.endsWith('/')) {
|
|
|
|
repositoryUrl.chop(1);
|
|
|
|
}
|
|
|
|
|
2024-06-28 12:52:48 +02:00
|
|
|
QString gitSSHCommand("");
|
|
|
|
|
|
|
|
if (repositoryUrl.contains("ptu-config.atb-comm.de")) {
|
|
|
|
QByteArray const v = qgetenv("GIT_SSH_COMMAND");
|
|
|
|
if (v.isEmpty()) {
|
|
|
|
QString sshKeyFile("/opt/app/tools/atbupdate/.keys/id_ed25519_ptuConfig");
|
|
|
|
if (QFileInfo(sshKeyFile).exists()) {
|
|
|
|
gitSSHCommand = "ssh -i /opt/app/tools/atbupdate/.keys/id_ed25519_ptuConfig";
|
|
|
|
if (!qputenv("GIT_SSH_COMMAND", QByteArray(gitSSHCommand.toStdString().c_str()))) {
|
|
|
|
qCritical() << "ERROR: GIT_SSH_COMMAND not put into env. Exiting...";
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
qCritical() << "ERROR ssh-key-file" << sshKeyFile << "does not exists. Exiting...";
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
gitSSHCommand = QString(v.toStdString().c_str());
|
|
|
|
qCritical() << "WARNING GIT_SSH_COMMAND already set in enviroment:"
|
|
|
|
<< gitSSHCommand;
|
|
|
|
if (gitSSHCommand != "ssh -i /opt/app/tools/atbupdate/.keys/id_ed25519_ptuConfig") {
|
|
|
|
qCritical() << "ERROR" << gitSSHCommand << "wrong. Exiting...";
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-11-16 14:16:31 +01:00
|
|
|
QString plugInDir = parser.plugInDir();
|
|
|
|
QString plugInName = parser.plugInName();
|
|
|
|
QString workingDir = parser.workingDir();
|
2023-11-21 16:16:28 +01:00
|
|
|
QString iniFileName = parser.iniFileName();
|
2023-11-16 14:16:31 +01:00
|
|
|
bool const dryRun = parser.dryRun();
|
|
|
|
bool const noUpdatePsaHardware = parser.noUpdatePsaHardware();
|
|
|
|
bool const showYoctoVersion = parser.yoctoVersion();
|
|
|
|
bool const showYoctoInstallStatus = parser.yoctoInstallStatus();
|
|
|
|
bool const showExtendedVersion = parser.extendedVersion();
|
2023-11-21 09:46:11 +01:00
|
|
|
bool const alwaysDownloadConfig = parser.alwaysDownloadConfig();
|
|
|
|
bool const alwaysDownloadDC = parser.alwaysDownloadDC();
|
2023-06-19 15:59:17 +02:00
|
|
|
|
2023-11-16 14:16:31 +01:00
|
|
|
QString const rtPath = QCoreApplication::applicationDirPath();
|
2023-10-18 11:28:06 +02:00
|
|
|
|
2023-11-29 11:29:52 +01:00
|
|
|
int const machineNr = Utils::read1stLineOfFile("/mnt/system_data/machine_nr");
|
|
|
|
int const customerNr = Utils::read1stLineOfFile("/mnt/system_data/cust_nr");
|
|
|
|
int const zoneNr = Utils::read1stLineOfFile("/mnt/system_data/zone_nr");
|
|
|
|
QString const branchName = (zoneNr != 0)
|
|
|
|
? QString("zg1/zone%1").arg(zoneNr) : "master";
|
|
|
|
|
2023-11-16 14:16:31 +01:00
|
|
|
qInfo() << "pwd ......................" << rtPath;
|
|
|
|
qInfo() << "repositoryUrl ............" << repositoryUrl;
|
2024-06-28 12:52:48 +02:00
|
|
|
if (!gitSSHCommand.isEmpty()) {
|
|
|
|
qInfo() << "GIT_SSH_COMMAND .........." << gitSSHCommand;
|
|
|
|
}
|
2023-11-16 14:16:31 +01:00
|
|
|
qInfo() << "plugInDir ................" << plugInDir;
|
|
|
|
qInfo() << "plugInName ..............." << plugInName;
|
|
|
|
qInfo() << "workingDir ..............." << workingDir;
|
|
|
|
qInfo() << "dryRun ..................." << dryRun;
|
|
|
|
qInfo() << "noUpdatePsaHardware ......" << noUpdatePsaHardware;
|
2023-11-21 09:46:11 +01:00
|
|
|
qInfo() << "alwaysDownloadConfig ....." << alwaysDownloadConfig;
|
|
|
|
qInfo() << "alwaysDownloadDC ........." << alwaysDownloadDC;
|
2023-11-21 16:16:28 +01:00
|
|
|
qInfo() << "showYoctoVersion ........." << showYoctoVersion;
|
|
|
|
qInfo() << "showYoctoInstallStatus ..." << showYoctoInstallStatus;
|
|
|
|
qInfo() << "showExtendedVersion ......" << showExtendedVersion;
|
|
|
|
qInfo() << "iniFileName .............." << iniFileName;
|
2023-11-16 14:16:31 +01:00
|
|
|
qInfo() << "extended-version ........." << APP_EXTENDED_VERSION;
|
2023-11-29 11:29:52 +01:00
|
|
|
qInfo() << "machineNr ................" << machineNr;
|
|
|
|
qInfo() << "customerNr ..............." << customerNr;
|
|
|
|
qInfo() << "zoneNr ..................." << zoneNr;
|
2023-10-18 11:28:06 +02:00
|
|
|
|
2023-10-12 12:12:16 +02:00
|
|
|
if (showExtendedVersion) {
|
|
|
|
printf(APP_EXTENDED_VERSION"\n");
|
|
|
|
return 0;
|
|
|
|
}
|
2023-10-18 11:26:30 +02:00
|
|
|
if (showYoctoVersion) {
|
|
|
|
printf("%s\n", Worker::getATBUpdateToolYoctoVersion().toStdString().c_str());
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (showYoctoInstallStatus) {
|
|
|
|
printf("%s\n", Worker::getATBUpdateToolYoctoInstallationStatus().toStdString().c_str());
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2023-11-16 14:16:31 +01:00
|
|
|
|
|
|
|
QThread::currentThread()->setObjectName("main thread");
|
|
|
|
qInfo() << "Main thread" << QThread::currentThreadId();
|
|
|
|
|
|
|
|
|
2023-06-16 16:48:58 +02:00
|
|
|
if (!QDir(plugInDir).exists()) {
|
|
|
|
qCritical() << plugInDir
|
|
|
|
<< "does not exists, but has to contain dc-library";
|
2024-05-03 13:31:04 +02:00
|
|
|
if (noUpdatePsaHardware == false) {
|
|
|
|
exit(-1);
|
|
|
|
}
|
2023-06-16 16:48:58 +02:00
|
|
|
}
|
2023-07-06 16:54:01 +02:00
|
|
|
|
2023-06-19 15:59:17 +02:00
|
|
|
// before loading the library, delete all possible shared memory segments
|
|
|
|
#if defined Q_OS_LINUX || defined Q_OS_UNIX
|
|
|
|
// system("rm -rf /tmp/qipc*");
|
|
|
|
#else
|
|
|
|
#error "Only tested under UNIX/LINUX"
|
|
|
|
#endif
|
2023-05-26 13:02:45 +02:00
|
|
|
|
2023-09-06 09:10:14 +02:00
|
|
|
Worker worker(customerNr,
|
2023-07-17 16:54:18 +02:00
|
|
|
machineNr,
|
|
|
|
zoneNr,
|
2023-11-16 14:16:31 +01:00
|
|
|
repositoryUrl,
|
2023-07-17 16:54:18 +02:00
|
|
|
branchName,
|
2023-11-06 16:20:27 +01:00
|
|
|
plugInDir,
|
2023-09-06 09:10:14 +02:00
|
|
|
plugInName,
|
2023-07-14 13:29:52 +02:00
|
|
|
workingDir,
|
2023-11-06 16:20:27 +01:00
|
|
|
noUpdatePsaHardware,
|
2023-11-21 09:46:11 +01:00
|
|
|
alwaysDownloadConfig,
|
|
|
|
alwaysDownloadDC,
|
2023-07-19 16:45:43 +02:00
|
|
|
dryRun);
|
2023-07-14 13:29:52 +02:00
|
|
|
|
2023-11-06 16:20:27 +01:00
|
|
|
MainWindow mw(&worker);
|
2023-08-05 18:50:50 +02:00
|
|
|
worker.setMainWindow(&mw);
|
|
|
|
|
2023-08-02 15:40:44 +02:00
|
|
|
mw.setWindowFlags(Qt::Window | Qt::FramelessWindowHint);
|
2023-09-28 11:47:09 +02:00
|
|
|
mw.showFullScreen();
|
2023-08-02 15:40:44 +02:00
|
|
|
|
2023-07-14 13:29:52 +02:00
|
|
|
return a.exec();
|
2023-04-05 14:43:27 +02:00
|
|
|
}
|