當前位置: 首頁>>代碼示例>>Java>>正文


Java IPolicyContext類代碼示例

本文整理匯總了Java中io.apiman.gateway.engine.policy.IPolicyContext的典型用法代碼示例。如果您正苦於以下問題:Java IPolicyContext類的具體用法?Java IPolicyContext怎麽用?Java IPolicyContext使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


IPolicyContext類屬於io.apiman.gateway.engine.policy包,在下文中一共展示了IPolicyContext類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: verifyResult

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
/**
 * Verify the session data.
 *
 * @param result    the result of retrieving session data
 * @param sessionId the ID of the session
 * @param request   the service request
 * @param context   the policy context
 * @param config    the policy configuration
 * @return the result of the validation
 */
private ValidationResult verifyResult(IAsyncResult<Session> result, String sessionId, ApiRequest request,
                                      IPolicyContext context, CookieValidateConfigBean config) {

    final ValidationResult validationResult;
    final Session sessionData = result.getResult();

    if (result.isSuccess() && null != sessionData && StringUtils.isNotBlank(sessionData.getSessionId())) {
        validationResult = verifySessionData(sessionData, sessionId, request, context, config);

    } else {
        //noinspection ThrowableResultOfMethodCallIgnored
        if (null != result.getError()) {
            LOGGER.error(MESSAGES.format("ErrorReadingSessionData", sessionId), result.getError());
        }

        // session not present
        validationResult = new ValidationResult(false,
                MESSAGES.format("MissingSessionData", sessionId));
    }

    return validationResult;
}
 
開發者ID:outofcoffee,項目名稱:apiman-plugins-session,代碼行數:33,代碼來源:CookieValidatePolicy.java

示例2: extendSession

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
/**
 * Extend the session with a new expiry time.
 *
 * @param context     the policy context
 * @param sessionData the session to extend
 */
private void extendSession(final IPolicyContext context, final Session sessionData) {
    final long newExpiry = (TimeUtil.getNowInMillis() + sessionData.getValidityPeriod());
    sessionData.setExpires(newExpiry);

    LOGGER.debug(MESSAGES.format("ExtendingSession", sessionData.getSessionId(), newExpiry));

    // store updated session data
    final ISessionStore sessionStore = SessionStoreFactory.getSessionStore(context);
    sessionStore.storeSession(sessionData.getSessionId(), sessionData, result -> {
        if (result.isSuccess()) {
            LOGGER.info(MESSAGES.format(
                    "UpdatedSessionData", sessionData.getSessionId(), sessionData));
        } else {
            LOGGER.error(MESSAGES.format("ErrorUpdatingSessionData",
                    sessionData.getSessionId(), sessionData), result.getError());
        }
    });
}
 
開發者ID:outofcoffee,項目名稱:apiman-plugins-session,代碼行數:25,代碼來源:CookieValidatePolicy.java

示例3: doContinue

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
/**
 * Either continue the policy chain or skip, depending on the policy configuration.
 *
 * @param request the service request
 * @param context the policy context
 * @param config  the policy configuration
 * @param chain   the policy chain
 */
private void doContinue(ApiRequest request, IPolicyContext context, CookieRemoveConfigBean config,
                        IPolicyChain<ApiRequest> chain) {

    if (config.getSkipBackendCall()) {
        // don't call the back-end service
        LOGGER.info(MESSAGES.format("SkippingBackEndCall"));

        context.setConnectorInterceptor(new ShortcircuitConnectorInterceptor());
        chain.doSkip(request);

    } else {
        // call the back-end service
        chain.doApply(request);
    }
}
 
開發者ID:outofcoffee,項目名稱:apiman-plugins-session,代碼行數:24,代碼來源:CookieRemovePolicy.java

示例4: invalidateSession

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
/**
 * Invalidate session data for the given session, then manipulate the chain accordingly.
 *
 * @param sessionId the ID of the session
 * @param request   the service request
 * @param context   the policy context
 * @param chain     the policy chain
 * @param config    the policy configuration
 */
private void invalidateSession(final String sessionId, final ApiRequest request, final IPolicyContext context,
                               final IPolicyChain<ApiRequest> chain, final CookieRemoveConfigBean config) {

    final ISessionStore sessionStore = SessionStoreFactory.getSessionStore(context);
    sessionStore.deleteSession(sessionId, result -> {
        if (result.isSuccess()) {
            // session data removed
            LOGGER.info(MESSAGES.format("SessionInvalidated", sessionId));
            doContinue(request, context, config, chain);

        } else {
            // failed to remove session data
            final String failureMessage = MESSAGES.format(
                    "SessionInvalidationFailed", sessionId);
            LOGGER.error(failureMessage, result.getError());

            // policy failure
            chain.doFailure(new PolicyFailure(PolicyFailureType.Other,
                    HttpURLConnection.HTTP_INTERNAL_ERROR, failureMessage));
        }
    });
}
 
開發者ID:outofcoffee,項目名稱:apiman-plugins-session,代碼行數:32,代碼來源:CookieRemovePolicy.java

示例5: storeSessionData

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
/**
 * Store session information.
 *
 * @param context                the policy context
 * @param config                 the policy configuration
 * @param sessionId              the ID of the session generated in {@link #generateCookie(CookieIssueConfigBean)}
 * @param authenticatedPrincipal the authenticated principal extracted from the API response
 */
private static void storeSessionData(IPolicyContext context, CookieIssueConfigBean config, final String sessionId,
                                     String authenticatedPrincipal) {

    // build and store a new session
    final Session sessionData = SessionUtil.buildSession(sessionId, authenticatedPrincipal, config.getValidityPeriod());
    LOGGER.debug(MESSAGES.format("StoringSessionData", sessionId, sessionData));

    final ISessionStore sessionStore = SessionStoreFactory.getSessionStore(context);
    sessionStore.storeSession(sessionId, sessionData, result -> {
        if (result.isSuccess()) {
            LOGGER.info(MESSAGES.format(
                    "StoredSessionData", sessionId, sessionData));

        } else {
            LOGGER.error(MESSAGES.format(
                    "ErrorStoringSessionData", sessionId, sessionData), result.getError());
        }
    });
}
 
開發者ID:outofcoffee,項目名稱:apiman-plugins-session,代碼行數:28,代碼來源:CookieIssuePolicy.java

示例6: doTokenAuth

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
private Holder<Boolean> doTokenAuth(Holder<Boolean> successStatus, ApiRequest request,
        IPolicyContext context, KeycloakOauthConfigBean config, IPolicyChain<ApiRequest> chain,
        String rawToken) {
    try {
        AccessToken parsedToken = RSATokenVerifier.verifyToken(rawToken, config.getRealmCertificate()
                .getPublicKey(), config.getRealm());

        delegateKerberosTicket(request, config, parsedToken);
        forwardHeaders(request, config, rawToken, parsedToken);
        stripAuthTokens(request, config);
        forwardAuthRoles(context, config, parsedToken);

        RequestMetric metric = context.getAttribute(PolicyContextKeys.REQUEST_METRIC, (RequestMetric) null);
        if (metric != null) {
            metric.setUser(parsedToken.getPreferredUsername());
        }

        return successStatus.setValue(true);
    } catch (VerificationException e) {
        System.out.println(e);
        chain.doFailure(failureFactory.verificationException(context, e));
        return successStatus.setValue(false);
    }
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:25,代碼來源:KeycloakOauthPolicy.java

示例7: forwardAuthRoles

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
private void forwardAuthRoles(IPolicyContext context, KeycloakOauthConfigBean config,
        AccessToken parsedToken) {

    if (config.getForwardRoles().getActive()) {
        Access access = null;

        if (config.getForwardRoles().getApplicationName() != null) {
            access = parsedToken.getResourceAccess(config.getForwardRoles().getApplicationName());
        } else {
            access = parsedToken.getRealmAccess();
        }

        if (access == null || access.getRoles() == null) {
            context.setAttribute(AuthorizationPolicy.AUTHENTICATED_USER_ROLES, Collections.<String>emptySet());
        } else {
            context.setAttribute(AuthorizationPolicy.AUTHENTICATED_USER_ROLES, access.getRoles());
        }
    }
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:20,代碼來源:KeycloakOauthPolicy.java

示例8: doApply

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
@Override
protected void doApply(ApiRequest request, IPolicyContext context, TransformationConfigBean config,
        IPolicyChain<ApiRequest> chain) {
    DataFormat clientFormat = config.getClientFormat();
    DataFormat serverFormat = config.getServerFormat();

    if (isValidTransformation(clientFormat, serverFormat)) {
        context.setAttribute(CLIENT_FORMAT, clientFormat);
        context.setAttribute(SERVER_FORMAT, serverFormat);

        request.getHeaders().put(CONTENT_TYPE, serverFormat.getContentType());
        request.getHeaders().remove(CONTENT_LENGTH);
        
        request.getHeaders().put(ACCEPT, serverFormat.getContentType());
    }

    super.doApply(request, context, config, chain);
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:19,代碼來源:TransformationPolicy.java

示例9: doApply

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
/**
 * @see io.apiman.gateway.engine.policies.AbstractMappedPolicy#doApply(io.apiman.gateway.engine.beans.ApiResponse, io.apiman.gateway.engine.policy.IPolicyContext, java.lang.Object, io.apiman.gateway.engine.policy.IPolicyChain)
 */
@Override
protected void doApply(ApiResponse response, IPolicyContext context, CircuitBreakerConfigBean config,
        IPolicyChain<ApiResponse> chain) {
    Circuit circuit = context.getAttribute(CircuitBreakerPolicy.class.getName() + ".circuit", (Circuit) null); //$NON-NLS-1$
    boolean isFault = isCircuitFault(response, config);
    if (circuit.isResetting()) {
        if (isFault) {
            circuit.trip();
        } else {
            circuit.reset();
        }
    } else {
        if (isFault) {
            circuit.addFault();
        }
    }
    super.doApply(response, context, config, chain);
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:22,代碼來源:CircuitBreakerPolicy.java

示例10: doApply

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
/**
 * @see io.apiman.gateway.engine.policies.AbstractMappedPolicy#doApply(io.apiman.gateway.engine.beans.ApiResponse, io.apiman.gateway.engine.policy.IPolicyContext, java.lang.Object, io.apiman.gateway.engine.policy.IPolicyChain)
 */
@Override
protected void doApply(ApiResponse response, IPolicyContext context, LogHeadersConfigBean config,
        IPolicyChain<ApiResponse> chain) {
    IApimanLogger logger = context.getLogger(getClass());
    if (config.getDirection() != LogHeadersDirectionType.request) {
        String endpoint = context.getAttribute(ENDPOINT_ATTRIBUTE, ""); //$NON-NLS-1$
        if (config.isLogStatusCode()) {
            logger.info(String.format("Status code %d for %s", response.getCode(), endpoint));
        }
        if (config.isLogHeaders()) {
            logHeaders(logger, response.getHeaders(), HttpDirection.RESPONSE, endpoint);
        }
    }
    chain.doApply(response);
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:19,代碼來源:LogHeadersPolicy.java

示例11: BatchedRep

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
public BatchedRep(Auth3ScaleBean auth3ScaleBean,
        ApiRequest request,
        ApiResponse response,
        IPolicyContext context,
        ReporterImpl<BatchedReportData> reporter,
        StandardAuthCache authCache,
        BatchedAuthCache heuristicCache) {
    this.config = auth3ScaleBean.getThreescaleConfig().getProxyConfig().getBackendConfig();
    this.backendUri = auth3ScaleBean.getBackendEndpoint();
    this.request = request;
    this.context = context;
    this.reporter = reporter;
    this.authCache = authCache;
    this.heuristicCache = heuristicCache;
    this.httpClient = context.getComponent(IHttpClientComponent.class);
    this.failureFactory = context.getComponent(IPolicyFailureFactoryComponent.class);
    this.logger = context.getLogger(BatchedRep.class);
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:19,代碼來源:BatchedRep.java

示例12: BatchedAuth

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
public BatchedAuth(Auth3ScaleBean auth3ScaleBean,
        ApiRequest request,
        IPolicyContext context,
        StandardAuthCache authCache,
        BatchedAuthCache heuristicCache) {
    this.backendUri = auth3ScaleBean.getBackendEndpoint();
    this.config = auth3ScaleBean.getThreescaleConfig().getProxyConfig().getBackendConfig();
    this.request = request;
    this.context = context;
    this.authCache = authCache;
    this.heuristicCache = heuristicCache;
    this.logger = context.getLogger(BatchedAuth.class);
    this.serviceId = config.getProxy().getServiceId();
    this.httpClient = context.getComponent(IHttpClientComponent.class);
    this.failureFactory = context.getComponent(IPolicyFailureFactoryComponent.class);
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:17,代碼來源:BatchedAuth.java

示例13: doApply

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
@Override
protected void doApply(ApiRequest request, IPolicyContext context, Auth3ScaleBean config, IPolicyChain<ApiRequest> chain) {
    init(context);

    try {
        auth3scale.getAuth(config, request, context)
            // If a policy failure occurs, call chain.doFailure.
            .policyFailureHandler(chain::doFailure)
            // If succeeded or error.
            .auth(result -> {
                if (result.isSuccess()) {
                    // Keep the API request around so the auth apikey(s) can be accessed, etc.
                    context.setAttribute(AUTH3SCALE_REQUEST, request);
                    chain.doApply(request);
                } else {
                    chain.throwError(result.getError());
                }
            });
    } catch (Exception e) {
        logger.error("Unexpected error", e);
        e.printStackTrace();
        chain.throwError(UNEXPECTED_ERROR);
    }
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:25,代碼來源:Auth3Scale.java

示例14: start

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
public BatchedReporter start(IPolicyContext context, BatchedReporterOptions options) {
    if (started) {
        throw new IllegalStateException("Already started");
    }

    this.retryReporter = new RetryReporter(options.getRetryQueueMaxSize());
    reporters.add(retryReporter);

    this.httpClient = context.getComponent(IHttpClientComponent.class);
    this.periodic = context.getComponent(IPeriodicComponent.class);
    this.logger = context.getLogger(BatchedReporter.class);

    this.timerId = periodic.setPeriodicTimer(options.getReportingInterval(),
            options.getInitialWait(),
            id -> send());
    started = true;
    return this;
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:19,代碼來源:BatchedReporter.java

示例15: AuthRep

import io.apiman.gateway.engine.policy.IPolicyContext; //導入依賴的package包/類
public AuthRep(IPolicyContext context) {
    batchedReporter = new BatchedReporter()
            .start(context, new BatchedReporterOptions());

    // API Key
    ApiKeyAuthRepFactory apiKeyFactory = new ApiKeyAuthRepFactory();
    authTypeFactory.put(AuthTypeEnum.API_KEY, apiKeyFactory);

    // App Id
    AppIdAuthRepFactory appIdFactory = new AppIdAuthRepFactory();
    authTypeFactory.put(AuthTypeEnum.APP_ID, appIdFactory);

    // Add different RL strategies (bad name... TODO better name!).
    // Standard naive rate limiting.
    principalFactoryMap.put(RateLimitingStrategy.STANDARD, new StandardStrategyFactory());
    principalFactoryMap.put(RateLimitingStrategy.BATCHED_HYBRID, new BatchedStrategyFactory(batchedReporter));
}
 
開發者ID:apiman,項目名稱:apiman-plugins,代碼行數:18,代碼來源:AuthRep.java


注:本文中的io.apiman.gateway.engine.policy.IPolicyContext類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。