micrach/repositories/files_repository.go

92 lines
1.7 KiB
Go
Raw Permalink Normal View History

2021-09-01 18:40:13 +03:00
package repositories
import (
"context"
Db "micrach/db"
2021-09-01 23:00:37 +03:00
"github.com/jackc/pgtype"
2021-09-03 02:34:45 +03:00
"github.com/jackc/pgx/v4"
2021-09-01 18:40:13 +03:00
)
type FilesRepository struct{}
var Files FilesRepository
func (r *FilesRepository) Create(f File) error {
sql := `
INSERT INTO files (post_id, name, ext, size)
VALUES ($1, $2, $3, $4)
`
row := Db.Pool.QueryRow(
2021-09-01 18:40:13 +03:00
context.TODO(), sql, f.PostID, f.Name, f.Ext, f.Size,
)
err := row.Scan()
2021-09-03 02:34:45 +03:00
if err != nil && err != pgx.ErrNoRows {
return err
}
2021-09-01 18:40:13 +03:00
return nil
}
2021-09-01 23:00:37 +03:00
func (r *FilesRepository) GetByPostIDs(postIDs []int) (map[int][]File, error) {
sql := `
2021-09-11 16:05:31 +03:00
SELECT id, post_id, name, size, ext
2021-09-01 23:00:37 +03:00
FROM files
WHERE post_id = ANY ($1)
ORDER BY id ASC
`
ids := &pgtype.Int4Array{}
ids.Set(postIDs)
2021-09-08 18:50:33 +03:00
rows, err := Db.Pool.Query(context.TODO(), sql, ids)
2021-09-01 23:00:37 +03:00
if err != nil {
return nil, err
}
if rows.Err() != nil {
return nil, rows.Err()
}
filesMapByPostId := make(map[int][]File)
for rows.Next() {
var file File
2021-09-11 16:05:31 +03:00
err = rows.Scan(&file.ID, &file.PostID, &file.Name, &file.Size, &file.Ext)
2021-09-01 23:00:37 +03:00
if err != nil {
return nil, err
}
if filesMapByPostId[file.PostID] == nil {
filesMapByPostId[file.PostID] = []File{}
}
filesMapByPostId[file.PostID] = append(
filesMapByPostId[file.PostID],
file,
)
}
return filesMapByPostId, nil
}
2021-09-10 19:16:53 +03:00
2021-09-11 16:05:31 +03:00
func (r *FilesRepository) CreateInTx(tx pgx.Tx, f File) (int, error) {
2021-09-10 19:16:53 +03:00
sql := `
INSERT INTO files (post_id, name, ext, size)
VALUES ($1, $2, $3, $4)
2021-09-11 16:05:31 +03:00
RETURNING id
2021-09-10 19:16:53 +03:00
`
row := tx.QueryRow(
context.TODO(), sql, f.PostID, f.Name, f.Ext, f.Size,
)
2021-09-11 16:05:31 +03:00
createdFile := new(File)
err := row.Scan(&createdFile.ID)
2021-09-10 19:16:53 +03:00
if err != nil && err != pgx.ErrNoRows {
2021-09-11 16:05:31 +03:00
return 0, err
2021-09-10 19:16:53 +03:00
}
2021-09-11 16:05:31 +03:00
return createdFile.ID, nil
2021-09-10 19:16:53 +03:00
}