Skip to content

Commit

Permalink
Relax dependency constraint on ymlr open-api-spex#500 (open-api-spex#502
Browse files Browse the repository at this point in the history
)

According to OpenAPI spec v3.1, strings of format "byte" contain
base64-encoded values
  • Loading branch information
thbar authored and gmile committed Oct 3, 2022
1 parent def1794 commit 68ecf9e
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 2 deletions.
10 changes: 10 additions & 0 deletions lib/open_api_spex/cast/string.ex
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,16 @@ defmodule OpenApiSpex.Cast.String do
end
end

def cast(%{value: value, schema: %{format: :byte}} = ctx) when is_binary(value) do
case Base.decode64(value) do
{:ok, result} ->
{:ok, result}

_ ->
Cast.error(ctx, {:invalid_format, :base64})
end
end

@uuid_valid_characters [
?0,
?1,
Expand Down
2 changes: 1 addition & 1 deletion mix.exs
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ defmodule OpenApiSpex.Mixfile do
{:phoenix, "~> 1.3", only: [:dev, :test]},
{:plug, "~> 1.7"},
{:poison, "~> 3.0 or ~> 4.0 or ~> 5.0", optional: true},
{:ymlr, "~> 2.0", optional: true}
{:ymlr, "~> 2.0 or ~> 3.0", optional: true}
]
end

Expand Down
2 changes: 1 addition & 1 deletion mix.lock
Original file line number Diff line number Diff line change
Expand Up @@ -19,5 +19,5 @@
"plug_crypto": {:hex, :plug_crypto, "1.2.2", "05654514ac717ff3a1843204b424477d9e60c143406aa94daf2274fdd280794d", [:mix], [], "hexpm", "87631c7ad914a5a445f0a3809f99b079113ae4ed4b867348dd9eec288cecb6db"},
"poison": {:hex, :poison, "5.0.0", "d2b54589ab4157bbb82ec2050757779bfed724463a544b6e20d79855a9e43b24", [:mix], [{:decimal, "~> 2.0", [hex: :decimal, repo: "hexpm", optional: true]}], "hexpm", "11dc6117c501b80c62a7594f941d043982a1bd05a1184280c0d9166eb4d8d3fc"},
"telemetry": {:hex, :telemetry, "1.0.0", "0f453a102cdf13d506b7c0ab158324c337c41f1cc7548f0bc0e130bbf0ae9452", [:rebar3], [], "hexpm", "73bc09fa59b4a0284efb4624335583c528e07ec9ae76aca96ea0673850aec57a"},
"ymlr": {:hex, :ymlr, "2.0.0", "7525b6da40250777c35456017ef44f7faec06da254eafcf9f9cfb0d65f4c8cb7", [:mix], [], "hexpm", "f9301ad7ea377213b506f6e58ddffd1a7743e24238bb70e572ee510bdc2d1d5a"},
"ymlr": {:hex, :ymlr, "3.0.1", "c7b459262aa52cbfee5d324995ac1bff8c765983460b1a4bb792f0f4db392232", [:mix], [], "hexpm", "759ce05102f7cb741cc65148044443d330cc75c9abd0769d5735bbf522219309"},
}
10 changes: 10 additions & 0 deletions test/cast/string_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,16 @@ defmodule OpenApiSpex.CastStringTest do
assert error.format == :date
end

test "string with format (byte)" do
schema = %Schema{type: :string, format: :byte}
date_string = Base.encode64("hello")
assert {:ok, "hello"} = cast(value: date_string, schema: schema)
assert {:error, [error]} = cast(value: "not-a-base64-string", schema: schema)
assert error.reason == :invalid_format
assert error.value == "not-a-base64-string"
assert error.format == :base64
end

test "casts a string with valid uuid format" do
schema = %Schema{type: :string, format: :uuid}

Expand Down

0 comments on commit 68ecf9e

Please sign in to comment.