fix for overloaded pgpsql function

This commit is contained in:
keyan 2021-09-09 10:46:20 -05:00
parent 93428e3183
commit f23da4397f
4 changed files with 16 additions and 6 deletions

View File

@ -352,9 +352,11 @@ const createItem = async (parent, { title, url, text, parentId }, { me, models }
throw new AuthenticationError('you must be logged in')
}
console.log(me)
const [item] = await serialize(models, models.$queryRaw(
`${SELECT} FROM create_item($1, $2, $3, $4, $5) AS "Item"`,
title, url, text, Number(parentId), me.id))
title, url, text, Number(parentId), Number(me.id)))
await createMentions(item, models)

View File

@ -9,6 +9,12 @@ export default gql`
pageTitle(url: String!): String
}
enum ItemAct {
VOTE
BOOST
TIP
}
extend type Mutation {
createLink(title: String!, url: String): Item!
updateLink(id: ID!, title: String!, url: String): Item!
@ -16,7 +22,7 @@ export default gql`
updateDiscussion(id: ID!, title: String!, text: String): Item!
createComment(text: String!, parentId: ID!): Item!
updateComment(id: ID!, text: String!): Item!
act(id: ID!, act: String!, sats: Int): Int!
act(id: ID!, act: ItemAct!, sats: Int): Int!
}
type Items {

View File

@ -12,7 +12,7 @@ export default function UpVote ({ itemId, meSats, className }) {
const [act] = useMutation(
gql`
mutation act($id: ID!, $sats: Int!) {
act(id: $id, act: 'VOTE', sats: $sats)
act(id: $id, act: VOTE, sats: $sats)
}`, {
update (cache, { data: { act } }) {
// read in the cached object so we don't use meSats prop

View File

@ -90,7 +90,9 @@ BEGIN
END;
$$;
-- if user has free comments or posts, use that
-- make sure we nuke the old versions
DROP FUNCTION create_item(text,text,text,integer,text);
CREATE OR REPLACE FUNCTION create_item(title TEXT, url TEXT, text TEXT, parent_id INTEGER, user_id INTEGER)
RETURNS "Item"
LANGUAGE plpgsql
@ -104,7 +106,7 @@ DECLARE
BEGIN
PERFORM ASSERT_SERIALIZED();
SELECT (msats / 1000), "freePosts", "freeComments"
SELECT (msats / 1000), id, "freePosts", "freeComments"
INTO user_sats, free_posts, free_comments
FROM users WHERE id = user_id;