org.wildfly.test.security.common.elytron.SimpleAuthConfig Maven / Gradle / Ivy
/*
* Copyright 2017 Red Hat, Inc.
*
* 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 org.wildfly.test.security.common.elytron;
import java.util.Properties;
import org.jboss.as.test.integration.management.util.CLIWrapper;
/**
* Elytron authentication configuration implementation.
*
* @author Stefan Guilhen
*/
public class SimpleAuthConfig extends AbstractConfigurableElement {
private final Boolean anonymous;
private final Boolean allowAllMechanisms;
private final String[] allowSaslMechanisms;
private final String[] forbidSaslMechanisms;
private final Properties mechanismProperties;
private final String authenticationName;
private final String authorizationName;
private final CredentialReference credentialReference;
private final String extendsAttr;
private final String host;
private final String port;
private final String protocol;
private final String realm;
private final String securityDomain;
private SimpleAuthConfig(final Builder builder) {
super(builder);
this.anonymous = builder.anonymous;
this.allowAllMechanisms = builder.allowAllMechanisms;
this.allowSaslMechanisms = builder.allowSaslMechanisms;
this.forbidSaslMechanisms = builder.forbidSaslMechanisms;
this.mechanismProperties = builder.mechanismProperties;
this.authenticationName = builder.authenticationName;
this.authorizationName = builder.authorizationName;
this.credentialReference = builder.credentialReference;
this.extendsAttr = builder.extendsAttr;
this.host = builder.host;
this.port = builder.port;
this.protocol = builder.protocol;
this.realm = builder.realm;
this.securityDomain = builder.securityDomain;
}
@Override
public void create(CLIWrapper cli) throws Exception {
final StringBuilder sb = new StringBuilder("/subsystem=elytron/authentication-configuration=\"");
sb.append(name).append("\":add(");
if (anonymous != null) {
sb.append(anonymous.booleanValue() == true ? "" : "!").append("anonymous, ");
}
if (allowAllMechanisms != null) {
sb.append(allowAllMechanisms.booleanValue() == true ? "" : "!").append("allow-all-mechanisms, ");
}
if (allowSaslMechanisms != null && allowSaslMechanisms.length > 0) {
sb.append("allow-sasl-mechanisms=[");
for (String mech : allowSaslMechanisms) {
sb.append(mech).append(" ");
}
sb.append("], ");
}
if (forbidSaslMechanisms != null && forbidSaslMechanisms.length > 0) {
sb.append("forbid-sasl-mechanisms=[");
for (String mech : forbidSaslMechanisms) {
sb.append(mech).append(" ");
}
sb.append("], ");
}
if (mechanismProperties != null && !mechanismProperties.isEmpty()) {
sb.append("mechanism-properties={");
for (Object key : mechanismProperties.keySet()) {
sb.append(key.toString()).append("=").append(mechanismProperties.getProperty(key.toString()));
sb.append(", ");
}
sb.append("}, ");
}
if (authenticationName != null && !authenticationName.isEmpty()) {
sb.append(String.format("authentication-name=\"%s\", ", authenticationName));
}
if (authorizationName != null && !authorizationName.isEmpty()) {
sb.append(String.format("authorization-name=\"%s\", ", authorizationName));
}
if (credentialReference != null) {
sb.append(credentialReference.asString());
}
if (extendsAttr != null && !extendsAttr.isEmpty()) {
sb.append(String.format("extends=\"%s\", ", extendsAttr));
}
if (host != null && !host.isEmpty()) {
sb.append(String.format("host=\"%s\", ", host));
}
if (port != null && !port.isEmpty()) {
sb.append(String.format("port=\"%s\", ", port));
}
if (protocol != null && !protocol.isEmpty()) {
sb.append(String.format("protocol=\"%s\", ", protocol));
}
if (realm != null && !realm.isEmpty()) {
sb.append(String.format("realm=\"%s\", ", realm));
}
if (securityDomain != null && !securityDomain.isEmpty()) {
sb.append(String.format("security-domain=\"%s\", ", securityDomain));
}
sb.append(")");
cli.sendLine(sb.toString());
}
@Override
public void remove(CLIWrapper cli) throws Exception {
cli.sendLine(String.format("/subsystem=elytron/authentication-configuration=\"%s\":remove", name));
}
public static Builder builder() {
return new Builder();
}
public static final class Builder extends AbstractConfigurableElement.Builder {
private Boolean anonymous;
private Boolean allowAllMechanisms;
private String[] allowSaslMechanisms;
private String[] forbidSaslMechanisms;
private Properties mechanismProperties;
private String authenticationName;
private String authorizationName;
private CredentialReference credentialReference;
private String extendsAttr;
private String host;
private String port;
private String protocol;
private String realm;
private String securityDomain;
private Builder() {
}
public Builder allowAnonymous(final Boolean allowAnonymous) {
this.anonymous = allowAnonymous;
return this;
}
public Builder allowAllMechanisms(final Boolean allowAllMechanisms) {
this.allowAllMechanisms = allowAllMechanisms;
return this;
}
public Builder withAllowedSaslMechanisms(final String... allowedSaslMechanisms) {
this.allowSaslMechanisms = allowedSaslMechanisms;
return this;
}
public Builder withForbiddenSaslMechanisms(final String... forbiddenSaslMechanisms) {
this.forbidSaslMechanisms = forbiddenSaslMechanisms;
return this;
}
public Builder withMechanismProperties(final Properties mechanismProperties) {
this.mechanismProperties = mechanismProperties;
return this;
}
public Builder withAuthenticationName(final String authenticationName) {
this.authenticationName = authenticationName;
return this;
}
public Builder withAuthorizationName(final String authorizationName) {
this.authorizationName = authorizationName;
return this;
}
public Builder withCredentialReference(final CredentialReference credentialReference) {
this.credentialReference = credentialReference;
return this;
}
public Builder withExtends(final String extendsAttr) {
this.extendsAttr = extendsAttr;
return this;
}
public Builder withHost(final String host) {
this.host = host;
return this;
}
public Builder withPort(final String port) {
this.port = port;
return this;
}
public Builder withProtocol(final String protocol) {
this.protocol = protocol;
return this;
}
public Builder withRealm(final String realm) {
this.realm = realm;
return this;
}
public Builder withSecurityDomain(final String securityDomain) {
this.securityDomain = securityDomain;
return this;
}
public SimpleAuthConfig build() {
return new SimpleAuthConfig(this);
}
@Override
protected Builder self() {
return this;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy