// Code generated by sqlc. DO NOT EDIT. // versions: // sqlc v1.30.0 // source: reaction.sql package db import ( "context" "github.com/jackc/pgx/v5/pgtype" ) const addReaction = `-- name: AddReaction :one INSERT INTO comment_reaction (comment_id, workspace_id, actor_type, actor_id, emoji) VALUES ($1, $2, $3, $4, $5) ON CONFLICT (comment_id, actor_type, actor_id, emoji) DO UPDATE SET created_at = comment_reaction.created_at RETURNING id, comment_id, workspace_id, actor_type, actor_id, emoji, created_at ` type AddReactionParams struct { CommentID pgtype.UUID `json:"comment_id"` WorkspaceID pgtype.UUID `json:"workspace_id"` ActorType string `json:"actor_type"` ActorID pgtype.UUID `json:"actor_id"` Emoji string `json:"emoji"` } func (q *Queries) AddReaction(ctx context.Context, arg AddReactionParams) (CommentReaction, error) { row := q.db.QueryRow(ctx, addReaction, arg.CommentID, arg.WorkspaceID, arg.ActorType, arg.ActorID, arg.Emoji, ) var i CommentReaction err := row.Scan( &i.ID, &i.CommentID, &i.WorkspaceID, &i.ActorType, &i.ActorID, &i.Emoji, &i.CreatedAt, ) return i, err } const listReactionsByCommentIDs = `-- name: ListReactionsByCommentIDs :many SELECT id, comment_id, workspace_id, actor_type, actor_id, emoji, created_at FROM comment_reaction WHERE comment_id = ANY($1::uuid[]) ORDER BY created_at ASC ` func (q *Queries) ListReactionsByCommentIDs(ctx context.Context, dollar_1 []pgtype.UUID) ([]CommentReaction, error) { rows, err := q.db.Query(ctx, listReactionsByCommentIDs, dollar_1) if err != nil { return nil, err } defer rows.Close() items := []CommentReaction{} for rows.Next() { var i CommentReaction if err := rows.Scan( &i.ID, &i.CommentID, &i.WorkspaceID, &i.ActorType, &i.ActorID, &i.Emoji, &i.CreatedAt, ); err != nil { return nil, err } items = append(items, i) } if err := rows.Err(); err != nil { return nil, err } return items, nil } const removeReaction = `-- name: RemoveReaction :exec DELETE FROM comment_reaction WHERE comment_id = $1 AND actor_type = $2 AND actor_id = $3 AND emoji = $4 ` type RemoveReactionParams struct { CommentID pgtype.UUID `json:"comment_id"` ActorType string `json:"actor_type"` ActorID pgtype.UUID `json:"actor_id"` Emoji string `json:"emoji"` } func (q *Queries) RemoveReaction(ctx context.Context, arg RemoveReactionParams) error { _, err := q.db.Exec(ctx, removeReaction, arg.CommentID, arg.ActorType, arg.ActorID, arg.Emoji, ) return err }