add: coin purchases + donator badge
This commit is contained in:
parent
fd529d3847
commit
44f9edd67e
21 changed files with 345 additions and 38 deletions
|
@ -129,6 +129,7 @@ impl DataManager {
|
|||
is_deactivated: get!(x->29(i32)) as i8 == 1,
|
||||
ban_expire: get!(x->30(i64)) as usize,
|
||||
coins: get!(x->31(i32)),
|
||||
checkouts: serde_json::from_str(&get!(x->32(String)).to_string()).unwrap(),
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -285,7 +286,7 @@ impl DataManager {
|
|||
|
||||
let res = execute!(
|
||||
&conn,
|
||||
"INSERT INTO users VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14, $15, $16, $17, $18, $19, $20, $21, $22, $23, $24, $25, $26, $27, $28, $29, $30, $31, $32)",
|
||||
"INSERT INTO users VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10, $11, $12, $13, $14, $15, $16, $17, $18, $19, $20, $21, $22, $23, $24, $25, $26, $27, $28, $29, $30, $31, $32, $33)",
|
||||
params![
|
||||
&(data.id as i64),
|
||||
&(data.created as i64),
|
||||
|
@ -318,7 +319,8 @@ impl DataManager {
|
|||
&serde_json::to_string(&data.channel_mutes).unwrap(),
|
||||
&if data.is_deactivated { 1_i32 } else { 0_i32 },
|
||||
&(data.ban_expire as i64),
|
||||
&(data.coins as i32)
|
||||
&(data.coins as i32),
|
||||
&serde_json::to_string(&data.checkouts).unwrap(),
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -1061,6 +1063,7 @@ impl DataManager {
|
|||
auto_method!(update_user_channel_mutes(Vec<usize>)@get_user_by_id -> "UPDATE users SET channel_mutes = $1 WHERE id = $2" --serde --cache-key-tmpl=cache_clear_user);
|
||||
auto_method!(update_user_ban_expire(i64)@get_user_by_id -> "UPDATE users SET ban_expire = $1 WHERE id = $2" --cache-key-tmpl=cache_clear_user);
|
||||
auto_method!(update_user_coins(i32)@get_user_by_id -> "UPDATE users SET coins = $1 WHERE id = $2" --cache-key-tmpl=cache_clear_user);
|
||||
auto_method!(update_user_checkouts(Vec<String>)@get_user_by_id -> "UPDATE users SET checkouts = $1 WHERE id = $2" --serde --cache-key-tmpl=cache_clear_user);
|
||||
|
||||
auto_method!(get_user_by_stripe_id(&str)@get_user_from_row -> "SELECT * FROM users WHERE stripe_id = $1" --name="user" --returns=User);
|
||||
auto_method!(update_user_stripe_id(&str)@get_user_by_id -> "UPDATE users SET stripe_id = $1 WHERE id = $2" --cache-key-tmpl=cache_clear_user);
|
||||
|
|
|
@ -30,5 +30,6 @@ CREATE TABLE IF NOT EXISTS users (
|
|||
channel_mutes TEXT NOT NULL,
|
||||
is_deactivated INT NOT NULL,
|
||||
ban_expire BIGINT NOT NULL,
|
||||
coins INT NOT NULL
|
||||
coins INT NOT NULL,
|
||||
checkouts TEXT NOT NULL
|
||||
)
|
||||
|
|
|
@ -41,3 +41,7 @@ ADD COLUMN IF NOT EXISTS coins INT DEFAULT 0;
|
|||
-- requests data
|
||||
ALTER TABLE requests
|
||||
ADD COLUMN IF NOT EXISTS data TEXT DEFAULT '"Null"';
|
||||
|
||||
-- users checkouts
|
||||
ALTER TABLE users
|
||||
ADD COLUMN IF NOT EXISTS checkouts TEXT DEFAULT '[]';
|
||||
|
|
|
@ -109,6 +109,12 @@ impl DataManager {
|
|||
// check values
|
||||
let mut sender = self.get_user_by_id(data.sender).await?;
|
||||
let mut receiver = self.get_user_by_id(data.receiver).await?;
|
||||
|
||||
if sender.id == self.0.0.system_user {
|
||||
// system user can create coins from the void
|
||||
sender.coins = i32::MAX;
|
||||
}
|
||||
|
||||
let (sender_bankrupt, receiver_bankrupt) = data.apply(&mut sender, &mut receiver);
|
||||
|
||||
if sender_bankrupt | receiver_bankrupt {
|
||||
|
@ -118,7 +124,10 @@ impl DataManager {
|
|||
}
|
||||
|
||||
if apply {
|
||||
self.update_user_coins(sender.id, sender.coins).await?;
|
||||
if sender.id != self.0.0.system_user {
|
||||
self.update_user_coins(sender.id, sender.coins).await?;
|
||||
}
|
||||
|
||||
self.update_user_coins(receiver.id, receiver.coins).await?;
|
||||
} else {
|
||||
// we haven't applied the transfer, so this must be pending
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue