You've already forked AstralRinth
forked from didirus/AstralRinth
* Add way to fetch team members, fix files not being returned with version route * Make it compile * Fixes * Use default error handling
111 lines
2.7 KiB
Rust
111 lines
2.7 KiB
Rust
use super::ids::*;
|
|
|
|
pub struct TeamBuilder {
|
|
pub members: Vec<TeamMemberBuilder>,
|
|
}
|
|
pub struct TeamMemberBuilder {
|
|
pub user_id: UserId,
|
|
pub name: String,
|
|
pub role: String,
|
|
}
|
|
|
|
impl TeamBuilder {
|
|
pub async fn insert(
|
|
self,
|
|
transaction: &mut sqlx::Transaction<'_, sqlx::Postgres>,
|
|
) -> Result<TeamId, super::DatabaseError> {
|
|
let team_id = generate_team_id(&mut *transaction).await?;
|
|
|
|
let team = Team { id: team_id };
|
|
|
|
sqlx::query!(
|
|
"
|
|
INSERT INTO teams (id)
|
|
VALUES ($1)
|
|
",
|
|
team.id as TeamId,
|
|
)
|
|
.execute(&mut *transaction)
|
|
.await?;
|
|
|
|
for member in self.members {
|
|
let team_member_id = generate_team_member_id(&mut *transaction).await?;
|
|
let team_member = TeamMember {
|
|
id: team_member_id,
|
|
team_id,
|
|
user_id: member.user_id,
|
|
name: member.name,
|
|
role: member.role,
|
|
};
|
|
|
|
sqlx::query!(
|
|
"
|
|
INSERT INTO team_members (id, team_id, user_id, member_name, role)
|
|
VALUES ($1, $2, $3, $4, $5)
|
|
",
|
|
team_member.id as TeamMemberId,
|
|
team_member.team_id as TeamId,
|
|
team_member.user_id as UserId,
|
|
team_member.name,
|
|
team_member.role,
|
|
)
|
|
.execute(&mut *transaction)
|
|
.await?;
|
|
}
|
|
|
|
Ok(team_id)
|
|
}
|
|
}
|
|
|
|
/// A team of users who control a mod
|
|
pub struct Team {
|
|
/// The id of the team
|
|
pub id: TeamId,
|
|
}
|
|
|
|
/// A member of a team
|
|
pub struct TeamMember {
|
|
pub id: TeamMemberId,
|
|
pub team_id: TeamId,
|
|
/// The ID of the user associated with the member
|
|
pub user_id: UserId,
|
|
/// The name of the user
|
|
pub name: String,
|
|
pub role: String,
|
|
}
|
|
|
|
impl TeamMember {
|
|
pub async fn get_from_team<'a, 'b, E>(
|
|
id: TeamId,
|
|
executor: E,
|
|
) -> Result<Vec<TeamMember>, super::DatabaseError>
|
|
where
|
|
E: sqlx::Executor<'a, Database = sqlx::Postgres>,
|
|
{
|
|
use futures::stream::TryStreamExt;
|
|
|
|
let team_members = sqlx::query!(
|
|
"
|
|
SELECT id, user_id, member_name, role
|
|
FROM team_members
|
|
WHERE team_id = $1
|
|
",
|
|
id as TeamId,
|
|
)
|
|
.fetch_many(executor)
|
|
.try_filter_map(|e| async {
|
|
Ok(e.right().map(|m| TeamMember {
|
|
id: TeamMemberId(m.id),
|
|
team_id: id,
|
|
user_id: UserId(m.user_id),
|
|
name: m.member_name,
|
|
role: m.role,
|
|
}))
|
|
})
|
|
.try_collect::<Vec<TeamMember>>()
|
|
.await?;
|
|
|
|
Ok(team_members)
|
|
}
|
|
}
|