/* * Copyright (C) 2016 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.settings.enterprise; import android.content.Context; import java.util.Date; public interface EnterprisePrivacyFeatureProvider { /** * Returns whether the device is managed by a Device Owner app. */ boolean hasDeviceOwner(); /** * Returns whether the device is in COMP mode (primary user managed by a Device Owner app and * work profile managed by a Profile Owner app). */ boolean isInCompMode(); /** * Returns the name of the organization managing the device via a Device Owner app. If the * device is not managed by a Device Owner app or the name of the managing organization was not * set, returns {@code null}. */ String getDeviceOwnerOrganizationName(); /** * Returns a message informing the user that the device is managed by a Device Owner app. The * message includes a Learn More link that takes the user to the enterprise privacy section of * Settings. If the device is not managed by a Device Owner app, returns {@code null}. */ CharSequence getDeviceOwnerDisclosure(); /** * Returns the time at which the Device Owner last retrieved security logs, or {@code null} if * logs were never retrieved by the Device Owner on this device. */ Date getLastSecurityLogRetrievalTime(); /** * Returns the time at which the Device Owner last requested a bug report, or {@code null} if no * bug report was ever requested by the Device Owner on this device. */ Date getLastBugReportRequestTime(); /** * Returns the time at which the Device Owner last retrieved network logs, or {@code null} if * logs were never retrieved by the Device Owner on this device. */ Date getLastNetworkLogRetrievalTime(); /** * Returns whether security logging is currently enabled. */ boolean isSecurityLoggingEnabled(); /** * Returns whether network logging is currently enabled. */ boolean isNetworkLoggingEnabled(); /** * Returns whether the Device Owner or Profile Owner in the current user set an always-on VPN. */ boolean isAlwaysOnVpnSetInCurrentUser(); /** * Returns whether the Profile Owner in the current user's managed profile (if any) set an * always-on VPN. */ boolean isAlwaysOnVpnSetInManagedProfile(); /** * Returns the number of failed login attempts that the Device Owner or Profile Owner allows * before the current user is wiped, or zero if no such limit is set. */ int getMaximumFailedPasswordsBeforeWipeInCurrentUser(); /** * Returns the number of failed login attempts that the Profile Owner allows before the current * user's managed profile (if any) is wiped, or zero if no such limit is set. */ int getMaximumFailedPasswordsBeforeWipeInManagedProfile(); /** * Returns the label of the current user's input method if that input method was set by a Device * Owner or Profile Owner in that user. Otherwise, returns {@code null}. */ String getImeLabelIfOwnerSet(); /** * Returns the number of CA certificates that the Device Owner or Profile Owner installed in * current user. */ int getNumberOfOwnerInstalledCaCertsForCurrentUser(); /** * Returns the number of CA certificates that the Device Owner or Profile Owner installed in * the current user's managed profile (if any). */ int getNumberOfOwnerInstalledCaCertsForManagedProfile(); /** * Returns the number of Device Admin apps active in the current user and the user's managed * profile (if any). */ int getNumberOfActiveDeviceAdminsForCurrentUserAndManagedProfile(); /** * Returns {@code true} if it is possilbe to resolve an Intent to launch the "Your work policy * info" page provided by the active Device Owner or Profile Owner app if it exists, {@code * false} otherwise. */ boolean hasWorkPolicyInfo(); /** * Launches the Device Owner or Profile Owner's activity that displays the "Your work policy * info" page. Returns {@code true} if the activity has indeed been launched. */ boolean showWorkPolicyInfo(Context activityContext); /** * Launches the parental controls settings page. Returns {@code true} if the activity has * been launched. */ boolean showParentalControls(); }