Я пытаюсь сканировать загруженные документы на наличие вирусов при загрузке пользователем с помощью дополнения Heroku Сканер вложений .
Я пытаюсь закодировать файл напрямую с помощью Poison.encode, но он выдает ошибку, поэтому не уверен, что это правильный метод.Любая помощь приветствуется, ниже приведена моя попытка отправки HTTPoison-запроса и ошибка из Poison.encode!.
def scan do
url = System.get_env("ATTACHMENT_SCANNER_URL") <> "/requests"
token = System.get_env("ATTACHMENT_SCANNER_API_TOKEN")
headers =
[
"Authorization": "bearer " <> token,
"Content-Type": "multipart/form-data",
]
file_path = local_path_to_pdf_file
file = file_path |> File.read!
body = Poison.encode!(%{file: file})
res = HTTPoison.post(url, body, headers, recv_timeout: 40_000)
end
Poison.encode (file) error:
iex(3)> Poison.encode(file)
** (FunctionClauseError) no function clause matching in Poison.Encoder.BitString.chunk_size/3
The following arguments were given to Poison.Encoder.BitString.chunk_size/3:
# 1
<<226, 227, 207, 211, 13, 10, 49, 48, 51, 32, 48, 32, 111, 98, 106, 13, 60, 60,
47, 76, 105, 110, 101, 97, 114, 105, 122, 101, 100, 32, 49, 47, 76, 32, 50,
53, 50, 53, 51, 52, 51, 47, 79, 32, 49, 48, 53, 47, 69, 32, ...>>
# 2
nil
# 3
1
ps.Мне нужно отправить файл напрямую, и я не могу разместить образ публично, поэтому примеры node.js в документации не будут работать.