1 /* 2 * Copyright (C) 2018 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 package com.android.server.content; 17 18 import android.content.Context; 19 import android.database.ContentObserver; 20 import android.provider.Settings; 21 import android.provider.Settings.Global; 22 import android.util.KeyValueListParser; 23 import android.util.Slog; 24 25 import com.android.internal.os.BackgroundThread; 26 27 import java.io.PrintWriter; 28 29 public class SyncManagerConstants extends ContentObserver { 30 private static final String TAG = "SyncManagerConfig"; 31 32 private final Object mLock = new Object(); 33 private final Context mContext; 34 35 private static final String KEY_INITIAL_SYNC_RETRY_TIME_IN_SECONDS = 36 "initial_sync_retry_time_in_seconds"; 37 private static final int DEF_INITIAL_SYNC_RETRY_TIME_IN_SECONDS = 30; 38 private int mInitialSyncRetryTimeInSeconds = DEF_INITIAL_SYNC_RETRY_TIME_IN_SECONDS; 39 40 private static final String KEY_RETRY_TIME_INCREASE_FACTOR = 41 "retry_time_increase_factor"; 42 private static final float DEF_RETRY_TIME_INCREASE_FACTOR = 2.0f; 43 private float mRetryTimeIncreaseFactor = DEF_RETRY_TIME_INCREASE_FACTOR; 44 45 private static final String KEY_MAX_SYNC_RETRY_TIME_IN_SECONDS = 46 "max_sync_retry_time_in_seconds"; 47 private static final int DEF_MAX_SYNC_RETRY_TIME_IN_SECONDS = 60 * 60; 48 private int mMaxSyncRetryTimeInSeconds = DEF_MAX_SYNC_RETRY_TIME_IN_SECONDS; 49 50 private static final String KEY_MAX_RETRIES_WITH_APP_STANDBY_EXEMPTION = 51 "max_retries_with_app_standby_exemption"; 52 private static final int DEF_MAX_RETRIES_WITH_APP_STANDBY_EXEMPTION = 5; 53 private int mMaxRetriesWithAppStandbyExemption = DEF_MAX_RETRIES_WITH_APP_STANDBY_EXEMPTION; 54 55 private static final String KEY_EXEMPTION_TEMP_ALLOWLIST_DURATION_IN_SECONDS = 56 "exemption_temp_whitelist_duration_in_seconds"; 57 private static final int DEF_EXEMPTION_TEMP_ALLOWLIST_DURATION_IN_SECONDS = 10 * 60; 58 private int mKeyExemptionTempWhitelistDurationInSeconds 59 = DEF_EXEMPTION_TEMP_ALLOWLIST_DURATION_IN_SECONDS; 60 SyncManagerConstants(Context context)61 protected SyncManagerConstants(Context context) { 62 super(null); 63 mContext = context; 64 } 65 start()66 public void start() { 67 BackgroundThread.getHandler().post(() -> { 68 mContext.getContentResolver().registerContentObserver(Settings.Global.getUriFor( 69 Settings.Global.SYNC_MANAGER_CONSTANTS), false, this); 70 refresh(); 71 }); 72 } 73 74 @Override onChange(boolean selfChange)75 public void onChange(boolean selfChange) { 76 refresh(); 77 } 78 refresh()79 private void refresh() { 80 synchronized (mLock) { 81 82 String newValue = Settings.Global.getString(mContext.getContentResolver(), 83 Global.SYNC_MANAGER_CONSTANTS); 84 final KeyValueListParser parser = new KeyValueListParser(','); 85 try { 86 parser.setString(newValue); 87 } catch (IllegalArgumentException e) { 88 Slog.wtf(TAG, "Bad constants: " + newValue); 89 } 90 91 mInitialSyncRetryTimeInSeconds = parser.getInt( 92 KEY_INITIAL_SYNC_RETRY_TIME_IN_SECONDS, 93 DEF_INITIAL_SYNC_RETRY_TIME_IN_SECONDS); 94 95 mMaxSyncRetryTimeInSeconds = parser.getInt( 96 KEY_MAX_SYNC_RETRY_TIME_IN_SECONDS, 97 DEF_MAX_SYNC_RETRY_TIME_IN_SECONDS); 98 99 mRetryTimeIncreaseFactor = parser.getFloat( 100 KEY_RETRY_TIME_INCREASE_FACTOR, 101 DEF_RETRY_TIME_INCREASE_FACTOR); 102 103 mMaxRetriesWithAppStandbyExemption = parser.getInt( 104 KEY_MAX_RETRIES_WITH_APP_STANDBY_EXEMPTION, 105 DEF_MAX_RETRIES_WITH_APP_STANDBY_EXEMPTION); 106 107 mKeyExemptionTempWhitelistDurationInSeconds = parser.getInt( 108 KEY_EXEMPTION_TEMP_ALLOWLIST_DURATION_IN_SECONDS, 109 DEF_EXEMPTION_TEMP_ALLOWLIST_DURATION_IN_SECONDS); 110 111 } 112 } 113 getInitialSyncRetryTimeInSeconds()114 public int getInitialSyncRetryTimeInSeconds() { 115 synchronized (mLock) { 116 return mInitialSyncRetryTimeInSeconds; 117 } 118 } 119 getRetryTimeIncreaseFactor()120 public float getRetryTimeIncreaseFactor() { 121 synchronized (mLock) { 122 return mRetryTimeIncreaseFactor; 123 } 124 } 125 getMaxSyncRetryTimeInSeconds()126 public int getMaxSyncRetryTimeInSeconds() { 127 synchronized (mLock) { 128 return mMaxSyncRetryTimeInSeconds; 129 } 130 } 131 getMaxRetriesWithAppStandbyExemption()132 public int getMaxRetriesWithAppStandbyExemption() { 133 synchronized (mLock) { 134 return mMaxRetriesWithAppStandbyExemption; 135 } 136 } 137 getKeyExemptionTempWhitelistDurationInSeconds()138 public int getKeyExemptionTempWhitelistDurationInSeconds() { 139 synchronized (mLock) { 140 return mKeyExemptionTempWhitelistDurationInSeconds; 141 } 142 } 143 dump(PrintWriter pw, String prefix)144 public void dump(PrintWriter pw, String prefix) { 145 synchronized (mLock) { 146 pw.print(prefix); 147 pw.println("SyncManager Config:"); 148 149 pw.print(prefix); 150 pw.print(" mInitialSyncRetryTimeInSeconds="); 151 pw.println(mInitialSyncRetryTimeInSeconds); 152 153 pw.print(prefix); 154 pw.print(" mRetryTimeIncreaseFactor="); 155 pw.println(mRetryTimeIncreaseFactor); 156 157 pw.print(prefix); 158 pw.print(" mMaxSyncRetryTimeInSeconds="); 159 pw.println(mMaxSyncRetryTimeInSeconds); 160 161 pw.print(prefix); 162 pw.print(" mMaxRetriesWithAppStandbyExemption="); 163 pw.println(mMaxRetriesWithAppStandbyExemption); 164 165 pw.print(prefix); 166 pw.print(" mKeyExemptionTempWhitelistDurationInSeconds="); 167 pw.println(mKeyExemptionTempWhitelistDurationInSeconds); 168 } 169 } 170 } 171