1 /* 2 * Copyright (C) 2014 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package com.android.inputmethod.latin.accounts; 18 19 import androidx.annotation.NonNull; 20 21 import javax.annotation.Nullable; 22 23 /** 24 * Handles changes to account used to sign in to the keyboard. 25 * e.g. account switching/sign-in/sign-out from the keyboard 26 * user toggling the sync preference. 27 */ 28 public class AccountStateChangedListener { 29 30 /** 31 * Called when the current account being used in keyboard is signed out. 32 * 33 * @param oldAccount the account that was signed out of. 34 */ onAccountSignedOut(@onNull String oldAccount)35 public static void onAccountSignedOut(@NonNull String oldAccount) { 36 } 37 38 /** 39 * Called when the user signs-in to the keyboard. 40 * This may be called when the user switches accounts to sign in with a different account. 41 * 42 * @param oldAccount the previous account that was being used for sign-in. 43 * May be null for a fresh sign-in. 44 * @param newAccount the account being used for sign-in. 45 */ onAccountSignedIn(@ullable String oldAccount, @NonNull String newAccount)46 public static void onAccountSignedIn(@Nullable String oldAccount, @NonNull String newAccount) { 47 } 48 49 /** 50 * Called when the user toggles the sync preference. 51 * 52 * @param account the account being used for sync. 53 * @param syncEnabled indicates whether sync has been enabled or not. 54 */ onSyncPreferenceChanged(@ullable String account, boolean syncEnabled)55 public static void onSyncPreferenceChanged(@Nullable String account, boolean syncEnabled) { 56 } 57 58 /** 59 * Forces an immediate sync to happen. 60 * This should only be used for debugging purposes. 61 * 62 * @param account the account to use for sync. 63 */ forceSync(@ullable String account)64 public static void forceSync(@Nullable String account) { 65 } 66 67 /** 68 * Forces an immediate deletion of user's data. 69 * This should only be used for debugging purposes. 70 * 71 * @param account the account to use for sync. 72 */ forceDelete(@ullable String account)73 public static void forceDelete(@Nullable String account) { 74 } 75 } 76