1 /* 2 * Copyright (C) 2018 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file 5 * except in compliance with the License. You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software distributed under the 10 * License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 11 * KIND, either express or implied. See the License for the specific language governing 12 * permissions and limitations under the License. 13 */ 14 15 package com.android.systemui.shared.plugins; 16 17 import android.annotation.IntDef; 18 import android.content.ComponentName; 19 20 /** 21 * Enables and disables plugins. 22 */ 23 public interface PluginEnabler { 24 25 int ENABLED = 0; 26 int DISABLED_MANUALLY = 1; 27 int DISABLED_INVALID_VERSION = 2; 28 int DISABLED_FROM_EXPLICIT_CRASH = 3; 29 int DISABLED_FROM_SYSTEM_CRASH = 4; 30 31 @IntDef({ENABLED, DISABLED_MANUALLY, DISABLED_INVALID_VERSION, DISABLED_FROM_EXPLICIT_CRASH, 32 DISABLED_FROM_SYSTEM_CRASH}) 33 @interface DisableReason { 34 } 35 36 /** Enables plugin via the PackageManager. */ setEnabled(ComponentName component)37 void setEnabled(ComponentName component); 38 39 /** Disables a plugin via the PackageManager and records the reason for disabling. */ setDisabled(ComponentName component, @DisableReason int reason)40 void setDisabled(ComponentName component, @DisableReason int reason); 41 42 /** Returns true if the plugin is enabled in the PackageManager. */ isEnabled(ComponentName component)43 boolean isEnabled(ComponentName component); 44 45 /** 46 * Returns the reason that a plugin is disabled, (if it is). 47 * 48 * It should return {@link #ENABLED} if the plugin is turned on. 49 * It should return {@link #DISABLED_MANUALLY} if the plugin is off but the reason is unknown. 50 */ 51 @DisableReason getDisableReason(ComponentName componentName)52 int getDisableReason(ComponentName componentName); 53 } 54