com.microsoft.graph.beta.generated.models.IosManagedAppProtection Maven / Gradle / Ivy
package com.microsoft.graph.beta.models;
import com.microsoft.kiota.serialization.Parsable;
import com.microsoft.kiota.serialization.ParseNode;
import com.microsoft.kiota.serialization.SerializationWriter;
import java.util.HashMap;
import java.util.Map;
import java.util.Objects;
/**
* Policy used to configure detailed management settings targeted to specific security groups and for a specified set of apps on an iOS device
*/
@jakarta.annotation.Generated("com.microsoft.kiota")
public class IosManagedAppProtection extends TargetedManagedAppProtection implements Parsable {
/**
* Instantiates a new {@link IosManagedAppProtection} and sets the default values.
*/
public IosManagedAppProtection() {
super();
this.setOdataType("#microsoft.graph.iosManagedAppProtection");
}
/**
* 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 IosManagedAppProtection}
*/
@jakarta.annotation.Nonnull
public static IosManagedAppProtection createFromDiscriminatorValue(@jakarta.annotation.Nonnull final ParseNode parseNode) {
Objects.requireNonNull(parseNode);
return new IosManagedAppProtection();
}
/**
* Gets the allowedIosDeviceModels property value. Semicolon seperated list of device models allowed, as a string, for the managed app to work.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getAllowedIosDeviceModels() {
return this.backingStore.get("allowedIosDeviceModels");
}
/**
* Gets the allowWidgetContentSync property value. Indicates if content sync for widgets is allowed for iOS on App Protection Policies
* @return a {@link Boolean}
*/
@jakarta.annotation.Nullable
public Boolean getAllowWidgetContentSync() {
return this.backingStore.get("allowWidgetContentSync");
}
/**
* Gets the appActionIfAccountIsClockedOut property value. Defines a managed app behavior, either block or warn, if the user is clocked out (non-working time). Possible values are: block, wipe, warn.
* @return a {@link ManagedAppRemediationAction}
*/
@jakarta.annotation.Nullable
public ManagedAppRemediationAction getAppActionIfAccountIsClockedOut() {
return this.backingStore.get("appActionIfAccountIsClockedOut");
}
/**
* Gets the appActionIfIosDeviceModelNotAllowed property value. An admin initiated action to be applied on a managed app.
* @return a {@link ManagedAppRemediationAction}
*/
@jakarta.annotation.Nullable
public ManagedAppRemediationAction getAppActionIfIosDeviceModelNotAllowed() {
return this.backingStore.get("appActionIfIosDeviceModelNotAllowed");
}
/**
* Gets the appDataEncryptionType property value. Represents the level to which app data is encrypted for managed apps
* @return a {@link ManagedAppDataEncryptionType}
*/
@jakarta.annotation.Nullable
public ManagedAppDataEncryptionType getAppDataEncryptionType() {
return this.backingStore.get("appDataEncryptionType");
}
/**
* Gets the apps property value. List of apps to which the policy is deployed.
* @return a {@link java.util.List}
*/
@jakarta.annotation.Nullable
public java.util.List getApps() {
return this.backingStore.get("apps");
}
/**
* Gets the customBrowserProtocol property value. A custom browser protocol to open weblink on iOS. When this property is configured, ManagedBrowserToOpenLinksRequired should be true.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getCustomBrowserProtocol() {
return this.backingStore.get("customBrowserProtocol");
}
/**
* Gets the customDialerAppProtocol property value. Protocol of a custom dialer app to click-to-open a phone number on iOS, for example, skype:.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getCustomDialerAppProtocol() {
return this.backingStore.get("customDialerAppProtocol");
}
/**
* Gets the deployedAppCount property value. Count of apps to which the current policy is deployed.
* @return a {@link Integer}
*/
@jakarta.annotation.Nullable
public Integer getDeployedAppCount() {
return this.backingStore.get("deployedAppCount");
}
/**
* Gets the deploymentSummary property value. Navigation property to deployment summary of the configuration.
* @return a {@link ManagedAppPolicyDeploymentSummary}
*/
@jakarta.annotation.Nullable
public ManagedAppPolicyDeploymentSummary getDeploymentSummary() {
return this.backingStore.get("deploymentSummary");
}
/**
* Gets the disableProtectionOfManagedOutboundOpenInData property value. Disable protection of data transferred to other apps through IOS OpenIn option. This setting is only allowed to be True when AllowedOutboundDataTransferDestinations is set to ManagedApps.
* @return a {@link Boolean}
*/
@jakarta.annotation.Nullable
public Boolean getDisableProtectionOfManagedOutboundOpenInData() {
return this.backingStore.get("disableProtectionOfManagedOutboundOpenInData");
}
/**
* Gets the exemptedAppProtocols property value. Apps in this list will be exempt from the policy and will be able to receive data from managed apps.
* @return a {@link java.util.List}
*/
@jakarta.annotation.Nullable
public java.util.List getExemptedAppProtocols() {
return this.backingStore.get("exemptedAppProtocols");
}
/**
* Gets the exemptedUniversalLinks property value. A list of custom urls that are allowed to invocate an unmanaged app
* @return a {@link java.util.List}
*/
@jakarta.annotation.Nullable
public java.util.List getExemptedUniversalLinks() {
return this.backingStore.get("exemptedUniversalLinks");
}
/**
* Gets the faceIdBlocked property value. Indicates whether use of the FaceID is allowed in place of a pin if PinRequired is set to True.
* @return a {@link Boolean}
*/
@jakarta.annotation.Nullable
public Boolean getFaceIdBlocked() {
return this.backingStore.get("faceIdBlocked");
}
/**
* The deserialization information for the current model
* @return a {@link Map>}
*/
@jakarta.annotation.Nonnull
public Map> getFieldDeserializers() {
final HashMap> deserializerMap = new HashMap>(super.getFieldDeserializers());
deserializerMap.put("allowedIosDeviceModels", (n) -> { this.setAllowedIosDeviceModels(n.getStringValue()); });
deserializerMap.put("allowWidgetContentSync", (n) -> { this.setAllowWidgetContentSync(n.getBooleanValue()); });
deserializerMap.put("appActionIfAccountIsClockedOut", (n) -> { this.setAppActionIfAccountIsClockedOut(n.getEnumValue(ManagedAppRemediationAction::forValue)); });
deserializerMap.put("appActionIfIosDeviceModelNotAllowed", (n) -> { this.setAppActionIfIosDeviceModelNotAllowed(n.getEnumValue(ManagedAppRemediationAction::forValue)); });
deserializerMap.put("appDataEncryptionType", (n) -> { this.setAppDataEncryptionType(n.getEnumValue(ManagedAppDataEncryptionType::forValue)); });
deserializerMap.put("apps", (n) -> { this.setApps(n.getCollectionOfObjectValues(ManagedMobileApp::createFromDiscriminatorValue)); });
deserializerMap.put("customBrowserProtocol", (n) -> { this.setCustomBrowserProtocol(n.getStringValue()); });
deserializerMap.put("customDialerAppProtocol", (n) -> { this.setCustomDialerAppProtocol(n.getStringValue()); });
deserializerMap.put("deployedAppCount", (n) -> { this.setDeployedAppCount(n.getIntegerValue()); });
deserializerMap.put("deploymentSummary", (n) -> { this.setDeploymentSummary(n.getObjectValue(ManagedAppPolicyDeploymentSummary::createFromDiscriminatorValue)); });
deserializerMap.put("disableProtectionOfManagedOutboundOpenInData", (n) -> { this.setDisableProtectionOfManagedOutboundOpenInData(n.getBooleanValue()); });
deserializerMap.put("exemptedAppProtocols", (n) -> { this.setExemptedAppProtocols(n.getCollectionOfObjectValues(KeyValuePair::createFromDiscriminatorValue)); });
deserializerMap.put("exemptedUniversalLinks", (n) -> { this.setExemptedUniversalLinks(n.getCollectionOfPrimitiveValues(String.class)); });
deserializerMap.put("faceIdBlocked", (n) -> { this.setFaceIdBlocked(n.getBooleanValue()); });
deserializerMap.put("filterOpenInToOnlyManagedApps", (n) -> { this.setFilterOpenInToOnlyManagedApps(n.getBooleanValue()); });
deserializerMap.put("managedUniversalLinks", (n) -> { this.setManagedUniversalLinks(n.getCollectionOfPrimitiveValues(String.class)); });
deserializerMap.put("messagingRedirectAppUrlScheme", (n) -> { this.setMessagingRedirectAppUrlScheme(n.getStringValue()); });
deserializerMap.put("minimumRequiredSdkVersion", (n) -> { this.setMinimumRequiredSdkVersion(n.getStringValue()); });
deserializerMap.put("minimumWarningSdkVersion", (n) -> { this.setMinimumWarningSdkVersion(n.getStringValue()); });
deserializerMap.put("minimumWipeSdkVersion", (n) -> { this.setMinimumWipeSdkVersion(n.getStringValue()); });
deserializerMap.put("protectInboundDataFromUnknownSources", (n) -> { this.setProtectInboundDataFromUnknownSources(n.getBooleanValue()); });
deserializerMap.put("thirdPartyKeyboardsBlocked", (n) -> { this.setThirdPartyKeyboardsBlocked(n.getBooleanValue()); });
return deserializerMap;
}
/**
* Gets the filterOpenInToOnlyManagedApps property value. Defines if open-in operation is supported from the managed app to the filesharing locations selected. This setting only applies when AllowedOutboundDataTransferDestinations is set to ManagedApps and DisableProtectionOfManagedOutboundOpenInData is set to False.
* @return a {@link Boolean}
*/
@jakarta.annotation.Nullable
public Boolean getFilterOpenInToOnlyManagedApps() {
return this.backingStore.get("filterOpenInToOnlyManagedApps");
}
/**
* Gets the managedUniversalLinks property value. A list of custom urls that are allowed to invocate a managed app
* @return a {@link java.util.List}
*/
@jakarta.annotation.Nullable
public java.util.List getManagedUniversalLinks() {
return this.backingStore.get("managedUniversalLinks");
}
/**
* Gets the messagingRedirectAppUrlScheme property value. When a specific app redirection is enforced by protectedMessagingRedirectAppType in an App Protection Policy, this value defines the app url redirect schemes which are allowed to be used.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getMessagingRedirectAppUrlScheme() {
return this.backingStore.get("messagingRedirectAppUrlScheme");
}
/**
* Gets the minimumRequiredSdkVersion property value. Versions less than the specified version will block the managed app from accessing company data.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getMinimumRequiredSdkVersion() {
return this.backingStore.get("minimumRequiredSdkVersion");
}
/**
* Gets the minimumWarningSdkVersion property value. Versions less than the specified version will result in warning message on the managed app from accessing company data.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getMinimumWarningSdkVersion() {
return this.backingStore.get("minimumWarningSdkVersion");
}
/**
* Gets the minimumWipeSdkVersion property value. Versions less than the specified version will block the managed app from accessing company data.
* @return a {@link String}
*/
@jakarta.annotation.Nullable
public String getMinimumWipeSdkVersion() {
return this.backingStore.get("minimumWipeSdkVersion");
}
/**
* Gets the protectInboundDataFromUnknownSources property value. Protect incoming data from unknown source. This setting is only allowed to be True when AllowedInboundDataTransferSources is set to AllApps.
* @return a {@link Boolean}
*/
@jakarta.annotation.Nullable
public Boolean getProtectInboundDataFromUnknownSources() {
return this.backingStore.get("protectInboundDataFromUnknownSources");
}
/**
* Gets the thirdPartyKeyboardsBlocked property value. Defines if third party keyboards are allowed while accessing a managed app
* @return a {@link Boolean}
*/
@jakarta.annotation.Nullable
public Boolean getThirdPartyKeyboardsBlocked() {
return this.backingStore.get("thirdPartyKeyboardsBlocked");
}
/**
* 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);
super.serialize(writer);
writer.writeStringValue("allowedIosDeviceModels", this.getAllowedIosDeviceModels());
writer.writeBooleanValue("allowWidgetContentSync", this.getAllowWidgetContentSync());
writer.writeEnumValue("appActionIfAccountIsClockedOut", this.getAppActionIfAccountIsClockedOut());
writer.writeEnumValue("appActionIfIosDeviceModelNotAllowed", this.getAppActionIfIosDeviceModelNotAllowed());
writer.writeEnumValue("appDataEncryptionType", this.getAppDataEncryptionType());
writer.writeCollectionOfObjectValues("apps", this.getApps());
writer.writeStringValue("customBrowserProtocol", this.getCustomBrowserProtocol());
writer.writeStringValue("customDialerAppProtocol", this.getCustomDialerAppProtocol());
writer.writeIntegerValue("deployedAppCount", this.getDeployedAppCount());
writer.writeObjectValue("deploymentSummary", this.getDeploymentSummary());
writer.writeBooleanValue("disableProtectionOfManagedOutboundOpenInData", this.getDisableProtectionOfManagedOutboundOpenInData());
writer.writeCollectionOfObjectValues("exemptedAppProtocols", this.getExemptedAppProtocols());
writer.writeCollectionOfPrimitiveValues("exemptedUniversalLinks", this.getExemptedUniversalLinks());
writer.writeBooleanValue("faceIdBlocked", this.getFaceIdBlocked());
writer.writeBooleanValue("filterOpenInToOnlyManagedApps", this.getFilterOpenInToOnlyManagedApps());
writer.writeCollectionOfPrimitiveValues("managedUniversalLinks", this.getManagedUniversalLinks());
writer.writeStringValue("messagingRedirectAppUrlScheme", this.getMessagingRedirectAppUrlScheme());
writer.writeStringValue("minimumRequiredSdkVersion", this.getMinimumRequiredSdkVersion());
writer.writeStringValue("minimumWarningSdkVersion", this.getMinimumWarningSdkVersion());
writer.writeStringValue("minimumWipeSdkVersion", this.getMinimumWipeSdkVersion());
writer.writeBooleanValue("protectInboundDataFromUnknownSources", this.getProtectInboundDataFromUnknownSources());
writer.writeBooleanValue("thirdPartyKeyboardsBlocked", this.getThirdPartyKeyboardsBlocked());
}
/**
* Sets the allowedIosDeviceModels property value. Semicolon seperated list of device models allowed, as a string, for the managed app to work.
* @param value Value to set for the allowedIosDeviceModels property.
*/
public void setAllowedIosDeviceModels(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("allowedIosDeviceModels", value);
}
/**
* Sets the allowWidgetContentSync property value. Indicates if content sync for widgets is allowed for iOS on App Protection Policies
* @param value Value to set for the allowWidgetContentSync property.
*/
public void setAllowWidgetContentSync(@jakarta.annotation.Nullable final Boolean value) {
this.backingStore.set("allowWidgetContentSync", value);
}
/**
* Sets the appActionIfAccountIsClockedOut property value. Defines a managed app behavior, either block or warn, if the user is clocked out (non-working time). Possible values are: block, wipe, warn.
* @param value Value to set for the appActionIfAccountIsClockedOut property.
*/
public void setAppActionIfAccountIsClockedOut(@jakarta.annotation.Nullable final ManagedAppRemediationAction value) {
this.backingStore.set("appActionIfAccountIsClockedOut", value);
}
/**
* Sets the appActionIfIosDeviceModelNotAllowed property value. An admin initiated action to be applied on a managed app.
* @param value Value to set for the appActionIfIosDeviceModelNotAllowed property.
*/
public void setAppActionIfIosDeviceModelNotAllowed(@jakarta.annotation.Nullable final ManagedAppRemediationAction value) {
this.backingStore.set("appActionIfIosDeviceModelNotAllowed", value);
}
/**
* Sets the appDataEncryptionType property value. Represents the level to which app data is encrypted for managed apps
* @param value Value to set for the appDataEncryptionType property.
*/
public void setAppDataEncryptionType(@jakarta.annotation.Nullable final ManagedAppDataEncryptionType value) {
this.backingStore.set("appDataEncryptionType", value);
}
/**
* Sets the apps property value. List of apps to which the policy is deployed.
* @param value Value to set for the apps property.
*/
public void setApps(@jakarta.annotation.Nullable final java.util.List value) {
this.backingStore.set("apps", value);
}
/**
* Sets the customBrowserProtocol property value. A custom browser protocol to open weblink on iOS. When this property is configured, ManagedBrowserToOpenLinksRequired should be true.
* @param value Value to set for the customBrowserProtocol property.
*/
public void setCustomBrowserProtocol(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("customBrowserProtocol", value);
}
/**
* Sets the customDialerAppProtocol property value. Protocol of a custom dialer app to click-to-open a phone number on iOS, for example, skype:.
* @param value Value to set for the customDialerAppProtocol property.
*/
public void setCustomDialerAppProtocol(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("customDialerAppProtocol", value);
}
/**
* Sets the deployedAppCount property value. Count of apps to which the current policy is deployed.
* @param value Value to set for the deployedAppCount property.
*/
public void setDeployedAppCount(@jakarta.annotation.Nullable final Integer value) {
this.backingStore.set("deployedAppCount", value);
}
/**
* Sets the deploymentSummary property value. Navigation property to deployment summary of the configuration.
* @param value Value to set for the deploymentSummary property.
*/
public void setDeploymentSummary(@jakarta.annotation.Nullable final ManagedAppPolicyDeploymentSummary value) {
this.backingStore.set("deploymentSummary", value);
}
/**
* Sets the disableProtectionOfManagedOutboundOpenInData property value. Disable protection of data transferred to other apps through IOS OpenIn option. This setting is only allowed to be True when AllowedOutboundDataTransferDestinations is set to ManagedApps.
* @param value Value to set for the disableProtectionOfManagedOutboundOpenInData property.
*/
public void setDisableProtectionOfManagedOutboundOpenInData(@jakarta.annotation.Nullable final Boolean value) {
this.backingStore.set("disableProtectionOfManagedOutboundOpenInData", value);
}
/**
* Sets the exemptedAppProtocols property value. Apps in this list will be exempt from the policy and will be able to receive data from managed apps.
* @param value Value to set for the exemptedAppProtocols property.
*/
public void setExemptedAppProtocols(@jakarta.annotation.Nullable final java.util.List value) {
this.backingStore.set("exemptedAppProtocols", value);
}
/**
* Sets the exemptedUniversalLinks property value. A list of custom urls that are allowed to invocate an unmanaged app
* @param value Value to set for the exemptedUniversalLinks property.
*/
public void setExemptedUniversalLinks(@jakarta.annotation.Nullable final java.util.List value) {
this.backingStore.set("exemptedUniversalLinks", value);
}
/**
* Sets the faceIdBlocked property value. Indicates whether use of the FaceID is allowed in place of a pin if PinRequired is set to True.
* @param value Value to set for the faceIdBlocked property.
*/
public void setFaceIdBlocked(@jakarta.annotation.Nullable final Boolean value) {
this.backingStore.set("faceIdBlocked", value);
}
/**
* Sets the filterOpenInToOnlyManagedApps property value. Defines if open-in operation is supported from the managed app to the filesharing locations selected. This setting only applies when AllowedOutboundDataTransferDestinations is set to ManagedApps and DisableProtectionOfManagedOutboundOpenInData is set to False.
* @param value Value to set for the filterOpenInToOnlyManagedApps property.
*/
public void setFilterOpenInToOnlyManagedApps(@jakarta.annotation.Nullable final Boolean value) {
this.backingStore.set("filterOpenInToOnlyManagedApps", value);
}
/**
* Sets the managedUniversalLinks property value. A list of custom urls that are allowed to invocate a managed app
* @param value Value to set for the managedUniversalLinks property.
*/
public void setManagedUniversalLinks(@jakarta.annotation.Nullable final java.util.List value) {
this.backingStore.set("managedUniversalLinks", value);
}
/**
* Sets the messagingRedirectAppUrlScheme property value. When a specific app redirection is enforced by protectedMessagingRedirectAppType in an App Protection Policy, this value defines the app url redirect schemes which are allowed to be used.
* @param value Value to set for the messagingRedirectAppUrlScheme property.
*/
public void setMessagingRedirectAppUrlScheme(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("messagingRedirectAppUrlScheme", value);
}
/**
* Sets the minimumRequiredSdkVersion property value. Versions less than the specified version will block the managed app from accessing company data.
* @param value Value to set for the minimumRequiredSdkVersion property.
*/
public void setMinimumRequiredSdkVersion(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("minimumRequiredSdkVersion", value);
}
/**
* Sets the minimumWarningSdkVersion property value. Versions less than the specified version will result in warning message on the managed app from accessing company data.
* @param value Value to set for the minimumWarningSdkVersion property.
*/
public void setMinimumWarningSdkVersion(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("minimumWarningSdkVersion", value);
}
/**
* Sets the minimumWipeSdkVersion property value. Versions less than the specified version will block the managed app from accessing company data.
* @param value Value to set for the minimumWipeSdkVersion property.
*/
public void setMinimumWipeSdkVersion(@jakarta.annotation.Nullable final String value) {
this.backingStore.set("minimumWipeSdkVersion", value);
}
/**
* Sets the protectInboundDataFromUnknownSources property value. Protect incoming data from unknown source. This setting is only allowed to be True when AllowedInboundDataTransferSources is set to AllApps.
* @param value Value to set for the protectInboundDataFromUnknownSources property.
*/
public void setProtectInboundDataFromUnknownSources(@jakarta.annotation.Nullable final Boolean value) {
this.backingStore.set("protectInboundDataFromUnknownSources", value);
}
/**
* Sets the thirdPartyKeyboardsBlocked property value. Defines if third party keyboards are allowed while accessing a managed app
* @param value Value to set for the thirdPartyKeyboardsBlocked property.
*/
public void setThirdPartyKeyboardsBlocked(@jakarta.annotation.Nullable final Boolean value) {
this.backingStore.set("thirdPartyKeyboardsBlocked", value);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy