-
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
Add a built-in function to reverse arrays and strings #3736
Comments
Hey, can I pick this up ? |
Just a thought, the strings implementation should work on runes, not individual characters, to avoid unicode troubles we've had in other built-ins. |
@nityanandagohain of course! Thank you! Let us know if you need some sort of assistance. |
I tried to make the changes locally but I am not able to build and test on M1 machine, can I get any help
I did try to make it work bytecodealliance/wasmtime-go#53 (comment) , but wasn't successful With docker the image isn't available for arm64
|
Can you try |
🏓 Did you get unstuck? Let me know if you need more assistance here! 😃 |
@srenatus, is this available? |
@olamiko we haven't heard back, so I suppose it is available again. Go for it! Let me know if you could use any kind of assistance. |
ast: Updated the builtins list partially fixes open-policy-agent#3736 Signed-off-by: Olamide Omolola <omololaolamidex@gmail.com>
ast: Updated the builtins list partially fixes open-policy-agent#3736 Signed-off-by: Olamide Omolola <omololaolamidex@gmail.com>
Go right ahead @kristiansvalland 👍 We'll find another issue for @olamiko to work on when he returns. |
…ctions. 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>
…ctions. (#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 #3736 Signed-off-by: Kristian Svalland <kristian.svalland@gmail.com>
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>
OPA does not currently include a built-in function for reversing strings and arrays. While it's possible to write a comprehension that does this, it's a bit cumbersome. We can add two simple built-in functions for reversing strings and arrays:
The text was updated successfully, but these errors were encountered: