Сценарии - новая версия API
-
Пользователь @fanagor написал в Сценарии - новая версия API:
Добрый день. Пара вопросов.
- Команда this.execOS('export IAM_TOKEN=
yc iam create-token
') из сценария возвращает ошибку ...
При этом из терминала все хорошо выполняется.
Добрый день. Здесь команда оболочки, напрямую не запустится.
Попробуйте поместить строку в файл c расширением .sh и вызвать этот файл на выполнение:
this.execOS ('/home/pi/myscript.sh')
Для файла скрипта после сохранения нужно установить права на выполнение:chmod 777 /home/pi/myscript.sh
- Как передать значения из переменой в глобальную переменную используемую в проекте ?
Если переменную сценария в глобальную переменную проекта, то присвоить через global.set. Если переменной нет - она будет создана
global.set('myglobalvar', xx);
В другом сценарии можно считать:
let myxx = global.get('myglobalvar');
Или Вы хотите результат выполнения команды execOS присвоить?
- Команда this.execOS('export IAM_TOKEN=
-
@intrapro да, результат команды execOS
-
Пользователь @intrapro написал в Сценарии - новая версия API:
Добрый день. Здесь команда оболочки, напрямую не запустится.
Попробуйте поместить строку в файл c расширением .sh и вызвать этот файл на выполнение:
this.execOS ('/home/pi/myscript.shтот же самый результат.
18.05 21:35:09.144 Trigger LAMP_23
18.05 21:35:09.144 Started
18.05 21:35:09.145 execOS: /myscript8.sh
18.05 21:35:09.272 Stopped
18.05 21:35:09.305 execOS error: Error: Command failed: /myscript8.sh
/myscript8.sh: 1: /myscript8.sh: yc: not foundне хочет.
-
Пользователь @fanagor написал в Сценарии - новая версия API:
/myscript8.sh: 1: /myscript8.sh: yc: not found
не хочет.
Похоже, yc действительно не находит, возможно, пути нет PATH
Попробуйте в терминале выполнить команду, чтобы увидеть, откуда запускается ycwhich yc
И посмотрите текущее значение PATH, он должен включать путь до yc
echo $PATH
-
Пользователь @fanagor написал в Сценарии - новая версия API:
@intrapro да, результат команды execOS
Тогда можно без экспорта, напрямую считать результат в сценарии
script({ start() { this.execOS(`yc iam create-token`, 'saveToken'); }, saveToken(stdout) { this.log('stdout='+stdout); global.set('myToken', stdout); } });
-
Пользователь @intrapro написал в Сценарии - новая версия API:
this.execOS(
yc iam create-token
, 'saveToken');не понял в чем было дело, путь в $PATH был, но получилось сделать только прописав полный путь this.execOS('/root/yandex-cloud/bin/yc iam create-token','saveToken');
здесь, ок, спасибо.
Другая проблема при выполнении команды OS
this.execOS(curl -X POST -H "Authorization: Bearer ${global.get('myToken')}" --data-urlencode "text=Здравствуй мир" -d "lang=ru-RU&folderId=b1g39r55fbahkvak21ha" "https://tts.api.cloud.yandex.net/speech/v1/tts:synthesize" > aaa92.ogg
)или curl -X POST -H "Authorization: Bearer ${stdout}" --data-urlencode "text=Здравствуй мир" -d "lang=ru-RU&folderId=b1g39r55fbahkvak21ha" "https://tts.api.cloud.yandex.net/speech/v1/tts:synthesize" > aaa9.ogg
если из того же сценария где и считывается переменная в сценарийлог пишет:
20.05 21:24:17.379 Trigger LAMP_24
20.05 21:24:17.380 Started
20.05 21:24:17.386 execOS: curl -X POST -H "Authorization: Bearer Cgg..........
" --data-urlencode "text=Здравствуй мир" -d "lang=ru-RU&folderId=b1g39r55fbahkvak21ha" "https://tts.api.cloud.yandex.net/speech/v1/tts:synthesize" > aaa92.ogg
20.05 21:24:17.396 Stopped
20.05 21:24:17.481 execOS error: Error: Command failed: curl -X POST -H "Authorization: Bearer Cgg... --data-urlencode "text=Здравствуй мир" -d "lang=ru-RU&folderId=b1g39r55fbahkvak21ha" "https://tts.api.cloud.yandex.net/speech/v1/tts:synthesize" > aaa92.ogg
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
100 127 0 0 100 127 0 1788 --:--:-- --:--:-- --:--:-- 1788
curl: (92) HTTP/2 stream 1 was not closed cleanly: PROTOCOL_ERROR (err 1)20.05 21:24:17.481 stdout:
20.05 21:24:17.481 stderr: % Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
100 127 0 0 100 127 0 1788 --:--:-- --:--:-- --:--:-- 1788
curl: (92) HTTP/2 stream 1 was not closed cleanly: PROTOCOL_ERROR (err 1)при этом если в команду прописать не переменную а сам токен, все проходит. Из терминала и так и так все гуд.
-
Пользователь @fanagor написал в Сценарии - новая версия API:
Другая проблема при выполнении команды OS
this.execOS(curl -X POST -H "Authorization: Bearer ${global.get('myToken')}" --data-urlencode "text=Здравствуй мир" -d "lang=ru-RU&folderId=b1g39r55fbahkvak21ha" "https://tts.api.cloud.yandex.net/speech/v1/tts:synthesize" > aaa92.ogg
)
лог пишет: .....
curl: (92) HTTP/2 stream 1 was not closed cleanly: PROTOCOL_ERROR (err 1)при этом если в команду прописать не переменную а сам токен, все проходит. Из терминала и так и так все гуд.
Есть две версии:
- Токен содержит лишние символы в начале и в конце (перевод строки, пробелы), это все убрать перед сохранением
saveToken(stdout) { let myToken = stdout.replace(/^\s+/, '').replace(/\s+$/,''); global.set('myToken', myToken); this.log('myToken='+ global.get('myToken')+'!'); // Посмотреть, что здесь выводится }
- Менее вероятно - неверно берется из global или подстановка внутри строки неверно отрабатывает
let token = global.get('myToken'); this.log('token='+ token+'!'); // Посмотреть, что здесь this.execOS(`curl -X POST -H "Authorization: Bearer ${token}" --data-urlencode... `);
-
Пользователь @intrapro написал в Сценарии - новая версия API:
saveToken(stdout) {
let myToken = stdout.replace(/^\s+/, '').replace(/\s+$/,'');
global.set('myToken', myToken);
this.log('myToken='+ global.get('myToken')+'!'); // Посмотреть, что здесь выводится
}Отлично, помогло, действительно заползали лишние символы.
Спасибо !!
-
Не в эту ветку, но спрошу, по умолчанию IH действует от имени пользователя ROOT ?
root@ih-server-big:/opt/intrahouse-c#
Можно ли под другим пользователем "по умолчанию" ?
-
Пользователь @fanagor написал в Сценарии - новая версия API:
Не в эту ветку, но спрошу, по умолчанию IH действует от имени пользователя ROOT ?
root@ih-server-big:/opt/intrahouse-c#
Можно ли под другим пользователем "по умолчанию" ?Да, конечно, Вы можете создать своего пользователя и делать установку под ним. Но нужно дать ему достаточно прав для доступа:
- К папкам внутри /opt и /var/lib
- К периферии и портам, с которыми работает система
- Этот пользователь должен иметь права на sudo.
Запуск из-под sudo используется при установке пакетов через npm, так как IH ставит пакеты при установке плагинов и их обновлении прозрачно для пользователя. Используемая версия npm требует такой доступ. Возможно, в 5 версии использование sudo получится избежать.
-
Это сообщение удалено!
-
Добрый день. Как с помощью блок схем задать гистерезис включения отключения насоса ГВС? Прошу прощения если это уже обсуждалось.
-
Добрый день, коллеги. У меня сценарий получает данные от плагина через param и obj. При приходе запроса track=hello&artist=yellow&album=hits устройствам (актуатор аналоговый) присваиваются значения hello, yellow и hits соответственно. А при приходе запроса track=hello&artist=&album= устройствам присваивается hello, 0 (ноль) и 0 (ноль) соответственно. Как в сценарии определить отсутствие параметра и присвоить устройству вместо ноля символ пробела или пустую строку?
-
@int144, никак! Я пробовал по разному, но пробел, отсутствие символа и т.д. актуатору аналоговому присвоить нельзя. В своем "событийном" виджете при отсутствии событий просто отображаю "Нет событий".
-
@Alex_Jet, спасибо, понял. Жаль, конечно. А как выяснить, что пустой параметр - if(obj.artist === undefined)?
-
@int144, да, именно так.
-
@Alex_Jet, я так сделал, а в отладчике
01.06 19:57:45.696 assign PIHALL_TRACK5_5.value= Радио 7
01.06 19:57:45.696 assign PIHALL_ALBUM4_5.value=
01.06 19:57:45.696 assign PIHALL_ARTIST3_5.value=
undefined почему-то не срабатывает
-
@Alex_Jet, сработало только на if(obj.artist === "")
-
Добрый день! Поскажите, в чем может быть проблема:
Команда включает порт 5 (pin=5) на 5 сек (click=5) на ESP 8266/http://192.168.0.41/gpio?st=1&pin=5&click=5
Если посылать эту команду через Chrome, то все отрабытывает пормально (порт включается и выключается через 5 сек), но если вызывать из сценария
require ("http").get(`http://192.168.0.41/gpio?st=1&pin=5&click=5 `);
то порт остается включенным. Такое впечатление, что click=5 не отсылается. Как посмотреть в отлатчике, что там отсылается? У меня не видно отправляемую команду.
-
@gis Добрый день.
Попробуйте убрать последний пробелrequire ("http").get(`http://192.168.0.41/gpio?st=1&pin=5&click=5 `); // После 5 есть пробел require ("http").get(`http://192.168.0.41/gpio?st=1&pin=5&click=5`);