From 4a4fe6eb3ecf4f42e0e8c26cdd9bb46377de04dd Mon Sep 17 00:00:00 2001 From: azhi Date: Tue, 16 Jan 2018 18:18:00 +0300 Subject: [PATCH] allow passing binary data structs as attachments arc allows storing `%{filename: filename, binary: data}`, and now arc_ecto allows these structs to be accepted in `cast_attachments` fixes #54 --- lib/arc_ecto/schema.ex | 5 +++++ test/schema_test.exs | 5 +++++ 2 files changed, 10 insertions(+) diff --git a/lib/arc_ecto/schema.ex b/lib/arc_ecto/schema.ex index 28538b8..ea4382e 100644 --- a/lib/arc_ecto/schema.ex +++ b/lib/arc_ecto/schema.ex @@ -36,6 +36,11 @@ defmodule Arc.Ecto.Schema do # Allow casting Plug.Uploads {field, upload = %{__struct__: Plug.Upload}}, fields -> [{field, {upload, scope}} | fields] + # Allow casting binary data structs + {field, upload = %{filename: filename, binary: binary}}, fields + when is_binary(filename) and is_binary(binary) -> + [{field, {upload, scope}} | fields] + # If casting a binary (path), ensure we've explicitly allowed paths {field, path}, fields when is_binary(path) -> cond do diff --git a/test/schema_test.exs b/test/schema_test.exs index 4ab07a5..2812523 100644 --- a/test/schema_test.exs +++ b/test/schema_test.exs @@ -113,4 +113,9 @@ defmodule ArcTest.Ecto.Schema do changeset = TestUser.url_changeset(%TestUser{}, %{"avatar" => "/path/to/my/file.png"}) assert not called DummyDefinition.store({"/path/to/my/file.png", %TestUser{}}) end + + test_with_mock "casting binary data struct attachments", DummyDefinition, [store: fn({%{filename: "/path/to/my/file.png", binary: <<1, 2, 3>>}, %TestUser{}}) -> {:ok, "file.png"} end] do + changeset = TestUser.changeset(%TestUser{}, %{"avatar" => %{filename: "/path/to/my/file.png", binary: <<1, 2, 3>>}}) + assert called DummyDefinition.store({%{filename: "/path/to/my/file.png", binary: <<1, 2, 3>>}, %TestUser{}}) + end end