com.microsoft.graph.generated.models.AccessPackageAssignmentApprovalSettings Maven / Gradle / Ivy
package com.microsoft.graph.models;
import com.microsoft.kiota.serialization.AdditionalDataHolder;
import com.microsoft.kiota.serialization.Parsable;
import com.microsoft.kiota.serialization.ParseNode;
import com.microsoft.kiota.serialization.SerializationWriter;
import com.microsoft.kiota.store.BackedModel;
import com.microsoft.kiota.store.BackingStore;
import com.microsoft.kiota.store.BackingStoreFactorySingleton;
import java.util.HashMap;
import java.util.Map;
import java.util.Objects;
@jakarta.annotation.Generated("com.microsoft.kiota")
public class AccessPackageAssignmentApprovalSettings implements AdditionalDataHolder, BackedModel, Parsable {
/**
* Stores model information.
*/
@jakarta.annotation.Nonnull
protected BackingStore backingStore;
/**
* Instantiates a new {@link AccessPackageAssignmentApprovalSettings} and sets the default values.
*/
public AccessPackageAssignmentApprovalSettings() {
this.backingStore = BackingStoreFactorySingleton.instance.createBackingStore();
this.setAdditionalData(new HashMap<>());
}
/**
* Creates a new instance of the appropriate class based on discriminator value
* @param parseNode The parse node to use to read the discriminator value and create the object
* @return a {@link AccessPackageAssignmentApprovalSettings}
*/
@jakarta.annotation.Nonnull
public static AccessPackageAssignmentApprovalSettings createFromDiscriminatorValue(@jakarta.annotation.Nonnull final ParseNode parseNode) {
Objects.requireNonNull(parseNode);
return new AccessPackageAssignmentApprovalSettings();
}
/**
* Gets the AdditionalData property value. Stores additional data not described in the OpenAPI description found when deserializing. Can be used for serialization as well.
* @return a {@link Map}
*/
@jakarta.annotation.Nonnull
public Map getAdditionalData() {
Map value = this.backingStore.get("additionalData");
if(value == null) {
value = new HashMap<>();
this.setAdditionalData(value);
}
return value;
}
/**
* Gets the backingStore property value. Stores model information.
* @return a {@link BackingStore}
*/
@jakarta.annotation.Nonnull
public BackingStore getBackingStore() {
return this.backingStore;
}
/**
* The deserialization information for the current model
* @return a {@link Map>}
*/
@jakarta.annotation.Nonnull
public Map> getFieldDeserializers() {
final HashMap> deserializerMap = new HashMap>(4);
deserializerMap.put("isApprovalRequiredForAdd", (n) -> { this.setIsApprovalRequiredForAdd(n.getBooleanValue()); });
deserializerMap.put("isApprovalRequiredForUpdate", (n) -> { this.setIsApprovalRequiredForUpdate(n.getBooleanValue()); });
deserializerMap.put("@odata.type", (n) -> { this.setOdataType(n.getStringValue()); });
deserializerMap.put("stages", (n) -> { this.setStages(n.getCollectionOfObjectValues(AccessPackageApprovalStage::createFromDiscriminatorValue)); });
return deserializerMap;
}
/**
* Gets the isApprovalRequiredForAdd property value. If false, then approval isn't required for new requests in this policy.
* @return a {@link Boolean}
*/
@jakarta.annotation.Nullable
public Boolean getIsApprovalRequiredForAdd() {
return this.backingStore.get("isApprovalRequiredForAdd");
}
/**
* Gets the isApprovalRequiredForUpdate property value. If false, then approval isn't required for updates to requests in this policy.
* @return a {@link Boolean}
*/
@jakarta.annotation.Nullable
public Boolean getIsApprovalRequiredForUpdate() {
return this.backingStore.get("isApprovalRequiredForUpdate");
}
/**
* Gets the @odata.type property value. The OdataType property
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getOdataType() {
return this.backingStore.get("odataType");
}
/**
* Gets the stages property value. If approval is required, the one, two or three elements of this collection define each of the stages of approval. An empty array is present if no approval is required.
* @return a {@link java.util.List}
*/
@jakarta.annotation.Nullable
public java.util.List getStages() {
return this.backingStore.get("stages");
}
/**
* Serializes information the current object
* @param writer Serialization writer to use to serialize this model
*/
public void serialize(@jakarta.annotation.Nonnull final SerializationWriter writer) {
Objects.requireNonNull(writer);
writer.writeBooleanValue("isApprovalRequiredForAdd", this.getIsApprovalRequiredForAdd());
writer.writeBooleanValue("isApprovalRequiredForUpdate", this.getIsApprovalRequiredForUpdate());
writer.writeStringValue("@odata.type", this.getOdataType());
writer.writeCollectionOfObjectValues("stages", this.getStages());
writer.writeAdditionalData(this.getAdditionalData());
}
/**
* Sets the AdditionalData property value. Stores additional data not described in the OpenAPI description found when deserializing. Can be used for serialization as well.
* @param value Value to set for the AdditionalData property.
*/
public void setAdditionalData(@jakarta.annotation.Nullable final Map value) {
this.backingStore.set("additionalData", value);
}
/**
* Sets the backingStore property value. Stores model information.
* @param value Value to set for the backingStore property.
*/
public void setBackingStore(@jakarta.annotation.Nonnull final BackingStore value) {
Objects.requireNonNull(value);
this.backingStore = value;
}
/**
* Sets the isApprovalRequiredForAdd property value. If false, then approval isn't required for new requests in this policy.
* @param value Value to set for the isApprovalRequiredForAdd property.
*/
public void setIsApprovalRequiredForAdd(@jakarta.annotation.Nullable final Boolean value) {
this.backingStore.set("isApprovalRequiredForAdd", value);
}
/**
* Sets the isApprovalRequiredForUpdate property value. If false, then approval isn't required for updates to requests in this policy.
* @param value Value to set for the isApprovalRequiredForUpdate property.
*/
public void setIsApprovalRequiredForUpdate(@jakarta.annotation.Nullable final Boolean value) {
this.backingStore.set("isApprovalRequiredForUpdate", value);
}
/**
* Sets the @odata.type property value. The OdataType property
* @param value Value to set for the @odata.type property.
*/
public void setOdataType(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("odataType", value);
}
/**
* Sets the stages property value. If approval is required, the one, two or three elements of this collection define each of the stages of approval. An empty array is present if no approval is required.
* @param value Value to set for the stages property.
*/
public void setStages(@jakarta.annotation.Nullable final java.util.List value) {
this.backingStore.set("stages", value);
}
}