// Code generated by sqlc. DO NOT EDIT. // versions: // sqlc v1.30.0 // source: user.sql package db import ( "context" "github.com/jackc/pgx/v5/pgtype" ) const createUser = `-- name: CreateUser :one INSERT INTO "user" (name, email, avatar_url) VALUES ($1, $2, $3) RETURNING id, name, email, avatar_url, created_at, updated_at ` type CreateUserParams struct { Name string `json:"name"` Email string `json:"email"` AvatarUrl pgtype.Text `json:"avatar_url"` } func (q *Queries) CreateUser(ctx context.Context, arg CreateUserParams) (User, error) { row := q.db.QueryRow(ctx, createUser, arg.Name, arg.Email, arg.AvatarUrl) var i User err := row.Scan( &i.ID, &i.Name, &i.Email, &i.AvatarUrl, &i.CreatedAt, &i.UpdatedAt, ) return i, err } const getUser = `-- name: GetUser :one SELECT id, name, email, avatar_url, created_at, updated_at FROM "user" WHERE id = $1 ` func (q *Queries) GetUser(ctx context.Context, id pgtype.UUID) (User, error) { row := q.db.QueryRow(ctx, getUser, id) var i User err := row.Scan( &i.ID, &i.Name, &i.Email, &i.AvatarUrl, &i.CreatedAt, &i.UpdatedAt, ) return i, err } const getUserByEmail = `-- name: GetUserByEmail :one SELECT id, name, email, avatar_url, created_at, updated_at FROM "user" WHERE email = $1 ` func (q *Queries) GetUserByEmail(ctx context.Context, email string) (User, error) { row := q.db.QueryRow(ctx, getUserByEmail, email) var i User err := row.Scan( &i.ID, &i.Name, &i.Email, &i.AvatarUrl, &i.CreatedAt, &i.UpdatedAt, ) return i, err } const updateUser = `-- name: UpdateUser :one UPDATE "user" SET name = COALESCE($2, name), avatar_url = COALESCE($3, avatar_url), updated_at = now() WHERE id = $1 RETURNING id, name, email, avatar_url, created_at, updated_at ` type UpdateUserParams struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` AvatarUrl pgtype.Text `json:"avatar_url"` } func (q *Queries) UpdateUser(ctx context.Context, arg UpdateUserParams) (User, error) { row := q.db.QueryRow(ctx, updateUser, arg.ID, arg.Name, arg.AvatarUrl) var i User err := row.Scan( &i.ID, &i.Name, &i.Email, &i.AvatarUrl, &i.CreatedAt, &i.UpdatedAt, ) return i, err }