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

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

/*
 * Copyright (C) 2019-2021 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.Map;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;


/**
 * A class that represents an element in {@code authorization_details}
 * which is defined in "OAuth 2.0 Rich Authorization Requests".
 *
 * @since 2.56
 */
public class AuthzDetailsElement implements Serializable
{
    private static final long serialVersionUID = 4L;


    private String type;
    private String[] locations;
    private String[] actions;
    private String[] dataTypes;
    private String identifier;
    private String[] privileges;
    private String otherFields;


    /**
     * Get the type of this element.
     *
     * 

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "The type of authorization data as a string. This field MAY define which * other elements are allowed in the request. This element is REQUIRED." *

*
* * @return * The type of this element. */ public String getType() { return type; } /** * Set the type of this element. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "The type of authorization data as a string. This field MAY define which * other elements are allowed in the request. This element is REQUIRED." *

*
* * @param type * The type of this element. * * @return * {@code this} object. */ public AuthzDetailsElement setType(String type) { this.type = type; return this; } /** * Get the resources and/or resource servers. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "An array of strings representing the location of the resource or * resource server. These strings are typically URIs identifying the * location of the RS." *

*
* * @return * The resources and/or resource servers. */ public String[] getLocations() { return locations; } /** * Set the resources and/or resource servers. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "An array of strings representing the location of the resource or * resource server. These strings are typically URIs identifying the * location of the RS." *

*
* * @param locations * The resources and/or resource servers. * * @return * {@code this} object. */ public AuthzDetailsElement setLocations(String[] locations) { this.locations = locations; return this; } /** * Get the actions. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "An array of strings representing the kinds of actions to be taken * at the resource." *

*
* * @return * The actions. */ public String[] getActions() { return actions; } /** * Set the actions. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "An array of strings representing the kinds of actions to be taken * at the resource." *

*
* * @param actions * The actions. * * @return * {@code this} object. */ public AuthzDetailsElement setActions(String[] actions) { this.actions = actions; return this; } /** * Get the data types. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "An array of strings representing the kinds of data being requested * from the resource." *

*
* * @return * The data types. * * @since 2.85 */ public String[] getDataTypes() { return dataTypes; } /** * Set the data types. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "An array of strings representing the kinds of data being requested * from the resource." *

*
* * @param dataTypes * The data types. * * @return * {@code this} object. * * @since 2.85 */ public AuthzDetailsElement setDataTypes(String[] dataTypes) { this.dataTypes = dataTypes; return this; } /** * Get the identifier of a specific resource. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "A string identifier indicating a specific resource available at the API." *

*
* * @return * The identifier of a specific resource. */ public String getIdentifier() { return identifier; } /** * Set the identifier of a specific resource. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "A string identifier indicating a specific resource available at the API." *

*
* * @param identifier * The identifier of a specific resource. * * @return * {@code this} object. */ public AuthzDetailsElement setIdentifier(String identifier) { this.identifier = identifier; return this; } /** * Get the types or levels of privilege. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "An array of strings representing the types or levels of privilege * being requested at the resource." *

*
* * @return * Types or levels of privilege. * * @since 2.91 */ public String[] getPrivileges() { return privileges; } /** * Set the types or levels of privilege. * *

* From "OAuth 2.0 Rich Authorization Requests": *

* *
*

* "An array of strings representing the types or levels of privilege * being requested at the resource." *

*
* * @param privileges * Types or levels of privilege. * * @return * {@code this} object. * * @since 2.91 */ public AuthzDetailsElement setPrivileges(String[] privileges) { this.privileges = privileges; return this; } /** * Get the other fields (than the pre-defined ones such as {@code type} * and {@code locations}) as a string in the JSON format. * *

* The content varies depending on the {@code type} field. *

* * @return * Other fields in the JSON format. This may be {@code null}. * * @see #getOtherFieldsAsMap() */ public String getOtherFields() { return otherFields; } /** * Set the other fields (than the pre-defined ones such as {@code type} * and {@code locations}) as a string in the JSON format. * *

* The content varies depending on the {@code type} field. *

* * @param otherFields * Other fields in the JSON format. * * @return * {@code this} object. */ public AuthzDetailsElement setOtherFields(String otherFields) { this.otherFields = otherFields; return this; } /** * Get the other fields (than {@code type}, {@code locations}, * {@code actions} and {@code identifier}) as a {@link Map} object. * *

* The content varies depending on the {@code type} field. *

* * @return * Other fields as a {@link Map} object. This may be {@code null}. * * @see #getOtherFields() */ public Map getOtherFieldsAsMap() { if (otherFields == null) { return null; } return new Gson().fromJson(otherFields, Map.class); } /** * Set the other fields (than {@code type}, {@code locations}, * {@code actions} and {@code identifier}) using a {@link Map} * object. The internal value is stored as a string serialization * of the {@link Map} object. * *

* The content varies depending on the {@code type} field. *

* * @param otherFields * A {@code Map} instance holding other fields. * * @return * {@code this} object. * * @see #getOtherFieldsAsMap() * * @since 2.99 */ public AuthzDetailsElement setOtherFieldsFromMap(Map otherFields) { if (otherFields == null) { this.otherFields = null; } else { this.otherFields = new Gson().toJson(otherFields, Map.class); } return this; } /** * Convert this instance into a JSON string. * *

* "Other fields" (the string returned from {@link #getOtherFields()} are * expanded into the output JSON. *

* * @return * A JSON string that represents this instance. * * @since 2.57 */ public String toJson() { return createSerializer().toJson(this); } /** * Build an {@code AuthzDetailsElement} instance from a JSON string. * *

* The following is an example of input JSON. *

* *
     * {
     *   "type"      : "my_type",
     *   "locations" : ["loc0", "loc1"],
     *   "actions"   : ["act0", "act1"],
     *   "identifier": "my_id",
     *   "prop0"     : "a",
     *   "prop1"     : ["b", "c"],
     *   "prop2"     : {
     *     "sub0": "d",
     *     "sub1": ["e", "f"]
     *   }
     * }
     * 
* * @param json * A JSON string. * * @return * An {@code AuthzDetailsElement} instance built from the input JSON. * * @since 2.57 */ public static AuthzDetailsElement fromJson(String json) { if (json == null) { return null; } return createDeserializer().fromJson(json, AuthzDetailsElement.class); } /** * Create a serializer for {@link AuthzDetailsElement}. */ private static Gson createSerializer() { return new GsonBuilder() .registerTypeAdapter( AuthzDetailsElement.class, new AuthzDetailsElementSerializer()) .create(); } /** * Create a deserializer for {@link AuthzDetailsElement}. */ private static Gson createDeserializer() { return new GsonBuilder() .registerTypeAdapter( AuthzDetailsElement.class, new AuthzDetailsElementDeserializer()) .create(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy