com.microsoft.graph.models.AccessPackageCatalog Maven / Gradle / Ivy
// Template Source: BaseEntity.java.tt
// ------------------------------------------------------------------------------
// Copyright (c) Microsoft Corporation. All Rights Reserved. Licensed under the MIT License. See License in the project root for license information.
// ------------------------------------------------------------------------------
package com.microsoft.graph.models;
import com.microsoft.graph.serializer.ISerializer;
import com.microsoft.graph.serializer.IJsonBackedObject;
import com.microsoft.graph.serializer.AdditionalDataManager;
import java.util.EnumSet;
import com.microsoft.graph.http.BaseCollectionPage;
import com.microsoft.graph.models.AccessPackageCatalogType;
import com.microsoft.graph.models.AccessPackageCatalogState;
import com.microsoft.graph.models.Entity;
import com.microsoft.graph.requests.AccessPackageCollectionPage;
import com.microsoft.graph.requests.CustomCalloutExtensionCollectionPage;
import com.microsoft.graph.requests.AccessPackageResourceRoleCollectionPage;
import com.microsoft.graph.requests.AccessPackageResourceCollectionPage;
import com.microsoft.graph.requests.AccessPackageResourceScopeCollectionPage;
import com.google.gson.JsonObject;
import com.google.gson.annotations.SerializedName;
import com.google.gson.annotations.Expose;
import javax.annotation.Nullable;
import javax.annotation.Nonnull;
// **NOTE** This file was generated by a tool and any changes will be overwritten.
/**
* The class for the Access Package Catalog.
*/
public class AccessPackageCatalog extends Entity implements IJsonBackedObject {
/**
* The Catalog Type.
* Whether the catalog is created by a user or entitlement management. The possible values are: userManaged, serviceDefault, serviceManaged, unknownFutureValue.
*/
@SerializedName(value = "catalogType", alternate = {"CatalogType"})
@Expose
@Nullable
public AccessPackageCatalogType catalogType;
/**
* The Created Date Time.
* The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. Read-only.
*/
@SerializedName(value = "createdDateTime", alternate = {"CreatedDateTime"})
@Expose
@Nullable
public java.time.OffsetDateTime createdDateTime;
/**
* The Description.
* The description of the access package catalog.
*/
@SerializedName(value = "description", alternate = {"Description"})
@Expose
@Nullable
public String description;
/**
* The Display Name.
* The display name of the access package catalog.
*/
@SerializedName(value = "displayName", alternate = {"DisplayName"})
@Expose
@Nullable
public String displayName;
/**
* The Is Externally Visible.
* Whether the access packages in this catalog can be requested by users outside of the tenant.
*/
@SerializedName(value = "isExternallyVisible", alternate = {"IsExternallyVisible"})
@Expose
@Nullable
public Boolean isExternallyVisible;
/**
* The Modified Date Time.
* The Timestamp type represents date and time information using ISO 8601 format and is always in UTC time. For example, midnight UTC on Jan 1, 2014 is 2014-01-01T00:00:00Z. Read-only.
*/
@SerializedName(value = "modifiedDateTime", alternate = {"ModifiedDateTime"})
@Expose
@Nullable
public java.time.OffsetDateTime modifiedDateTime;
/**
* The State.
* Has the value published if the access packages are available for management. The possible values are: unpublished, published, unknownFutureValue.
*/
@SerializedName(value = "state", alternate = {"State"})
@Expose
@Nullable
public AccessPackageCatalogState state;
/**
* The Access Packages.
* The access packages in this catalog. Read-only. Nullable.
*/
@Nullable
public com.microsoft.graph.requests.AccessPackageCollectionPage accessPackages;
/**
* The Custom Workflow Extensions.
*
*/
@SerializedName(value = "customWorkflowExtensions", alternate = {"CustomWorkflowExtensions"})
@Expose
@Nullable
public com.microsoft.graph.requests.CustomCalloutExtensionCollectionPage customWorkflowExtensions;
/**
* The Resource Roles.
*
*/
@SerializedName(value = "resourceRoles", alternate = {"ResourceRoles"})
@Expose
@Nullable
public com.microsoft.graph.requests.AccessPackageResourceRoleCollectionPage resourceRoles;
/**
* The Resources.
* Access package resources in this catalog.
*/
@SerializedName(value = "resources", alternate = {"Resources"})
@Expose
@Nullable
public com.microsoft.graph.requests.AccessPackageResourceCollectionPage resources;
/**
* The Resource Scopes.
*
*/
@SerializedName(value = "resourceScopes", alternate = {"ResourceScopes"})
@Expose
@Nullable
public com.microsoft.graph.requests.AccessPackageResourceScopeCollectionPage resourceScopes;
/**
* Sets the raw JSON object
*
* @param serializer the serializer
* @param json the JSON object to set this object to
*/
public void setRawObject(@Nonnull final ISerializer serializer, @Nonnull final JsonObject json) {
if (json.has("accessPackages")) {
accessPackages = serializer.deserializeObject(json.get("accessPackages"), com.microsoft.graph.requests.AccessPackageCollectionPage.class);
}
if (json.has("customWorkflowExtensions")) {
customWorkflowExtensions = serializer.deserializeObject(json.get("customWorkflowExtensions"), com.microsoft.graph.requests.CustomCalloutExtensionCollectionPage.class);
}
if (json.has("resourceRoles")) {
resourceRoles = serializer.deserializeObject(json.get("resourceRoles"), com.microsoft.graph.requests.AccessPackageResourceRoleCollectionPage.class);
}
if (json.has("resources")) {
resources = serializer.deserializeObject(json.get("resources"), com.microsoft.graph.requests.AccessPackageResourceCollectionPage.class);
}
if (json.has("resourceScopes")) {
resourceScopes = serializer.deserializeObject(json.get("resourceScopes"), com.microsoft.graph.requests.AccessPackageResourceScopeCollectionPage.class);
}
}
}