Skip to content

Latest commit

 

History

History
65 lines (41 loc) · 3.21 KB

README.md

File metadata and controls

65 lines (41 loc) · 3.21 KB

FieldMask

Build Status Coverage Status hex.pm version hex.pm downloads

FieldMask implements Partial Responses protocol of Google+ API purely in Elixir via algorithmic method rather than grammar way which is adopted by fieldmask.

It's the counterpart of JSON Mask in JavaScript and jsonmask in Python.

Installation

The package can be installed by adding ex_fieldmask to your list of dependencies in mix.exs:

def deps do
  [
    {:ex_fieldmask, "~> 0.3.0"} # replace version with newest one
  ]
end

Examples

iex> FieldMask.mask("a,b", %{"a" => 1, "b" => 2, "c" => 3})
{:ok, %{"a" => 1, "b" => 2}}

iex> FieldMask.mask("a/b", %{"a" => %{"b" => 2, "c" => 3}})
{:ok, %{"a" => %{"b" => 2}}}

iex> FieldMask.mask("a(b,c)", %{"a" => %{"b" => 1, "c" => 2, "d" => 3}, "e" => 4})
{:ok, %{"a" => %{"b" => 1, "c" => 2}}}

iex> FieldMask.mask("a/*/c", %{"a" => %{"b" => %{"c" => 2, "e" => 1}, "d" => %{ "c" => 4, "f" => 3}}})
{:ok, %{"a" => %{"b" => %{"c" => 2}, "d" => %{"c" => 4}}}}

iex> FieldMask.mask("a/b)", %{"a" => 1, "b" => 2, "c" => 3})
{:error, "Invalid text with mismatched brackets: a/b)"}

Check test folder to see more examples.

It returns {:ok, masked_json} or {:error, error_message}. masked_json is either a Map or a List in Elixir and error_message is a String. Besides, if text in invalid or data isn't a decoded JSON, exception would be raised. You are expected to rescue the exception or just let it crash catering to the actual condition.

Use Poison or other JSON related packages to encode/decode a JSON to/from inner data structure of Elixir.

One more thing

Take a look at json-mask#syntax for the syntax and grammar of Partial Responses protocol of Google+ API.

Unlike package fieldmask also in the Seniverse orgnization, this one adopt algorithmic way to parse descriptive text and mask your data object. By this way, it's not that strict while parsing text. For example, "a(b)c" is equivalent to "a(b),c" although you miss the comma ,. They can both pass the validation and compiled as %{"a" => %{"b" => %{}}, "c" => %{}} to do the masking job. This is intentional but you should always use the strict valid syntax.

Benchmark

See fieldmask_benchmark.

ChangeLog

CHANGELOG

License

Apache 2.0