diff --git a/CHANGELOG.md b/CHANGELOG.md index d03ee5f4eb..125b321289 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,27 +3,118 @@ All notable changes to this project will be documented in this file. This project adheres to [Semantic Versioning](http://semver.org/). -## Unreleased +## 0.50.0 -### Runtime +This release contains a mix of new features, bugfixes, security fixes, optimizations and build updates related to +OPA's published images. + +### New Built-in Functions: JSON Schema Verification and Validation + +These new built-in functions add functionality to verify and validate JSON Schema ([#5486](https://github.com/open-policy-agent/opa/pull/5486)) (co-authored by @jkulvich and @johanfylling). + +- `json.verify_schema`: Checks that the input is a valid JSON schema object +- `json.match_schema`: Checks that the document matches the JSON schema + +See the [documentation](https://www.openpolicyagent.org/docs/v0.50.0/policy-reference/#object) for all details. + +### Annotations scoped to `package` carries across modules + +`package` scoped schema annotations are now applied across modules instead of only local to the module where +it's declared ([#5251](https://github.com/open-policy-agent/opa/issues/5251)) (authored by @johanfylling). This change may cause compile-time errors and behavioural changes to +type checking when the `schemas` annotation is used, and to rules calling the `rego.metadata.chain()` built-in function: + + - Existing projects with the same package declared in multiple files will trigger a `rego_type_error: package annotation redeclared` +error _if_ two or more of these are annotated with the `package` scope. + - If using the `package` scope, the `schemas` annotation will be applied to type checking also for rules declared in +another file than the annotation declaration, as long as the package is the same. + - The chain of metadata returned by the `rego.metadata.chain()` built-in function will now contain an entry for the +package even if the annotations are declared in another file, if the scope is `package`. + +### Remote bundle URL shorthand for `run` command + +To load a remote bundle using `opa run`, the `set` directive can be provided multiple times as shown below: +``` + $ opa run -s --set "services.default.url=https://example.com" \ + --set "bundles.example.service=default" \ + --set "bundles.example.resource=/bundles/bundle.tar.gz" \ + --set "bundles.example.persist=true" +``` + +The following command can be used as a shorthand to easily start OPA with a remote bundle ([#5674](https://github.com/open-policy-agent/opa/issues/5674)) (authored by @anderseknert): +``` +$ opa run -s https://example.com/bundles/bundle.tar.gz +``` + +### Performance Improvements for `json.patch` Built-in Function + +Performance improvements in `json.patch` were achieved with the introduction of a new `EditTree` data structure, +which is built for applying in-place modifications to an `ast.Term`, and can render the final result of all edits efficiently +by applying all patches in a JSON-Patch sequence rapidly, and then collapsing all edits at the end with minimal wasted `ast.Term` copying (authored by @philipaconrad). +For more details and benchmarks refer [#5494](https://github.com/open-policy-agent/opa/pull/5494) and [#5390](https://github.com/open-policy-agent/opa/pull/5390). + +### Surface decision log errors via status API + +Errors encountered during decision log uploads will now be surfaced via the Status API in addition to being logged. This +functionality should give users greater visibility into any issues OPA may face while processing, uploading logs etc ([#5637](https://github.com/open-policy-agent/opa/issues/5637)) (authored by @ashutosh-narkar). -- ast: Annotations scoped to package carries across module ([#5251](https://github.com/open-policy-agent/opa/issues/5251)). -- ast: strict check of unused vars is extended to include arguments ([#5602](https://github.com/open-policy-agent/opa/issues/5602)) +See the [documentation](https://www.openpolicyagent.org/docs/v0.50.0/management-status/#status-service-api) for more details. -### Breaking changes +### OPA Published Images Update All published OPA images now run with a non-root uid/gid. The `uid:gid` is set to `1000:1000` for all images. As a result -there is no longer a need for the `-rootless` image variant and hence it will be not be published after the current release. +there is no longer a need for the `-rootless` image variant and hence it will be not be published as part of future releases. This change is in line with container security best practices. OPA can still be run with root privileges by explicitly setting the user, either with the `--user` argument for `docker run`, or by specifying the `securityContext` in the Kubernetes Pod specification. -The change to the `package` scope in [#5251](https://github.com/open-policy-agent/opa/issues/5251) may cause compile-time errors and behavioural changes to type checking when the `schemas` annotation is used, and to rules calling the `rego.metadata.chain()` built-in function: -- Existing projects with the same package declared in multiple files will trigger a `rego_type_error: package annotation redeclared` error _if_ two or more of these are annotated with the `package` scope. -- If using the `package` scope, the `schemas` annotation will be applied to type checking also for rules declared in another file than the annotation declaration, as long as the package is the same. -- The chain of metadata returned by the `rego.metadata.chain()` built-in function will now contain an entry for the package even if the annotations are declared in another file, if the scope is `package`. +### Runtime, Tooling, SDK + +- server: Support compression of response payloads if HTTP client supports it ([#5310](https://github.com/open-policy-agent/opa/issues/5310)) authored by @AdrianArnautu +- bundle: Ensure the bundle resulting from merging a set of bundles does not contain `nil` data ([#5703](https://github.com/open-policy-agent/opa/issues/5703)) authored by @anderseknert +- repl: Use lowercase for repl commands only and keep any provided arguments as-is ([#5229](https://github.com/open-policy-agent/opa/issues/5229)) authored by @Trolloldem +- metrics: New endpoint `/metrics/alloc_bytes` to show OPA's memory utilization ([#5715](https://github.com/open-policy-agent/opa/pull/5715)) authored by @anderseknert +- server: When using OPA TLS authorization, authz policy authors will now have access to the client certificates +presented as part of the TLS connection. This new data will be available under the key `client_certificates` ([#5538](https://github.com/open-policy-agent/opa/issues/5538)) authored by @charlieegan3 +- server: Use streaming implementation of json.Decode rather than using an intermediate buffer for the incoming request ([#5661](https://github.com/open-policy-agent/opa/pull/5661)) authored by @anderseknert + +### Topdown and Rego + +- ast: Extend compiler `strict` mode check to include unused arguments ([#5602](https://github.com/open-policy-agent/opa/issues/5602)) authored by @boranx. This change may cause +compile-time errors for policies that have unused arguments in the scope when the `strict` mode is enabled. These +variables could be replaced with `_` (wildcard) or get cleaned up if they are not intended to be used in the body of the functions. +- ast: Respect inlined `schemas` annotations even if `--schema` flag isn't used ([#5506](https://github.com/open-policy-agent/opa/issues/5506)) authored by @johanfylling +- ast: Force type-checker to respect `allow_net` capability when fetching remote schemas ([#5670](https://github.com/open-policy-agent/opa/issues/5670)) authored by @johanfylling +- ast/parse: Provide custom parsing options that allow location information of AST nodes to be included in their JSON +representation. This location information can be used by tools that work with the OPA AST ([#3143](https://github.com/open-policy-agent/opa/issues/3143)) authored by @charlieegan3 + +### Docs + +- docs/policy-reference: Fix typo in policy reference doc ([#5654](https://github.com/open-policy-agent/opa/pull/5654)) authored by @alvarogomez93 +- docs/extensions: Fix sample code provided in the custom built-in implementation example ([#5666](https://github.com/open-policy-agent/opa/pull/5666)) authored by @Ronnie-personal +- docs/bundles: Clarify delta bundle behavior when it contains an empty list of patch operations ([#5629](https://github.com/open-policy-agent/opa/issues/5629)) authored by @charlieegan3 +- docs/http-api-authz: Update the HTTP API authz tutorial with steps related to proper bundle creation ([#5682](https://github.com/open-policy-agent/opa/pull/5682)) authored by @lamoboos223 +- Fix broken 'future keywords' url link ([#5686](https://github.com/open-policy-agent/opa/pull/5686)) authored by @neelanjan00 + + +### Website + Ecosystem + +- Ecosystem: + - Styra Load ([#5659](https://github.com/open-policy-agent/opa/pull/5659)) authored by @charlieegan3 + +- Website: + - Update OPA documentation search to use Algolia v3 ([#5706](https://github.com/open-policy-agent/opa/pull/5706)) authored by @Parsifal-M + - Drop Google Universal Analytics (UA) code as part of Google Analytics 4 migration (authored by @chalin) + +### Miscellaneous + +- Dependency bumps, notably: + - golang from 1.20.1 to 1.20.2 + - github.com/containerd/containerd from 1.6.16 to 1.6.19 + - github.com/golang/protobuf from 1.5.2 to 1.5.3 + - golang.org/x/net from 0.5.0 to 0.8.0 + - google.golang.org/grpc from 1.52.3 to 1.53.0 + - OpenTelemetry-related dependencies (#5701) -Another change in [#5602](https://github.com/open-policy-agent/opa/issues/5251) may cause compile-time errors for policies that have unused arguments in the scope when the strict mode is enabled. These variables could be replaced with `_` (wildcard) or get cleaned up if they are not intended to be used in the body of the functions. ## 0.49.2 diff --git a/builtin_metadata.json b/builtin_metadata.json index 2ec6d77493..441e752cd9 100644 --- a/builtin_metadata.json +++ b/builtin_metadata.json @@ -324,6 +324,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the number without its sign.", @@ -422,6 +423,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -523,6 +525,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the intersection of two sets.", @@ -622,6 +625,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -723,6 +727,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Concatenates two arrays.", @@ -773,6 +778,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the reverse of a given array.", @@ -883,6 +889,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a slice of a given array. If `start` is greater or equal than `stop`, `slice` is `[]`.", @@ -984,6 +991,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": ":=", @@ -1081,6 +1089,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Deserializes the base64 encoded input string.", @@ -1180,6 +1189,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Serializes the input string into base64 encoding.", @@ -1258,6 +1268,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies the input string is base64 encoded.", @@ -1357,6 +1368,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Deserializes the base64url encoded input string.", @@ -1456,6 +1468,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Serializes the input string into base64url encoding.", @@ -1532,6 +1545,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Serializes the input string into base64url encoding without padding.", @@ -1631,6 +1645,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the bitwise \"AND\" of two integers.", @@ -1729,6 +1744,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a new integer with its bits shifted `s` bits to the left.", @@ -1823,6 +1839,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the bitwise negation (flip) of an integer.", @@ -1921,6 +1938,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the bitwise \"OR\" of two integers.", @@ -2019,6 +2037,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a new integer with its bits shifted `s` bits to the right.", @@ -2117,6 +2136,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the bitwise \"XOR\" (exclusive-or) of two integers.", @@ -2214,6 +2234,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -2310,6 +2331,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -2406,6 +2428,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -2502,6 +2525,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -2598,6 +2622,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -2694,6 +2719,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -2763,6 +2789,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Rounds the number _up_ to the nearest integer.", @@ -2867,6 +2894,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Joins a set or array of strings with a delimiter.", @@ -2971,6 +2999,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `true` if the search string is included in the base string", @@ -3071,6 +3100,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": " Count takes a collection or string and returns the number of elements (or characters) in it.", @@ -3126,6 +3156,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a string representing the MD5 HMAC of the input message using the input key.", @@ -3181,6 +3212,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a string representing the SHA1 HMAC of the input message using the input key.", @@ -3236,6 +3268,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a string representing the SHA256 HMAC of the input message using the input key.", @@ -3291,6 +3324,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a string representing the SHA512 HMAC of the input message using the input key.", @@ -3390,6 +3424,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a string representing the input string hashed with the MD5 function", @@ -3489,6 +3524,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a string representing the input string hashed with the SHA1 function", @@ -3588,6 +3624,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a string representing the input string hashed with the SHA256 function", @@ -3647,6 +3684,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns one or more certificates from the given string containing PEM\nor base64 encoded DER certificates after verifying the supplied certificates form a complete\ncertificate chain back to a trusted root.\n\nThe first certificate is treated as the root and the last is treated as the leaf,\nwith all others being treated as intermediates.", @@ -3732,6 +3770,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a PKCS #10 certificate signing request from the given PEM-encoded PKCS#10 certificate signing request.", @@ -3832,6 +3871,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns zero or more certificates from the given encoded string containing\nDER certificate data.\n\nIf the input is empty, the function will return null. The input string should be a list of one or more\nconcatenated PEM blocks. The whole input of concatenated PEM blocks can optionally be Base64 encoded.", @@ -3888,6 +3928,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a JWK for signing a JWT from the given PEM-encoded RSA private key.", @@ -3993,6 +4034,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Divides the first number by the second number.", @@ -4099,6 +4141,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns true if the search string ends with the base string.", @@ -4200,6 +4243,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": "=", @@ -4301,6 +4345,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": "==", @@ -4372,6 +4417,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Rounds the number _down_ to the nearest integer.", @@ -4477,6 +4523,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the string representation of the number in the given base after rounding it down to an integer value.", @@ -4585,6 +4632,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Parses and matches strings against the glob notation. Not to be confused with `regex.globs_match`.", @@ -4684,6 +4732,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a string which represents a version of the pattern where all asterisks have been escaped.", @@ -4780,6 +4829,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Computes the set of reachable nodes in the graph from a set of starting nodes.", @@ -4833,6 +4883,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Computes the set of reachable paths in the graph from a set of starting nodes.", @@ -4877,6 +4928,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Checks that a GraphQL query is valid against a given schema. The query and/or schema can be either GraphQL strings or AST objects from the other GraphQL builtin functions.", @@ -4921,6 +4973,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns AST objects for a given GraphQL query and schema after validating the query against the schema. Returns undefined if errors were encountered during parsing or validation. The query and/or schema can be either GraphQL strings or AST objects from the other GraphQL builtin functions.", @@ -4965,6 +5018,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a boolean indicating success or failure alongside the parsed ASTs for a given GraphQL query and schema after validating the query against the schema. The query and/or schema can be either GraphQL strings or AST objects from the other GraphQL builtin functions.", @@ -5005,6 +5059,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns an AST object for a GraphQL query.", @@ -5045,6 +5100,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns an AST object for a GraphQL schema.", @@ -5077,6 +5133,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Checks that the input is a valid GraphQL schema. The schema can be either a GraphQL string or an AST object from the other GraphQL builtin functions.", @@ -5180,6 +5237,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": "\u003e", @@ -5283,6 +5341,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": "\u003e=", @@ -5360,6 +5419,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Deserializes the hex-encoded input string.", @@ -5436,6 +5496,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Serializes the input string using hex-encoding.", @@ -5535,6 +5596,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a HTTP response to the given HTTP request.", @@ -5639,6 +5701,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the index of a substring contained inside a string.", @@ -5692,6 +5755,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a list of all the indexes of a substring contained inside a string.", @@ -5747,6 +5811,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": "in", @@ -5803,6 +5868,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": "in", @@ -5853,6 +5919,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "introduced": "v0.34.0", @@ -5948,6 +6015,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the intersection of the given input sets.", @@ -6048,6 +6116,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Decodes a JSON Web Token and outputs it as an object.", @@ -6153,6 +6222,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies a JWT signature under parameterized constraints and decodes the claims if it is valid.\nSupports the following algorithms: HS256, HS384, HS512, RS256, RS384, RS512, ES256, ES384, ES512, PS256, PS384 and PS512.", @@ -6263,6 +6333,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Encodes and optionally signs a JSON Web Token. Inputs are taken as objects, not encoded strings (see `io.jwt.encode_sign_raw`).", @@ -6373,6 +6444,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Encodes and optionally signs a JSON Web Token.", @@ -6478,6 +6550,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a ES256 JWT signature is valid.", @@ -6574,6 +6647,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a ES384 JWT signature is valid.", @@ -6670,6 +6744,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a ES512 JWT signature is valid.", @@ -6775,6 +6850,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a HS256 (secret) JWT signature is valid.", @@ -6871,6 +6947,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a HS384 (secret) JWT signature is valid.", @@ -6967,6 +7044,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a HS512 (secret) JWT signature is valid.", @@ -7072,6 +7150,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a PS256 JWT signature is valid.", @@ -7168,6 +7247,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a PS384 JWT signature is valid.", @@ -7264,6 +7344,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a PS512 JWT signature is valid.", @@ -7369,6 +7450,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a RS256 JWT signature is valid.", @@ -7465,6 +7547,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a RS384 JWT signature is valid.", @@ -7561,6 +7644,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies if a RS512 JWT signature is valid.", @@ -7660,6 +7744,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `true` if the input value is an array.", @@ -7759,6 +7844,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `true` if the input value is a boolean.", @@ -7858,6 +7944,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `true` if the input value is null.", @@ -7957,6 +8044,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `true` if the input value is a number.", @@ -8056,6 +8144,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns true if the input value is an object", @@ -8155,6 +8244,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `true` if the input value is a set.", @@ -8254,6 +8344,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `true` if the input value is a string.", @@ -8358,6 +8449,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Filters the object. For example: `json.filter({\"a\": {\"b\": \"x\", \"c\": \"y\"}}, [\"a/b\"])` will result in `{\"a\": {\"b\": \"x\"}}`). Paths are not filtered in-order and are deduplicated before being evaluated.", @@ -8436,6 +8528,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies the input string is a valid JSON document.", @@ -8536,6 +8629,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Serializes the input term to JSON.", @@ -8561,10 +8655,11 @@ } ], "available": [ + "v0.50.0", "edge" ], "description": "Checks that the document matches the JSON schema.", - "introduced": "edge", + "introduced": "v0.50.0", "result": { "description": "`output` is of the form `[match, errors]`. If the document is valid given the schema, then `match` is `true`, and `errors` is an empty array. Otherwise, `match` is `false` and `errors` is an array of objects describing the error(s).", "name": "output", @@ -8638,6 +8733,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Patches an object according to RFC6902. For example: `json.patch({\"a\": {\"foo\": 1}}, [{\"op\": \"add\", \"path\": \"/a/bar\", \"value\": 2}])` results in `{\"a\": {\"foo\": 1, \"bar\": 2}`. The patches are applied atomically: if any of them fails, the result will be undefined. Additionally works on sets, where a value contained in the set is considered to be its path.", @@ -8738,6 +8834,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Removes paths from an object. For example: `json.remove({\"a\": {\"b\": \"x\", \"c\": \"y\"}}, [\"a/b\"])` will result in `{\"a\": {\"c\": \"y\"}}`. Paths are not removed in-order and are deduplicated before being evaluated.", @@ -8838,6 +8935,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Deserializes the input string.", @@ -8858,10 +8956,11 @@ } ], "available": [ + "v0.50.0", "edge" ], "description": "Checks that the input is a valid JSON schema object. The schema can be either a JSON string or an JSON object.", - "introduced": "edge", + "introduced": "v0.50.0", "result": { "description": "`output` is of the form `[valid, error]`. If the schema is valid, then `valid` is `true`, and `error` is `null`. Otherwise, `valid` is `false` and `error` is a string describing the error.", "name": "output", @@ -8958,6 +9057,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the input string but with all characters in lower-case.", @@ -9061,6 +9161,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": "\u003c", @@ -9164,6 +9265,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": "\u003c=", @@ -9263,6 +9365,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the maximum value in a collection.", @@ -9362,6 +9465,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the minimum value in a collection.", @@ -9465,6 +9569,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Minus subtracts the second number from the first number or computes the difference between two sets.", @@ -9569,6 +9674,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Multiplies two numbers.", @@ -9673,6 +9779,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "infix": "!=", @@ -9776,6 +9883,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Checks if a CIDR or IP is contained within another CIDR. `output` is `true` if `cidr_or_ip` (e.g. `127.0.0.64/26` or `127.0.0.1`) is contained within `cidr` (e.g. `127.0.0.1/24`) and `false` otherwise. Supports both IPv4 and IPv6 notations.", @@ -9873,6 +9981,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Checks if collections of cidrs or ips are contained within another collection of cidrs and returns matches. This function is similar to `net.cidr_contains` except it allows callers to pass collections of CIDRs or IPs as arguments and returns the matches (as opposed to a boolean result indicating a match between two CIDRs/IPs).", @@ -9972,6 +10081,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Expands CIDR to set of hosts (e.g., `net.cidr_expand(\"192.168.0.0/30\")` generates 4 hosts: `{\"192.168.0.0\", \"192.168.0.1\", \"192.168.0.2\", \"192.168.0.3\"}`).", @@ -10075,6 +10185,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Checks if a CIDR intersects with another CIDR (e.g. `192.168.0.0/16` overlaps with `192.168.1.0/24`). Supports both IPv4 and IPv6 notations.", @@ -10106,6 +10217,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Parses an IPv4/IPv6 CIDR and returns a boolean indicating if the provided CIDR is valid.", @@ -10184,6 +10296,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Merges IP addresses and subnets into the smallest possible list of CIDRs (e.g., `net.cidr_merge([\"192.0.128.0/24\", \"192.0.129.0/24\"])` generates `{\"192.0.128.0/23\"}`.This function merges adjacent subnets where possible, those contained within others and also removes any duplicates.\nSupports both IPv4 and IPv6 notations. IPv6 inputs need a prefix length (e.g. \"/128\").", @@ -10285,6 +10398,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -10334,6 +10448,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the set of IP addresses (both v4 and v6) that the passed-in `name` resolves to using the standard name resolution mechanisms available.", @@ -10420,6 +10535,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns an array of numbers in the given (inclusive) range. If `a==b`, then `range == [a]`; if `a \u003e b`, then `range` is in descending order.", @@ -10522,6 +10638,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Filters the object by keeping only specified keys. For example: `object.filter({\"a\": {\"b\": \"x\", \"c\": \"y\"}, \"d\": \"z\"}, [\"a\"])` will result in `{\"a\": {\"b\": \"x\", \"c\": \"y\"}}`).", @@ -10632,6 +10749,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns value of an object's key if present, otherwise a default. If the supplied `key` is an `array`, then `object.get` will search through a nested object or array using each key in turn. For example: `object.get({\"a\": [{ \"b\": true }]}, [\"a\", 0, \"b\"], false)` results in `true`.", @@ -10661,6 +10779,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a set of an object's keys. For example: `object.keys({\"a\": 1, \"b\": true, \"c\": \"d\")` results in `{\"a\", \"b\", \"c\"}`.", @@ -10764,6 +10883,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Removes specified keys from an object.", @@ -10809,6 +10929,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Determines if an object `sub` is a subset of another object `super`.Object `sub` is a subset of object `super` if and only if every key in `sub` is also in `super`, **and** for all keys which `sub` and `super` share, they have the same value. This function works with objects, sets, arrays and a set of array and set.If both arguments are objects, then the operation is recursive, e.g. `{\"c\": {\"x\": {10, 15, 20}}` is a subset of `{\"a\": \"b\", \"c\": {\"x\": {10, 15, 20, 25}, \"y\": \"z\"}`. If both arguments are sets, then this function checks if every element of `sub` is a member of `super`, but does not attempt to recurse. If both arguments are arrays, then this function checks if `sub` appears contiguously in order within `super`, and also does not attempt to recurse. If `super` is array and `sub` is set, then this function checks if `super` contains every element of `sub` with no consideration of ordering, and also does not attempt to recurse.", @@ -10910,6 +11031,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Creates a new object of the asymmetric union of two objects. For example: `object.union({\"a\": 1, \"b\": 2, \"c\": {\"d\": 3}}, {\"a\": 7, \"c\": {\"d\": 4, \"e\": 5}})` will result in `{\"a\": 7, \"b\": 2, \"c\": {\"d\": 4, \"e\": 5}}`.", @@ -10957,6 +11079,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Creates a new object that is the asymmetric union of all objects merged from left to right. For example: `object.union_n([{\"a\": 1}, {\"b\": 2}, {\"a\": 3}])` will result in `{\"b\": 2, \"a\": 3}`.", @@ -11051,6 +11174,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns an object that describes the runtime environment where OPA is deployed.", @@ -11154,6 +11278,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the union of two sets.", @@ -11258,6 +11383,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Plus adds two numbers together.", @@ -11307,6 +11433,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "introduced": "v0.34.0", @@ -11401,6 +11528,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Muliplies elements of an array or set of numbers", @@ -11437,6 +11565,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Signs an HTTP request object for Amazon Web Services. Currently implements [AWS Signature Version 4 request signing](https://docs.aws.amazon.com/AmazonS3/latest/API/sig-v4-authenticating-requests.html) by the `Authorization` header method.", @@ -11498,6 +11627,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a random integer between `0` and `n` (`n` exlusive). If `n` is `0`, then `y` is always `0`. For any given argument pair (`str`, `n`), the output will be consistent throughout a query evaluation.", @@ -11599,6 +11729,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -11707,6 +11838,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns all successive matches of the expression.", @@ -11816,6 +11948,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the specified number of matches when matching the input against the pattern.", @@ -11919,6 +12052,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Checks if the intersection of two glob-style regular expressions matches a non-empty set of non-empty strings.\nThe set of regex symbols is limited for this builtin: only `.`, `*`, `+`, `[`, `-`, `]` and `\\` are treated as special symbols.", @@ -12000,6 +12134,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Checks if a string is a valid regular expression: the detailed syntax for patterns is defined by https://github.com/google/re2/wiki/Syntax.", @@ -12086,6 +12221,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Matches a string against a regular expression.", @@ -12129,6 +12265,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Find and replaces the text using the regular expression pattern.", @@ -12233,6 +12370,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Splits the input string by the occurrences of the given pattern.", @@ -12348,6 +12486,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Matches a string against a pattern, where there pattern may be glob-like", @@ -12383,6 +12522,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the chain of metadata for the active rule.\nOrdered starting at the active rule, going outward to the most distant node in its package ancestry.\nA chain entry is a JSON document with two members: \"path\", an array representing the path of the node; and \"annotations\", a JSON document containing the annotations declared for the node.\nThe first entry in the chain always points to the active rule, even if it has no declared annotations (in which case the \"annotations\" member is not present).", @@ -12419,6 +12559,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns annotations declared for the active rule and using the _rule_ scope.", @@ -12524,6 +12665,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Parses the input Rego string and returns an object representation of the AST.", @@ -12626,6 +12768,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the remainder for of `x` divided by `y`, for `y != 0`.", @@ -12737,6 +12880,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Replace replaces all instances of a sub-string.", @@ -12837,6 +12981,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Rounds the number to the nearest integer.", @@ -12923,6 +13068,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Compares valid SemVer formatted version strings.", @@ -13005,6 +13151,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Validates that the input is a valid SemVer string.", @@ -13106,6 +13253,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "deprecated": true, @@ -13204,6 +13352,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a sorted array.", @@ -13309,6 +13458,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Split returns an array containing elements of the input string split on a delimiter.", @@ -13414,6 +13564,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the given string, formatted.", @@ -13519,6 +13670,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns true if the search string begins with the base string.", @@ -13559,6 +13711,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns true if any of the search strings begins with any of the base strings.", @@ -13599,6 +13752,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns true if any of the search strings ends with any of the base strings.", @@ -13704,6 +13858,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Replaces a string from a list of old, new string pairs.\nReplacements are performed in the order they appear in the target string, without overlapping matches.\nThe old string comparisons are done in argument order.", @@ -13752,6 +13907,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Reverses a given string.", @@ -13860,6 +14016,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the portion of a string for a given `offset` and a `length`. If `length \u003c 0`, `output` is the remainder of the string.", @@ -13959,6 +14116,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Sums elements of an array or set of numbers.", @@ -14065,6 +14223,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the nanoseconds since epoch after adding years, months and days to nanoseconds. `undefined` if the result would be outside the valid time range that can fit within an `int64`.", @@ -14165,6 +14324,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the `[hour, minute, second]` of the day for the nanoseconds since epoch.", @@ -14265,6 +14425,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the `[year, month, day]` for the nanoseconds since epoch.", @@ -14336,6 +14497,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the difference between two unix timestamps in nanoseconds (with optional timezone strings).", @@ -14360,6 +14522,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the formatted timestamp for the nanoseconds since epoch.", @@ -14454,6 +14617,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the current time since epoch in nanoseconds.", @@ -14554,6 +14718,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the duration in nanoseconds represented by a string.", @@ -14659,6 +14824,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the time in nanoseconds parsed from the string in the given format. `undefined` if the result would be outside the valid time range that can fit within an `int64`.", @@ -14758,6 +14924,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the time in nanoseconds parsed from the string in RFC3339 format. `undefined` if the result would be outside the valid time range that can fit within an `int64`.", @@ -14858,6 +15025,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the day of the week (Monday, Tuesday, ...) for the nanoseconds since epoch.", @@ -14957,6 +15125,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Converts a string, bool, or number value to a number: Strings are converted to numbers using `strconv.Atoi`, Boolean `false` is converted to 0 and `true` is converted to 1.", @@ -15056,6 +15225,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Emits `note` as a `Note` event in the query explanation. Query explanations show the exact expressions evaluated by OPA during policy execution. For example, `trace(\"Hello There!\")` includes `Note \"Hello There!\"` in the query explanation. To include variables in the message, use `sprintf`. For example, `person := \"Bob\"; trace(sprintf(\"Hello There! %v\", [person]))` will emit `Note \"Hello There! Bob\"` inside of the explanation.", @@ -15161,6 +15331,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `value` with all leading or trailing instances of the `cutset` characters removed.", @@ -15266,6 +15437,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `value` with all leading instances of the `cutset` chartacters removed.", @@ -15371,6 +15543,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `value` without the prefix. If `value` doesn't start with `prefix`, it is returned unchanged.", @@ -15476,6 +15649,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `value` with all trailing instances of the `cutset` chartacters removed.", @@ -15576,6 +15750,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Return the given string with all leading and trailing white space removed.", @@ -15681,6 +15856,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns `value` without the suffix. If `value` doesn't end with `suffix`, it is returned unchanged.", @@ -15780,6 +15956,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the type of its input value.", @@ -15880,6 +16057,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the union of the given input sets.", @@ -15921,6 +16099,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Converts strings like \"10G\", \"5K\", \"4M\", \"1500m\" and the like into a number.\nThis number can be a non-integer, such as 1.5, 0.22, etc. Supports standard metric decimal and\nbinary SI units (e.g., K, Ki, M, Mi, G, Gi etc.) m, K, M, G, T, P, and E are treated as decimal\nunits and Ki, Mi, Gi, Ti, Pi, and Ei are treated as binary units.\n\nNote that 'm' and 'M' are case-sensitive, to allow distinguishing between \"milli\" and \"mega\" units respectively. Other units are case-insensitive.", @@ -16021,6 +16200,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Converts strings like \"10GB\", \"5K\", \"4mb\" into an integer number of bytes.\nSupports standard byte units (e.g., KB, KiB, etc.) KB, MB, GB, and TB are treated as decimal\nunits and KiB, MiB, GiB, and TiB are treated as binary units. The bytes symbol (b/B) in the\nunit is optional and omitting it wil give the same result (e.g. Mi and MiB).", @@ -16121,6 +16301,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns the input string but with all characters in upper-case.", @@ -16220,6 +16401,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Decodes a URL-encoded input string.", @@ -16299,6 +16481,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Decodes the given URL query string into an object.", @@ -16398,6 +16581,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Encodes the input string into a URL-encoded string.", @@ -16497,6 +16681,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Encodes the given object into a URL encoded query string.", @@ -16587,6 +16772,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Returns a new UUIDv4.", @@ -16686,6 +16872,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Generates `[path, value]` tuples for all nested documents of `x` (recursively). Queries can use `walk` to traverse documents nested under `x`.", @@ -16765,6 +16952,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Verifies the input string is a valid YAML document.", @@ -16865,6 +17053,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Serializes the input term to YAML.", @@ -16965,6 +17154,7 @@ "v0.49.0", "v0.49.1", "v0.49.2", + "v0.50.0", "edge" ], "description": "Deserializes the input string.", diff --git a/capabilities/v0.50.0.json b/capabilities/v0.50.0.json new file mode 100644 index 0000000000..4fe0c2b7fe --- /dev/null +++ b/capabilities/v0.50.0.json @@ -0,0 +1,4598 @@ +{ + "builtins": [ + { + "name": "abs", + "decl": { + "args": [ + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "all", + "decl": { + "args": [ + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "and", + "decl": { + "args": [ + { + "of": { + "type": "any" + }, + "type": "set" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "result": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "function" + }, + "infix": "\u0026" + }, + { + "name": "any", + "decl": { + "args": [ + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "array.concat", + "decl": { + "args": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "result": { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "array.reverse", + "decl": { + "args": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "result": { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "array.slice", + "decl": { + "args": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "assign", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": ":=" + }, + { + "name": "base64.decode", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "base64.encode", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "base64.is_valid", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "base64url.decode", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "base64url.encode", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "base64url.encode_no_pad", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "bits.and", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "bits.lsh", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "bits.negate", + "decl": { + "args": [ + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "bits.or", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "bits.rsh", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "bits.xor", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "cast_array", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "cast_boolean", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "cast_null", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "null" + }, + "type": "function" + } + }, + { + "name": "cast_object", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "function" + } + }, + { + "name": "cast_set", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "cast_string", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "ceil", + "decl": { + "args": [ + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "concat", + "decl": { + "args": [ + { + "type": "string" + }, + { + "of": [ + { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + { + "of": { + "type": "string" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "contains", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "count", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "crypto.hmac.md5", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "crypto.hmac.sha1", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "crypto.hmac.sha256", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "crypto.hmac.sha512", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "crypto.md5", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "crypto.sha1", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "crypto.sha256", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "crypto.x509.parse_and_verify_certificates", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "static": [ + { + "type": "boolean" + }, + { + "dynamic": { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "array" + } + ], + "type": "array" + }, + "type": "function" + } + }, + { + "name": "crypto.x509.parse_certificate_request", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "function" + } + }, + { + "name": "crypto.x509.parse_certificates", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "dynamic": { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "crypto.x509.parse_rsa_private_key", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "function" + } + }, + { + "name": "div", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + }, + "infix": "/" + }, + { + "name": "endswith", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "eq", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": "=" + }, + { + "name": "equal", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": "==" + }, + { + "name": "floor", + "decl": { + "args": [ + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "format_int", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "glob.match", + "decl": { + "args": [ + { + "type": "string" + }, + { + "of": [ + { + "type": "null" + }, + { + "dynamic": { + "type": "string" + }, + "type": "array" + } + ], + "type": "any" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "glob.quote_meta", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "graph.reachable", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + }, + "type": "object" + }, + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "graph.reachable_paths", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + }, + "type": "object" + }, + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "of": { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "graphql.is_valid", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + }, + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "graphql.parse", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + }, + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + } + ], + "result": { + "static": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "array" + }, + "type": "function" + } + }, + { + "name": "graphql.parse_and_verify", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + }, + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + } + ], + "result": { + "static": [ + { + "type": "boolean" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "array" + }, + "type": "function" + } + }, + { + "name": "graphql.parse_query", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "function" + } + }, + { + "name": "graphql.parse_schema", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "function" + } + }, + { + "name": "graphql.schema_is_valid", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "gt", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": "\u003e" + }, + { + "name": "gte", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": "\u003e=" + }, + { + "name": "hex.decode", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "hex.encode", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "http.send", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "result": { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "function" + }, + "nondeterministic": true + }, + { + "name": "indexof", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "indexof_n", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "dynamic": { + "type": "number" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "internal.member_2", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": "in" + }, + { + "name": "internal.member_3", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": "in" + }, + { + "name": "internal.print", + "decl": { + "args": [ + { + "dynamic": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "array" + } + ], + "type": "function" + } + }, + { + "name": "intersection", + "decl": { + "args": [ + { + "of": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "set" + } + ], + "result": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "io.jwt.decode", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "static": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "type": "string" + } + ], + "type": "array" + }, + "type": "function" + } + }, + { + "name": "io.jwt.decode_verify", + "decl": { + "args": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "result": { + "static": [ + { + "type": "boolean" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "array" + }, + "type": "function" + }, + "nondeterministic": true + }, + { + "name": "io.jwt.encode_sign", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "result": { + "type": "string" + }, + "type": "function" + }, + "nondeterministic": true + }, + { + "name": "io.jwt.encode_sign_raw", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + }, + "nondeterministic": true + }, + { + "name": "io.jwt.verify_es256", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_es384", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_es512", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_hs256", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_hs384", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_hs512", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_ps256", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_ps384", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_ps512", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_rs256", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_rs384", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "io.jwt.verify_rs512", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "is_array", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "is_boolean", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "is_null", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "is_number", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "is_object", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "is_set", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "is_string", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "json.filter", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "of": [ + { + "dynamic": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + }, + "type": "array" + }, + { + "of": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "json.is_valid", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "json.marshal", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "json.match_schema", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + }, + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + } + ], + "result": { + "static": [ + { + "type": "boolean" + }, + { + "dynamic": { + "static": [ + { + "key": "desc", + "value": { + "type": "string" + } + }, + { + "key": "error", + "value": { + "type": "string" + } + }, + { + "key": "field", + "value": { + "type": "string" + } + }, + { + "key": "type", + "value": { + "type": "string" + } + } + ], + "type": "object" + }, + "type": "array" + } + ], + "type": "array" + }, + "type": "function" + } + }, + { + "name": "json.patch", + "decl": { + "args": [ + { + "type": "any" + }, + { + "dynamic": { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "static": [ + { + "key": "op", + "value": { + "type": "string" + } + }, + { + "key": "path", + "value": { + "type": "any" + } + } + ], + "type": "object" + }, + "type": "array" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "json.remove", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "of": [ + { + "dynamic": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + }, + "type": "array" + }, + { + "of": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "json.unmarshal", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "json.verify_schema", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "type": "any" + } + ], + "result": { + "static": [ + { + "type": "boolean" + }, + { + "of": [ + { + "type": "null" + }, + { + "type": "string" + } + ], + "type": "any" + } + ], + "type": "array" + }, + "type": "function" + } + }, + { + "name": "lower", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "lt", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": "\u003c" + }, + { + "name": "lte", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": "\u003c=" + }, + { + "name": "max", + "decl": { + "args": [ + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "min", + "decl": { + "args": [ + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "minus", + "decl": { + "args": [ + { + "of": [ + { + "type": "number" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + }, + { + "of": [ + { + "type": "number" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "of": [ + { + "type": "number" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + }, + "type": "function" + }, + "infix": "-" + }, + { + "name": "mul", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + }, + "infix": "*" + }, + { + "name": "neq", + "decl": { + "args": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + }, + "infix": "!=" + }, + { + "name": "net.cidr_contains", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "net.cidr_contains_matches", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + }, + "type": "array" + }, + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + } + }, + "type": "object" + }, + { + "of": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + }, + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + }, + "type": "array" + }, + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + } + }, + "type": "object" + }, + { + "of": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "of": { + "static": [ + { + "type": "any" + }, + { + "type": "any" + } + ], + "type": "array" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "net.cidr_expand", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "of": { + "type": "string" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "net.cidr_intersects", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "net.cidr_is_valid", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "net.cidr_merge", + "decl": { + "args": [ + { + "of": [ + { + "dynamic": { + "of": [ + { + "type": "string" + } + ], + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "string" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "of": { + "type": "string" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "net.cidr_overlap", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "net.lookup_ip_addr", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "of": { + "type": "string" + }, + "type": "set" + }, + "type": "function" + }, + "nondeterministic": true + }, + { + "name": "numbers.range", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "dynamic": { + "type": "number" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "object.filter", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "object.get", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "type": "any" + }, + { + "type": "any" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "object.keys", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "result": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "object.remove", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "object.subset", + "decl": { + "args": [ + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + }, + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "object.union", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "object.union_n", + "decl": { + "args": [ + { + "dynamic": { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "array" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "opa.runtime", + "decl": { + "result": { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "function" + }, + "nondeterministic": true + }, + { + "name": "or", + "decl": { + "args": [ + { + "of": { + "type": "any" + }, + "type": "set" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "result": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "function" + }, + "infix": "|" + }, + { + "name": "plus", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + }, + "infix": "+" + }, + { + "name": "print", + "decl": { + "type": "function", + "variadic": { + "type": "any" + } + } + }, + { + "name": "product", + "decl": { + "args": [ + { + "of": [ + { + "dynamic": { + "type": "number" + }, + "type": "array" + }, + { + "of": { + "type": "number" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "providers.aws.sign_req", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + { + "type": "number" + } + ], + "result": { + "dynamic": { + "key": { + "type": "any" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "function" + } + }, + { + "name": "rand.intn", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + }, + "nondeterministic": true + }, + { + "name": "re_match", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "regex.find_all_string_submatch_n", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + }, + { + "type": "number" + } + ], + "result": { + "dynamic": { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "regex.find_n", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + }, + { + "type": "number" + } + ], + "result": { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "regex.globs_match", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "regex.is_valid", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "regex.match", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "regex.replace", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "regex.split", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "regex.template_match", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + }, + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "rego.metadata.chain", + "decl": { + "result": { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "rego.metadata.rule", + "decl": { + "result": { + "type": "any" + }, + "type": "function" + } + }, + { + "name": "rego.parse_module", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "any" + } + }, + "type": "object" + }, + "type": "function" + } + }, + { + "name": "rem", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + }, + "infix": "%" + }, + { + "name": "replace", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "round", + "decl": { + "args": [ + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "semver.compare", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "semver.is_valid", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "set_diff", + "decl": { + "args": [ + { + "of": { + "type": "any" + }, + "type": "set" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "result": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "sort", + "decl": { + "args": [ + { + "of": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "of": { + "type": "any" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "split", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + "type": "function" + } + }, + { + "name": "sprintf", + "decl": { + "args": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "any" + }, + "type": "array" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "startswith", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "strings.any_prefix_match", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + { + "of": { + "type": "string" + }, + "type": "set" + } + ], + "type": "any" + }, + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + { + "of": { + "type": "string" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "strings.any_suffix_match", + "decl": { + "args": [ + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + { + "of": { + "type": "string" + }, + "type": "set" + } + ], + "type": "any" + }, + { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + { + "of": { + "type": "string" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "strings.replace_n", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "type": "string" + } + }, + "type": "object" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "strings.reverse", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "substring", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "sum", + "decl": { + "args": [ + { + "of": [ + { + "dynamic": { + "type": "number" + }, + "type": "array" + }, + { + "of": { + "type": "number" + }, + "type": "set" + } + ], + "type": "any" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "time.add_date", + "decl": { + "args": [ + { + "type": "number" + }, + { + "type": "number" + }, + { + "type": "number" + }, + { + "type": "number" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "time.clock", + "decl": { + "args": [ + { + "of": [ + { + "type": "number" + }, + { + "static": [ + { + "type": "number" + }, + { + "type": "string" + } + ], + "type": "array" + } + ], + "type": "any" + } + ], + "result": { + "static": [ + { + "type": "number" + }, + { + "type": "number" + }, + { + "type": "number" + } + ], + "type": "array" + }, + "type": "function" + } + }, + { + "name": "time.date", + "decl": { + "args": [ + { + "of": [ + { + "type": "number" + }, + { + "static": [ + { + "type": "number" + }, + { + "type": "string" + } + ], + "type": "array" + } + ], + "type": "any" + } + ], + "result": { + "static": [ + { + "type": "number" + }, + { + "type": "number" + }, + { + "type": "number" + } + ], + "type": "array" + }, + "type": "function" + } + }, + { + "name": "time.diff", + "decl": { + "args": [ + { + "of": [ + { + "type": "number" + }, + { + "static": [ + { + "type": "number" + }, + { + "type": "string" + } + ], + "type": "array" + } + ], + "type": "any" + }, + { + "of": [ + { + "type": "number" + }, + { + "static": [ + { + "type": "number" + }, + { + "type": "string" + } + ], + "type": "array" + } + ], + "type": "any" + } + ], + "result": { + "static": [ + { + "type": "number" + }, + { + "type": "number" + }, + { + "type": "number" + }, + { + "type": "number" + }, + { + "type": "number" + }, + { + "type": "number" + } + ], + "type": "array" + }, + "type": "function" + } + }, + { + "name": "time.format", + "decl": { + "args": [ + { + "of": [ + { + "type": "number" + }, + { + "static": [ + { + "type": "number" + }, + { + "type": "string" + } + ], + "type": "array" + }, + { + "static": [ + { + "type": "number" + }, + { + "type": "string" + }, + { + "type": "string" + } + ], + "type": "array" + } + ], + "type": "any" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "time.now_ns", + "decl": { + "result": { + "type": "number" + }, + "type": "function" + }, + "nondeterministic": true + }, + { + "name": "time.parse_duration_ns", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "time.parse_ns", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "time.parse_rfc3339_ns", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "time.weekday", + "decl": { + "args": [ + { + "of": [ + { + "type": "number" + }, + { + "static": [ + { + "type": "number" + }, + { + "type": "string" + } + ], + "type": "array" + } + ], + "type": "any" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "to_number", + "decl": { + "args": [ + { + "of": [ + { + "type": "null" + }, + { + "type": "boolean" + }, + { + "type": "number" + }, + { + "type": "string" + } + ], + "type": "any" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "trace", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "trim", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "trim_left", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "trim_prefix", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "trim_right", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "trim_space", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "trim_suffix", + "decl": { + "args": [ + { + "type": "string" + }, + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "type_name", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "union", + "decl": { + "args": [ + { + "of": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "set" + } + ], + "result": { + "of": { + "type": "any" + }, + "type": "set" + }, + "type": "function" + } + }, + { + "name": "units.parse", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "units.parse_bytes", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "number" + }, + "type": "function" + } + }, + { + "name": "upper", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "urlquery.decode", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "urlquery.decode_object", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "dynamic": { + "type": "string" + }, + "type": "array" + } + }, + "type": "object" + }, + "type": "function" + } + }, + { + "name": "urlquery.encode", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "urlquery.encode_object", + "decl": { + "args": [ + { + "dynamic": { + "key": { + "type": "string" + }, + "value": { + "of": [ + { + "type": "string" + }, + { + "dynamic": { + "type": "string" + }, + "type": "array" + }, + { + "of": { + "type": "string" + }, + "type": "set" + } + ], + "type": "any" + } + }, + "type": "object" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "uuid.rfc4122", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "string" + }, + "type": "function" + }, + "nondeterministic": true + }, + { + "name": "walk", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "static": [ + { + "dynamic": { + "type": "any" + }, + "type": "array" + }, + { + "type": "any" + } + ], + "type": "array" + }, + "type": "function" + }, + "relation": true + }, + { + "name": "yaml.is_valid", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "boolean" + }, + "type": "function" + } + }, + { + "name": "yaml.marshal", + "decl": { + "args": [ + { + "type": "any" + } + ], + "result": { + "type": "string" + }, + "type": "function" + } + }, + { + "name": "yaml.unmarshal", + "decl": { + "args": [ + { + "type": "string" + } + ], + "result": { + "type": "any" + }, + "type": "function" + } + } + ], + "future_keywords": [ + "contains", + "every", + "if", + "in" + ], + "wasm_abi_versions": [ + { + "version": 1, + "minor_version": 1 + }, + { + "version": 1, + "minor_version": 2 + } + ], + "features": [ + "rule_head_ref_string_prefixes" + ] +} diff --git a/version/version.go b/version/version.go index 397a817263..5e8cfaaf68 100644 --- a/version/version.go +++ b/version/version.go @@ -10,7 +10,7 @@ import ( ) // Version is the canonical version of OPA. -var Version = "0.50.0-dev" +var Version = "0.50.0" // GoVersion is the version of Go this was built with var GoVersion = runtime.Version()