-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
topdown: Use json.Valid
instead of util.UnmarshalJSON
#4203
Merged
anderseknert
merged 1 commit into
open-policy-agent:main
from
kristiansvalland:feature/json-valid-native-go-method
Jan 10, 2022
Merged
topdown: Use json.Valid
instead of util.UnmarshalJSON
#4203
anderseknert
merged 1 commit into
open-policy-agent:main
from
kristiansvalland:feature/json-valid-native-go-method
Jan 10, 2022
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
…necessary allocations. Signed-off-by: Kristian Svalland <kristian.svalland@gmail.com>
anderseknert
approved these changes
Jan 10, 2022
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice! Thanks Kristian 👍
srenatus
approved these changes
Jan 10, 2022
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice
justinlindh-wf
added a commit
to justinlindh-wf/opa
that referenced
this pull request
Jan 12, 2022
commit dbf3e9c9817ea625e0868d83c6e56ebd75e8c248 Merge: 6572cf6e 24050684 Author: Justin Lindh <justin.lindh@webfilings.com> Date: Wed Jan 12 14:07:56 2022 -0700 Merge branch 'reachable_paths' of github.com:justinlindh-wf/opa into reachable_paths Signed-off-by: Justin Lindh <justin.lindh@webfilings.com> commit 6572cf6e040dbff50e4518ba646429b9ba0414ce Author: Justin Lindh <justin.lindh@webfilings.com> Date: Wed Jan 12 14:07:47 2022 -0700 ast: remove unnecessary array nesting and cleanup tests Signed-off-by: Justin Lindh <justin.lindh@webfilings.com> commit 2405068419e9299b12c43cdd09828e0009ba3fbd Merge: dd39b4bd 38d0df0 Author: Justin Lindh <justin.lindh@workiva.com> Date: Wed Jan 12 11:08:10 2022 -0700 Merge branch 'main' into reachable_paths commit dd39b4bdf340f46182a34058490f1ed1bd3dacf9 Author: Justin Lindh <justin.lindh@workiva.com> Date: Wed Jan 12 11:04:42 2022 -0700 Update docs/content/policy-reference.md Co-authored-by: Stephan Renatus <stephan@styra.com> commit 38d0df0 Author: Anders Eknert <anders@eknert.com> Date: Tue Jan 11 09:24:31 2022 +0100 cicd: Update release notes mentions (open-policy-agent#4207) Since Github will automatically link to user profiles mentioned by their username, _and_ create a "Contributors" section for the release notes with user avatars, it seems good to follow that convention. Signed-off-by: Anders Eknert <anders@eknert.com> commit c676a7e Author: wasm-updater <wasm-updater@github.com> Date: Tue Jan 11 06:49:24 2022 +0000 wasm: Update generated binaries commit 3250a2c Author: Kristian Svalland <54534849+kristiansvalland@users.noreply.github.com> Date: Tue Jan 11 07:47:33 2022 +0100 wasm: Add native support for json.is_valid (open-policy-agent#4204) 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 open-policy-agent#4140 Signed-off-by: Kristian Svalland <kristian.svalland@gmail.com> commit abc08cd8977cb677cbb28c6c55afe9e17658cf3a Author: Justin Lindh <justin.lindh@webfilings.com> Date: Mon Jan 10 16:44:09 2022 -0700 ast: rename test cases from yml to yaml Signed-off-by: Justin Lindh <justin.lindh@webfilings.com> commit 3fdce9e23406422a24b82f21a792c2ac92b8f650 Author: Justin Lindh <justin.lindh@webfilings.com> Date: Mon Jan 10 14:17:02 2022 -0700 ast: graph.reachable_paths is SDK-dependant Signed-off-by: Justin Lindh <justin.lindh@webfilings.com> commit 79d86d0a1af1c220eb4da180e85b6ebccab7738e Merge: 791f1bbc 04425f05 Author: Justin Lindh <justin.lindh@webfilings.com> Date: Mon Jan 10 13:13:31 2022 -0700 Merge branch 'reachable_paths' of github.com:justinlindh-wf/opa into reachable_paths commit 791f1bbc952919660f024f094b7e2579895c26e0 Merge: fe6fef47 6090608 Author: Justin Lindh <justin.lindh@webfilings.com> Date: Mon Jan 10 13:12:13 2022 -0700 Merge branch 'main' of github.com:open-policy-agent/opa into reachable_paths commit fe6fef470f4aea8035d7ab175ce20a53deab2052 Author: Justin Lindh <justin.lindh@webfilings.com> Date: Mon Jan 10 13:11:54 2022 -0700 ast: add graph.reachable_paths Signed-off-by: Justin Lindh <justin.lindh@webfilings.com> commit 04425f0543ba149cefde7a6880abac7d8161354b Merge: 1afc295c 6090608 Author: Justin Lindh <justin.lindh@workiva.com> Date: Mon Jan 10 12:56:34 2022 -0700 Merge branch 'main' into reachable_paths commit 6090608 Author: Anders Eknert <anders@eknert.com> Date: Mon Jan 10 20:51:39 2022 +0100 opa inspect: unhide command (open-policy-agent#4194) People aren't going to find it unless we show it's there. Signed-off-by: Anders Eknert <anders@eknert.com> commit 1afc295c6b246eecd383a02afb6c79a118bd7ffd Author: Justin Lindh <justin.lindh@webfilings.com> Date: Mon Jan 10 12:50:27 2022 -0700 ast: add graph.reachable_paths Signed-off-by: Justin Lindh <justin.lindh@webfilings.com> commit 8b33bca Author: Kristian Svalland <54534849+kristiansvalland@users.noreply.github.com> Date: Mon Jan 10 20:04:30 2022 +0100 topdown: Use `json.Valid` instead of `util.UnmarshalJSON` to avoid unnecessary allocations. (open-policy-agent#4203) Signed-off-by: Kristian Svalland <kristian.svalland@gmail.com> commit 4985e4b Author: Anders Eknert <anders@eknert.com> Date: Mon Jan 10 10:39:55 2022 +0100 docs: Consistent indentation (open-policy-agent#4201) Must have missed these last iteration.. Signed-off-by: Anders Eknert <anders@eknert.com> commit 75ba6bf Author: Corey Hinkle <bugg123@gmail.com> Date: Fri Jan 7 15:56:13 2022 -0500 Add detail-tab for collapsable markdown (open-policy-agent#4199) Default markdown renderer does not allow for unsafe combinations. Shortcode provided to wrap markdown that may contain URLs as opposed to allowing unsafe rendering. Signed-off-by: Corey Hinkle <bugg123@gmail.com> commit 3cf8839 Author: Dan Oliver <djoliver89@gmail.com> Date: Fri Jan 7 12:52:37 2022 +0000 docs/management-bundles: add hint that S3 regional endpoint should be used (open-policy-agent#4196) Global endpoints lead to 307 responses until they're fully provisioned; that in turn causes the Authorization header to not be forwarded, and the GET request thus fails. Signed-off-by: Dan Oliver <dan.oliver@iress.com> commit 829086a Author: Anders Eknert <anders@eknert.com> Date: Fri Jan 7 13:18:09 2022 +0100 Ensure http.send caching works in system.authz (open-policy-agent#4195) Fixes open-policy-agent#3946 Signed-off-by: Anders Eknert <anders@eknert.com> commit cf37313 Author: Anders Eknert <anders@eknert.com> Date: Fri Jan 7 09:50:24 2022 +0100 opa eval: add description to all formats (open-policy-agent#4191) Add description for `--format=source` and `--format=raw` to `opa eval -h` output. Signed-off-by: Anders Eknert <anders@eknert.com> commit 61c0c46 Author: Peter ONeill <33669114+peteroneilljr@users.noreply.github.com> Date: Fri Jan 7 08:29:58 2022 +0200 docs/ssh-and-sudo-authorization: Add Missing Filename (open-policy-agent#4192) Signed-off-by: Peter ONeill <peteroneilljr@gmail.com> commit b3ef19e Author: Matt Mahnke <mattmahn@users.noreply.github.com> Date: Thu Jan 6 15:03:31 2022 -0600 docs: fix typo for tls-cert-refresh-period (open-policy-agent#4190) Signed-off-by: Matt Mahnke <mattmahn@users.noreply.github.com> commit 52ddfd9 Author: Shuhei Kitagawa <shuheiktgw@users.noreply.github.com> Date: Thu Jan 6 17:58:27 2022 +0900 topdown: Support indexof_n built-in function (open-policy-agent#4172) Fixes open-policy-agent#4155 Signed-off-by: shuheiktgw <s-kitagawa@mercari.com> commit 449fdfe Author: José Carlos Chávez <jcchavezs@gmail.com> Date: Thu Jan 6 09:13:57 2022 +0100 chore: improves auth plugin resolution. (open-policy-agent#4175) * chore: improves auth plugin resolution. Currently when aiming to use a Plugin in credentials section, if the plugin is known then it will be resolved, if it isn't, it will be passed to the supported credentials and tried to be cast as HTTPAuthPlugin which ends up in a casting issue without further feedback on what was the plugin string. Signed-off-by: José Carlos Chávez <jcchavezs@gmail.com> commit 16f85a4 Author: Stephan Renatus <stephan.renatus@gmail.com> Date: Thu Jan 6 08:49:39 2022 +0100 website: update redirects (open-policy-agent#4103) The "Option 5" redirect never worked, the fragment (i.e. behind the #) never reaches the server, it's a client-side thing. Adds a redirect for the renamed contrib section. Signed-off-by: Stephan Renatus <stephan.renatus@gmail.com> commit c0a692d Author: Vlad Iovanov <vlad@aserto.com> Date: Thu Jan 6 08:42:22 2022 +0200 logging: Remove logger GetFields function (open-policy-agent#4116) This removes the GetFields function from the logger interface, as mentioned in open-policy-agent#4114. GetFields used to be called in one place, creating a new logger using fields from an http client afaict. I am not sure if my changes have the desired effect in that case, or how this was desired to work - since the fields of the client are always changing when making requests. Fixes open-policy-agent#4114. Signed-off-by: viovanov <vlad@aserto.com> commit ca6259c Author: Anders Eknert <anders@eknert.com> Date: Wed Jan 5 18:54:55 2022 +0100 docs: Fix integration policy (open-policy-agent#4185) `some id` left after policy cleanup caused the Rego compiler to rightfully protest when I tried integrating OPA as a library today. Signed-off-by: Anders Eknert <anders@eknert.com> commit 78f0ae2 Author: rvalkenaers <rien.valkenaers@gmail.com> Date: Wed Jan 5 16:57:59 2022 +0100 docs: fix configuration example (open-policy-agent#4184) Signed-off-by: rvalkenaers <rien.valkenaers@gmail.com> commit f22e9cc Author: Anders Eknert <anders@eknert.com> Date: Wed Jan 5 07:51:08 2022 +0100 Apply credentials masking on opa.runtime().config (open-policy-agent#4165) In order to prevent sensitive data to accidentally leak out into policies, reuse masking logic previously serving the /v1/config endpoint. Fixes open-policy-agent#4159 Signed-off-by: Anders Eknert <anders@eknert.com> commit 50dc871 Author: Shuhei Kitagawa <shuheiktgw@users.noreply.github.com> Date: Wed Jan 5 15:34:16 2022 +0900 topdown: Improve the builtin indexof function performance (open-policy-agent#4169) Signed-off-by: shuheiktgw <s-kitagawa@mercari.com> commit d3fbd53 Author: Anders Eknert <anders@eknert.com> Date: Tue Jan 4 19:22:53 2022 +0100 Build darwin/arm64 in post tag workflow (open-policy-agent#4182) Signed-off-by: Anders Eknert <anders@eknert.com> commit 67def9b Author: Anders Eknert <anders@eknert.com> Date: Tue Jan 4 18:35:32 2022 +0100 Prepare v0.37.0 development (open-policy-agent#4180) Signed-off-by: Anders Eknert <anders@eknert.com> commit c2b2c62 Author: Anders Eknert <anders@eknert.com> Date: Tue Jan 4 16:49:24 2022 +0100 Prepare v0.36.0 release (open-policy-agent#4178) Signed-off-by: Anders Eknert <anders@eknert.com> commit 0ddf1db Author: Anders Eknert <anders@eknert.com> Date: Thu Dec 30 20:25:32 2021 +0100 Add Open Service Mesh to ecosystem (open-policy-agent#4171) Also: * Add some links to Kubernetes authorization item * Add SPIFFE/SPIRE blog * Extend Rego tests to verify added/modified YAML files as valid The last point was intended to be for the integrations.yaml file only, but thinking more about it made sense not to limit the check to a single file. Signed-off-by: Anders Eknert <anders@eknert.com> commit 06664d0 Author: Shuhei Kitagawa <shuheiktgw@users.noreply.github.com> Date: Tue Dec 28 16:43:28 2021 +0900 ci: Update golangci-lint to v1.43.0 (open-policy-agent#4173) Signed-off-by: shuheiktgw <s-kitagawa@mercari.com> commit 31422b4 Author: wasm-updater <wasm-updater@github.com> Date: Mon Dec 27 11:49:38 2021 +0000 wasm: Update generated binaries commit 6f81c4a Author: Kristian Svalland <54534849+kristiansvalland@users.noreply.github.com> Date: Mon Dec 27 12:47:39 2021 +0100 Add `array.reverse(array)` and `strings.reverse(string)` built-in functions. (open-policy-agent#4161) The function `array.reverse` takes an array as an argument, and returns an array with a reversed order of elements. The function `strings.reverse` takes a string as an argument, and returns a string with a reversed order of unicode code points. WASM support is included for both built-ins. Fixes open-policy-agent#3736 Signed-off-by: Kristian Svalland <kristian.svalland@gmail.com> commit 328ffcd Author: yilinzeng <36651058+yzeng25@users.noreply.github.com> Date: Fri Dec 24 23:33:23 2021 +0800 docs/website add blog links for apisix blog (open-policy-agent#4168) Signed-off-by: yilin <yzeng25@wisc.edu>
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
While looking into #4140, I noticed that the topdown code for json.is_valid checks validity of json documents by unmarshaling them and checking if there is an error. This leads to allocations proportional to the size of the document, which could affect performance.
This change avoids unnecessary allocations and should offer improved speed and efficiency.
I do not think that changes to tests are necessary because:
Number
instead of float, but I think that difference is only important for unmarshaling, and not validating.Also, for reference, I wrote a simple benchmark to compare the two implementations here: https://github.com/kristiansvalland/json-valid-benchmark
For completeness of this PR, I include the results achieved on my local workstation here as well:
Hardware: cpu: Intel(R) Core(TM) i7-9750H CPU @ 2.60GHz