Ruslan Polupan
Ruslan PolupanJuly 10, 2019, 8:29 a.m.

IMpos project. Part 001. Statement of the problem

Small introduction.

For me, programming is a hobby in order to keep my thought processes in good shape. Therefore, for sure there will be not quite professional approaches to solving a particular problem. Therefore, I will always be glad to any advice and criticism. I decided to participate in filling the Development Diaries section in order to structure and discipline my own development process.

The project was conceived as a set of tools for changing the settings of the M-Pos filling station operator's software. This set should allow technical support staff to quickly change system settings simultaneously on several (up to 200) objects without using manual execution of SQL queries. This will also allow non-IT employees to change settings, freeing up technical support time to solve more pressing problems.


The databases used are Firebird of the current version 3.0.4.

iMpos (MPos Instruments) assumes the use of the following database drivers:

  • QIBASE to work with the central database and gas station databases. Driver assembly is described here .
  • QSQLLITE for storing current program settings, user base and logging of performed operations, etc. Driver assembly is not required.

The current task is to change the name of the types of fuel (Summer/Winter) in the database of filling stations and on the fiscal receipt of the cash register. To do this, you need to make changes to the settings in the MIGRATEOPTIONS table in the gas station database. After that, in the process of closing the shift at the gas station and removing the Z-report, changes will occur in the fiscal memory of the cash register.

The general algorithm of the program:

  • Connect to the SQLite settings database. If it is missing create;
  • Get connection parameters to the Central Bank (central database). If missing, create a new entry and connect;
  • If user identification is required, call up the identification window. Carry out logging about the entrance;
  • Launching the main window of the application;
  • Calling the dialog box Names of fuel;
  • display a list of operating gas stations with the ability for the user to select individual gas stations, a separate region, all gas stations;
  • get a list of selected gas stations;
  • get the connection parameters to the database of each gas station;
  • ask the user for further actions View names or Set names ;
  • Connect in a separate thread to each gas station, depending on the task, either get data from the gas station (SELECT) or install (UPDATE). In progress, display the current state of the request, as well as the status of its execution.
  • upon successful receipt of the list of titles, display it and provide the ability to print information or save it to a *.xlsx file.
  • when setting parameters, display the process and completion status. log into the SQLite database;
We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

Дмитрий
  • July 10, 2019, 9:25 a.m.

Исправьте опечатку:
"iMpos (MPos Instruments) предполагает использование слКдующий драйверов баз данных:"

Ruslan Polupan
  • July 10, 2019, 10:45 a.m.

Спасибо, исправил.

Evgenii Legotckoi
  • July 11, 2019, 3:35 a.m.

Вопрос есть. Базы пользователей в SQLite. Там хранятся логины и пароли поьлзователей? Или просто какая-то общая информация с настройками под конкретного пользователя?

Ruslan Polupan
  • July 11, 2019, 3:47 a.m.

Пароль пользователя программы. Для отслеживания кто и когда сделал изменения и все. Пароли к базам хранятся самих базах и в зашифрованном виде. Ну и настройки системы хранятся там. а также логи действия и сформированные скрипты.

Evgenii Legotckoi
  • July 11, 2019, 3:50 a.m.

Понятно, а просто шифруете одни пароли, или сразу всю базу данных SQLite? Насколько знаю, есть плагин для шифрования SQLite базы данных.

Ruslan Polupan
  • July 11, 2019, 3:56 a.m.

Задумывался над этим, но в свете текщих задач в этом нет особой необходимости.

Comments

Only authorized users can post comments.
Please, Log in or Sign up
e
  • ehot
  • March 31, 2024, 8:29 p.m.

C++ - Тест 003. Условия и циклы

  • Result:78points,
  • Rating points2
B

C++ - Test 002. Constants

  • Result:16points,
  • Rating points-10
B

C++ - Test 001. The first program and data types

  • Result:46points,
  • Rating points-6
Last comments
k
kmssrFeb. 9, 2024, 12:43 a.m.
Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVADec. 25, 2023, 4:30 p.m.
Boost - static linking in CMake project under Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
J
JonnyJoDec. 25, 2023, 2:38 p.m.
Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
G
GvozdikDec. 19, 2023, 3:01 a.m.
Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Now discuss on the forum
G
GarApril 22, 2024, 11:46 a.m.
Clipboard Как скопировать окно целиком в clipb?
DA
Dr Gangil AcademicsApril 20, 2024, 1:45 p.m.
Unlock Your Aesthetic Potential: Explore MSC in Facial Aesthetics and Cosmetology in India Embark on a transformative journey with an msc in facial aesthetics and cosmetology in india . Delve into the intricate world of beauty and rejuvenation, guided by expert faculty and …
a
a_vlasovApril 14, 2024, 12:41 p.m.
Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
Павел Дорофеев
Павел ДорофеевApril 14, 2024, 8:35 a.m.
QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь
f
fastrexApril 4, 2024, 10:47 a.m.
Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…

Follow us in social networks