Skip to content
This repository was archived by the owner on Jun 7, 2020. It is now read-only.

[BLOCKED][NEW] Add option in settings to download one's data #2305

Open
wants to merge 3 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import chat.rocket.android.db.DatabaseManagerFactory
import chat.rocket.android.helper.UserHelper
import chat.rocket.android.main.presentation.MainNavigator
import chat.rocket.android.server.domain.AnalyticsTrackingInteractor
import chat.rocket.android.server.domain.GetCurrentLanguageInteractor
import chat.rocket.android.server.domain.GetCurrentServerInteractor
import chat.rocket.android.server.domain.PermissionsInteractor
import chat.rocket.android.server.domain.RemoveAccountInteractor
Expand All @@ -19,10 +18,13 @@ import chat.rocket.android.util.extension.launchUI
import chat.rocket.android.util.extension.toHex
import chat.rocket.android.util.extensions.adminPanelUrl
import chat.rocket.android.util.extensions.avatarUrl
import chat.rocket.android.util.extensions.isNotNullNorBlank
import chat.rocket.android.util.retryIO
import chat.rocket.common.util.ifNull
import chat.rocket.core.RocketChatClient
import chat.rocket.core.internal.rest.deleteOwnAccount
import chat.rocket.core.internal.rest.me
import chat.rocket.core.internal.rest.requestDataDownload
import chat.rocket.core.internal.rest.serverInfo
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.withContext
Expand All @@ -40,22 +42,24 @@ class SettingsPresenter @Inject constructor(
private val tokenRepository: TokenRepository,
private val permissions: PermissionsInteractor,
private val rocketChatClientFactory: RocketChatClientFactory,
getCurrentServerInteractor: GetCurrentServerInteractor,
serverInteractor: GetCurrentServerInteractor,
removeAccountInteractor: RemoveAccountInteractor,
databaseManagerFactory: DatabaseManagerFactory,
connectionManagerFactory: ConnectionManagerFactory,
private val saveLanguageInteractor: SaveCurrentLanguageInteractor
) : CheckServerPresenter(
strategy = strategy,
factory = rocketChatClientFactory,
serverInteractor = getCurrentServerInteractor,
serverInteractor = serverInteractor,
removeAccountInteractor = removeAccountInteractor,
tokenRepository = tokenRepository,
dbManagerFactory = databaseManagerFactory,
managerFactory = connectionManagerFactory,
tokenView = view,
navigator = navigator
) {
private val serverUrl = serverInteractor.get()!!
private val client: RocketChatClient = rocketChatClientFactory.get(serverUrl)
private val token = tokenRepository.get(currentServer)

fun setupView() {
Expand Down Expand Up @@ -91,6 +95,28 @@ class SettingsPresenter @Inject constructor(
}
}

fun requestDataDownload() {
launchUI(strategy) {
try {
userHelper.user()?.let { user ->
val response = retryIO { client.requestDataDownload(user.id) }
if (response.requested) {
view.showMessage("Data download request placed successfully")
} else if (response.exportOperation.status.isNotNullNorBlank()) {
view.showMessage("Data download request already placed and has status: ${ response.exportOperation.status }")
}
}
} catch (exception: Exception) {
Timber.d(exception, "Error placing request for data download")
exception.message?.let {
view.showMessage("Error placing request for data download: $it")
}.ifNull {
view.showGenericErrorMessage()
}
}
}
}

fun enableAnalyticsTracking(isEnabled: Boolean) {
analyticsTrackingInteractor.save(isEnabled)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,8 @@ class SettingsFragment : Fragment(), SettingsView, AppLanguageView {

text_language.setOnClickListener { changeLanguage() }

text_download_my_data.setOnClickListener { presenter.requestDataDownload() }

text_review_this_app.setOnClickListener { showAppOnStore() }

text_share_this_app.setOnClickListener { shareApp() }
Expand Down
21 changes: 20 additions & 1 deletion app/src/main/res/layout/fragment_settings.xml
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,25 @@
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/text_contact_us" />

<TextView
android:id="@+id/text_download_my_data"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:background="@color/colorLightGrey"
android:fontFamily="sans-serif-medium"
android:foreground="?selectableItemBackground"
android:paddingStart="16dp"
android:paddingTop="8dp"
android:paddingEnd="16dp"
android:paddingBottom="8dp"
android:text="@string/msg_download_my_data"
android:textColor="#DE000000"
android:textSize="16sp"
android:textStyle="normal"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/text_language" />

<TextView
android:id="@+id/text_review_this_app"
android:layout_width="0dp"
Expand All @@ -128,7 +147,7 @@
android:textStyle="normal"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/text_language" />
app:layout_constraintTop_toBottomOf="@+id/text_download_my_data" />

<TextView
android:id="@+id/text_share_this_app"
Expand Down
1 change: 1 addition & 0 deletions app/src/main/res/values/strings.xml
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ https://github.com/RocketChat/java-code-styles/blob/master/CODING_STYLE.md#strin
<!-- Settings messages -->
<string name="msg_contact_us">Contact us</string>
<string name="msg_language">Language</string>
<string name="msg_download_my_data">Download My Data</string>
<string name="msg_review_this_app">Review this app</string>
<string name="msg_share_this_app">Share this app</string>
<string name="msg_administration">Administration</string>
Expand Down