Files
phylum/server/internal/core/db/bookmarks.sql.go
2024-11-21 11:32:06 +05:30

112 lines
2.5 KiB
Go

// Code generated by sqlc. DO NOT EDIT.
// versions:
// sqlc v1.26.0
// source: bookmarks.sql
package db
import (
"context"
"github.com/google/uuid"
"github.com/jackc/pgx/v5/pgtype"
)
const addBookmark = `-- name: AddBookmark :one
INSERT INTO bookmarks(
username,
resource_id,
name
) VALUES (
$1::TEXT,
$2::UUID,
$3::TEXT
) ON CONFLICT(username, resource_id) DO UPDATE
SET
created = CASE WHEN bookmarks.deleted IS NULL THEN CURRENT_TIMESTAMP ELSE bookmarks.created END,
modified = CURRENT_TIMESTAMP,
deleted = NULL,
name = $3::TEXT
RETURNING username, resource_id, name, created, modified, deleted
`
type AddBookmarkParams struct {
Username string
ResourceID uuid.UUID
Name string
}
func (q *Queries) AddBookmark(ctx context.Context, arg AddBookmarkParams) (Bookmark, error) {
row := q.db.QueryRow(ctx, addBookmark, arg.Username, arg.ResourceID, arg.Name)
var i Bookmark
err := row.Scan(
&i.Username,
&i.ResourceID,
&i.Name,
&i.Created,
&i.Modified,
&i.Deleted,
)
return i, err
}
const deleteBookmarkByUsernameResourceID = `-- name: DeleteBookmarkByUsernameResourceID :one
DELETE FROM bookmarks WHERE username = $1::TEXT AND resource_id = $2::UUID
RETURNING username, resource_id, name, created, modified, deleted
`
type DeleteBookmarkByUsernameResourceIDParams struct {
Username string
ResourceID uuid.UUID
}
func (q *Queries) DeleteBookmarkByUsernameResourceID(ctx context.Context, arg DeleteBookmarkByUsernameResourceIDParams) (Bookmark, error) {
row := q.db.QueryRow(ctx, deleteBookmarkByUsernameResourceID, arg.Username, arg.ResourceID)
var i Bookmark
err := row.Scan(
&i.Username,
&i.ResourceID,
&i.Name,
&i.Created,
&i.Modified,
&i.Deleted,
)
return i, err
}
const listBookmarks = `-- name: ListBookmarks :many
SELECT username, resource_id, name, created, modified, deleted FROM bookmarks b WHERE username = $1::TEXT AND modified > $2::TIMESTAMP
`
type ListBookmarksParams struct {
Username string
Since pgtype.Timestamp
}
func (q *Queries) ListBookmarks(ctx context.Context, arg ListBookmarksParams) ([]Bookmark, error) {
rows, err := q.db.Query(ctx, listBookmarks, arg.Username, arg.Since)
if err != nil {
return nil, err
}
defer rows.Close()
var items []Bookmark
for rows.Next() {
var i Bookmark
if err := rows.Scan(
&i.Username,
&i.ResourceID,
&i.Name,
&i.Created,
&i.Modified,
&i.Deleted,
); err != nil {
return nil, err
}
items = append(items, i)
}
if err := rows.Err(); err != nil {
return nil, err
}
return items, nil
}