stacker.news/prisma/migrations/20230508223532_earn_add/migration.sql

20 lines
673 B
PL/PgSQL

CREATE OR REPLACE FUNCTION earn(user_id INTEGER, earn_msats BIGINT, created_at TIMESTAMP(3),
type "EarnType", type_id INTEGER, rank INTEGER)
RETURNS void AS $$
DECLARE
BEGIN
PERFORM ASSERT_SERIALIZED();
-- insert into earn
INSERT INTO "Earn" (msats, "userId", created_at, type, "typeId", rank)
VALUES (earn_msats, user_id, created_at, type, type_id, rank);
-- give the user the sats
UPDATE users
SET msats = msats + earn_msats, "stackedMsats" = "stackedMsats" + earn_msats
WHERE id = user_id;
IF type = 'POST' OR type = 'COMMENT' THEN
PERFORM sats_after_tip(type_id, NULL, earn_msats);
END IF;
END;
$$ LANGUAGE plpgsql;