forked from Skynet/discord-bot
fix: last remaining uses of a username over ID
This commit is contained in:
parent
058fe2538a
commit
d7b5cd36ea
1 changed files with 10 additions and 9 deletions
|
@ -236,6 +236,7 @@ pub(crate) mod link {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) mod verify {
|
pub(crate) mod verify {
|
||||||
|
use serenity::model::id::UserId;
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::commands::link_email::link::{db_pending_clear_expired, get_verify_from_db};
|
use crate::commands::link_email::link::{db_pending_clear_expired, get_verify_from_db};
|
||||||
use serenity::model::user::User;
|
use serenity::model::user::User;
|
||||||
|
@ -277,9 +278,9 @@ pub(crate) mod verify {
|
||||||
return "Invalid verification code".to_string();
|
return "Invalid verification code".to_string();
|
||||||
}
|
}
|
||||||
|
|
||||||
match db_pending_clear_successful(&db, &command.user.name).await {
|
match db_pending_clear_successful(&db, &command.user.id).await {
|
||||||
Ok(_) => {
|
Ok(_) => {
|
||||||
return match set_discord(&db, &command.user.name, &details.email).await {
|
return match set_discord(&db, &command.user.id, &details.email).await {
|
||||||
Ok(_) => {
|
Ok(_) => {
|
||||||
// get teh right roles for the user
|
// get teh right roles for the user
|
||||||
set_server_roles(&db, &command.user, ctx).await;
|
set_server_roles(&db, &command.user, ctx).await;
|
||||||
|
@ -307,7 +308,7 @@ pub(crate) mod verify {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn db_pending_clear_successful(pool: &Pool<Sqlite>, user: &str) -> Result<Option<WolvesVerify>, Error> {
|
async fn db_pending_clear_successful(pool: &Pool<Sqlite>, user: &UserId) -> Result<Option<WolvesVerify>, Error> {
|
||||||
sqlx::query_as::<_, WolvesVerify>(
|
sqlx::query_as::<_, WolvesVerify>(
|
||||||
r#"
|
r#"
|
||||||
DELETE
|
DELETE
|
||||||
|
@ -315,12 +316,12 @@ pub(crate) mod verify {
|
||||||
WHERE discord = ?
|
WHERE discord = ?
|
||||||
"#,
|
"#,
|
||||||
)
|
)
|
||||||
.bind(user)
|
.bind(*user.as_u64() as i64)
|
||||||
.fetch_optional(pool)
|
.fetch_optional(pool)
|
||||||
.await
|
.await
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn set_discord(db: &Pool<Sqlite>, discord: &str, email: &str) -> Result<Option<Wolves>, Error> {
|
async fn set_discord(db: &Pool<Sqlite>, discord: &UserId, email: &str) -> Result<Option<Wolves>, Error> {
|
||||||
sqlx::query_as::<_, Wolves>(
|
sqlx::query_as::<_, Wolves>(
|
||||||
"
|
"
|
||||||
UPDATE wolves
|
UPDATE wolves
|
||||||
|
@ -328,14 +329,14 @@ pub(crate) mod verify {
|
||||||
WHERE email = ?
|
WHERE email = ?
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
.bind(discord)
|
.bind(*discord.as_u64() as i64)
|
||||||
.bind(email)
|
.bind(email)
|
||||||
.fetch_optional(db)
|
.fetch_optional(db)
|
||||||
.await
|
.await
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn set_server_roles(db: &Pool<Sqlite>, discord: &User, ctx: &Context) {
|
async fn set_server_roles(db: &Pool<Sqlite>, discord: &User, ctx: &Context) {
|
||||||
if let Ok(servers) = get_servers(db, &discord.name).await {
|
if let Ok(servers) = get_servers(db, &discord.id).await {
|
||||||
for server in servers {
|
for server in servers {
|
||||||
if let Ok(mut member) = server.server.member(&ctx.http, &discord.id).await {
|
if let Ok(mut member) = server.server.member(&ctx.http, &discord.id).await {
|
||||||
if let Some(config) = get_server_config(db, &server.server).await {
|
if let Some(config) = get_server_config(db, &server.server).await {
|
||||||
|
@ -368,7 +369,7 @@ pub(crate) mod verify {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn get_servers(db: &Pool<Sqlite>, discord: &str) -> Result<Vec<ServerMembersWolves>, Error> {
|
async fn get_servers(db: &Pool<Sqlite>, discord: &UserId) -> Result<Vec<ServerMembersWolves>, Error> {
|
||||||
sqlx::query_as::<_, ServerMembersWolves>(
|
sqlx::query_as::<_, ServerMembersWolves>(
|
||||||
"
|
"
|
||||||
SELECT *
|
SELECT *
|
||||||
|
@ -377,7 +378,7 @@ pub(crate) mod verify {
|
||||||
WHERE discord = ?
|
WHERE discord = ?
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
.bind(discord)
|
.bind(*discord.as_u64() as i64)
|
||||||
.fetch_all(db)
|
.fetch_all(db)
|
||||||
.await
|
.await
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue