dev.cel.runtime.RuntimeUnknownResolver Maven / Gradle / Ivy
Show all versions of validators Show documentation
// Copyright 2022 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package dev.cel.runtime;
import com.google.errorprone.annotations.CanIgnoreReturnValue;
import dev.cel.common.annotations.Internal;
import java.util.HashMap;
import java.util.Map;
import java.util.Optional;
/**
* Runtime representation of the current state in an iterative evaluation session.
*
* This is used by the interpreter to coordinate identifying and tracking unknown values through
* evaluation.
*
*
CEL Library Internals. Do Not Use.
*/
@Internal
public class RuntimeUnknownResolver {
private static final CelAttributeResolver DEFAULT_RESOLVER = new NullAttributeResolver();
/** The underlying resolver for known values. */
private final GlobalResolver resolver;
/** Resolver for unknown and resolved attributes. */
private final CelAttributeResolver attributeResolver;
private final boolean attributeTrackingEnabled;
private RuntimeUnknownResolver(
GlobalResolver resolver,
CelAttributeResolver attributeResolver,
boolean attributeTrackingEnabled) {
this.resolver = resolver;
this.attributeResolver = attributeResolver;
this.attributeTrackingEnabled = attributeTrackingEnabled;
}
public static RuntimeUnknownResolver fromResolver(GlobalResolver resolver) {
// This prevents calculating the attribute trail if it will never be used for
// efficiency, but doesn't change observable behavior.
return new RuntimeUnknownResolver(
resolver, DEFAULT_RESOLVER, /* attributeTrackingEnabled= */ false) {};
}
public static Builder builder() {
return new Builder();
}
/** Builder for {@link RuntimeUnknownResolver}. */
public static class Builder {
private CelAttributeResolver attributeResolver;
private GlobalResolver resolver;
private Builder() {
resolver = Activation.EMPTY;
attributeResolver = DEFAULT_RESOLVER;
}
@CanIgnoreReturnValue
public Builder setResolver(GlobalResolver resolver) {
this.resolver = resolver;
return this;
}
@CanIgnoreReturnValue
public Builder setAttributeResolver(CelAttributeResolver resolver) {
attributeResolver = resolver;
return this;
}
public RuntimeUnknownResolver build() {
return new RuntimeUnknownResolver(resolver, attributeResolver, true);
}
}
/**
* Return a single element unknown set if the attribute is partially unknown based on the defined
* patterns.
*/
Optional maybePartialUnknown(CelAttribute attribute) {
return attributeResolver.maybePartialUnknown(attribute);
}
/** Resolve a simple name to a value. */
DefaultInterpreter.IntermediateResult resolveSimpleName(String name, Long exprId) {
CelAttribute attr = CelAttribute.EMPTY;
if (attributeTrackingEnabled) {
attr = CelAttribute.fromQualifiedIdentifier(name);
Optional