145 lines
5.0 KiB
Kotlin
145 lines
5.0 KiB
Kotlin
/* Copyright 2018 Conny Duck
|
|
*
|
|
* This file is a part of Tusky.
|
|
*
|
|
* 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.
|
|
*
|
|
* Tusky 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 Tusky; if not,
|
|
* see <http://www.gnu.org/licenses>. */
|
|
|
|
package com.keylesspalace.tusky.db
|
|
|
|
import androidx.room.ColumnInfo
|
|
import androidx.room.Entity
|
|
import androidx.room.Index
|
|
import androidx.room.PrimaryKey
|
|
import androidx.room.TypeConverters
|
|
import com.keylesspalace.tusky.TabData
|
|
import com.keylesspalace.tusky.defaultTabs
|
|
import com.keylesspalace.tusky.entity.Emoji
|
|
import com.keylesspalace.tusky.entity.Status
|
|
|
|
@Entity(
|
|
indices = [
|
|
Index(
|
|
value = ["domain", "accountId"],
|
|
unique = true
|
|
)
|
|
]
|
|
)
|
|
@TypeConverters(Converters::class)
|
|
data class AccountEntity(
|
|
@field:PrimaryKey(autoGenerate = true) var id: Long,
|
|
val domain: String,
|
|
var accessToken: String,
|
|
var clientId: String?, // nullable for backward compatibility
|
|
var clientSecret: String?, // nullable for backward compatibility
|
|
var isActive: Boolean,
|
|
var accountId: String = "",
|
|
var username: String = "",
|
|
var displayName: String = "",
|
|
var profilePictureUrl: String = "",
|
|
var notificationsEnabled: Boolean = true,
|
|
var notificationsMentioned: Boolean = true,
|
|
var notificationsFollowed: Boolean = true,
|
|
var notificationsFollowRequested: Boolean = false,
|
|
var notificationsReblogged: Boolean = true,
|
|
var notificationsFavorited: Boolean = true,
|
|
var notificationsPolls: Boolean = true,
|
|
var notificationsSubscriptions: Boolean = true,
|
|
var notificationsSignUps: Boolean = true,
|
|
var notificationsUpdates: Boolean = true,
|
|
var notificationsReports: Boolean = true,
|
|
var notificationSound: Boolean = true,
|
|
var notificationVibration: Boolean = true,
|
|
var notificationLight: Boolean = true,
|
|
var defaultPostPrivacy: Status.Visibility = Status.Visibility.PUBLIC,
|
|
var defaultMediaSensitivity: Boolean = false,
|
|
var defaultPostLanguage: String = "",
|
|
var alwaysShowSensitiveMedia: Boolean = false,
|
|
/** True if content behind a content warning is shown by default */
|
|
var alwaysOpenSpoiler: Boolean = false,
|
|
|
|
/**
|
|
* True if the "Download media previews" preference is true. This implies
|
|
* that media previews are shown as well as downloaded.
|
|
*/
|
|
var mediaPreviewEnabled: Boolean = true,
|
|
/**
|
|
* ID of the last notification the user read on the Notification, list, and should be restored
|
|
* to view when the user returns to the list.
|
|
*
|
|
* May not be the ID of the most recent notification if the user has scrolled down the list.
|
|
*/
|
|
var lastNotificationId: String = "0",
|
|
/**
|
|
* ID of the most recent Mastodon notification that Tusky has fetched to show as an
|
|
* Android notification.
|
|
*/
|
|
@ColumnInfo(defaultValue = "0")
|
|
var notificationMarkerId: String = "0",
|
|
var emojis: List<Emoji> = emptyList(),
|
|
var tabPreferences: List<TabData> = defaultTabs(),
|
|
var notificationsFilter: String = "[\"follow_request\"]",
|
|
// Scope cannot be changed without re-login, so store it in case
|
|
// the scope needs to be changed in the future
|
|
var oauthScopes: String = "",
|
|
var unifiedPushUrl: String = "",
|
|
var pushPubKey: String = "",
|
|
var pushPrivKey: String = "",
|
|
var pushAuth: String = "",
|
|
var pushServerKey: String = "",
|
|
|
|
/**
|
|
* ID of the status at the top of the visible list in the home timeline when the
|
|
* user navigated away.
|
|
*/
|
|
var lastVisibleHomeTimelineStatusId: String? = null,
|
|
|
|
/** true if the connected Mastodon account is locked (has to manually approve all follow requests **/
|
|
@ColumnInfo(defaultValue = "0")
|
|
var locked: Boolean = false,
|
|
|
|
@ColumnInfo(defaultValue = "0")
|
|
var hasDirectMessageBadge: Boolean = false
|
|
) {
|
|
|
|
val identifier: String
|
|
get() = "$domain:$accountId"
|
|
|
|
val fullName: String
|
|
get() = "@$username@$domain"
|
|
|
|
fun logout() {
|
|
// deleting credentials so they cannot be used again
|
|
accessToken = ""
|
|
clientId = null
|
|
clientSecret = null
|
|
}
|
|
|
|
fun isLoggedIn() = accessToken.isNotEmpty()
|
|
|
|
override fun equals(other: Any?): Boolean {
|
|
if (this === other) return true
|
|
if (javaClass != other?.javaClass) return false
|
|
|
|
other as AccountEntity
|
|
|
|
if (id == other.id) return true
|
|
return domain == other.domain && accountId == other.accountId
|
|
}
|
|
|
|
override fun hashCode(): Int {
|
|
var result = id.hashCode()
|
|
result = 31 * result + domain.hashCode()
|
|
result = 31 * result + accountId.hashCode()
|
|
return result
|
|
}
|
|
}
|