forked from loafle/openapi-generator-original
[Elixir] Fixes issue with maps/dictionary not present in payload (#13874)
* Adds fix to deserialize nullable maps * Generate Samples
This commit is contained in:
@@ -19,13 +19,18 @@ defmodule {{moduleName}}.Deserializer do
|
||||
end
|
||||
|
||||
def deserialize(model, field, :map, mod, options) do
|
||||
model
|
||||
|> Map.update!(
|
||||
field,
|
||||
&Map.new(&1, fn {key, val} ->
|
||||
{key, Poison.Decode.decode(val, Keyword.merge(options, [as: struct(mod)]))}
|
||||
end)
|
||||
)
|
||||
maybe_transform_map = fn
|
||||
nil ->
|
||||
nil
|
||||
|
||||
existing_value ->
|
||||
Map.new(existing_value, fn
|
||||
{key, val} ->
|
||||
{key, Poison.Decode.decode(val, Keyword.merge(options, as: struct(mod)))}
|
||||
end)
|
||||
end
|
||||
|
||||
Map.update!(model, field, maybe_transform_map)
|
||||
end
|
||||
|
||||
def deserialize(model, field, :date, _, _options) do
|
||||
|
||||
@@ -21,13 +21,18 @@ defmodule OpenapiPetstore.Deserializer do
|
||||
end
|
||||
|
||||
def deserialize(model, field, :map, mod, options) do
|
||||
model
|
||||
|> Map.update!(
|
||||
field,
|
||||
&Map.new(&1, fn {key, val} ->
|
||||
{key, Poison.Decode.decode(val, Keyword.merge(options, [as: struct(mod)]))}
|
||||
end)
|
||||
)
|
||||
maybe_transform_map = fn
|
||||
nil ->
|
||||
nil
|
||||
|
||||
existing_value ->
|
||||
Map.new(existing_value, fn
|
||||
{key, val} ->
|
||||
{key, Poison.Decode.decode(val, Keyword.merge(options, as: struct(mod)))}
|
||||
end)
|
||||
end
|
||||
|
||||
Map.update!(model, field, maybe_transform_map)
|
||||
end
|
||||
|
||||
def deserialize(model, field, :date, _, _options) do
|
||||
|
||||
Reference in New Issue
Block a user