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


Java AuthenticationContext類代碼示例

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


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

示例1: assertDefaultRealmWorks

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
/**
 * Tests if DIGEST-* mechanism with default realm used works correctly for both valid and invalid username/password
 * combinations.
 *
 * @param mechanism DIGEST mechanism name
 */
private void assertDefaultRealmWorks(String mechanism) throws Exception {
    try (CLIWrapper cli = new CLIWrapper(true)) {
        cli.sendLine(String.format(
                "/subsystem=elytron/sasl-authentication-factory=%s:write-attribute(name=mechanism-configurations, value=[{mechanism-name=%s}])",
                NAME, mechanism));
    }
    ServerReload.reloadIfRequired(TestSuiteEnvironment.getModelControllerClient());

    AuthenticationConfiguration authnCfg = AuthenticationConfiguration.empty()
            .setSaslMechanismSelector(SaslMechanismSelector.fromString(mechanism)).useName(USERNAME)
            .usePassword(USERNAME + PASSWORD_SFX);
    AuthenticationContext.empty().with(MatchRule.ALL, authnCfg).run(() -> assertWhoAmI(USERNAME));

    authnCfg = AuthenticationConfiguration.empty().setSaslMechanismSelector(SaslMechanismSelector.fromString(mechanism))
            .useName("noSuchUser").usePassword("aPassword");
    AuthenticationContext.empty().with(MatchRule.ALL, authnCfg).run(() -> assertAuthenticationFails(
            "Authentication should fail when the user doesn't exist in the security-realm"));
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:25,代碼來源:DefaultRealmDigestMgmtSaslTestCase.java

示例2: assertKerberosSaslMechPasses

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
/**
 * Asserts that given user can authenticate with given Kerberos SASL mechanism.
 */
protected void assertKerberosSaslMechPasses(String mech, String user, String password, boolean withSsl)
        throws MalformedURLException, LoginException, Exception {
    // 1. Authenticate to Kerberos.
    final LoginContext lc = KerberosTestUtils.loginWithKerberos(KRB5_CONFIGURATION, user, password);
    try {
        AuthenticationConfiguration authCfg = AuthenticationConfiguration.empty()
                .setSaslMechanismSelector(SaslMechanismSelector.fromString(mech))
                .useGSSCredential(getGSSCredential(lc.getSubject()));

        AuthenticationContext authnCtx = AuthenticationContext.empty().with(MatchRule.ALL, authCfg);
        if (withSsl) {
            authnCtx = authnCtx.withSsl(MatchRule.ALL, sslFactory);
        }
        final AuthenticationContext authnCtxFinal = authnCtx;
        Subject.doAs(lc.getSubject(), (PrivilegedAction<Void>) () -> {
            authnCtxFinal.run(() -> assertWhoAmI(user + "@JBOSS.ORG", withSsl));
            return null;
        });
    } finally {
        lc.logout();
    }
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:26,代碼來源:AbstractKerberosMgmtSaslTestBase.java

示例3: assertKerberosSaslMechFails

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
protected void assertKerberosSaslMechFails(String mech, String user, String password, boolean withSsl)
        throws MalformedURLException, LoginException, Exception {
    // 1. Authenticate to Kerberos.
    final LoginContext lc = KerberosTestUtils.loginWithKerberos(KRB5_CONFIGURATION, user, password);
    try {
        AuthenticationConfiguration authCfg = AuthenticationConfiguration.empty()
                .setSaslMechanismSelector(SaslMechanismSelector.fromString(mech))
                .useGSSCredential(getGSSCredential(lc.getSubject()));

        AuthenticationContext authnCtx = AuthenticationContext.empty().with(MatchRule.ALL, authCfg);
        if (withSsl) {
            authnCtx = authnCtx.withSsl(MatchRule.ALL, sslFactory);
        }
        final AuthenticationContext authnCtxFinal = authnCtx;
        Subject.doAs(lc.getSubject(), (PrivilegedAction<Void>) () -> {
            authnCtxFinal.run(() -> assertAuthenticationFails(null, null, withSsl));
            return null;
        });
    } finally {
        lc.logout();
    }
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:23,代碼來源:AbstractKerberosMgmtSaslTestBase.java

示例4: testMatchingFilteringProperties

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
/**
 * Tests SASL mechanism filtering through policy properties which are matched by EXTERNAL mechanism.
 *
 * @see <a href="https://issues.jboss.org/browse/ELY-982">ELY-982</a>
 */
@Test
public void testMatchingFilteringProperties() throws Exception {
    Map<String, String> mechanismProperties = new HashMap<>();
    mechanismProperties.put(Sasl.POLICY_NOPLAINTEXT, "true");
    mechanismProperties.put(Sasl.POLICY_NOACTIVE, "true");
    mechanismProperties.put(Sasl.POLICY_NODICTIONARY, "true");
    AuthenticationConfiguration authCfg = AuthenticationConfiguration.empty()
            .setSaslMechanismSelector(SaslMechanismSelector.fromString(MECHANISM))
            .useMechanismProperties(mechanismProperties);

    SecurityFactory<SSLContext> ssl = new SSLContextBuilder().setClientMode(true)
            .setKeyManager(getKeyManager(CLIENT_KEYSTORE_FILE)).setTrustManager(getTrustManager()).build();
    AuthenticationContext.empty().with(MatchRule.ALL, authCfg).withSsl(MatchRule.ALL, ssl)
            .run(() -> assertWhoAmI("client"));
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:21,代碼來源:ExternalMgmtSaslTestCase.java

示例5: testNullProvider

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
/**
 * Tests wrongly configured security Provider in the clients AuthenticationConfiguration.
 */
@Test
public void testNullProvider() throws Exception {
    String mechanismName = getMechanism();
    AuthenticationConfiguration authnCfg = AuthenticationConfiguration.empty()
            .setSaslMechanismSelector(SaslMechanismSelector.fromString(mechanismName))
            .useProviders(() -> new Provider[] { null });
    if ("ANONYMOUS".equals(mechanismName)) {
        authnCfg = authnCfg.useAnonymous();
    } else if ("OAUTHBEARER".equals(mechanismName)) {
        authnCfg = authnCfg.useBearerTokenCredential(new BearerTokenCredential(JWT_TOKEN));
    } else if (!"JBOSS-LOCAL-USER".equals(mechanismName)) {
        authnCfg = authnCfg.useName(USERNAME).usePassword(USERNAME + PASSWORD_SFX);
    }
    AuthenticationContext.empty().with(MatchRule.ALL, authnCfg).run(() -> assertAuthenticationFails());
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:19,代碼來源:AbstractMgmtSaslTestBase.java

示例6: createDomainClient

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
/**
 * Create a new model controller client. The client can (and should) be closed without affecting other usages.
 *
 * @param authConfigUri the path to the {@code wildfly-config.xml} to use or {@code null}
 *
 * @return the domain client
 */
public DomainClient createDomainClient(final URI authConfigUri) {
    final DomainTestConnection connection = this.connection;
    if(connection == null) {
        throw new IllegalStateException();
    }
    if (authConfigUri == null) {
        return DomainClient.Factory.create(connection.createClient());
    }
    try {
        final AuthenticationContext context = ElytronXmlParser.parseAuthenticationClientConfiguration(authConfigUri).create();
        return DomainClient.Factory.create(new ContextualModelControllerClient(connection.createClient(), context));
    } catch (GeneralSecurityException | ConfigXMLParseException e) {
        throw new RuntimeException("Failed to parse authentication configuration: " + authConfigUri, e);
    }
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:23,代碼來源:DomainLifecycleUtil.java

示例7: RemoteDomainConnection

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
RemoteDomainConnection(final String localHostName, final ProtocolConnectionConfiguration configuration, final AuthenticationContext authenticationContext,
                       final SecurityRealm realm,  final String username, final List<DiscoveryOption> discoveryOptions,
                       final ExecutorService executorService,
                       final ScheduledExecutorService scheduledExecutorService,
                       final HostRegistrationCallback callback,
                       final RunningMode runningMode) {
    this.callback = callback;
    this.localHostName = localHostName;
    this.configuration = configuration;
    this.authenticationContext = authenticationContext;
    this.username = username;
    this.realm = realm;
    this.discoveryOptions = discoveryOptions;
    this.executorService = executorService;
    this.channelHandler = new ManagementChannelHandler(this, executorService);
    this.scheduledExecutorService = scheduledExecutorService;
    this.runningMode = runningMode;
    this.connectionManager = ProtocolConnectionManager.create(new InitialConnectTask());
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:20,代碼來源:RemoteDomainConnection.java

示例8: deploy

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
@Override
public void deploy(DeploymentPhaseContext context) throws DeploymentUnitProcessingException {
    AuthenticationContext authenticationContext = context.getAttachment(AUTHENTICATION_CONTEXT_KEY);
    if (authenticationContext != null) {
        AuthenticationContext.getContextManager().setClassLoaderDefault(
                context.getDeploymentUnit().getAttachment(MODULE).getClassLoader(), authenticationContext);
    }
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:9,代碼來源:AuthenticationContextAssociationProcessor.java

示例9: performRuntime

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
protected void performRuntime(final OperationContext context, final ModelNode operation, final ModelNode model) throws OperationFailedException {

            RuntimeCapability<Void> runtimeCapability = DIR_CONTEXT_RUNTIME_CAPABILITY.fromBaseCapability(context.getCurrentAddressValue());
            ServiceName serviceName = runtimeCapability.getCapabilityServiceName(DirContextSupplier.class);

            final InjectedValue<ExceptionSupplier<CredentialSource, Exception>> credentialSourceSupplierInjector = new InjectedValue<>();
            final InjectedValue<AuthenticationContext> authenticationContextInjector = new InjectedValue<>();
            final InjectedValue<SSLContext> sslContextInjector = new InjectedValue<>();

            TrivialService<DirContextSupplier> service = new TrivialService<>(obtainDirContextSupplier(context, model, credentialSourceSupplierInjector, authenticationContextInjector, sslContextInjector));
            ServiceBuilder<DirContextSupplier> serviceBuilder = context.getServiceTarget().addService(serviceName, service);

            String sslContextName = SSL_CONTEXT.resolveModelAttribute(context, model).asStringOrNull();
            if (sslContextName != null) {
                String sslCapability = RuntimeCapability.buildDynamicCapabilityName(SSL_CONTEXT_CAPABILITY, sslContextName);
                ServiceName sslServiceName = context.getCapabilityServiceName(sslCapability, SSLContext.class);
                serviceBuilder.addDependency(sslServiceName, SSLContext.class, sslContextInjector);
            }

            if (CREDENTIAL_REFERENCE.resolveModelAttribute(context, model).isDefined()) {
                credentialSourceSupplierInjector.inject(CredentialReference.getCredentialSourceSupplier(context, CREDENTIAL_REFERENCE, model, serviceBuilder));
            }

            String authenticationContextName = AUTHENTICATION_CONTEXT.resolveModelAttribute(context, model).asStringOrNull();
            if (authenticationContextName != null) {
                String acCapability = RuntimeCapability.buildDynamicCapabilityName(AUTHENTICATION_CONTEXT_CAPABILITY, authenticationContextName);
                ServiceName acServiceName = context.getCapabilityServiceName(acCapability, AuthenticationContext.class);
                serviceBuilder.addDependency(acServiceName, AuthenticationContext.class, authenticationContextInjector);
            }

            serviceBuilder
                    .setInitialMode(ServiceController.Mode.ACTIVE)
                    .install();
        }
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:35,代碼來源:DirContextDefinition.java

示例10: testCorrectMechanismPasses

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
/**
 * Tests that client is able to use mechanism when server allows it.
 */
@Test
public void testCorrectMechanismPasses() throws Exception {
    AuthenticationConfiguration authCfg = AuthenticationConfiguration.empty()
            .setSaslMechanismSelector(SaslMechanismSelector.fromString(MECHANISM));

    SecurityFactory<SSLContext> ssl = new SSLContextBuilder().setClientMode(true)
            .setKeyManager(getKeyManager(CLIENT_KEYSTORE_FILE)).setTrustManager(getTrustManager()).build();
    AuthenticationContext.empty().with(MatchRule.ALL, authCfg).withSsl(MatchRule.ALL, ssl)
            .run(() -> assertWhoAmI("client"));
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:14,代碼來源:ExternalMgmtSaslTestCase.java

示例11: assertUnmatchingFilteringPropertyFails

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
/**
 * @param policyProperty
 * @throws Exception
 */
private void assertUnmatchingFilteringPropertyFails(String policyProperty) throws Exception {
    Map<String, String> mechanismProperties = new HashMap<>();
    mechanismProperties.put(policyProperty, "true");
    AuthenticationConfiguration authCfg = AuthenticationConfiguration.empty()
            .setSaslMechanismSelector(SaslMechanismSelector.fromString(MECHANISM))
            .useMechanismProperties(mechanismProperties);

    SecurityFactory<SSLContext> ssl = new SSLContextBuilder().setClientMode(true)
            .setKeyManager(getKeyManager(CLIENT_KEYSTORE_FILE)).setTrustManager(getTrustManager()).build();
    AuthenticationContext.empty().with(MatchRule.ALL, authCfg).withSsl(MatchRule.ALL, ssl)
            .run(() -> assertAuthenticationFails(
                    String.format("The EXTERNAL SASL mechanism should not be selected, when property %s is true.", policyProperty)));
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:18,代碼來源:ExternalMgmtSaslTestCase.java

示例12: testUntrustedCertFails

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
/**
 * Tests that client with wrong (untrusted) certificate is not able to execute operation on server through the mechanism.
 */
@Test
public void testUntrustedCertFails() throws Exception {
    AuthenticationConfiguration authCfg = AuthenticationConfiguration.empty()
            .setSaslMechanismSelector(SaslMechanismSelector.fromString(MECHANISM));

    SecurityFactory<SSLContext> ssl = new SSLContextBuilder().setClientMode(true)
            .setKeyManager(getKeyManager(UNTRUSTED_STORE_FILE)).setTrustManager(getTrustManager()).build();
    AuthenticationContext.empty().with(MatchRule.ALL, authCfg).withSsl(MatchRule.ALL, ssl)
            .run(() -> assertCertAuthenticationFails(
                    "Client certificate authentication should fail for an untrusted certificate."));
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:15,代碼來源:ExternalMgmtSaslTestCase.java

示例13: testWrongCredentialsFail

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
/**
 * Tests that invalid credentials results in authentication failure.
 */
@Test
public void testWrongCredentialsFail() throws Exception {
    String mechanismName = getMechanism();
    if ("ANONYMOUS".equals(mechanismName)) {
        LOGGER.info("We don't test ANONYMOUS mechanism with wrong user credentials.");
        return;
    }

    AuthenticationConfiguration authnCfg = AuthenticationConfiguration.empty()
            .setSaslMechanismSelector(SaslMechanismSelector.fromString(mechanismName)).useName(USERNAME)
            .usePassword("wrongPassword").useProviders(() -> new Provider[] { PROVIDER_ELYTRON });
    AuthenticationContext.empty().with(MatchRule.ALL, authnCfg).run(() -> assertAuthenticationFails());
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:17,代碼來源:AbstractMgmtSaslTestBase.java

示例14: createValidConfigForMechanism

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
protected AuthenticationContext createValidConfigForMechanism(String mechanismName, String username) {
    AuthenticationConfiguration authnCfg = AuthenticationConfiguration.empty()
            .setSaslMechanismSelector(SaslMechanismSelector.fromString(mechanismName));
    if ("ANONYMOUS".equals(mechanismName)) {
        authnCfg = authnCfg.useAnonymous();
    } else if ("OAUTHBEARER".equals(mechanismName)) {
        authnCfg = authnCfg.useBearerTokenCredential(new BearerTokenCredential(JWT_TOKEN));
    } else if (!"JBOSS-LOCAL-USER".equals(mechanismName)) {
        authnCfg = authnCfg.useName(username).usePassword(username + PASSWORD_SFX);
    }
    return AuthenticationContext.empty().with(MatchRule.ALL, authnCfg);
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:13,代碼來源:AbstractMgmtSaslTestBase.java

示例15: testExpiredToken

import org.wildfly.security.auth.client.AuthenticationContext; //導入依賴的package包/類
@Test
public void testExpiredToken() throws Exception {
    AuthenticationContext.empty()
            .with(MatchRule.ALL,
                    AuthenticationConfiguration.empty().setSaslMechanismSelector(SaslMechanismSelector.ALL)
                            .useBearerTokenCredential(new BearerTokenCredential(TOKEN_EXPIRED)))
            .run(() -> assertAuthenticationFails());
}
 
開發者ID:wildfly,項目名稱:wildfly-core,代碼行數:9,代碼來源:OauthbearerMgmtSaslTestCase.java


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