io.gravitee.gateway.api.ExecutionContext Maven / Gradle / Ivy
/*
* Copyright © 2015 The Gravitee team (http://gravitee.io)
*
* 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
*
* http://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 io.gravitee.gateway.api;
import io.gravitee.el.TemplateEngine;
import io.gravitee.gateway.reactive.api.tracing.Tracer;
import java.util.Enumeration;
import java.util.Map;
/**
* @author David BRASSELY (david.brassely at graviteesource.com)
* @author Azize ELAMRANI (azize.elamrani at graviteesource.com)
* @author Nicolas GERAUD (nicolas.geraud at graviteesource.com)
* @author GraviteeSource Team
*/
public interface ExecutionContext {
String ATTR_PREFIX = "gravitee.attribute.";
String ATTR_CONTEXT_PATH = ATTR_PREFIX + "context-path";
String ATTR_RESOLVED_PATH = ATTR_PREFIX + "resolved-path";
String ATTR_APPLICATION = ATTR_PREFIX + "application";
String ATTR_API = ATTR_PREFIX + "api";
String ATTR_API_DEPLOYED_AT = ATTR_PREFIX + "api.deployed-at";
String ATTR_SUBSCRIPTION_ID = ATTR_PREFIX + "user-id";
String ATTR_PLAN = ATTR_PREFIX + "plan";
String ATTR_REQUEST_METHOD = ATTR_PREFIX + "request.method";
String ATTR_REQUEST_ENDPOINT = ATTR_PREFIX + "request.endpoint";
String ATTR_INVOKER = ATTR_PREFIX + "request.invoker";
String ATTR_QUOTA_COUNT = ATTR_PREFIX + "quota.count";
String ATTR_QUOTA_REMAINING = ATTR_PREFIX + "quota.remaining";
String ATTR_QUOTA_LIMIT = ATTR_PREFIX + "quota.limit";
String ATTR_QUOTA_RESET_TIME = ATTR_PREFIX + "quota.reset.time";
String ATTR_USER = ATTR_PREFIX + "user";
String ATTR_USER_ROLES = ATTR_PREFIX + "user.roles";
String ATTR_ORGANIZATION = ATTR_PREFIX + "organization";
String ATTR_ENVIRONMENT = ATTR_PREFIX + "environment";
String ATTR_FAILURE_ATTRIBUTE = ATTR_PREFIX + "failure";
String ATTR_CLIENT_IDENTIFIER = ATTR_PREFIX + "clientIdentifier";
/**
* Skip security chain isn't prefixed to avoid breaking code where this constant isn't used.
*/
String ATTR_SECURITY_SKIP = "skip-security-chain";
String ATTR_INVOKER_SKIP = "invoker.skip";
String ATTR_VALIDATE_SUBSCRIPTION = "api.validateSubscription";
String ATTR_MAPPED_PATH = ATTR_PREFIX + "mapped-path";
Request request();
Response response();
T getComponent(Class componentClass);
/*
* Execution attributes management.
* This is a copy of the ServletRequest API.
*/
/**
* Stores an attribute in this request. Attributes are reset between requests.
*
* @param name a String specifying the name of the attribute
* @param value the Object to be stored
*/
void setAttribute(String name, Object value);
/**
* Removes an attribute from this request. This method is not generally needed as attributes only persist as
* long as the request is being handled.
*
* @param name a String specifying the name of the attribute to remove
*/
void removeAttribute(String name);
/**
* Returns the value of the named attribute as an Object, or null
if no attribute of the given
* name exists.
*
* @param name a String specifying the name of the attribute
* @return an Object containing the value of the attribute, or null if the attribute does not exist
*/
Object getAttribute(String name);
/**
* Returns an Enumeration containing the names of the attributes available to this request. This method returns
* an empty Enumeration if the request has no attributes available to it.
*
* @return an Enumeration of strings containing the names of the request's attributes
*/
Enumeration getAttributeNames();
Map getAttributes();
TemplateEngine getTemplateEngine();
Tracer getTracer();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy