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

com.azure.resourcemanager.authorization.fluent.models.MicrosoftGraphOAuth2PermissionGrant Maven / Gradle / Ivy

Go to download

This package contains Microsoft Azure Authorization Management SDK. For documentation on how to use this package, please see https://aka.ms/azsdk/java/mgmt

There is a newer version: 2.44.0
Show newest version
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// Code generated by Microsoft (R) AutoRest Code Generator.

package com.azure.resourcemanager.authorization.fluent.models;

import com.azure.core.annotation.Fluent;
import com.azure.json.JsonReader;
import com.azure.json.JsonToken;
import com.azure.json.JsonWriter;
import java.io.IOException;
import java.util.LinkedHashMap;
import java.util.Map;

/**
 * oAuth2PermissionGrant.
 */
@Fluent
public final class MicrosoftGraphOAuth2PermissionGrant extends MicrosoftGraphEntity {
    /*
     * The id of the client service principal for the application which is authorized to act on behalf of a signed-in
     * user when accessing an API. Required. Supports $filter (eq only).
     */
    private String clientId;

    /*
     * Indicates if authorization is granted for the client application to impersonate all users or only a specific
     * user. AllPrincipals indicates authorization to impersonate all users. Principal indicates authorization to
     * impersonate a specific user. Consent on behalf of all users can be granted by an administrator. Non-admin users
     * may be authorized to consent on behalf of themselves in some cases, for some delegated permissions. Required.
     * Supports $filter (eq only).
     */
    private String consentType;

    /*
     * The id of the user on behalf of whom the client is authorized to access the resource, when consentType is
     * Principal. If consentType is AllPrincipals this value is null. Required when consentType is Principal.
     */
    private String principalId;

    /*
     * The id of the resource service principal to which access is authorized. This identifies the API which the client
     * is authorized to attempt to call on behalf of a signed-in user.
     */
    private String resourceId;

    /*
     * A space-separated list of the claim values for delegated permissions which should be included in access tokens
     * for the resource application (the API). For example, openid User.Read GroupMember.Read.All. Each claim value
     * should match the value field of one of the delegated permissions defined by the API, listed in the
     * publishedPermissionScopes property of the resource service principal.
     */
    private String scope;

    /*
     * oAuth2PermissionGrant
     */
    private Map additionalProperties;

    /**
     * Creates an instance of MicrosoftGraphOAuth2PermissionGrant class.
     */
    public MicrosoftGraphOAuth2PermissionGrant() {
    }

    /**
     * Get the clientId property: The id of the client service principal for the application which is authorized to act
     * on behalf of a signed-in user when accessing an API. Required. Supports $filter (eq only).
     * 
     * @return the clientId value.
     */
    public String clientId() {
        return this.clientId;
    }

    /**
     * Set the clientId property: The id of the client service principal for the application which is authorized to act
     * on behalf of a signed-in user when accessing an API. Required. Supports $filter (eq only).
     * 
     * @param clientId the clientId value to set.
     * @return the MicrosoftGraphOAuth2PermissionGrant object itself.
     */
    public MicrosoftGraphOAuth2PermissionGrant withClientId(String clientId) {
        this.clientId = clientId;
        return this;
    }

    /**
     * Get the consentType property: Indicates if authorization is granted for the client application to impersonate all
     * users or only a specific user. AllPrincipals indicates authorization to impersonate all users. Principal
     * indicates authorization to impersonate a specific user. Consent on behalf of all users can be granted by an
     * administrator. Non-admin users may be authorized to consent on behalf of themselves in some cases, for some
     * delegated permissions. Required. Supports $filter (eq only).
     * 
     * @return the consentType value.
     */
    public String consentType() {
        return this.consentType;
    }

    /**
     * Set the consentType property: Indicates if authorization is granted for the client application to impersonate all
     * users or only a specific user. AllPrincipals indicates authorization to impersonate all users. Principal
     * indicates authorization to impersonate a specific user. Consent on behalf of all users can be granted by an
     * administrator. Non-admin users may be authorized to consent on behalf of themselves in some cases, for some
     * delegated permissions. Required. Supports $filter (eq only).
     * 
     * @param consentType the consentType value to set.
     * @return the MicrosoftGraphOAuth2PermissionGrant object itself.
     */
    public MicrosoftGraphOAuth2PermissionGrant withConsentType(String consentType) {
        this.consentType = consentType;
        return this;
    }

    /**
     * Get the principalId property: The id of the user on behalf of whom the client is authorized to access the
     * resource, when consentType is Principal. If consentType is AllPrincipals this value is null. Required when
     * consentType is Principal.
     * 
     * @return the principalId value.
     */
    public String principalId() {
        return this.principalId;
    }

    /**
     * Set the principalId property: The id of the user on behalf of whom the client is authorized to access the
     * resource, when consentType is Principal. If consentType is AllPrincipals this value is null. Required when
     * consentType is Principal.
     * 
     * @param principalId the principalId value to set.
     * @return the MicrosoftGraphOAuth2PermissionGrant object itself.
     */
    public MicrosoftGraphOAuth2PermissionGrant withPrincipalId(String principalId) {
        this.principalId = principalId;
        return this;
    }

    /**
     * Get the resourceId property: The id of the resource service principal to which access is authorized. This
     * identifies the API which the client is authorized to attempt to call on behalf of a signed-in user.
     * 
     * @return the resourceId value.
     */
    public String resourceId() {
        return this.resourceId;
    }

    /**
     * Set the resourceId property: The id of the resource service principal to which access is authorized. This
     * identifies the API which the client is authorized to attempt to call on behalf of a signed-in user.
     * 
     * @param resourceId the resourceId value to set.
     * @return the MicrosoftGraphOAuth2PermissionGrant object itself.
     */
    public MicrosoftGraphOAuth2PermissionGrant withResourceId(String resourceId) {
        this.resourceId = resourceId;
        return this;
    }

    /**
     * Get the scope property: A space-separated list of the claim values for delegated permissions which should be
     * included in access tokens for the resource application (the API). For example, openid User.Read
     * GroupMember.Read.All. Each claim value should match the value field of one of the delegated permissions defined
     * by the API, listed in the publishedPermissionScopes property of the resource service principal.
     * 
     * @return the scope value.
     */
    public String scope() {
        return this.scope;
    }

    /**
     * Set the scope property: A space-separated list of the claim values for delegated permissions which should be
     * included in access tokens for the resource application (the API). For example, openid User.Read
     * GroupMember.Read.All. Each claim value should match the value field of one of the delegated permissions defined
     * by the API, listed in the publishedPermissionScopes property of the resource service principal.
     * 
     * @param scope the scope value to set.
     * @return the MicrosoftGraphOAuth2PermissionGrant object itself.
     */
    public MicrosoftGraphOAuth2PermissionGrant withScope(String scope) {
        this.scope = scope;
        return this;
    }

    /**
     * Get the additionalProperties property: oAuth2PermissionGrant.
     * 
     * @return the additionalProperties value.
     */
    public Map additionalProperties() {
        return this.additionalProperties;
    }

    /**
     * Set the additionalProperties property: oAuth2PermissionGrant.
     * 
     * @param additionalProperties the additionalProperties value to set.
     * @return the MicrosoftGraphOAuth2PermissionGrant object itself.
     */
    public MicrosoftGraphOAuth2PermissionGrant withAdditionalProperties(Map additionalProperties) {
        this.additionalProperties = additionalProperties;
        return this;
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public MicrosoftGraphOAuth2PermissionGrant withId(String id) {
        super.withId(id);
        return this;
    }

    /**
     * Validates the instance.
     * 
     * @throws IllegalArgumentException thrown if the instance is not valid.
     */
    @Override
    public void validate() {
        super.validate();
    }

    /**
     * {@inheritDoc}
     */
    @Override
    public JsonWriter toJson(JsonWriter jsonWriter) throws IOException {
        jsonWriter.writeStartObject();
        jsonWriter.writeStringField("id", id());
        jsonWriter.writeStringField("clientId", this.clientId);
        jsonWriter.writeStringField("consentType", this.consentType);
        jsonWriter.writeStringField("principalId", this.principalId);
        jsonWriter.writeStringField("resourceId", this.resourceId);
        jsonWriter.writeStringField("scope", this.scope);
        if (additionalProperties != null) {
            for (Map.Entry additionalProperty : additionalProperties.entrySet()) {
                jsonWriter.writeUntypedField(additionalProperty.getKey(), additionalProperty.getValue());
            }
        }
        return jsonWriter.writeEndObject();
    }

    /**
     * Reads an instance of MicrosoftGraphOAuth2PermissionGrant from the JsonReader.
     * 
     * @param jsonReader The JsonReader being read.
     * @return An instance of MicrosoftGraphOAuth2PermissionGrant if the JsonReader was pointing to an instance of it,
     * or null if it was pointing to JSON null.
     * @throws IOException If an error occurs while reading the MicrosoftGraphOAuth2PermissionGrant.
     */
    public static MicrosoftGraphOAuth2PermissionGrant fromJson(JsonReader jsonReader) throws IOException {
        return jsonReader.readObject(reader -> {
            MicrosoftGraphOAuth2PermissionGrant deserializedMicrosoftGraphOAuth2PermissionGrant
                = new MicrosoftGraphOAuth2PermissionGrant();
            Map additionalProperties = null;
            while (reader.nextToken() != JsonToken.END_OBJECT) {
                String fieldName = reader.getFieldName();
                reader.nextToken();

                if ("id".equals(fieldName)) {
                    deserializedMicrosoftGraphOAuth2PermissionGrant.withId(reader.getString());
                } else if ("clientId".equals(fieldName)) {
                    deserializedMicrosoftGraphOAuth2PermissionGrant.clientId = reader.getString();
                } else if ("consentType".equals(fieldName)) {
                    deserializedMicrosoftGraphOAuth2PermissionGrant.consentType = reader.getString();
                } else if ("principalId".equals(fieldName)) {
                    deserializedMicrosoftGraphOAuth2PermissionGrant.principalId = reader.getString();
                } else if ("resourceId".equals(fieldName)) {
                    deserializedMicrosoftGraphOAuth2PermissionGrant.resourceId = reader.getString();
                } else if ("scope".equals(fieldName)) {
                    deserializedMicrosoftGraphOAuth2PermissionGrant.scope = reader.getString();
                } else {
                    if (additionalProperties == null) {
                        additionalProperties = new LinkedHashMap<>();
                    }

                    additionalProperties.put(fieldName, reader.readUntyped());
                }
            }
            deserializedMicrosoftGraphOAuth2PermissionGrant.additionalProperties = additionalProperties;

            return deserializedMicrosoftGraphOAuth2PermissionGrant;
        });
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy