1 /* 2 * Copyright (C) 2022 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.keyguard 18 19 import android.annotation.CurrentTimeMillisLong 20 import com.android.systemui.common.buffer.RingBuffer 21 import com.android.systemui.dump.DumpsysTableLogger 22 import com.android.systemui.dump.Row 23 24 /** Verbose debug information. */ 25 data class KeyguardActiveUnlockModel( 26 @CurrentTimeMillisLong override var timeMillis: Long = 0L, 27 override var userId: Int = 0, 28 override var listening: Boolean = false, 29 // keep sorted 30 var awakeKeyguard: Boolean = false, 31 var authInterruptActive: Boolean = false, 32 var fpLockedOut: Boolean = false, 33 var primaryAuthRequired: Boolean = false, 34 var switchingUser: Boolean = false, 35 var triggerActiveUnlockForAssistant: Boolean = false, 36 var userCanDismissLockScreen: Boolean = false, 37 ) : KeyguardListenModel() { 38 39 /** List of [String] to be used as a [Row] with [DumpsysTableLogger]. */ <lambda>null40 val asStringList: List<String> by lazy { 41 listOf( 42 DATE_FORMAT.format(timeMillis), 43 timeMillis.toString(), 44 userId.toString(), 45 listening.toString(), 46 // keep sorted 47 awakeKeyguard.toString(), 48 authInterruptActive.toString(), 49 fpLockedOut.toString(), 50 primaryAuthRequired.toString(), 51 switchingUser.toString(), 52 triggerActiveUnlockForAssistant.toString(), 53 userCanDismissLockScreen.toString(), 54 ) 55 } 56 57 /** 58 * [RingBuffer] to store [KeyguardActiveUnlockModel]. After the buffer is full, it will recycle 59 * old events. 60 * 61 * Do not use [append] to add new elements. Instead use [insert], as it will recycle if 62 * necessary. 63 */ 64 class Buffer { <lambda>null65 private val buffer = RingBuffer(CAPACITY) { KeyguardActiveUnlockModel() } 66 insertnull67 fun insert(model: KeyguardActiveUnlockModel) { 68 buffer.advance().apply { 69 timeMillis = model.timeMillis 70 userId = model.userId 71 listening = model.listening 72 // keep sorted 73 awakeKeyguard = model.awakeKeyguard 74 authInterruptActive = model.authInterruptActive 75 fpLockedOut = model.fpLockedOut 76 primaryAuthRequired = model.primaryAuthRequired 77 switchingUser = model.switchingUser 78 triggerActiveUnlockForAssistant = model.triggerActiveUnlockForAssistant 79 userCanDismissLockScreen = model.userCanDismissLockScreen 80 } 81 } 82 83 /** 84 * Returns the content of the buffer (sorted from latest to newest). 85 * 86 * @see KeyguardFingerprintListenModel.asStringList 87 */ toListnull88 fun toList(): List<Row> { 89 return buffer.asSequence().map { it.asStringList }.toList() 90 } 91 } 92 93 companion object { 94 const val CAPACITY = 20 // number of logs to retain 95 96 /** Headers for dumping a table using [DumpsysTableLogger]. */ 97 @JvmField 98 val TABLE_HEADERS = 99 listOf( 100 "timestamp", 101 "time_millis", 102 "userId", 103 "listening", 104 // keep sorted 105 "awakeKeyguard", 106 "authInterruptActive", 107 "fpLockedOut", 108 "primaryAuthRequired", 109 "switchingUser", 110 "triggerActiveUnlockForAssistant", 111 "userCanDismissLockScreen", 112 ) 113 } 114 } 115