stacker.news/prisma/migrations/20210513002503_withdrawl_funcs/migration.sql

58 lines
2.0 KiB
MySQL
Raw Normal View History

2021-05-13 01:51:37 +00:00
CREATE OR REPLACE FUNCTION create_withdrawl(lnd_id TEXT, invoice TEXT, msats_amount INTEGER, msats_max_fee INTEGER, username TEXT)
RETURNS "Withdrawl"
LANGUAGE plpgsql
AS $$
DECLARE
user_id INTEGER;
user_msats INTEGER;
withdrawl "Withdrawl";
BEGIN
SELECT msats, id INTO user_msats, user_id FROM users WHERE name = username;
IF (msats_amount + msats_max_fee) > user_msats THEN
RAISE EXCEPTION 'SN_INSUFFICIENT_FUNDS';
END IF;
INSERT INTO "Withdrawl" (hash, bolt11, "msatsPaying", "msatsFeePaying", "userId", updated_at)
VALUES (lnd_id, invoice, msats_amount, msats_max_fee, user_id, 'now') RETURNING * INTO withdrawl;
UPDATE users SET msats = msats - msats_amount - msats_max_fee WHERE id = user_id;
RETURN withdrawl;
END;
$$;
2021-05-13 21:19:51 +00:00
CREATE OR REPLACE FUNCTION confirm_withdrawl(wid INTEGER, msats_paid INTEGER, msats_fee_paid INTEGER)
2021-05-13 01:51:37 +00:00
RETURNS INTEGER
LANGUAGE plpgsql
AS $$
DECLARE
2021-05-13 21:19:51 +00:00
msats_fee_paying INTEGER;
user_id INTEGER;
2021-05-13 01:51:37 +00:00
BEGIN
2021-05-13 21:19:51 +00:00
IF EXISTS (SELECT 1 FROM "Withdrawl" WHERE id = wid AND status IS NULL) THEN
UPDATE "Withdrawl" SET status = 'CONFIRMED', "msatsPaid" = msats_paid, "msatsFeePaid" = msats_fee_paid WHERE id = wid;
SELECT "msatsFeePaying", "userId" INTO msats_fee_paying, user_id FROM "Withdrawl" WHERE id = wid;
UPDATE users SET msats = msats + (msats_fee_paying - msats_fee_paid) WHERE id = user_id;
END IF;
2021-05-13 01:51:37 +00:00
2021-05-13 21:19:51 +00:00
RETURN 0;
2021-05-13 01:51:37 +00:00
END;
$$;
2021-05-13 21:19:51 +00:00
CREATE OR REPLACE FUNCTION reverse_withdrawl(wid INTEGER, wstatus "WithdrawlStatus")
2021-05-13 01:51:37 +00:00
RETURNS INTEGER
LANGUAGE plpgsql
AS $$
DECLARE
2021-05-13 21:19:51 +00:00
msats_fee_paying INTEGER;
msats_paying INTEGER;
user_id INTEGER;
2021-05-13 01:51:37 +00:00
BEGIN
2021-05-13 21:19:51 +00:00
IF EXISTS (SELECT 1 FROM "Withdrawl" WHERE id = wid AND status IS NULL) THEN
UPDATE "Withdrawl" SET status = wstatus WHERE id = wid;
SELECT "msatsPaying", "msatsFeePaying", "userId" INTO msats_paying, msats_fee_paying, user_id FROM "Withdrawl" WHERE id = wid;
UPDATE users SET msats = msats + msats_paying + msats_fee_paying WHERE id = user_id;
END IF;
RETURN 0;
2021-05-13 01:51:37 +00:00
END;
$$;