-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
v1 SDK - full move #7192
v1 SDK - full move #7192
Conversation
Oh bother, this'll be fun 😩 .. |
fff4204
to
8b531ca
Compare
// Package v1 implements the v1 API for the Open Policy Agent (OPA). | ||
// The v1 API defaults to enforcing the v1 Rego syntax ([github.com/open-policy-agent/opa/v1/ast.RegoV1]). | ||
// Most packages outside the v1 API are deprecated. These constitute the older v0 API, which defaults to the v0 Rego syntax ([github.com/open-policy-agent/opa/v1/ast.RegoV0]). | ||
// The v0 API is provided as a means to ease transition to OPA 1.0 for 3rd party integrations, see [TODO: LINK TO V0 MIGRATION GUIDE]. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The v0 migration guide isn't completed yet. Whichever makes it into main
last will need to add the link.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
544a26a
to
fdb173d
Compare
const DefaultRegoVersion = RegoV1 | ||
|
||
const ( | ||
RegoUndefined RegoVersion = iota |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This rego-version is the default value for any ast.RegoVersion
struct field, e.g. ast.ParserOptions.RegoVersion
and ast.Module.regoVersion
. Which allows us to select whatever rego-version we should actually default to based on the user's imports.
E.g.:
|
||
_, errs := checker.CheckTypes(c.TypeEnv, elems, as) | ||
return errs | ||
return v1.NewCompiler().WithDefaultRegoVersion(DefaultRegoVersion) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So, ast.DefaultRegoVersion == ast.RegoV0
in this package. I wonder if we should use ast.RegoV0
here instead (and other places in the v0 API), as that is a bit more explicit ..
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This GH diff makes it look like this is a completely new file, but it looks like git actually knows better:
$ git blame v1/ast/builtins.go
4dc1c56552 ast/builtins.go (Torin Sandall 2016-05-16 14:21:32 -0700 1) // Copyright 2016 The OPA Authors. All rights reserved.
4dc1c56552 ast/builtins.go (Torin Sandall 2016-05-16 14:21:32 -0700 2) // Use of this source code is governed by an Apache2
4dc1c56552 ast/builtins.go (Torin Sandall 2016-05-16 14:21:32 -0700 3) // license that can be found in the LICENSE file.
4dc1c56552 ast/builtins.go (Torin Sandall 2016-05-16 14:21:32 -0700 4)
4dc1c56552 ast/builtins.go (Torin Sandall 2016-05-16 14:21:32 -0700 5) package ast
4dc1c56552 ast/builtins.go (Torin Sandall 2016-05-16 14:21:32 -0700 6)
ea2ea9b12b ast/builtins.go (Torin Sandall 2017-10-03 14:15:07 -0700 7) import (
ea2ea9b12b ast/builtins.go (Torin Sandall 2017-10-03 14:15:07 -0700 8) "strings"
ea2ea9b12b ast/builtins.go (Torin Sandall 2017-10-03 14:15:07 -0700 9)
67e8954b57 v1/ast/builtins.go (Johan Fylling 2024-11-21 16:35:26 +0100 10) "github.com/open-policy-agent/opa/v1/types"
ea2ea9b12b ast/builtins.go (Torin Sandall 2017-10-03 14:15:07 -0700 11) )
bad1c9a2b2 ast/builtins.go (Torin Sandall 2017-03-15 16:06:00 -0700 12)
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 13) // Builtins is the registry of built-in functions supported by OPA.
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 14) // Call RegisterBuiltin to add a new built-in.
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 15) var Builtins []*Builtin
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 16)
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 17) // RegisterBuiltin adds a new built-in function to the registry.
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 18) func RegisterBuiltin(b *Builtin) {
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 19) Builtins = append(Builtins, b)
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 20) BuiltinMap[b.Name] = b
95bdd4c824 ast/builtins.go (Torin Sandall 2017-02-09 16:59:44 -0800 21) if len(b.Infix) > 0 {
95bdd4c824 ast/builtins.go (Torin Sandall 2017-02-09 16:59:44 -0800 22) BuiltinMap[b.Infix] = b
95bdd4c824 ast/builtins.go (Torin Sandall 2017-02-09 16:59:44 -0800 23) }
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 24) }
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 25)
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 26) // DefaultBuiltins is the registry of built-in functions supported in OPA
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 27) // by default. When adding a new built-in function to OPA, update this
4dc1c56552 ast/builtins.go (Torin Sandall 2016-05-16 14:21:32 -0700 28) // list.
480281741b ast/builtins.go (Torin Sandall 2016-05-25 09:39:12 -0700 29) var DefaultBuiltins = [...]*Builtin{
ab91356d5b ast/builtins.go (Torin Sandall 2018-01-27 09:44:08 -0800 30) // Unification/equality ("=")
4dc1c56552 ast/builtins.go (Torin Sandall 2016-05-16 14:21:32 -0700 31) Equality,
6f90081ea3 ast/builtins.go (Torin Sandall 2016-11-25 10:53:21 -0800 32)
ab91356d5b ast/builtins.go (Torin Sandall 2018-01-27 09:44:08 -0800 33) // Assignment (":=")
ab91356d5b ast/builtins.go (Torin Sandall 2018-01-27 09:44:08 -0800 34) Assign,
ab91356d5b ast/builtins.go (Torin Sandall 2018-01-27 09:44:08 -0800 35)
f8286be64e ast/builtins.go (Stephan Renatus 2021-10-14 09:02:38 +0200 36) // Membership, infix "in": `x in xs`
f8286be64e ast/builtins.go (Stephan Renatus 2021-10-14 09:02:38 +0200 37) Member,
f8286be64e ast/builtins.go (Stephan Renatus 2021-10-14 09:02:38 +0200 38) MemberWithKey,
f8286be64e ast/builtins.go (Stephan Renatus 2021-10-14 09:02:38 +0200 39)
6f90081ea3 ast/builtins.go (Torin Sandall 2016-11-25 10:53:21 -0800 40) // Comparisons
0f8c6798f2 ast/builtins.go (Torin Sandall 2018-02-16 09:22:16 -0800 41) GreaterThan,
0f8c6798f2 ast/builtins.go (Torin Sandall 2018-02-16 09:22:16 -0800 42) GreaterThanEq,
0f8c6798f2 ast/builtins.go (Torin Sandall 2018-02-16 09:22:16 -0800 43) LessThan,
0f8c6798f2 ast/builtins.go (Torin Sandall 2018-02-16 09:22:16 -0800 44) LessThanEq,
0f8c6798f2 ast/builtins.go (Torin Sandall 2018-02-16 09:22:16 -0800 45) NotEqual,
0f8c6798f2 ast/builtins.go (Torin Sandall 2018-02-16 09:22:16 -0800 46) Equal,
6f90081ea3 ast/builtins.go (Torin Sandall 2016-11-25 10:53:21 -0800 47)
ast/doc.go
Outdated
// +--- Expression (Term | Terms | Variable Declaration) | ||
// | ||
// At query time, the policy engine expects policies to have been compiled. The compilation stage takes one or more modules and compiles them into a format that the policy engine supports. | ||
// Deprecated: Use [github.com/open-policy-agent/opa/v1/ast] instead. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This will put a deprecation message at the top of the doc page for the package:
and it will cause linters (such as staticcheck used in OPA) to warn about usage of deprecated functions and types when those are referenced.
However, it won't put deprecated notices on anything inside the deprecated package in the generated docs. For this, we need to explicitly tag each type, const, var, and function. We could brute force it by just adding a generic
//
// Deprecated: Use [github.com/open-policy-agent/opa/v1] instead.
everywhere. But before doing that to thousands of places, we should determine if it's necessary.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can web perhaps add some words, like "this package isn't going to go away but new projects are advised to start with v1"? If that's accurate. Just to avoid people panicking.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You mean "web" as in what's generated from here, or as in the separate v0-migration guide we're working on for the docs?
How about:
Deprecated: This package is intended for older projects transitioning from OPA v0.x and will remain for the lifetime of OPA v1.x, but its use is not recommended. For newer features and behaviours, such as defaulting to the Rego v1 syntax, use [github.com/open-policy-agent/opa/v1/ast] instead.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can web perhaps add some words
typing with gloves on in harsh weather, sorry 😅 "Can we perhaps add..." is what I had meant.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've updated all package deprecation notices to:
// Deprecated: This package is intended for older projects transitioning from OPA v0.x and will remain for the lifetime of OPA v1.x, but its use is not recommended.
// For newer features and behaviours, such as defaulting to the Rego v1 syntax, use the corresponding components in the [github.com/open-policy-agent/opa/v1] package instead.
// See https://www.openpolicyagent.org/docs/latest/v0-compatibility/ for more information.
// built-in definitions. | ||
var BuiltinMap map[string]*Builtin | ||
|
||
// Deprecated: Builtins can now be directly annotated with the |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Now would be our chance to get rid of all deprecated functions.
If we do it, should be done as a separate PR, though; otherwise, it'll just get buried in this already monstrous diff.
✅ Deploy Preview for openpolicyagent ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
@@ -69,7 +69,7 @@ export default async function localEval(groups, groupName, opaVersion) { | |||
// Returns 1st a function that consumes a string for the output format you want and produces an array of arguments and 2nd a map of module file names to strings that should be replaced in error messages. May throw a user-friendly error. | |||
async function prepEval(groups, groupName, opaVersion) { | |||
const {module, package: pkg, query, input, included} = getGroupData(groups, groupName) | |||
const base = ['eval', '--fail'] // Fail on undefined | |||
const base = ['eval', '--fail', '--v0-compatible'] // Fail on undefined |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Temporary measure to deal with all live blocks not being v1 compliant yet.
This is a bit annoying: every time I need to do a manual intervention when syncing with |
e80e6c2
to
925583a
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just realised I forgot ✅ this.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I haven't read through every change 😅 But a more hands-on review in the form of integrating this branch with Regal. There's a few things we've identified as needed / good to have... but let's have this merged and deal with it after.
Moving (most) source to v1 root package to prepare for v0/v1 API separation. Signed-off-by: Johan Fylling <[email protected]>
All packages, except for `cmd` and `internal`, have been moved into a new `v1` root package. Old packages are kept for backwards-compatibility reasons. All contained code is replaced with simple type aliases and proxy functions to `v1` implementations. Old packages default to the Rego v0 syntax, new `v1` packages default to the Rego v1 syntax. Signed-off-by: Johan Fylling <[email protected]>
ded2294
to
a3f090c
Compare
An alternative to the v1 SDK PR and the v0 global-toggle PR.
This 3rd option moves all (with some exceptions) of OPA proper to the
v1
package, and old root packages only contains type aliases and proxy functions.Pros:
Cons:
v1
package for v1. Devs will need to make sure they're not mixing-and-matching their imports improperly. IDE auto-complete can lead you astray.