1 /* 2 * Copyright (C) 2023 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.systemui.bouncer.domain.interactor 18 19 import android.util.Log 20 import com.android.systemui.CoreStartable 21 import com.android.systemui.bouncer.data.repository.BouncerMessageRepository 22 import com.android.systemui.dagger.SysUISingleton 23 import com.android.systemui.dagger.qualifiers.Application 24 import javax.inject.Inject 25 import kotlinx.coroutines.CoroutineScope 26 import kotlinx.coroutines.launch 27 28 private val TAG = BouncerMessageAuditLogger::class.simpleName!! 29 30 /** Logger that echoes bouncer messages state to logcat in debuggable builds. */ 31 @SysUISingleton 32 class BouncerMessageAuditLogger 33 @Inject 34 constructor( 35 @Application private val scope: CoroutineScope, 36 private val repository: BouncerMessageRepository, 37 ) : CoreStartable { startnull38 override fun start() { 39 scope.launch { repository.bouncerMessage.collect { Log.d(TAG, "bouncerMessage: $it") } } 40 } 41 } 42