All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.pdd.pop.ext.glassfish.tyrus.client.auth.AuthConfig Maven / Gradle / Ivy

/*
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 *
 * Copyright (c) 2014-2016 Oracle and/or its affiliates. All rights reserved.
 *
 * The contents of this file are subject to the terms of either the GNU
 * General Public License Version 2 only ("GPL") or the Common Development
 * and Distribution License("CDDL") (collectively, the "License").  You
 * may not use this file except in compliance with the License.  You can
 * obtain a copy of the License at
 * http://glassfish.java.net/public/CDDL+GPL_1_1.html
 * or packager/legal/LICENSE.txt.  See the License for the specific
 * language governing permissions and limitations under the License.
 *
 * When distributing the software, include this License Header Notice in each
 * file and include the License file at packager/legal/LICENSE.txt.
 *
 * GPL Classpath Exception:
 * Oracle designates this particular file as subject to the "Classpath"
 * exception as provided by Oracle in the GPL Version 2 section of the License
 * file that accompanied this code.
 *
 * Modifications:
 * If applicable, add the following below the License Header, with the fields
 * enclosed by brackets [] replaced by your own identifying information:
 * "Portions Copyright [year] [name of copyright owner]"
 *
 * Contributor(s):
 * If you wish your version of this file to be governed by only the CDDL or
 * only the GPL Version 2, indicate your decision by adding "[Contributor]
 * elects to include this software in this distribution under the [CDDL or GPL
 * Version 2] license."  If you don't indicate a single choice of license, a
 * recipient has the option to distribute your version of this file under
 * either the CDDL, the GPL Version 2 or to extend the choice of license to
 * its licensees as provided above.  However, if you add GPL Version 2 code
 * and therefore, elected the GPL Version 2 license, then the option applies
 * only if the new code is made subject to such option by the copyright
 * holder.
 */

package com.pdd.pop.ext.glassfish.tyrus.client.auth;

import java.nio.charset.Charset;
import java.util.Collections;
import java.util.Map;
import java.util.TreeMap;

import com.pdd.pop.ext.glassfish.tyrus.client.ClientManager;
import com.pdd.pop.ext.glassfish.tyrus.core.Beta;

/**
 * AuthConfig serves as a configuration of HTTP authentication.
 * 

* An instance of this class can be created by {@link AuthConfig} and it must be registered to property bag in {@link * ClientManager}. * * @author Ondrej Kosatka (ondrej.kosatka at oracle.com) * @see Authenticator * @see ClientManager#getProperties() */ @Beta public class AuthConfig { /** * Encoding used for authentication calculations. */ static final Charset CHARACTER_SET = Charset.forName("iso-8859-1"); /** * Basic authentication scheme key. */ static final String BASIC = "Basic"; /** * Digest authentication scheme key. */ static final String DIGEST = "Digest"; private final Map authenticators; private AuthConfig(Map authenticators) { TreeMap map = new TreeMap(String.CASE_INSENSITIVE_ORDER); map.putAll(authenticators); this.authenticators = Collections.unmodifiableMap(map); } /** * Get an unmodifiable map of authenticators, where case insensitive authentication scheme to {@link * Authenticator}. * * @return unmodifiable map of authenticators. Case insensitive authentication scheme is mapped to {@link * Authenticator}. */ public Map getAuthenticators() { return authenticators; } /** * Create new {@link Builder} instance, which contains provided Basic and Digest authenticators. * * @return builder instance. */ public static Builder builder() { return Builder.create(); } @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("AuthConfig{"); boolean first = true; for (Map.Entry authenticator : authenticators.entrySet()) { if (first) { first = false; } else { sb.append(", "); } sb.append(authenticator.getKey()); sb.append("->"); sb.append(authenticator.getValue().getClass().getName()); } sb.append("}"); return sb.toString(); } /** * The AuthConfig.Builder is a class used for creating an instance of {@link AuthConfig} for purpose of HTTP * Authentication. *

* Example 1 - building an authentication configuration enhanced with user defined NTLM authentication and * overridden Basic Authentication: *


     * AuthConfig authConfig = AuthConfig.Builder.create().
     *                          registerAuthProvider("NTLM", myAuthenticator).
     *                          registerAuthProvider("Basic", myBasicAuthenticator).
     *                          build();
     * 
* Example 2 - Building an authentication configuration with disabled Basic scheme authenticator: *

     * AuthConfig authConfig = AuthConfig.Builder.create().
     *                          disableProvidedBasicAuth().
     *                          build();
     * 
* * @see Credentials * @see Authenticator */ public static final class Builder { private final Map authenticators = new TreeMap(String.CASE_INSENSITIVE_ORDER); private Builder() { authenticators.put(BASIC, new BasicAuthenticator()); authenticators.put(DIGEST, new DigestAuthenticator()); } /** * Create new {@link Builder} instance, which contains provided Basic and Digest authenticators. * * @return {@link AuthConfig.Builder} instance. */ public static Builder create() { return new Builder(); } /** * Register {@link Authenticator} for provided authentication scheme. *

* Only one {@link Authenticator} for one authentication scheme can be registered. If current builder instance * already contains {@link Authenticator} for provided scheme, existing authenticator will be replaced. Note * that schemes are compared in case insensitive manner. * * @param scheme authentication scheme for which the registered authenticator will be used. Scheme is * compared case insensitive. * @param authenticator {@link Authenticator} instance to be registered. * @return updated {@link AuthConfig.Builder} instance. */ public final Builder registerAuthProvider(final String scheme, final Authenticator authenticator) { this.authenticators.put(scheme, authenticator); return this; } /** * Disable provided Basic {@link Authenticator}. * * @return updated {@link AuthConfig.Builder} instance. */ public final Builder disableProvidedBasicAuth() { if (authenticators.get(BASIC) != null && authenticators.get(BASIC) instanceof BasicAuthenticator) { authenticators.remove(BASIC); } return this; } /** * Disable provided Digest {@link Authenticator}. * * @return updated {@link AuthConfig.Builder} instance. */ public final Builder disableProvidedDigestAuth() { if (authenticators.get(DIGEST) != null && authenticators.get(DIGEST) instanceof DigestAuthenticator) { authenticators.remove(DIGEST); } return this; } /** * Build an instance of {@link AuthConfig}. * * @return an instance of {@link AuthConfig}. */ public AuthConfig build() { return new AuthConfig(authenticators); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy