Finished send logs feature from debug popup

This commit is contained in:
Sylvain Berfini 2020-06-01 11:39:05 +02:00
parent cd880ee06d
commit a880682672
7 changed files with 126 additions and 73 deletions

View file

@ -31,8 +31,8 @@ import androidx.lifecycle.ViewModelProvider
import androidx.navigation.fragment.findNavController import androidx.navigation.fragment.findNavController
import org.linphone.R import org.linphone.R
import org.linphone.activities.main.MainActivity import org.linphone.activities.main.MainActivity
import org.linphone.core.tools.Log
import org.linphone.databinding.AboutFragmentBinding import org.linphone.databinding.AboutFragmentBinding
import org.linphone.utils.AppUtils
class AboutFragment : Fragment() { class AboutFragment : Fragment() {
private lateinit var binding: AboutFragmentBinding private lateinit var binding: AboutFragmentBinding
@ -83,27 +83,8 @@ class AboutFragment : Fragment() {
val activity = requireActivity() as MainActivity val activity = requireActivity() as MainActivity
activity.showSnackBar(R.string.logs_url_copied_to_clipboard) activity.showSnackBar(R.string.logs_url_copied_to_clipboard)
shareUploadedLogsUrl(url) AppUtils.shareUploadedLogsUrl(activity, url)
} }
}) })
} }
// Logs
private fun shareUploadedLogsUrl(info: String) {
val appName = getString(R.string.app_name)
val intent = Intent(Intent.ACTION_SEND)
intent.putExtra(
Intent.EXTRA_EMAIL,
arrayOf(getString(R.string.about_bugreport_email))
)
intent.putExtra(Intent.EXTRA_SUBJECT, "$appName Logs")
intent.putExtra(Intent.EXTRA_TEXT, info)
intent.type = "text/plain"
try {
startActivity(Intent.createChooser(intent, "Send mail..."))
} catch (ex: ActivityNotFoundException) {
Log.e(ex)
}
}
} }

View file

@ -19,59 +19,14 @@
*/ */
package org.linphone.activities.main.about package org.linphone.activities.main.about
import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.ViewModel
import org.linphone.LinphoneApplication.Companion.coreContext import org.linphone.LinphoneApplication.Companion.coreContext
import org.linphone.LinphoneApplication.Companion.corePreferences import org.linphone.LinphoneApplication.Companion.corePreferences
import org.linphone.core.Core import org.linphone.utils.LogsUploadViewModel
import org.linphone.core.CoreListenerStub
import org.linphone.utils.Event
class AboutViewModel : ViewModel() { class AboutViewModel : LogsUploadViewModel() {
val appVersion: String = coreContext.appVersion val appVersion: String = coreContext.appVersion
val sdkVersion: String = coreContext.sdkVersion val sdkVersion: String = coreContext.sdkVersion
val showLogsButtons: Boolean = corePreferences.debugLogs val showLogsButtons: Boolean = corePreferences.debugLogs
val uploadInProgress = MutableLiveData<Boolean>()
val uploadFinishedEvent: MutableLiveData<Event<String>> by lazy {
MutableLiveData<Event<String>>()
}
private val listener = object : CoreListenerStub() {
override fun onLogCollectionUploadStateChanged(
core: Core,
state: Core.LogCollectionUploadState,
info: String
) {
if (state == Core.LogCollectionUploadState.Delivered) {
uploadInProgress.value = false
uploadFinishedEvent.value = Event(info)
} else if (state == Core.LogCollectionUploadState.NotDelivered) {
uploadInProgress.value = false
}
}
}
init {
coreContext.core.addListener(listener)
uploadInProgress.value = false
}
override fun onCleared() {
coreContext.core.removeListener(listener)
super.onCleared()
}
fun uploadLogs() {
uploadInProgress.value = true
coreContext.core.uploadLogCollection()
}
fun resetLogs() {
coreContext.core.resetLogCollection()
}
} }

View file

@ -20,6 +20,9 @@
package org.linphone.activities.main.dialer.fragments package org.linphone.activities.main.dialer.fragments
import android.app.AlertDialog import android.app.AlertDialog
import android.content.ClipData
import android.content.ClipboardManager
import android.content.Context
import android.net.Uri import android.net.Uri
import android.os.Bundle import android.os.Bundle
import android.view.LayoutInflater import android.view.LayoutInflater
@ -32,16 +35,20 @@ import androidx.navigation.fragment.findNavController
import org.linphone.LinphoneApplication.Companion.coreContext import org.linphone.LinphoneApplication.Companion.coreContext
import org.linphone.LinphoneApplication.Companion.corePreferences import org.linphone.LinphoneApplication.Companion.corePreferences
import org.linphone.R import org.linphone.R
import org.linphone.activities.main.MainActivity
import org.linphone.activities.main.dialer.viewmodels.DialerViewModel import org.linphone.activities.main.dialer.viewmodels.DialerViewModel
import org.linphone.activities.main.viewmodels.SharedMainViewModel import org.linphone.activities.main.viewmodels.SharedMainViewModel
import org.linphone.core.tools.Log import org.linphone.core.tools.Log
import org.linphone.databinding.DialerFragmentBinding import org.linphone.databinding.DialerFragmentBinding
import org.linphone.utils.AppUtils
class DialerFragment : Fragment() { class DialerFragment : Fragment() {
private lateinit var binding: DialerFragmentBinding private lateinit var binding: DialerFragmentBinding
private lateinit var viewModel: DialerViewModel private lateinit var viewModel: DialerViewModel
private lateinit var sharedViewModel: SharedMainViewModel private lateinit var sharedViewModel: SharedMainViewModel
private var uploadLogsInitiatedByUs = false
override fun onCreateView( override fun onCreateView(
inflater: LayoutInflater, inflater: LayoutInflater,
container: ViewGroup?, container: ViewGroup?,
@ -115,6 +122,23 @@ class DialerFragment : Fragment() {
} }
}) })
viewModel.uploadFinishedEvent.observe(viewLifecycleOwner, Observer {
it.consume { url ->
// To prevent being trigger when using the Send Logs button in About page
if (uploadLogsInitiatedByUs) {
val clipboard =
requireContext().getSystemService(Context.CLIPBOARD_SERVICE) as ClipboardManager
val clip = ClipData.newPlainText("Logs url", url)
clipboard.setPrimaryClip(clip)
val activity = requireActivity() as MainActivity
activity.showSnackBar(R.string.logs_url_copied_to_clipboard)
AppUtils.shareUploadedLogsUrl(activity, url)
}
}
})
Log.i("[Dialer] Pending call transfer mode = ${sharedViewModel.pendingCallTransfer}") Log.i("[Dialer] Pending call transfer mode = ${sharedViewModel.pendingCallTransfer}")
viewModel.transferVisibility.value = sharedViewModel.pendingCallTransfer viewModel.transferVisibility.value = sharedViewModel.pendingCallTransfer
} }
@ -126,6 +150,7 @@ class DialerFragment : Fragment() {
coreContext.core.nativePreviewWindowId = binding.videoPreviewWindow coreContext.core.nativePreviewWindowId = binding.videoPreviewWindow
} }
viewModel.updateShowVideoPreview() viewModel.updateShowVideoPreview()
uploadLogsInitiatedByUs = false
} }
private fun displayDebugPopup() { private fun displayDebugPopup() {
@ -137,7 +162,8 @@ class DialerFragment : Fragment() {
corePreferences.debugLogs = false corePreferences.debugLogs = false
} }
if (which == 1) { if (which == 1) {
// TODO: upload logs uploadLogsInitiatedByUs = true
viewModel.uploadLogs()
} }
} }
} else { } else {

View file

@ -21,14 +21,14 @@ package org.linphone.activities.main.dialer.viewmodels
import android.provider.Settings import android.provider.Settings
import androidx.lifecycle.MutableLiveData import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.ViewModel
import org.linphone.LinphoneApplication.Companion.coreContext import org.linphone.LinphoneApplication.Companion.coreContext
import org.linphone.LinphoneApplication.Companion.corePreferences import org.linphone.LinphoneApplication.Companion.corePreferences
import org.linphone.activities.main.dialer.NumpadDigitListener import org.linphone.activities.main.dialer.NumpadDigitListener
import org.linphone.core.* import org.linphone.core.*
import org.linphone.core.tools.Log import org.linphone.core.tools.Log
import org.linphone.utils.LogsUploadViewModel
class DialerViewModel : ViewModel() { class DialerViewModel : LogsUploadViewModel() {
val enteredUri = MutableLiveData<String>() val enteredUri = MutableLiveData<String>()
val atLeastOneCall = MutableLiveData<Boolean>() val atLeastOneCall = MutableLiveData<Boolean>()

View file

@ -19,8 +19,8 @@
*/ */
package org.linphone.utils package org.linphone.utils
import android.content.ContentUris import android.app.Activity
import android.content.ContentValues import android.content.*
import android.provider.ContactsContract import android.provider.ContactsContract
import android.text.Spanned import android.text.Spanned
import android.util.TypedValue import android.util.TypedValue
@ -29,6 +29,8 @@ import java.util.*
import java.util.regex.Pattern import java.util.regex.Pattern
import org.linphone.LinphoneApplication.Companion.coreContext import org.linphone.LinphoneApplication.Companion.coreContext
import org.linphone.LinphoneApplication.Companion.corePreferences import org.linphone.LinphoneApplication.Companion.corePreferences
import org.linphone.R
import org.linphone.core.tools.Log
/** /**
* Various utility methods for application * Various utility methods for application
@ -125,5 +127,23 @@ class AppUtils {
coreContext.context.resources.displayMetrics coreContext.context.resources.displayMetrics
) )
} }
fun shareUploadedLogsUrl(activity: Activity, info: String) {
val appName = activity.getString(R.string.app_name)
val intent = Intent(Intent.ACTION_SEND)
intent.putExtra(
Intent.EXTRA_EMAIL,
arrayOf(activity.getString(R.string.about_bugreport_email))
)
intent.putExtra(Intent.EXTRA_SUBJECT, "$appName Logs")
intent.putExtra(Intent.EXTRA_TEXT, info)
intent.type = "text/plain"
try {
activity.startActivity(Intent.createChooser(intent, activity.getString(R.string.share_uploaded_logs_link)))
} catch (ex: ActivityNotFoundException) {
Log.e(ex)
}
}
} }
} }

View file

@ -0,0 +1,70 @@
/*
* Copyright (c) 2010-2020 Belledonne Communications SARL.
*
* This file is part of linphone-android
* (see https://www.linphone.org).
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package org.linphone.utils
import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.ViewModel
import org.linphone.LinphoneApplication.Companion.coreContext
import org.linphone.core.Core
import org.linphone.core.CoreListenerStub
open class LogsUploadViewModel : ViewModel() {
val uploadInProgress = MutableLiveData<Boolean>()
val uploadFinishedEvent: MutableLiveData<Event<String>> by lazy {
MutableLiveData<Event<String>>()
}
private val listener = object : CoreListenerStub() {
override fun onLogCollectionUploadStateChanged(
core: Core,
state: Core.LogCollectionUploadState,
info: String
) {
if (state == Core.LogCollectionUploadState.Delivered) {
uploadInProgress.value = false
uploadFinishedEvent.value = Event(info)
} else if (state == Core.LogCollectionUploadState.NotDelivered) {
uploadInProgress.value = false
}
}
}
init {
coreContext.core.addListener(listener)
uploadInProgress.value = false
}
override fun onCleared() {
coreContext.core.removeListener(listener)
super.onCleared()
}
fun uploadLogs() {
uploadInProgress.value = true
coreContext.core.uploadLogCollection()
}
fun resetLogs() {
coreContext.core.resetLogCollection()
}
}

View file

@ -42,6 +42,7 @@
<item quantity="one">%d day</item> <item quantity="one">%d day</item>
<item quantity="other">%d days</item> <item quantity="other">%d days</item>
</plurals> </plurals>
<string name="share_uploaded_logs_link">Share logs link using...</string>
<!-- Errors --> <!-- Errors -->
<string name="invalid_email">Invalid email</string> <string name="invalid_email">Invalid email</string>