FreeTDS вставка BLOB внутри диалплан Asterisk - PullRequest
1 голос
/ 26 октября 2011

Внутри приложения 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

1 Ответ

1 голос
/ 27 октября 2011

Хорошо, поэтому способ сделать это в одной строке - использовать base64, например так:

(echo -e -n use "AVL \\ngo\\nexec spAVL_SetAlertIVR 1, '";(base64 myFile.wav|tr -d '\n');echo -n -e "'\\ngo") | tsql -H 192.168.1.111 -p 1433 -U sa -P x

Обратите внимание на использование "()" и "|"и трюк с использованием "tr -d" для удаления CR, оставленного командой base64.

Надеюсь, это поможет кому-то еще

...