Documentation ¶
Overview ¶
Package topdown provides low-level query evaluation support.
The topdown implementation is a modified version of the standard top-down evaluation algorithm used in Datalog. References and comprehensions are evaluated eagerly while all other terms are evaluated lazily.
Index ¶
- Constants
- func CounterAdd(ns, key, value ast.Value) (output ast.Value, err error)
- func CounterDelete(ns, key ast.Value) (output ast.Value, err error)
- func CounterGet(ns, key ast.Value) (output ast.Value, err error)
- func GaugeAdd(ns, key, value, duration ast.Value) (output ast.Value, err error)
- func GaugeDelete(ns, key ast.Value) (output ast.Value, err error)
- func GaugeGet(ns, key ast.Value) (output ast.Value, err error)
- func IsCancel(err error) bool
- func IsError(err error) bool
- func NewPrintHook(w io.Writer) print.Hook
- func PrettyTrace(w io.Writer, trace []*Event)
- func PrettyTraceWithLocation(w io.Writer, trace []*Event)
- func RegisterBuiltinFunc(name string, f BuiltinFunc)
- func RegisterFunctionalBuiltin1(name string, fun FunctionalBuiltin1)
- func RegisterFunctionalBuiltin2(name string, fun FunctionalBuiltin2)
- func RegisterFunctionalBuiltin3(name string, fun FunctionalBuiltin3)
- func RegisterFunctionalBuiltin4(name string, fun FunctionalBuiltin4)
- func RegisterPebbleStore(path string)
- func ShuffleModelAdd(key string, value *interface{})
- func ShuffleModelAddString(key string, value string)
- func ShuffleModelDel(key string)
- func ShuffleModelGet(key string) *interface{}
- func SmKeyAdd(key string, value string)
- func SmKeyGet(key string) string
- type BufferTracer
- type Builtin
- type BuiltinContext
- type BuiltinEmpty
- type BuiltinFunc
- type Cancel
- type Counter
- type Error
- type Event
- type FunctionalBuiltin1
- type FunctionalBuiltin2
- type FunctionalBuiltin3
- type FunctionalBuiltin4
- type Gauge
- type Halt
- type IndexRange
- type Instrumentation
- type JSONWebToken
- type Op
- type PersistApi
- type Query
- func (q *Query) Iter(ctx context.Context, iter func(QueryResult) error) error
- func (q *Query) PartialRun(ctx context.Context) (partials []ast.Body, support []*ast.Module, err error)
- func (q *Query) Run(ctx context.Context) (QueryResultSet, error)
- func (q *Query) WithBuiltins(builtins map[string]*Builtin) *Query
- func (q *Query) WithCancel(cancel Cancel) *Query
- func (q *Query) WithCompiler(compiler *ast.Compiler) *Query
- func (q *Query) WithDisableInlining(paths []ast.Ref) *Query
- func (q *Query) WithDistributedTracingOpts(tr tracing.Options) *Query
- func (q *Query) WithEarlyExit(enabled bool) *Query
- func (q *Query) WithIndexing(enabled bool) *Query
- func (q *Query) WithInput(input *ast.Term) *Query
- func (q *Query) WithInstrumentation(instr *Instrumentation) *Query
- func (q *Query) WithInterQueryBuiltinCache(c cache.InterQueryCache) *Query
- func (q *Query) WithMetrics(m metrics.Metrics) *Query
- func (q *Query) WithPartialNamespace(ns string) *Query
- func (q *Query) WithPrintHook(h print.Hook) *Query
- func (q *Query) WithQueryCompiler(queryCompiler ast.QueryCompiler) *Query
- func (q *Query) WithQueryTracer(tracer QueryTracer) *Query
- func (q *Query) WithResolver(ref ast.Ref, r resolver.Resolver) *Query
- func (q *Query) WithRuntime(runtime *ast.Term) *Query
- func (q *Query) WithSeed(r io.Reader) *Query
- func (q *Query) WithShallowInlining(yes bool) *Query
- func (q *Query) WithSkipPartialNamespace(yes bool) *Query
- func (q *Query) WithStore(store storage.Store) *Query
- func (q *Query) WithStrictBuiltinErrors(yes bool) *Query
- func (q *Query) WithTime(x time.Time) *Query
- func (q *Query) WithTracer(tracer Tracer) *Query
- func (q *Query) WithTransaction(txn storage.Transaction) *Query
- func (q *Query) WithUnknowns(terms []*ast.Term) *Query
- type QueryResult
- type QueryResultSet
- type QueryTracer
- type TraceConfig
- type Tracer
- type VarMetadata
Examples ¶
Constants ¶
const ( // InternalErr represents an unknown evaluation error. InternalErr string = "eval_internal_error" // CancelErr indicates the evaluation process was cancelled. CancelErr string = "eval_cancel_error" // ConflictErr indicates a conflict was encountered during evaluation. For // instance, a conflict occurs if a rule produces multiple, differing values // for the same key in an object. Conflict errors indicate the policy does // not account for the data loaded into the policy engine. ConflictErr string = "eval_conflict_error" // TypeErr indicates evaluation stopped because an expression was applied to // a value of an inappropriate type. TypeErr string = "eval_type_error" // BuiltinErr indicates a built-in function received a semantically invalid // input or encountered some kind of runtime error, e.g., connection // timeout, connection refused, etc. BuiltinErr string = "eval_builtin_error" // WithMergeErr indicates that the real and replacement data could not be merged. WithMergeErr string = "eval_with_merge_error" )
const ( // HTTPSendInternalErr represents a runtime evaluation error. HTTPSendInternalErr string = "eval_http_send_internal_error" // HTTPSendNetworkErr represents a network error. HTTPSendNetworkErr string = "eval_http_send_network_error" )
Variables ¶
This section is empty.
Functions ¶
func CounterAdd ¶ added in v0.37.13
func CounterDelete ¶ added in v0.37.13
func CounterGet ¶ added in v0.37.13
func GaugeDelete ¶ added in v0.37.13
func PrettyTrace ¶ added in v0.2.0
PrettyTrace pretty prints the trace to the writer.
func PrettyTraceWithLocation ¶ added in v0.37.13
PrettyTraceWithLocation prints the trace to the writer and includes location information
func RegisterBuiltinFunc ¶
func RegisterBuiltinFunc(name string, f BuiltinFunc)
RegisterBuiltinFunc adds a new built-in function to the evaluation engine.
func RegisterFunctionalBuiltin1 ¶ added in v0.4.0
func RegisterFunctionalBuiltin1(name string, fun FunctionalBuiltin1)
RegisterFunctionalBuiltin1 is deprecated use RegisterBuiltinFunc instead.
func RegisterFunctionalBuiltin2 ¶ added in v0.4.0
func RegisterFunctionalBuiltin2(name string, fun FunctionalBuiltin2)
RegisterFunctionalBuiltin2 is deprecated use RegisterBuiltinFunc instead.
func RegisterFunctionalBuiltin3 ¶ added in v0.4.0
func RegisterFunctionalBuiltin3(name string, fun FunctionalBuiltin3)
RegisterFunctionalBuiltin3 is deprecated use RegisterBuiltinFunc instead.
func RegisterFunctionalBuiltin4 ¶ added in v0.9.2
func RegisterFunctionalBuiltin4(name string, fun FunctionalBuiltin4)
RegisterFunctionalBuiltin4 is deprecated use RegisterBuiltinFunc instead.
func RegisterPebbleStore ¶ added in v0.37.13
func RegisterPebbleStore(path string)
func ShuffleModelAdd ¶ added in v0.37.13
func ShuffleModelAdd(key string, value *interface{})
func ShuffleModelAddString ¶ added in v0.37.13
func ShuffleModelDel ¶ added in v0.37.13
func ShuffleModelDel(key string)
func ShuffleModelGet ¶ added in v0.37.13
func ShuffleModelGet(key string) *interface{}
Types ¶
type BufferTracer ¶ added in v0.2.0
type BufferTracer []*Event
BufferTracer implements the Tracer and QueryTracer interface by simply buffering all events received.
func NewBufferTracer ¶ added in v0.2.0
func NewBufferTracer() *BufferTracer
NewBufferTracer returns a new BufferTracer.
func (*BufferTracer) Config ¶ added in v0.37.13
func (b *BufferTracer) Config() TraceConfig
Config returns the Tracers standard configuration
func (*BufferTracer) Enabled ¶ added in v0.2.0
func (b *BufferTracer) Enabled() bool
Enabled always returns true if the BufferTracer is instantiated.
func (*BufferTracer) Trace ¶ added in v0.2.0
func (b *BufferTracer) Trace(evt *Event)
Trace adds the event to the buffer. Deprecated: Use TraceEvent instead.
func (*BufferTracer) TraceEvent ¶ added in v0.37.13
func (b *BufferTracer) TraceEvent(evt Event)
TraceEvent adds the event to the buffer.
type Builtin ¶ added in v0.14.0
type Builtin struct { Decl *ast.Builtin Func BuiltinFunc }
Builtin represents a built-in function that queries can call.
type BuiltinContext ¶ added in v0.5.11
type BuiltinContext struct { Context context.Context // request context that was passed when query started Metrics metrics.Metrics // metrics registry for recording built-in specific metrics Seed io.Reader // randomization source Time *ast.Term // wall clock time Cancel Cancel // atomic value that signals evaluation to halt Runtime *ast.Term // runtime information on the OPA instance Cache builtins.Cache // built-in function state cache InterQueryBuiltinCache cache.InterQueryCache // cross-query built-in function state cache Location *ast.Location // location of built-in call Tracers []Tracer // Deprecated: Use QueryTracers instead QueryTracers []QueryTracer // tracer objects for trace() built-in function TraceEnabled bool // indicates whether tracing is enabled for the evaluation QueryID uint64 // identifies query being evaluated ParentID uint64 // identifies parent of query being evaluated PrintHook print.Hook // provides callback function to use for printing DistributedTracingOpts tracing.Options // options to be used by distributed tracing. Capabilities *ast.Capabilities // contains filtered or unexported fields }
BuiltinContext contains context from the evaluator that may be used by built-in functions.
func (*BuiltinContext) Rand ¶ added in v0.37.13
func (bctx *BuiltinContext) Rand() (*rand.Rand, error)
Rand returns a random number generator based on the Seed for this built-in context. The random number will be re-used across multiple calls to this function. If a random number generator cannot be created, an error is returned.
type BuiltinEmpty ¶ added in v0.4.0
type BuiltinEmpty struct{}
BuiltinEmpty is deprecated.
func (BuiltinEmpty) Error ¶ added in v0.4.0
func (BuiltinEmpty) Error() string
type BuiltinFunc ¶
BuiltinFunc defines an interface for implementing built-in functions. The built-in function is called with the plugged operands from the call (including the output operands.) The implementation should evaluate the operands and invoke the iterator for each successful/defined output value.
func GetBuiltin ¶ added in v0.37.13
func GetBuiltin(name string) BuiltinFunc
GetBuiltin returns a built-in function implementation, nil if no built-in found.
type Cancel ¶ added in v0.5.1
type Cancel interface { Cancel() Cancelled() bool }
Cancel defines the interface for cancelling topdown queries. Cancel operations are thread-safe and idempotent.
type Counter ¶ added in v0.37.13
type Counter struct {
Value int64
}
func NewCounter ¶ added in v0.37.13
func NewCounter() Counter
type Error ¶
type Error struct { Code string `json:"code"` Message string `json:"message"` Location *ast.Location `json:"location,omitempty"` }
Error is the error type returned by the Eval and Query functions when an evaluation error occurs.
type Event ¶ added in v0.2.0
type Event struct { Op Op // Identifies type of event. Node ast.Node // Contains AST node relevant to the event. Location *ast.Location // The location of the Node this event relates to. QueryID uint64 // Identifies the query this event belongs to. ParentID uint64 // Identifies the parent query this event belongs to. Locals *ast.ValueMap // Contains local variable bindings from the query context. Nil if variables were not included in the trace event. LocalMetadata map[ast.Var]VarMetadata // Contains metadata for the local variable bindings. Nil if variables were not included in the trace event. Message string // Contains message for Note events. Ref *ast.Ref // Identifies the subject ref for the event. Only applies to Index and Wasm operations. // contains filtered or unexported fields }
Event contains state associated with a tracing event.
type FunctionalBuiltin1 ¶ added in v0.4.0
FunctionalBuiltin1 is deprecated. Use BuiltinFunc instead.
type FunctionalBuiltin2 ¶ added in v0.4.0
FunctionalBuiltin2 is deprecated. Use BuiltinFunc instead.
type FunctionalBuiltin3 ¶ added in v0.4.0
FunctionalBuiltin3 is deprecated. Use BuiltinFunc instead.
type FunctionalBuiltin4 ¶ added in v0.9.2
FunctionalBuiltin4 is deprecated. Use BuiltinFunc instead.
type Gauge ¶ added in v0.37.13
type Gauge struct { Value int64 Duration int64 Timestamp map[int64]int64 // contains filtered or unexported fields }
func (*Gauge) GetDuration ¶ added in v0.37.13
func (*Gauge) SetDuration ¶ added in v0.37.13
type Halt ¶ added in v0.37.13
type Halt struct {
Err error
}
Halt is a special error type that built-in function implementations return to indicate that policy evaluation should stop immediately.
type IndexRange ¶ added in v0.37.13
type Instrumentation ¶ added in v0.7.0
type Instrumentation struct {
// contains filtered or unexported fields
}
Instrumentation implements helper functions to instrument query evaluation to diagnose performance issues. Instrumentation may be expensive in some cases, so it is disabled by default.
func NewInstrumentation ¶ added in v0.7.0
func NewInstrumentation(m metrics.Metrics) *Instrumentation
NewInstrumentation returns a new Instrumentation object. Performance diagnostics recorded on this Instrumentation object will stored in m.
type JSONWebToken ¶ added in v0.8.2
type JSONWebToken struct {
// contains filtered or unexported fields
}
JSONWebToken represent the 3 parts (header, payload & signature) of
a JWT in Base64.
type Op ¶ added in v0.2.0
type Op string
Op defines the types of tracing events.
const ( // EnterOp is emitted when a new query is about to be evaluated. EnterOp Op = "Enter" // ExitOp is emitted when a query has evaluated to true. ExitOp Op = "Exit" // EvalOp is emitted when an expression is about to be evaluated. EvalOp Op = "Eval" // RedoOp is emitted when an expression, rule, or query is being re-evaluated. RedoOp Op = "Redo" // SaveOp is emitted when an expression is saved instead of evaluated // during partial evaluation. SaveOp Op = "Save" // FailOp is emitted when an expression evaluates to false. FailOp Op = "Fail" // DuplicateOp is emitted when a query has produced a duplicate value. The search // will stop at the point where the duplicate was emitted and backtrack. DuplicateOp Op = "Duplicate" // NoteOp is emitted when an expression invokes a tracing built-in function. NoteOp Op = "Note" // IndexOp is emitted during an expression evaluation to represent lookup // matches. IndexOp Op = "Index" // WasmOp is emitted when resolving a ref using an external // Resolver. WasmOp Op = "Wasm" )
type PersistApi ¶ added in v0.37.13
type PersistApi interface { Set(key string, value interface{}) error SetString(key string, value string) error SetInteger(key string, value int64) error SetFloat(key string, value float64) error SetBool(key string, value bool) error SetBytes(key string, value []byte) error Get(key string) (interface{}, error) GetString(key string) (string, error) GetInteger(key string) (int64, error) GetBool(key string) (bool, error) GetFloat(key string) (float64, error) GetBytes(key string) ([]byte, error) Delete(key string) error }
func NewPebbleStorage ¶ added in v0.37.13
func NewPebbleStorage(path string, options pebble.Options) PersistApi
type Query ¶
type Query struct {
// contains filtered or unexported fields
}
Query provides a configurable interface for performing query evaluation.
func (*Query) Iter ¶ added in v0.5.11
Iter executes the query and invokes the iter function with query results produced by evaluating the query.
Example ¶
package main import ( "bytes" "context" "encoding/json" "fmt" "github.com/meta-quick/opax/ast" "github.com/meta-quick/opax/storage/inmem" "github.com/meta-quick/opax/topdown" ) func main() { // Initialize context for the example. Normally the caller would obtain the // context from an input parameter or instantiate their own. ctx := context.Background() compiler := ast.NewCompiler() // Define a dummy query and some data that the query will execute against. query, err := compiler.QueryCompiler().Compile(ast.MustParseBody(`data.a[_] = x; x >= 2`)) if err != nil { // Handle error. } var data map[string]interface{} // OPA uses Go's standard JSON library but assumes that numbers have been // decoded as json.Number instead of float64. You MUST decode with UseNumber // enabled. decoder := json.NewDecoder(bytes.NewBufferString(`{"a": [1,2,3,4]}`)) decoder.UseNumber() if err := decoder.Decode(&data); err != nil { // Handle error. } // Instantiate the policy engine's storage layer. store := inmem.NewFromObject(data) // Create a new transaction. Transactions allow the policy engine to // evaluate the query over a consistent snapshot fo the storage layer. txn, err := store.NewTransaction(ctx) if err != nil { // Handle error. } defer store.Abort(ctx, txn) // Prepare the evaluation parameters. Evaluation executes against the policy // engine's storage. In this case, we seed the storage with a single array // of number. Other parameters such as the input, tracing configuration, // etc. can be set on the query object. q := topdown.NewQuery(query). WithCompiler(compiler). WithStore(store). WithTransaction(txn) result := []interface{}{} // Execute the query and provide a callback function to accumulate the results. err = q.Iter(ctx, func(qr topdown.QueryResult) error { // Each variable in the query will have an associated binding. x := qr[ast.Var("x")] // The bindings are ast.Value types so we will convert to a native Go value here. v, err := ast.JSON(x.Value) if err != nil { return err } result = append(result, v) return nil }) // Inspect the query result. fmt.Println("result:", result) fmt.Println("err:", err) }
Output: result: [2 3 4] err: <nil>
func (*Query) PartialRun ¶ added in v0.5.11
func (q *Query) PartialRun(ctx context.Context) (partials []ast.Body, support []*ast.Module, err error)
PartialRun executes partial evaluation on the query with respect to unknown values. Partial evaluation attempts to evaluate as much of the query as possible without requiring values for the unknowns set on the query. The result of partial evaluation is a new set of queries that can be evaluated once the unknown value is known. In addition to new queries, partial evaluation may produce additional support modules that should be used in conjunction with the partially evaluated queries.
Example ¶
package main import ( "bytes" "context" "encoding/json" "fmt" "github.com/meta-quick/opax/ast" "github.com/meta-quick/opax/storage/inmem" "github.com/meta-quick/opax/topdown" ) func main() { // Initialize context for the example. Normally the caller would obtain the // context from an input parameter or instantiate their own. ctx := context.Background() var data map[string]interface{} decoder := json.NewDecoder(bytes.NewBufferString(`{ "roles": [ { "permissions": ["read_bucket"], "groups": ["dev", "test", "sre"] }, { "permissions": ["write_bucket", "delete_bucket"], "groups": ["sre"] } ] }`)) if err := decoder.Decode(&data); err != nil { // Handle error. } // Instantiate the policy engine's storage layer. store := inmem.NewFromObject(data) // Create a new transaction. Transactions allow the policy engine to // evaluate the query over a consistent snapshot fo the storage layer. txn, err := store.NewTransaction(ctx) if err != nil { // Handle error. } defer store.Abort(ctx, txn) // Define policy that searches for roles that match input request. If no // roles are found, allow is undefined and the caller will reject the // request. This is the user supplied policy that OPA will partially // evaluate. modules := map[string]*ast.Module{ "authz.rego": ast.MustParseModule(` package example default allow = false allow { role = data.roles[i] input.group = role.groups[j] input.permission = role.permissions[k] } `), } // Compile policy. compiler := ast.NewCompiler() if compiler.Compile(modules); compiler.Failed() { // Handle error. } // Construct query and mark the entire input document as partial. q := topdown.NewQuery(ast.MustParseBody("data.example.allow = true")). WithCompiler(compiler). WithUnknowns([]*ast.Term{ ast.MustParseTerm("input"), }). WithStore(store). WithTransaction(txn) // Execute partial evaluation. partial, _, err := q.PartialRun(ctx) if err != nil { // Handle error. } // Show result of partially evaluating the policy. fmt.Printf("# partial evaluation result (%d items):\n", len(partial)) for i := range partial { fmt.Println(partial[i]) } // Construct a new policy to contain the result of partial evaluation. module := ast.MustParseModule("package partial") for i := range partial { rule := &ast.Rule{ Head: &ast.Head{ Name: ast.Var("allow"), Value: ast.BooleanTerm(true), }, Body: partial[i], Module: module, } module.Rules = append(module.Rules, rule) } // Compile the partially evaluated policy with the original policy. modules["partial"] = module if compiler.Compile(modules); compiler.Failed() { // Handle error. } // Test different inputs against partially evaluated policy. inputs := []string{ `{"group": "dev", "permission": "read_bucket"}`, // allow `{"group": "dev", "permission": "write_bucket"}`, // deny `{"group": "sre", "permission": "write_bucket"}`, // allow } fmt.Println() fmt.Println("# evaluation results:") for i := range inputs { // Query partially evaluated policy. q = topdown.NewQuery(ast.MustParseBody("data.partial.allow = true")). WithCompiler(compiler). WithStore(store). WithTransaction(txn). WithInput(ast.MustParseTerm(inputs[i])) qrs, err := q.Run(ctx) if err != nil { // Handle error. } // Check if input is allowed. allowed := len(qrs) == 1 fmt.Printf("input %d allowed: %v\n", i+1, allowed) } }
Output: # partial evaluation result (5 items): "dev" = input.group; "read_bucket" = input.permission "test" = input.group; "read_bucket" = input.permission "sre" = input.group; "read_bucket" = input.permission "sre" = input.group; "write_bucket" = input.permission "sre" = input.group; "delete_bucket" = input.permission # evaluation results: input 1 allowed: true input 2 allowed: false input 3 allowed: true
func (*Query) Run ¶ added in v0.5.11
func (q *Query) Run(ctx context.Context) (QueryResultSet, error)
Run is a wrapper around Iter that accumulates query results and returns them in one shot.
Example ¶
package main import ( "bytes" "context" "encoding/json" "fmt" "github.com/meta-quick/opax/ast" "github.com/meta-quick/opax/storage/inmem" "github.com/meta-quick/opax/topdown" ) func main() { // Initialize context for the example. Normally the caller would obtain the // context from an input parameter or instantiate their own. ctx := context.Background() compiler := ast.NewCompiler() // Define a dummy query and some data that the query will execute against. query, err := compiler.QueryCompiler().Compile(ast.MustParseBody(`data.a[_] = x; x >= 2`)) if err != nil { // Handle error. } var data map[string]interface{} // OPA uses Go's standard JSON library but assumes that numbers have been // decoded as json.Number instead of float64. You MUST decode with UseNumber // enabled. decoder := json.NewDecoder(bytes.NewBufferString(`{"a": [1,2,3,4]}`)) decoder.UseNumber() if err := decoder.Decode(&data); err != nil { // Handle error. } // Instantiate the policy engine's storage layer. store := inmem.NewFromObject(data) // Create a new transaction. Transactions allow the policy engine to // evaluate the query over a consistent snapshot fo the storage layer. txn, err := store.NewTransaction(ctx) if err != nil { // Handle error. } defer store.Abort(ctx, txn) // Prepare the evaluation parameters. Evaluation executes against the policy // engine's storage. In this case, we seed the storage with a single array // of number. Other parameters such as the input, tracing configuration, // etc. can be set on the query object. q := topdown.NewQuery(query). WithCompiler(compiler). WithStore(store). WithTransaction(txn) rs, err := q.Run(ctx) // Inspect the query result set. fmt.Println("len:", len(rs)) for i := range rs { fmt.Printf("rs[%d][\"x\"]: %v\n", i, rs[i]["x"]) } fmt.Println("err:", err) }
Output: len: 3 rs[0]["x"]: 2 rs[1]["x"]: 3 rs[2]["x"]: 4 err: <nil>
func (*Query) WithBuiltins ¶ added in v0.14.0
WithBuiltins adds a set of built-in functions that can be called by the query.
func (*Query) WithCancel ¶ added in v0.5.11
WithCancel sets the cancellation object to use for the query. Set this if you need to abort queries based on a deadline. This is optional.
func (*Query) WithCompiler ¶ added in v0.5.11
WithCompiler sets the compiler to use for the query.
func (*Query) WithDisableInlining ¶ added in v0.13.0
WithDisableInlining adds a set of paths to the query that should be excluded from inlining. Inlining during partial evaluation can be expensive in some cases (e.g., when a cross-product is computed.) Disabling inlining avoids expensive computation at the cost of generating support rules.
func (*Query) WithDistributedTracingOpts ¶ added in v0.37.13
WithDistributedTracingOpts sets the options to be used by distributed tracing.
func (*Query) WithEarlyExit ¶ added in v0.37.13
WithEarlyExit will enable or disable using 'early exit' for the evaluation of the query. The default is enabled.
func (*Query) WithIndexing ¶ added in v0.37.13
WithIndexing will enable or disable using rule indexing for the evaluation of the query. The default is enabled.
func (*Query) WithInput ¶ added in v0.5.11
WithInput sets the input object to use for the query. References rooted at input will be evaluated against this value. This is optional.
func (*Query) WithInstrumentation ¶ added in v0.7.0
func (q *Query) WithInstrumentation(instr *Instrumentation) *Query
WithInstrumentation sets the instrumentation configuration to enable on the evaluation process. By default, instrumentation is turned off.
func (*Query) WithInterQueryBuiltinCache ¶ added in v0.37.13
func (q *Query) WithInterQueryBuiltinCache(c cache.InterQueryCache) *Query
WithInterQueryBuiltinCache sets the inter-query cache that built-in functions can utilize.
func (*Query) WithMetrics ¶ added in v0.5.11
WithMetrics sets the metrics collection to add evaluation metrics to. This is optional.
func (*Query) WithPartialNamespace ¶ added in v0.6.0
WithPartialNamespace sets the namespace to use for supporting rules generated as part of the partial evaluation process. The ns value must be a valid package path component.
func (*Query) WithQueryCompiler ¶ added in v0.37.13
func (q *Query) WithQueryCompiler(queryCompiler ast.QueryCompiler) *Query
WithQueryCompiler sets the queryCompiler used for the query.
func (*Query) WithQueryTracer ¶ added in v0.37.13
func (q *Query) WithQueryTracer(tracer QueryTracer) *Query
WithQueryTracer adds a query tracer to use during evaluation. This is optional. Disabled QueryTracers will be ignored.
func (*Query) WithResolver ¶ added in v0.37.13
WithResolver configures an external resolver to use for the given ref.
func (*Query) WithRuntime ¶ added in v0.10.0
WithRuntime sets the runtime data to execute the query with. The runtime data can be returned by the `opa.runtime` built-in function.
func (*Query) WithSeed ¶ added in v0.37.13
WithSeed sets a reader that will seed randomization required by built-in functions. If a seed is not provided crypto/rand.Reader is used.
func (*Query) WithShallowInlining ¶ added in v0.37.13
WithShallowInlining disables aggressive inlining performed during partial evaluation. When shallow inlining is enabled rules that depend (transitively) on unknowns are not inlined. Only rules/values that are completely known will be inlined.
func (*Query) WithSkipPartialNamespace ¶ added in v0.37.13
WithSkipPartialNamespace disables namespacing of saved support rules that are generated from the original policy (rules which are completely synthetic are still namespaced.)
func (*Query) WithStrictBuiltinErrors ¶ added in v0.37.13
WithStrictBuiltinErrors tells the evaluator to treat all built-in function errors as fatal errors.
func (*Query) WithTime ¶ added in v0.37.13
WithTime sets the time that will be returned by the time.now_ns() built-in function.
func (*Query) WithTracer ¶ added in v0.5.11
WithTracer adds a query tracer to use during evaluation. This is optional. Deprecated: Use WithQueryTracer instead.
func (*Query) WithTransaction ¶ added in v0.5.11
func (q *Query) WithTransaction(txn storage.Transaction) *Query
WithTransaction sets the transaction to use for the query. All queries should be performed over a consistent snapshot of the storage layer.
type QueryResult ¶ added in v0.2.1
QueryResult represents a single result returned by a query. The result contains bindings for all variables that appear in the query.
type QueryResultSet ¶ added in v0.2.1
type QueryResultSet []QueryResult
QueryResultSet represents a collection of results returned by a query.
type QueryTracer ¶ added in v0.37.13
type QueryTracer interface { Enabled() bool TraceEvent(Event) Config() TraceConfig }
QueryTracer defines the interface for tracing in the top-down evaluation engine. The implementation can provide additional configuration to modify the tracing behavior for query evaluations.
func WrapLegacyTracer ¶ added in v0.37.13
func WrapLegacyTracer(tracer Tracer) QueryTracer
WrapLegacyTracer will create a new QueryTracer which wraps an older Tracer instance.
type TraceConfig ¶ added in v0.37.13
type TraceConfig struct {
PlugLocalVars bool // Indicate whether to plug local variable bindings before calling into the tracer.
}
TraceConfig defines some common configuration for Tracer implementations
Source Files ¶
- aggregates.go
- arithmetic.go
- array.go
- binary.go
- bindings.go
- bits.go
- builtins.go
- cache.go
- cancel.go
- casts.go
- cidr.go
- comparison.go
- crypto.go
- doc.go
- encoding.go
- errors.go
- eval.go
- glob.go
- http.go
- input.go
- instrumentation.go
- json.go
- net.go
- numbers.go
- object.go
- parse.go
- parse_bytes.go
- persist.go
- print.go
- query.go
- reachable.go
- regex.go
- regex_template.go
- resolver.go
- runtime.go
- save.go
- semver.go
- sets.go
- strings.go
- time.go
- tokens.go
- trace.go
- type.go
- type_name.go
- uuid.go
- walk.go
Directories ¶
Path | Synopsis |
---|---|
Package builtins contains utilities for implementing built-in functions.
|
Package builtins contains utilities for implementing built-in functions. |
Package cache defines the inter-query cache interface that can cache data across queries
|
Package cache defines the inter-query cache interface that can cache data across queries |