Fix revocation of invites, allow for /user_id/teams to be useful
This commit is contained in:
parent
833cb99f41
commit
8c1688657a
@ -235,6 +235,16 @@ impl Version {
|
||||
.execute(exec)
|
||||
.await?;
|
||||
|
||||
sqlx::query!(
|
||||
"
|
||||
DELETE FROM downloads
|
||||
WHERE downloads.version_id = $1
|
||||
",
|
||||
id as VersionId,
|
||||
)
|
||||
.execute(exec)
|
||||
.await?;
|
||||
|
||||
use futures::TryStreamExt;
|
||||
|
||||
let files = sqlx::query!(
|
||||
|
||||
@ -45,6 +45,8 @@ impl Default for Permissions {
|
||||
/// A member of a team
|
||||
#[derive(Serialize, Deserialize, Clone)]
|
||||
pub struct TeamMember {
|
||||
/// The ID of the team this team member is a member of
|
||||
pub team_id: TeamId,
|
||||
/// The ID of the user associated with the member
|
||||
pub user_id: UserId,
|
||||
/// The role of the user in the team
|
||||
|
||||
@ -27,6 +27,7 @@ pub async fn team_members_get(
|
||||
let team_members: Vec<crate::models::teams::TeamMember> = members_data
|
||||
.into_iter()
|
||||
.map(|data| crate::models::teams::TeamMember {
|
||||
team_id: id,
|
||||
user_id: data.user_id.into(),
|
||||
role: data.role,
|
||||
permissions: Some(data.permissions),
|
||||
@ -44,6 +45,7 @@ pub async fn team_members_get(
|
||||
if team_member.accepted {
|
||||
team_members.push(
|
||||
crate::models::teams::TeamMember {
|
||||
team_id: id,
|
||||
user_id: team_member.user_id.into(),
|
||||
role: team_member.role,
|
||||
permissions: None,
|
||||
@ -298,7 +300,7 @@ pub async fn remove_team_member(
|
||||
}
|
||||
};
|
||||
|
||||
let delete_member = TeamMember::get_from_user_id(id, user_id, &**pool).await?;
|
||||
let delete_member = TeamMember::get_from_user_id_pending(id, user_id, &**pool).await?;
|
||||
|
||||
if let Some(delete_member) = delete_member {
|
||||
if delete_member.role == crate::models::teams::OWNER_ROLE {
|
||||
|
||||
@ -175,6 +175,7 @@ pub async fn teams(
|
||||
let team_members: Vec<crate::models::teams::TeamMember> = results
|
||||
.into_iter()
|
||||
.map(|data| crate::models::teams::TeamMember {
|
||||
team_id: data.team_id.into(),
|
||||
user_id: data.user_id.into(),
|
||||
role: data.role,
|
||||
permissions: if same_user {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user