Skip to content

Commit

Permalink
wasm: Add native support for json.is_valid (#4204)
Browse files Browse the repository at this point in the history
wasm: Add support for WASM and simple tests.
internal: Add opa_json_is_valid to map of wasm built-ins.
docs: Indicate that WASM support is now available for json.is_valid.

Fixes #4140

Signed-off-by: Kristian Svalland <kristian.svalland@gmail.com>
  • Loading branch information
kristiansvalland authored Jan 11, 2022
1 parent 6090608 commit 3250a2c
Show file tree
Hide file tree
Showing 5 changed files with 27 additions and 1 deletion.
2 changes: 1 addition & 1 deletion docs/content/policy-reference.md
Original file line number Diff line number Diff line change
Expand Up @@ -488,7 +488,7 @@ The following table shows examples of how ``glob.match`` works:
| <span class="opa-keep-it-together">``output := urlquery.decode_object(string)``</span> | ``output`` is URL query parameter decoded ``string`` represented as an ``object`` | ``SDK-dependent`` |
| <span class="opa-keep-it-together">``output := json.marshal(x)``</span> | ``output`` is ``x`` serialized to a JSON string ||
| <span class="opa-keep-it-together">``output := json.unmarshal(string)``</span> | ``output`` is ``string`` deserialized to a term from a JSON encoded string ||
| <span class="opa-keep-it-together">``output := json.is_valid(string)``</span> | ``output`` is a ``boolean`` that indicated whether ``string`` is a valid JSON document | ``SDK-dependent`` |
| <span class="opa-keep-it-together">``output := json.is_valid(string)``</span> | ``output`` is a ``boolean`` that indicated whether ``string`` is a valid JSON document | |
| <span class="opa-keep-it-together">``output := yaml.marshal(x)``</span> | ``output`` is ``x`` serialized to a YAML string | ``SDK-dependent`` |
| <span class="opa-keep-it-together">``output := yaml.unmarshal(string)``</span> | ``output`` is ``string`` deserialized to a term from YAML encoded string | ``SDK-dependent`` |
| <span class="opa-keep-it-together">``output := yaml.is_valid(string)``</span> | ``output`` is a ``boolean`` that indicated whether ``string`` is a valid YAML document that can be decoded by `yaml.unmarshal` | ``SDK-dependent`` |
Expand Down
1 change: 1 addition & 0 deletions internal/compiler/wasm/wasm.go
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,7 @@ var builtinsFunctions = map[string]string{
ast.GlobMatch.Name: "opa_glob_match",
ast.JSONMarshal.Name: "opa_json_marshal",
ast.JSONUnmarshal.Name: "opa_json_unmarshal",
ast.JSONIsValid.Name: "opa_json_is_valid",
ast.ObjectFilter.Name: "builtin_object_filter",
ast.ObjectGet.Name: "builtin_object_get",
ast.ObjectRemove.Name: "builtin_object_remove",
Expand Down
22 changes: 22 additions & 0 deletions wasm/src/encoding.c
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@
#include <limits.h>

#include "json.h"
#include "malloc.h"
#include "value.h"

static const unsigned char base64_table[65] =
Expand Down Expand Up @@ -316,3 +317,24 @@ opa_value *opa_json_marshal(opa_value *a)

return opa_string_allocated(v, strlen(v));
}

OPA_BUILTIN
opa_value *opa_json_is_valid(opa_value *a)
{
if (opa_value_type(a) != OPA_STRING)
{
return NULL;
}


opa_string_t *s = opa_cast_string(a);
opa_value *r = opa_json_parse(s->v, s->len);

if (r == NULL)
{
return opa_boolean(false);
}

opa_free(r);
return opa_boolean(true);
}
1 change: 1 addition & 0 deletions wasm/src/encoding.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,5 +10,6 @@ opa_value *opa_base64_url_decode(opa_value *a);
opa_value *opa_base64_url_encode(opa_value *a);
opa_value *opa_json_unmarshal(opa_value *a);
opa_value *opa_json_marshal(opa_value *a);
opa_value *opa_json_is_valid(opa_value *a);

#endif
2 changes: 2 additions & 0 deletions wasm/tests/test.c
Original file line number Diff line number Diff line change
Expand Up @@ -1790,6 +1790,8 @@ void test_json(void)
{
test("json/marshal", opa_value_compare(opa_json_marshal(opa_string_terminated("string")), opa_string_terminated("\"string\"")) == 0);
test("json/unmarshal", opa_value_compare(opa_json_unmarshal(opa_string_terminated("\"string\"")), opa_string_terminated("string")) == 0);
test("json/is_valid_true", opa_cast_boolean(opa_json_is_valid(opa_string_terminated("\"string\"")))->v);
test("json/is_valid_false", !opa_cast_boolean(opa_json_is_valid(opa_string_terminated("\"string")))->v);
}

WASM_EXPORT(test_object)
Expand Down

0 comments on commit 3250a2c

Please sign in to comment.