Внутри приложения Asterisk (dialplan) мне нужно вставить в базу данных MSSQL звуковой файл.Я использую freeTDS для связи с БД.
Пример таблицы называется "testblob"
(id int identity, name varchar(50), audiofile varbinary(MAX))
Я пытаюсь с этим кодом:
exten => s,n,Set(arch=${FILE(/var/lib/asterisk/sounds/custom/myFile.wav)})
exten => s,n,Verbose(${arch})
exten => s,n,Set(RESULT=${SHELL(echo -e use "AVL \\ngo\\ninsert into testblob (name, audiofile) values ('mar',${arch})\\ngo"|tsql -H x.x.x.x -p 1433 -U sa -P x)})
Ноне работает наверняка из-за «специальных символов» внутри переменной de $ {arch}.Я знаю, что внутри $ arch находится информация о файле, но я предполагаю, что мне нужно прочитать его в двоичном или 64-кодированном виде или что-то в этом роде.
Вопрос: есть ли способ вставить этот myFile.wav напрямую изоболочка?Что-то вроде:
echo -e use "AVL \\ngo\\ninsert into testblob (name, audiofile) values ('mar',####MAGIC GOES HERE TO READ MYFILE.WAV###)\\ngo"|tsql -H x.x.x.x -p 1433 -U sa -P x