com.microsoft.graph.beta.generated.models.SynchronizationRule Maven / Gradle / Ivy
package com.microsoft.graph.beta.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 SynchronizationRule implements AdditionalDataHolder, BackedModel, Parsable {
/**
* Stores model information.
*/
@jakarta.annotation.Nonnull
protected BackingStore backingStore;
/**
* Instantiates a new {@link SynchronizationRule} and sets the default values.
*/
public SynchronizationRule() {
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 SynchronizationRule}
*/
@jakarta.annotation.Nonnull
public static SynchronizationRule createFromDiscriminatorValue(@jakarta.annotation.Nonnull final ParseNode parseNode) {
Objects.requireNonNull(parseNode);
return new SynchronizationRule();
}
/**
* 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;
}
/**
* Gets the containerFilter property value. The names and identifiers of organizational units that are in scope for a synchronization rule. containerFilter and groupFilter are mutually exclusive properties that cannot be configured in the same request. Currently only supported for Azure AD Connect cloud sync scenarios.
* @return a {@link ContainerFilter}
*/
@jakarta.annotation.Nullable
public ContainerFilter getContainerFilter() {
return this.backingStore.get("containerFilter");
}
/**
* Gets the editable property value. true if the synchronization rule can be customized; false if this rule is read-only and shouldn't be changed.
* @return a {@link Boolean}
*/
@jakarta.annotation.Nullable
public Boolean getEditable() {
return this.backingStore.get("editable");
}
/**
* The deserialization information for the current model
* @return a {@link Map>}
*/
@jakarta.annotation.Nonnull
public Map> getFieldDeserializers() {
final HashMap> deserializerMap = new HashMap>(11);
deserializerMap.put("containerFilter", (n) -> { this.setContainerFilter(n.getObjectValue(ContainerFilter::createFromDiscriminatorValue)); });
deserializerMap.put("editable", (n) -> { this.setEditable(n.getBooleanValue()); });
deserializerMap.put("groupFilter", (n) -> { this.setGroupFilter(n.getObjectValue(GroupFilter::createFromDiscriminatorValue)); });
deserializerMap.put("id", (n) -> { this.setId(n.getStringValue()); });
deserializerMap.put("metadata", (n) -> { this.setMetadata(n.getCollectionOfObjectValues(StringKeyStringValuePair::createFromDiscriminatorValue)); });
deserializerMap.put("name", (n) -> { this.setName(n.getStringValue()); });
deserializerMap.put("objectMappings", (n) -> { this.setObjectMappings(n.getCollectionOfObjectValues(ObjectMapping::createFromDiscriminatorValue)); });
deserializerMap.put("@odata.type", (n) -> { this.setOdataType(n.getStringValue()); });
deserializerMap.put("priority", (n) -> { this.setPriority(n.getIntegerValue()); });
deserializerMap.put("sourceDirectoryName", (n) -> { this.setSourceDirectoryName(n.getStringValue()); });
deserializerMap.put("targetDirectoryName", (n) -> { this.setTargetDirectoryName(n.getStringValue()); });
return deserializerMap;
}
/**
* Gets the groupFilter property value. The names and identifiers of groups that are in scope for a synchronization rule. containerFilter and groupFilter are mutually exclusive properties that cannot be configured in the same request. Currently only supported for Azure AD Connect cloud sync scenarios.
* @return a {@link GroupFilter}
*/
@jakarta.annotation.Nullable
public GroupFilter getGroupFilter() {
return this.backingStore.get("groupFilter");
}
/**
* Gets the id property value. Synchronization rule identifier. Must be one of the identifiers recognized by the synchronization engine. Supported rule identifiers can be found in the synchronization template returned by the API.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getId() {
return this.backingStore.get("id");
}
/**
* Gets the metadata property value. Additional extension properties. Unless instructed explicitly by the support team, metadata values shouldn't be changed.
* @return a {@link java.util.List}
*/
@jakarta.annotation.Nullable
public java.util.List getMetadata() {
return this.backingStore.get("metadata");
}
/**
* Gets the name property value. Human-readable name of the synchronization rule. Not nullable.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getName() {
return this.backingStore.get("name");
}
/**
* Gets the objectMappings property value. Collection of object mappings supported by the rule. Tells the synchronization engine which objects should be synchronized.
* @return a {@link java.util.List}
*/
@jakarta.annotation.Nullable
public java.util.List getObjectMappings() {
return this.backingStore.get("objectMappings");
}
/**
* 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 priority property value. Priority relative to other rules in the synchronizationSchema. Rules with the lowest priority number will be processed first.
* @return a {@link Integer}
*/
@jakarta.annotation.Nullable
public Integer getPriority() {
return this.backingStore.get("priority");
}
/**
* Gets the sourceDirectoryName property value. Name of the source directory. Must match one of the directory definitions in synchronizationSchema.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getSourceDirectoryName() {
return this.backingStore.get("sourceDirectoryName");
}
/**
* Gets the targetDirectoryName property value. Name of the target directory. Must match one of the directory definitions in synchronizationSchema.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getTargetDirectoryName() {
return this.backingStore.get("targetDirectoryName");
}
/**
* 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.writeObjectValue("containerFilter", this.getContainerFilter());
writer.writeBooleanValue("editable", this.getEditable());
writer.writeObjectValue("groupFilter", this.getGroupFilter());
writer.writeStringValue("id", this.getId());
writer.writeCollectionOfObjectValues("metadata", this.getMetadata());
writer.writeStringValue("name", this.getName());
writer.writeCollectionOfObjectValues("objectMappings", this.getObjectMappings());
writer.writeStringValue("@odata.type", this.getOdataType());
writer.writeIntegerValue("priority", this.getPriority());
writer.writeStringValue("sourceDirectoryName", this.getSourceDirectoryName());
writer.writeStringValue("targetDirectoryName", this.getTargetDirectoryName());
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 containerFilter property value. The names and identifiers of organizational units that are in scope for a synchronization rule. containerFilter and groupFilter are mutually exclusive properties that cannot be configured in the same request. Currently only supported for Azure AD Connect cloud sync scenarios.
* @param value Value to set for the containerFilter property.
*/
public void setContainerFilter(@jakarta.annotation.Nullable final ContainerFilter value) {
this.backingStore.set("containerFilter", value);
}
/**
* Sets the editable property value. true if the synchronization rule can be customized; false if this rule is read-only and shouldn't be changed.
* @param value Value to set for the editable property.
*/
public void setEditable(@jakarta.annotation.Nullable final Boolean value) {
this.backingStore.set("editable", value);
}
/**
* Sets the groupFilter property value. The names and identifiers of groups that are in scope for a synchronization rule. containerFilter and groupFilter are mutually exclusive properties that cannot be configured in the same request. Currently only supported for Azure AD Connect cloud sync scenarios.
* @param value Value to set for the groupFilter property.
*/
public void setGroupFilter(@jakarta.annotation.Nullable final GroupFilter value) {
this.backingStore.set("groupFilter", value);
}
/**
* Sets the id property value. Synchronization rule identifier. Must be one of the identifiers recognized by the synchronization engine. Supported rule identifiers can be found in the synchronization template returned by the API.
* @param value Value to set for the id property.
*/
public void setId(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("id", value);
}
/**
* Sets the metadata property value. Additional extension properties. Unless instructed explicitly by the support team, metadata values shouldn't be changed.
* @param value Value to set for the metadata property.
*/
public void setMetadata(@jakarta.annotation.Nullable final java.util.List value) {
this.backingStore.set("metadata", value);
}
/**
* Sets the name property value. Human-readable name of the synchronization rule. Not nullable.
* @param value Value to set for the name property.
*/
public void setName(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("name", value);
}
/**
* Sets the objectMappings property value. Collection of object mappings supported by the rule. Tells the synchronization engine which objects should be synchronized.
* @param value Value to set for the objectMappings property.
*/
public void setObjectMappings(@jakarta.annotation.Nullable final java.util.List value) {
this.backingStore.set("objectMappings", 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 priority property value. Priority relative to other rules in the synchronizationSchema. Rules with the lowest priority number will be processed first.
* @param value Value to set for the priority property.
*/
public void setPriority(@jakarta.annotation.Nullable final Integer value) {
this.backingStore.set("priority", value);
}
/**
* Sets the sourceDirectoryName property value. Name of the source directory. Must match one of the directory definitions in synchronizationSchema.
* @param value Value to set for the sourceDirectoryName property.
*/
public void setSourceDirectoryName(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("sourceDirectoryName", value);
}
/**
* Sets the targetDirectoryName property value. Name of the target directory. Must match one of the directory definitions in synchronizationSchema.
* @param value Value to set for the targetDirectoryName property.
*/
public void setTargetDirectoryName(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("targetDirectoryName", value);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy