makes resolve_claims a single transaction
This commit is contained in:
@@ -100,20 +100,20 @@ pub fn fetch_claims(conn: &DbConnection) -> QueryResult<Vec<models::Claim>> {
|
||||
pub fn resolve_claims(conn: &DbConnection) -> QueryResult<()> {
|
||||
let data = models::claim::Claims(conn).grouped_by_item()?;
|
||||
dbg!(&data);
|
||||
for (item, mut claims) in data {
|
||||
if claims.len() > 1 {
|
||||
// TODO: better sorting mechanism :)
|
||||
claims.sort_by(|a,b| a.resolve.cmp(&b.resolve));
|
||||
conn.transaction(move || {
|
||||
for (item, mut claims) in data {
|
||||
if claims.len() > 1 {
|
||||
// TODO: better sorting mechanism :)
|
||||
claims.sort_by(|a,b| a.resolve.cmp(&b.resolve));
|
||||
}
|
||||
let winner = claims.get(0).expect("Claims should not be empty !");
|
||||
let player_id = winner.player_id;
|
||||
winner.resolve_claim(conn)?;
|
||||
models::player::AsPlayer(conn, player_id)
|
||||
.update_debt(item.sell_value())?;
|
||||
}
|
||||
let winner = claims.get(0).expect("Claims should not be empty !");
|
||||
let player_id = winner.player_id;
|
||||
conn.transaction(|| {
|
||||
winner.resolve_claim(conn)?;
|
||||
models::player::AsPlayer(conn, player_id)
|
||||
.update_debt(item.sell_value())
|
||||
})?;
|
||||
}
|
||||
Ok(())
|
||||
Ok(())
|
||||
})
|
||||
}
|
||||
|
||||
/// Split up and share group money among selected players
|
||||
|
||||
Reference in New Issue
Block a user