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

com.authlete.common.dto.ClientExtension Maven / Gradle / Ivy

/*
 * Copyright (C) 2017 Authlete, 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 com.authlete.common.dto;


import java.io.Serializable;
import java.util.Set;


/**
 * Client extension.
 *
 * 

* There are some attributes that belong to a client application but * should not be changed by the developer of the client application. * Basically, this class holds such attributes. *

* *

* For example, an authorization server may narrow the range of scopes * (permissions) that a particular client application can request. * In this case, it is meaningless if the developer of the client * application can freely decide the set of requestable scopes. It is * not the developer of the client application but the administrator * of the authorization server that should be allowed to define the * set of scopes that the client application can request. *

* * @author Takahiko Kawasaki * * @since 1.39 */ public class ClientExtension implements Serializable { private static final long serialVersionUID = 2L; private boolean requestableScopesEnabled; private String[] requestableScopes; /** * Check whether "Requestable Scopes per Client" is enabled or not. * *

* If this method returns {@code true}, a special set of scopes (permissions) * is defined on the server side (the {@code requestableScopes} array * represents the special set) and scopes which this client application can * request are limited to the scopes listed in the set. In other words, this * application cannot request scopes that are not included in the set. To be * specific, this client application cannot list other scopes in the {@code * scope} request parameter when it makes an authorization request. To be * exact, other scopes can be listed but will be ignored by the authorization * server. *

* *

* On the other hand, if this method returns {@code false}, the valid set of * scopes (permissions) that this client application can request is equal to * the whole scope set defined by the authorization server. *

* * @return * {@code true} if "Requestable Scopes per Client" is enabled * for this client. Otherwise, {@code false}. */ public boolean isRequestableScopesEnabled() { return requestableScopesEnabled; } /** * Enable or disable "Requestable Scopes per Client". * *

* See the description of {@link #isRequestableScopesEnabled()} for details * about "Requestable Scopes per Client". *

* * @param enabled * {@code true} to enable "Requestable Scopes per Client". * {@code false} to disable it. * * @return * {@code this} object. */ public ClientExtension setRequestableScopesEnabled(boolean enabled) { this.requestableScopesEnabled = enabled; return this; } /** * Get the set of scopes that this client application can request when * "Requestable Scopes per Client" is enabled (= when {@link * #isRequestableScopesEnabled()} returns {@code true}). * *

* See the description of {@link #isRequestableScopesEnabled()} for details * about "Requestable Scopes per Client". *

* * @return * The set of scopes that this client application can request * when "Requestable Scopes per Client" is enabled. */ public String[] getRequestableScopes() { return requestableScopes; } /** * Set the set of scopes that this client application can request when * "Requestable Scopes per Client" is enabled (= when {@link * #isRequestableScopesEnabled()} returns {@code true}). * *

* See the description of {@link #isRequestableScopesEnabled()} for details * about "Requestable Scopes per Client". *

* * @param scopes * A set of scopes. * * @return * {@code this} object. */ public ClientExtension setRequestableScopes(String[] scopes) { this.requestableScopes = scopes; return this; } /** * Set the set of scopes that this client application can request when * "Requestable Scopes per Client" is enabled (= when {@link * #isRequestableScopesEnabled()} returns {@code true}). * *

* See the description of {@link #isRequestableScopesEnabled()} for details * about "Requestable Scopes per Client". *

* * @param scopes * A set of scopes. * * @return * {@code this} object. * * @since 1.41 */ public ClientExtension setRequestableScopes(Set scopes) { if (scopes == null) { this.requestableScopes = null; return this; } int size = scopes.size(); this.requestableScopes = new String[size]; if (size != 0) { scopes.toArray(this.requestableScopes); } return this; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy