Add better data removal, fix small benign bug
parent
576e2ef563
commit
ef86e1e2d3
|
@ -6,4 +6,5 @@ DROP TABLE "user";
|
|||
|
||||
-- Trigger functions
|
||||
|
||||
DROP FUNCTION IF EXISTS delete_inactive_accounts();
|
||||
DROP FUNCTION IF EXISTS update_last_updated_column();
|
|
@ -1,4 +1,4 @@
|
|||
-- Trigger functions
|
||||
-- Functions
|
||||
|
||||
CREATE OR REPLACE FUNCTION update_last_updated_column()
|
||||
RETURNS TRIGGER AS $$
|
||||
|
@ -8,6 +8,13 @@ BEGIN
|
|||
END;
|
||||
$$ LANGUAGE plpgsql;
|
||||
|
||||
CREATE OR REPLACE FUNCTION delete_inactive_accounts() RETURNS void AS $$
|
||||
BEGIN
|
||||
DELETE FROM account
|
||||
WHERE last_updated < NOW() - INTERVAL '2 months';
|
||||
END;
|
||||
$$ LANGUAGE plpgsql;
|
||||
|
||||
-- Tables
|
||||
|
||||
CREATE TABLE "user" (
|
||||
|
@ -20,7 +27,7 @@ CREATE TABLE "link_request" (
|
|||
user_id TEXT UNIQUE NOT NULL,
|
||||
expires TIMESTAMP NOT NULL,
|
||||
|
||||
CONSTRAINT fk_user_id FOREIGN KEY (user_id) REFERENCES "user" (id)
|
||||
CONSTRAINT fk_user_id FOREIGN KEY (user_id) REFERENCES "user" (id) ON DELETE CASCADE
|
||||
);
|
||||
|
||||
CREATE TABLE "account" (
|
||||
|
@ -32,7 +39,7 @@ CREATE TABLE "account" (
|
|||
expires TIMESTAMP NOT NULL,
|
||||
last_updated TIMESTAMP NOT NULL DEFAULT NOW(),
|
||||
|
||||
CONSTRAINT fk_account_user_id FOREIGN KEY (user_id) REFERENCES "user" (id)
|
||||
CONSTRAINT fk_account_user_id FOREIGN KEY (user_id) REFERENCES "user" (id) ON DELETE CASCADE
|
||||
);
|
||||
|
||||
-- Triggers
|
||||
|
|
|
@ -61,16 +61,16 @@ impl Database {
|
|||
Ok(result)
|
||||
}
|
||||
|
||||
pub async fn delete_user(&self, user_id: impl AsRef<str>) -> Result<()> {
|
||||
pub async fn delete_user(&self, user_id: impl AsRef<str>) -> Result<usize> {
|
||||
use schema::user::dsl::*;
|
||||
|
||||
let mut connection = self.0.get().await?;
|
||||
diesel::delete(user)
|
||||
let affected = diesel::delete(user)
|
||||
.filter(id.eq(user_id.as_ref()))
|
||||
.execute(&mut connection)
|
||||
.await?;
|
||||
|
||||
Ok(())
|
||||
Ok(affected)
|
||||
}
|
||||
|
||||
pub async fn get_or_create_user(&self, user_id: impl AsRef<str>) -> Result<User> {
|
||||
|
|
|
@ -516,6 +516,11 @@ impl songbird::EventHandler for SessionHandle {
|
|||
}
|
||||
|
||||
EventContext::ClientDisconnect(ClientDisconnect { user_id }) => {
|
||||
// Ignore disconnects if we're inactive
|
||||
if !self.active().await.unwrap_or(false) {
|
||||
return None;
|
||||
}
|
||||
|
||||
match self.owner().await {
|
||||
Ok(id) if id.get() == user_id.0 => {
|
||||
debug!("Owner of session disconnected, stopping playback");
|
||||
|
|
|
@ -9,7 +9,11 @@ use crate::bot::{Context, FrameworkError};
|
|||
|
||||
/// Unlink your Spotify account from Spoticord
|
||||
#[poise::command(slash_command, on_error = on_error)]
|
||||
pub async fn unlink(ctx: Context<'_>) -> Result<()> {
|
||||
pub async fn unlink(
|
||||
ctx: Context<'_>,
|
||||
|
||||
#[description = "Also delete Discord account information"] user_data: Option<bool>,
|
||||
) -> Result<()> {
|
||||
let manager = ctx.data();
|
||||
let db = manager.database();
|
||||
let user_id = ctx.author().id.to_string();
|
||||
|
@ -19,7 +23,14 @@ pub async fn unlink(ctx: Context<'_>) -> Result<()> {
|
|||
session.shutdown_player().await;
|
||||
}
|
||||
|
||||
if db.delete_account(&user_id).await? == 0 {
|
||||
let deleted_account = db.delete_account(&user_id).await? != 0;
|
||||
let deleted_user = if user_data.unwrap_or(false) {
|
||||
db.delete_user(&user_id).await? != 0
|
||||
} else {
|
||||
false
|
||||
};
|
||||
|
||||
if !deleted_account && !deleted_user {
|
||||
ctx.send(
|
||||
CreateReply::default()
|
||||
.embed(
|
||||
|
|
Loading…
Reference in New Issue