我认为最好在此处跳过 graphql 并通过控制器进行操作。这是一个如何处理可下载CSV文件的伪示例,文件类型也可以使用put_resp_header处理。
CSV 控制器
def download_csv(conn, %{"id" => id}) do
fields = # Call fields from struct or DB
header = Enum.map(fields, &Phoenix.Naming.humanize/1)
items = # transform data more, Enum.map() |> etc...
csv = CSV.encode([header] ++ items) |> Enum.join
conn
|> put_resp_content_type("text/csv")
|> put_resp_header("content-disposition", ~s[attachment; filename="data.csv"])
|> text(csv)
end
路由器
get "/csv/:id/download_csv", CsvController, :download_csv
CSV 模板
<%= form_for @conn, Routes.customer_path(@conn, :download_csv, @customer.id), [method: :get], fn f -> %>
<button class="btn btn-primary">Download Full CDRs</button>
<% end %>