Библиотека проекта oscript.io
для автоматизации использования различных настроек для командных приложений/скриптов OneScript.
Возможности:
используйте пакетный менеджер opm
из стандартной поставки дистрибутива oscript.io
opm install params
После чего доступно использование модулей и классов библиотеки через #Использовать params
в коде скриптов.
Примеры вызова:
my-app command --settings my-settings.json --options 2
или
my-app command --settings server.json;"storage.json"
или
my-app command --spec-settings-key server.json;"storage.json"
или при использовании файла по умолчанию params.json (или другого, установленного в коде продукта)
my-app command --options 1
{
"default": {
"--ibconnection": "/F./build/ib",
"--db-user": "Администратор",
"--db-pwd": "",
"--ordinaryapp": "0"
},
"vanessa": {
"--vanessasettings": "./tools/VBParams.json",
"--workspace": ".",
"--pathvanessa": "./tools/vanessa-behavior/vanessa-behavior.epf",
"--additional": "/DisplayAllFunctions /L ru"
}
}
Параметры команды (vanessa
) имеют более высокий приоритет, чем настройки ключа default
В ключе default
удобно указывать параметры, которые являются общими для нескольких команд.
default
{
"--ibconnection": "/F./build/ib",
"vanessa": {
"--vanessasettings": "./tools/VBParams.json",
}
}
{
"--ibconnection": "/F./build/ib",
"--db-user": "Администратор",
"--db-pwd": "",
"--ordinaryapp": "0",
"--vanessasettings": "./tools/VBParams.json",
"--workspace": ".",
"--pathvanessa": "./tools/vanessa-behavior/vanessa-behavior.epf",
"--additional": "/DisplayAllFunctions /L ru"
}
Возможно чтение вложенных файлов (по ссылке)
ReadFile
,{
"ReadFile": "main.json",
"ReadFile.server1c": "c:\tools\settings\server1c.json",
"ReadFile.storage": "./storage.json"
}
{
"таймаут": 10,
"ИспользоватьТаймаут": true,
"ИспользоватьТиповуюВыгрузку": false
}
или
{
"таймаут": 10,
"ИспользоватьТаймаут": Истина,
"ИспользоватьТиповуюВыгрузку": Ложь
}
При разработке очень желательно указывать один параметр всего единожды, в одном месте файла/файлов.
{
"v8version": "8.3.10.2299",
"bin": "c:/program Files (x86)/1cv8/%v8version%/bin/1cv8.exe"
}
{
// простой комментарий
"таймаут": 10 // комментарий-продолжение строки
}
В случае необходимости переопределения параметров запуска используется схема приоритетов.
Приоритет в порядке возрастания (от минимального до максимального приоритета)
params.json
(в корне проекта)
--settings ../env.json
(указание файла настроек вручную)
явно_заданный_префикс_*
(из переменных окружения)
ONESCRIPT_APP_
Описание:
--settings tools/vrunner.json
Например:
- Переопределение переменной окружения:
Допустим, в файле vrunner.json указана настройка
"--db-user":"Администратор"
а нам для определенного случая надо переопределить имя пользователя,
тогда можно установить переменную: set RUNNER_DBUSER=Иванов
и в данный параметр будет передано значение Иванов
Очистка значения после установки
set RUNNER_DBUSER=Иванов
set RUNNER_DBUSER=
в данном случаи установлено полностью пустое значение и имя пользователя будет взято из tools/vrunner.json, если оно там есть.
Установка пустого значения:
set RUNNER_DBUSER=""
set RUNNER_DBUSER=''
Если необходимо установить в поле пустое значение, тогда указываем кавычки и в параметр --db-user
будет установлена пустая строка.
Переопределение через параметры командной строки.
Любое указание параметра в командной строке имеет наивысший приоритет.
Вся библиотека работает по принципам защитного программирования, в т.ч. активно используются утверждения.
В случае возникновения ошибочных ситуаций немедленно выбрасываются исключения.
Используется для обычного/простого использования библиотеки в своем приложении.
// Выполнить основной анализ и получить финальные параметры с учетом командной строки, переменных среды, файлов настроек
//
// Параметры:
// Парсер - <ПарсерАргументовКоманднойСтроки> - ранее инициализированный парсер со всеми настройками командной строки (из пакета cmdline)
// Аргументы - <Массив>, необязательный - набор аргументов командной строки,
// Если не указан, используется штатная коллекция АргументыКоманднойСтроки
// КлючФайлаНастроек - <Строка>, необязательный - именованный параметр командной строки,
// который указывает на json-файл настройки
// Если не указан, используется ключ "--settings"
// ПрефиксПеременныхСреды - <Строка>, необязательный -
// Если не указан, используется ключ "ONESCRIPT_APP_"
//
// Возвращаемое значение:
// <Соответствие> - итоговые параметры
//
Функция Прочитать(Парсер, Знач Аргументы = Неопределено,
Знач КлючФайлаНастроек = "", Знач ПрефиксПеременныхСреды = "") Экспорт
#Использовать params
Парсер = Новый ПарсерАргументовКоманднойСтроки();
Парсер.ДобавитьИменованныйПараметр("Параметр");
Параметры = ЧтениеПараметров.Прочитать(Парсер, АргументыКоманднойСтроки);
Если Параметры["Параметр"] = "Успешно" Тогда
ЗавершитьРаботу(0);
Иначе
ЗавершитьРаботу(1);
КонецЕсли;
// Получает значение параметра по имени ключа
// Предварительно нужно прочитать параметры с помощью метода Прочитать
//
// Параметры:
// КлючПараметра - <Строка> - произвольный ключ
//
// Возвращаемое значение:
// <Любой> - значение по ключу
//
// Возвращает ключ по умолчанию в файле настройки для всех параметров, которые не заданы в настройке команды
//
// Возвращаемое значение:
// <Строка> "default"
// Возвращает ключ командной строки для файла настроек
//
// Возвращаемое значение:
// <Строка> "--settings"
// Возвращает префикс переменных окружения по умолчанию
//
// Возвращаемое значение:
// <Строка> "ONESCRIPT_APP_"
// Возвращает имя по умолчанию для файла с настройками
//
// Возвращаемое значение:
// <Строка> "params.json"
// Возвращает префикс ключа для чтения вложенного файла настроек
//
// Возвращаемое значение:
// <Строка> "ReadFile"
//
+ метод Функция Прочитать(Парсер, Знач Аргументы = Неопределено,
Знач КлючФайлаНастроек = "", Знач ПрефиксПеременныхСреды = "") Экспорт
ЧтениеПараметров.Прочитать
Функция Получить(КлючПараметра) Экспорт
ЧтениеПараметров.Получить
// Установить текущий каталог проекта-клиента
//
// Параметры:
// ПарамТекущийКаталогПроекта - <Строка> - путь каталога
// Получить текущий каталог проекта-клиента
//
// Возвращаемое значение:
// <Строка> - путь каталога
// Установить путь к файлу настроек по умолчанию
//
// Параметры:
// НовыйПутьФайлаНастроек - <Строка> - путь файла
// Загрузить соответствие переменных окружения параметрам команд
//
// Параметры:
// Источник - <Соответствие или ФиксированноеСоответствие> - откуда загружаем
// ключ - имя переменной окружения
// значение - имя соответствующего ключа/параметра настройки
//
Управление выводом логов выполняется с помощью типовой для oscript-library настройки логирования через пакет logos.
Основной лог проекта имеет название oscript.lib.params
.