You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
MiraMaX166 c5dd2ec810
fix readme in some project
3 years ago
..
layout fix design in project ubl-settings-info, ubl-settings-bootloader, ubl-settings-datetime 3 years ago
pdf fix design in project ubl-settings-info, ubl-settings-bootloader, ubl-settings-datetime 3 years ago
pic fix design in project ubl-settings-info, ubl-settings-bootloader, ubl-settings-datetime 3 years ago
README.md fix readme in some project 3 years ago

README.md

ТЕХНИЧЕСКОЕ ЗАДАНИЕ на разработку утилиты ubl-settings-datetime

  1. ОПИСАНИЕ:

    Графическое средство настройки даты и времени в ОС UBLinux

  2. ЭТАПЫ И СРОКИ СОЗДАНИЯ ПРИЛОЖЕНИЯ:

    1. Общий срок работ по созданию приложения составляет N дней:
      1. N дня - макет и дизайн приложения и его утверждение
      2. N дней - разработка приложения
      3. N дня - тестирование приложения и исправление ошибок
    2. Перечень этапов разработки приложения:
      1. Разработка макета и дизайна приложения
      2. Утверждение и доработка макета
      3. Создание работающего интерфейса, включая полную разработку действующих ярлыков, кнопок и т.д.
    3. Проектирование алгоритма работы приложения
    4. Написание работающего кода приложения, включая полноценно работающие элементы графического интерфейса, а также перевод (поддержка локализации En, Ru), самостоятельно
    5. Тестирование и исправление ошибок, самостоятельно
    6. Публикация
  3. ТЕХНОЛОГИЧЕСКИЕ ТРЕБОВАНИЯ:

    1. Приложение разрабатывается под нужды операционной системы UBLinux
    2. Использование фирменного логотипа компании
    3. Название приложения, техническое: ubl-settings-datetime (далее ${NAME_APPLICATION})
    4. Название приложения, публичное: Дата и время
    5. Стек технологий:
      1. Язык программирования: Bash или C(++)
      2. Приложение для разработки графического интерфейса: Glade 3
      3. Графические библиотеки: GTK3
      4. Операционная система разработки: UBLinux DB
    6. Структура:
      1. В исходных кодах использовать префикс корня CMAKE_INSTALL_PREFIX для сборки приложений. Например, CMAKE_INSTALL_PREFIX/share.
      2. Bash/C(++): Весь функционал сосредоточен в графической части, вызовы и исполнение процедур написаны на языках Bash, C(++) /usr/bin/${NAME_APPLICATION} (скомпилированный бинарный файл)
      3. Графическая часть, фронт /usr/share/${NAME_APPLICATION}/ui/${NAME_APPLICATION}.glade
      4. Стили виджетов GTK /usr/share/${NAME_APPLICATION}/css/${NAME_APPLICATION}.css
      5. Элементы изображений
        1. Иконки: /usr/share/icons/hicolor/scalable/apps/${NAME_APPLICATION}{*.png,*.svg} Файлы изображений png иконок должны иметь имена вида:
          • ru.ublinux.${NAME_APPLICATION}.svg
          • ru.ublinux.${NAME_APPLICATION}.${NAME_ICONS}.svg Где ${NAME_ICONS} - имя графического элемента, например: checked, warning, alert и т.д. Файлы изображений png иконок должны генерироваться из svg файла в размеры 16, 32, 48, 64 пикселей сценарием make-файла.
        2. Изображения: /usr/share/${NAME_APPLICATION}/ui/{*.png,*.svg}
      6. Локализация En/Ru
        1. Для локализации должен быть создан файл-шаблон ${NAME_APPLICATION}.pot, на его основе должны быть созданы сами po-файлы переводов на необходимые языки, через файл сборки из po-файлов компилируются mo-файлы и размещаются сценарием установки по указанному пути: /usr/share/locale/${LANG}/LC_MESSAGES/${FILE_MO} где ${LANG} - каталог с именем локали, например, "ru" или "ru_RU", ${FILE_MO} - файл локализации программы, например, "${NAME_APPLICATION}.mo"
        2. Вывод всех текстовых элементов осуществляется через средства локализации.
      7. Версия ПО
        1. Файл, в котором хранится версия - VERSION.md, находится в корне каталога проекта.
        2. При компиляции (через сценарий make-файла) данные из файла VERSION.md передаются в значение переменной (-ых) version_application в файлах-исходниках ПО.
  4. ТЕХНИЧЕСКОЕ ЗАДАНИЕ:

    1. Ярлык (desktop-файл):
      1. Type: Application
      2. Exec: ubl-settings-datetime
      3. Categories: X-UBL-SettingsManager;X-UBL-SystemSettings
    2. Главное окно:
      1. Требования к внешнему виду:
        1. Адаптивный (резиновый) дизайн.
        2. Наличие элементов интерфейса:
          1. Статических - не меняют свою ширину при изменении размеров окна или родительского элемента.
          2. Динамических - меняют свою ширину при изменении размеров окна или родительского элемента. Обычно занимают пространство от края до края окна или родительского элемента, либо пространство от рядом расположенного элемента до до края окна или родительского элемента.
        3. Минимальный размер окна до прекращения масштабирования 800 на 600 пикселей.
        4. Шапка в стиле приложений GTK3 с содержимым:
          1. Иконка приложения. Статический элемент. Выравнивание по левому краю.
          2. Кнопка с выпадающим списком "Загрузить" -> ("Загрузить глобальную конфигурацию, Загрузить локальную конфигурацию"). Статический элемент. Выравнивание по левому краю.
          3. Заголовок окна, название приложения. Выравнивание по центру между элементами.
          4. Кнопка с выпадающим списком "Сохранить" -> ("Сохранить глобальную и локальную конфигурацию, Сохранить глобальную конфигурацию, Сохранить локальную конфигурацию"). Статический элемент. Выравнивание по правому краю.
          5. Кнопка с иконкой с выпадающим списком -> "Справка, О приложении". Статический элемент. Выравнивание по правому краю.
          6. Стандартные элементы окна, кнопки "Свернуть, Минимизировать/На весь экран, Закрыть"
        5. В верхней части крупный логотип утилиты, с права от него краткое описание утилиты. Фон заполнен изображением. Статические элементы. Выравнивание по левому краю.
        6. Срока уведомления, представляющая собой полосу с инфографикой строки уведомлений. Динамический элемент. От края до края окна по горизонтали.
        7. Рабочая область.
      2. Требования к "Рабочей области". Динамический элемент. От края до края по горизонтали и вертикали окна. Выводятся группы настроек запуска:
        1. Блок с заголовком "Текущие дата и время". Динамический элемент. От края до края окна по горизонтали.
          1. лейбл "Время". Статический элемент. Выравнивание по левому краю.
          2. счётчик от 00 до 23 (часы). Статический элемент. Выравнивание по левому краю.
          3. лейбл ":" (разделитель). Статический элемент. Выравнивание по левому краю.
          4. счётчик от 00 до 59 (минуты). Статический элемент. Выравнивание по левому краю.
          5. лейбл "Дата". Статический элемент. Выравнивание по левому краю.
          6. поле ввода. Ввод даты в формате ДД.ММ.ГГГГ. Динамический элемент. Выравнивание по левому краю. Делит пространство с соседними элементами.
          7. кнопка с иконкой календаря. Вызов объекта датапикер (визуальное представление выбора даты). Статический элемент. Выравнивание по левому краю.
          8. кнопка "Синхронизировать". Синхронизация выставленных даты и времени с часами и датой системы. Неактивно, если выбраны значения "По умолчанию, DHCP, Вручную" чекбокса в блоке "Синхронизация через NTP". Динамический элемент. Выравнивание по левому краю. Делит пространство в равных долях с соседними элементами.
          9. кнопка "Синхронизировать аппаратное время". Синхронизация даты и времени с временем BIOS рабочей станции. Динамический элемент. Выравнивание по левому краю. Делит пространство в равных долях с соседними элементами.
        2. Блок с заголовком "Синхронизация через NTP". Динамический элемент. От края до края окна по горизонтали.
          1. комбобокс с вариантами выбора сервера: "Остановлено, По умолчанию, DHCP, Вручную". При выборе "По умолчанию", второе поле для ввода вручную становится заблокированным для манипуляций - текст введённого поля серый. При выборе "По умолчанию" в конфигурационный файл передаются значения: "NTPSERVERS=default". Статический элемент. Выравнивание по левому краю.
          2. поле ввода для ручного указания серверов. Неактивно, если выбраны значения "Отключено, Остановлено, По умолчанию, DHCP" комбобокса в блоке "Синхронизация через NTP". Динамический элемент. Выравнивание по левому краю. Делит пространство с соседними элементами.
        3. Блок с заголовком "Часовой пояс". Динамический элемент. От края до края окна по горизонтали.
          1. лейбл "Синхронизация аппаратного времени:". Статический элемент. Выравнивание по левому краю.
          2. комбобокс с вариантами "Локальное время, Время по UTC". Динамический элемент. Выравнивание по левому краю. Делит пространство с соседними элементами.
          3. лейбл "Регион:". Статический элемент. Выравнивание по левому краю.
          4. комбобокс. Локализованный перечень регионов. Динамический элемент. Выравнивание по левому краю. Делит пространство с соседними элементами.
          5. лейбл "Зона:". Статический элемент. Выравнивание по левому краю.
          6. комбобокс. Перечень городов с поправкой на часовой пояс. Например, "(UTC +06) Омск". Перечень регионов, локализация стандартными средствами. Динамический элемент. Выравнивание по левому краю. Делит пространство с соседними элементами.
  5. ОСОБЕННОСТИ

    1. При загрузке утилиты по умолчанию загружаются данные из локального конфигурационного файла (выполняются команды блоков "Чтение значений: из локального конфигурационного файла").
    2. Функции записи в локальный конфигурационный файл и чтения-записи в глобальный конфигурационный файл должны проходить процедуру повышения привилегий прав пользователя через polkit.
    3. Сохранение должно происходить только при наличии изменённых данных в элементах форм приложения, в противном случае выводить в информационной строке сообщение: "Нечего сохранять!".
    4. Кнопка "Загрузить" -> ("Загрузить глобальную конфигурацию, Загрузить локальную конфигурацию"). При нажатии на кнопку происходит открытие меню с пунктами: "Загрузить глобальную конфигурацию, Загрузить локальную конфигурацию". Загрузка текущей и глобальной конфигурации в системе через скрипт ubconfig (выполняются команды блоков "Чтение значений: из локального конфигурационного файла"), загрузка конфигурации из файла настроек ОС ublinux.ini (выполняются команды блоков "Чтение значений: из глобального конфигурационного файла").
    5. Кнопка "Сохранить" -> ("Сохранить глобальную и локальную конфигурацию). Сохраняет текущие настройки через скрипт ubconfig (выполняются команды блоков "Установить значение: в локальный конфигурационный файл") и в конфигурационный файл настроек ОС ublinux.ini (выполняются команды блоков "Установить значение: в глобальный конфигурационный файл"). При выборе пунктов "Сохранить глобальную конфигурацию, Сохранить локальную конфигурацию" происходит отдельное сохранение настроек.
    6. Кнопка с иконкой с выпадающим списком -> “Справка, О приложении”
      1. Справка - запуск браузера с переходом на ссылку:
        1. локализованный (ru_RU) вариант: https://wiki.ublinux.ru/ru/Программное_обеспечениерограммы_и_утилиты/Все/${NAME_APPLICATION} (далее ${URLWIKI})
        2. локализованный (en_EN) вариант: https://wiki.ublinux.com/ru/Программное_обеспечениерограммы_и_утилиты/Все/${NAME_APPLICATION} (далее ${URLWIKI})
      2. О приложении. Открывается диалоговое окно с выводом информации о программе:
      3. Заголовок окна по локализованному названию утилиты
        1. Копирайты, порядок:
          1. Иконка приложения
          2. Название утилиты
          3. Версия программы (переменная version_application)
          4. Название утилиты, локализованное
          5. Ссылка "Домашняя страница проекта" на https://ublinux.ru/
          6. Авторские права © ООО "Юбисофт", 2022 - $LASTYEAR
            • локализованный (en_EN) вариант: "Copyright © UBSoft LLC, 2022 - $LASTYEAR"
            • где $LASTYEAR - текущий год.
    7. Обработчик ошибок. Встроенный небольшой обработчик кодов внутренних ошибок, который должен передавать статус возникшей ошибки в строку уведомления. Например: "Невозможно прочитать значение параметра XXXXXX!"
    8. Строка уведомлений. Цвет в зависимости от сигнала:
      • песочный, пиктограмма "Птичка", сообщения об удачных загрузках или сохранениях конфигураций системы.
      • красный, пиктограмма "Восклицательный знак", сообщения об ошибках при сохранении, загрузке параметров конфигурации, при ошибках в работе программы, полученных от обработчика ошибок.
  6. КОМАНДЫ

    1. Справка, О приложении > Домашняя страница проекта: xdg-open ${URLWIKI} &
    2. Текущие дата и время
      1. Чтение значения:
        1. через средства функции на языке С(++)
      2. Установить значение:
        1. счётчики часы и минуты: date +%T -s "h:m:sec" (кнопка "Синхронизировать")
        2. дата: date +%Y%m%d -s "2000:06:14" (кнопка "Синхронизировать")
      3. Синхронизировать аппаратное время:
      4. Установить значение: hwclock --systohc (кнопка "Синхронизировать аппаратное время")
    3. Синхронизация через NTP
      1. Чтение значения:
        1. из локального конфигурационного файла: /usr/bin/ubconfig --default --source system get network NTPSERVERS
        2. из глобального конфигурационного файла: /usr/bin/ubconfig --default --source global get network NTPSERVERS
      2. Установить значение:
        1. "Остановлено" в локальный конфигурационный файл: /usr/bin/ubconfig --target system set network NTPSERVERS=stop в глобальный конфигурационный файл: /usr/bin/ubconfig --target global set network NTPSERVERS=stop
        2. "По умолчанию" в локальный конфигурационный файл: /usr/bin/ubconfig --target system set network NTPSERVERS=default в глобальный конфигурационный файл: /usr/bin/ubconfig --target global set network NTPSERVERS=default
        3. "DHCP" в локальный конфигурационный файл: /usr/bin/ubconfig --target system set network NTPSERVERS=dhcp в глобальный конфигурационный файл: /usr/bin/ubconfig --target global set network NTPSERVERS=dhcp
        4. "Вручную" в локальный конфигурационный файл: /usr/bin/ubconfig --target system set network NTPSERVERS=$VALUE в глобальный конфигурационный файл: /usr/bin/ubconfig --target global set network NTPSERVERS=$VALUE где $VALUE - перечень серверов, полученных из поля в блоке "Синхронизация через NTP", разделённых "," или ";".
      3. Если выбрано значение "По умолчанию", то неактивное поле ввода заполняется командой:
        • ubconfig --source default get [] NTPSERVERS_DEFAULT
      4. Проверка запущенных процессов синхронизации (systemd-timesyncd, ntpd, chronyd) и остановка этих сервисов сервисов, осуществляется выполнением команды /usr/bin/ubconfig remove network NTPSERVERS при выборе опции "Остановлено" из выпадающего списка блока "Синхронизация через NTP"
    4. Часовой пояс
      1. Синхронизация аппаратного времени:
        1. Чтение значений:
          • из локального конфигурационного файла: /usr/bin/ubconfig --default --source system get clock HWCLOCK_SYNC
          • из глобального конфигурационного файла: /usr/bin/ubconfig --default --source global get clock HWCLOCK_SYNC
        2. Установить значение:
          1. "Локальное время" в локальный конфигурационный файл: /usr/bin/ubconfig --target system set clock HWCLOCK_SYNC=localtime в глобальный конфигурационный файл: /usr/bin/ubconfig --target global set clock HWCLOCK_SYNC=localtime
          2. "Время по UTC" в локальный конфигурационный файл: /usr/bin/ubconfig --target system set clock HWCLOCK_SYNC=utc в глобальный конфигурационный файл: /usr/bin/ubconfig --target global set clock HWCLOCK_SYNC=utc
      2. Комбобокс "Регион", "Зона":
        1. Чтение значений:
          • из локального конфигурационного файла: /usr/bin/ubconfig --default --source system get clock ZONE
          • из глобального конфигурационного файла: /usr/bin/ubconfig --default --source global get clock ZONE
        2. Установить значение:
          • в локальный конфигурационный файл: /usr/bin/ubconfig --target system set clock ZONE=$VALUE
          • в глобальный конфигурационный файл: /usr/bin/ubconfig --target global set clock ZONE=$VALUE где $VALUE - сложение срок-значений из комбобокса "Регион" и "Зона" через символ "/", например "Asia/Omsk".
  7. ПОМОЩЬ И ПАРАМЕТРЫ ЗАПУСКА

    1. Помощь

      • Пример вывода:

        ubl-settings-datetime version: $VERSION GTK settings datetime for UBLinux

        Использование: ubl-settings-datetime [OPTIONS...] Параметры приложения: $OPTIONS

        Где $OPTIONS - параметры запуска, $VERSION - версия программы (переменная version_application).

    2. Параметры запуска:

      1. -h, --help - Показать параметры справки
      2. -V, --version - Показать текущую версию
      3. --lock-datetime - Блокировка изменения даты и времени
      4. --lock-timezone - Блокировка изменения часового пояса
      5. --lock-ntp-mode - Блокировка выбора режима NTP
      6. --lock-ntp-edit - Блокировка перечня NTP серверов
      7. --lock-save - Блокировка сохранения локальной и глобальной конфигурации
      8. --lock-save-local - Блокировка сохранения локальной конфигурации
      9. --lock-save-global - Блокировка сохранения глобальной конфигурации
      10. --lock-load-global - Блокировка загрузки глобальной конфигурации
    3. Действия при указанных параметрах:

      1. --lock-datetime - делать неактивными лейбл "Время:", счётчик (часы), лейбл ":", счётчик (минуты), лейбл "Дата:", поле ввода, кнопка с иконкой календаря.
      2. --lock-timezone - делать неактивными лейбл "Регион:", комбобокс с выбором регионов, лейбл "Зона:", комбобокс с выбором зон.
      3. --lock-ntp-mode - делать неактивным выпадающий список вариантов синхронизации NTP.
      4. --lock-ntp-edit - делать неактивным поле ввода списка серверов NTP.
      5. --lock-save - делать неактивной кнопку "Сохранить".
      6. --lock-save-local - делать неактивным пункт "Сохранить локальную конфигурацию" в выпадающем списке кнопки "Сохранить".
      7. --lock-save-global - делать неактивным пункт "Сохранить глобальную и локальную конфигурацию" и "Сохранить глобальную конфигурацию" в выпадающем списке кнопки "Сохранить".
      8. --lock-load-global - делать неактивным пункт "Сохранить глобальную и локальную конфигурацию" и "Загрузить глобальную конфигурацию" в выпадающем списке кнопки "Загрузить".
  8. ПРИБЛИЗИТЕЛЬНЫЙ МАКЕТ ПРИЛОЖЕНИЯ.

    1. Главное окно