2019-02-09 12:30:49 +00:00
|
|
|
package models
|
|
|
|
|
|
|
|
import (
|
|
|
|
"database/sql"
|
2019-08-14 21:40:51 +00:00
|
|
|
|
2019-02-09 12:30:49 +00:00
|
|
|
"github.com/jmoiron/sqlx"
|
2019-02-14 23:42:52 +00:00
|
|
|
"github.com/stashapp/stash/pkg/database"
|
2019-02-09 12:30:49 +00:00
|
|
|
)
|
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
type StudioQueryBuilder struct{}
|
2019-02-09 12:30:49 +00:00
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
func NewStudioQueryBuilder() StudioQueryBuilder {
|
|
|
|
return StudioQueryBuilder{}
|
2019-02-09 12:30:49 +00:00
|
|
|
}
|
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
func (qb *StudioQueryBuilder) Create(newStudio Studio, tx *sqlx.Tx) (*Studio, error) {
|
2019-02-09 12:30:49 +00:00
|
|
|
ensureTx(tx)
|
|
|
|
result, err := tx.NamedExec(
|
|
|
|
`INSERT INTO studios (image, checksum, name, url, created_at, updated_at)
|
|
|
|
VALUES (:image, :checksum, :name, :url, :created_at, :updated_at)
|
|
|
|
`,
|
|
|
|
newStudio,
|
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
studioID, err := result.LastInsertId()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := tx.Get(&newStudio, `SELECT * FROM studios WHERE id = ? LIMIT 1`, studioID); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &newStudio, nil
|
|
|
|
}
|
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
func (qb *StudioQueryBuilder) Update(updatedStudio Studio, tx *sqlx.Tx) (*Studio, error) {
|
2019-02-09 12:30:49 +00:00
|
|
|
ensureTx(tx)
|
|
|
|
_, err := tx.NamedExec(
|
2019-02-14 22:53:32 +00:00
|
|
|
`UPDATE studios SET `+SQLGenKeys(updatedStudio)+` WHERE studios.id = :id`,
|
2019-02-09 12:30:49 +00:00
|
|
|
updatedStudio,
|
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := tx.Get(&updatedStudio, `SELECT * FROM studios WHERE id = ? LIMIT 1`, updatedStudio.ID); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &updatedStudio, nil
|
|
|
|
}
|
|
|
|
|
2019-08-14 21:40:51 +00:00
|
|
|
func (qb *StudioQueryBuilder) Destroy(id string, tx *sqlx.Tx) error {
|
|
|
|
// remove studio from scenes
|
|
|
|
_, err := tx.Exec("UPDATE scenes SET studio_id = null WHERE studio_id = ?", id)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// remove studio from scraped items
|
|
|
|
_, err = tx.Exec("UPDATE scraped_items SET studio_id = null WHERE studio_id = ?", id)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return executeDeleteQuery("studios", id, tx)
|
|
|
|
}
|
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
func (qb *StudioQueryBuilder) Find(id int, tx *sqlx.Tx) (*Studio, error) {
|
2019-02-09 12:30:49 +00:00
|
|
|
query := "SELECT * FROM studios WHERE id = ? LIMIT 1"
|
|
|
|
args := []interface{}{id}
|
|
|
|
return qb.queryStudio(query, args, tx)
|
|
|
|
}
|
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
func (qb *StudioQueryBuilder) FindBySceneID(sceneID int) (*Studio, error) {
|
2019-02-09 12:30:49 +00:00
|
|
|
query := "SELECT studios.* FROM studios JOIN scenes ON studios.id = scenes.studio_id WHERE scenes.id = ? LIMIT 1"
|
|
|
|
args := []interface{}{sceneID}
|
|
|
|
return qb.queryStudio(query, args, nil)
|
|
|
|
}
|
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
func (qb *StudioQueryBuilder) FindByName(name string, tx *sqlx.Tx) (*Studio, error) {
|
2019-02-09 12:30:49 +00:00
|
|
|
query := "SELECT * FROM studios WHERE name = ? LIMIT 1"
|
|
|
|
args := []interface{}{name}
|
|
|
|
return qb.queryStudio(query, args, tx)
|
|
|
|
}
|
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
func (qb *StudioQueryBuilder) Count() (int, error) {
|
2019-02-11 20:36:10 +00:00
|
|
|
return runCountQuery(buildCountQuery("SELECT studios.id FROM studios"), nil)
|
|
|
|
}
|
|
|
|
|
2019-05-27 19:34:26 +00:00
|
|
|
func (qb *StudioQueryBuilder) All() ([]*Studio, error) {
|
2019-02-14 22:53:32 +00:00
|
|
|
return qb.queryStudios(selectAll("studios")+qb.getStudioSort(nil), nil, nil)
|
2019-02-09 12:30:49 +00:00
|
|
|
}
|
|
|
|
|
2019-05-27 19:34:26 +00:00
|
|
|
func (qb *StudioQueryBuilder) Query(findFilter *FindFilterType) ([]*Studio, int) {
|
2019-02-09 12:30:49 +00:00
|
|
|
if findFilter == nil {
|
|
|
|
findFilter = &FindFilterType{}
|
|
|
|
}
|
|
|
|
|
2019-05-27 19:34:26 +00:00
|
|
|
var whereClauses []string
|
|
|
|
var havingClauses []string
|
|
|
|
var args []interface{}
|
2019-02-09 12:30:49 +00:00
|
|
|
body := selectDistinctIDs("studios")
|
2019-05-30 22:59:29 +00:00
|
|
|
body += `
|
2019-08-15 01:30:32 +00:00
|
|
|
left join scenes on studios.id = scenes.studio_id
|
2019-05-30 22:59:29 +00:00
|
|
|
`
|
2019-02-09 12:30:49 +00:00
|
|
|
|
|
|
|
if q := findFilter.Q; q != nil && *q != "" {
|
|
|
|
searchColumns := []string{"studios.name"}
|
|
|
|
whereClauses = append(whereClauses, getSearch(searchColumns, *q))
|
|
|
|
}
|
|
|
|
|
|
|
|
sortAndPagination := qb.getStudioSort(findFilter) + getPagination(findFilter)
|
|
|
|
idsResult, countResult := executeFindQuery("studios", body, args, sortAndPagination, whereClauses, havingClauses)
|
|
|
|
|
2019-05-27 19:34:26 +00:00
|
|
|
var studios []*Studio
|
2019-02-09 12:30:49 +00:00
|
|
|
for _, id := range idsResult {
|
|
|
|
studio, _ := qb.Find(id, nil)
|
2019-05-27 19:34:26 +00:00
|
|
|
studios = append(studios, studio)
|
2019-02-09 12:30:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return studios, countResult
|
|
|
|
}
|
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
func (qb *StudioQueryBuilder) getStudioSort(findFilter *FindFilterType) string {
|
2019-02-09 12:30:49 +00:00
|
|
|
var sort string
|
|
|
|
var direction string
|
|
|
|
if findFilter == nil {
|
|
|
|
sort = "name"
|
|
|
|
direction = "ASC"
|
|
|
|
} else {
|
|
|
|
sort = findFilter.GetSort("name")
|
|
|
|
direction = findFilter.GetDirection()
|
|
|
|
}
|
|
|
|
return getSort(sort, direction, "studios")
|
|
|
|
}
|
|
|
|
|
2019-02-14 22:53:32 +00:00
|
|
|
func (qb *StudioQueryBuilder) queryStudio(query string, args []interface{}, tx *sqlx.Tx) (*Studio, error) {
|
2019-02-09 12:30:49 +00:00
|
|
|
results, err := qb.queryStudios(query, args, tx)
|
|
|
|
if err != nil || len(results) < 1 {
|
|
|
|
return nil, err
|
|
|
|
}
|
2019-05-27 19:34:26 +00:00
|
|
|
return results[0], nil
|
2019-02-09 12:30:49 +00:00
|
|
|
}
|
|
|
|
|
2019-05-27 19:34:26 +00:00
|
|
|
func (qb *StudioQueryBuilder) queryStudios(query string, args []interface{}, tx *sqlx.Tx) ([]*Studio, error) {
|
2019-02-09 12:30:49 +00:00
|
|
|
var rows *sqlx.Rows
|
|
|
|
var err error
|
|
|
|
if tx != nil {
|
|
|
|
rows, err = tx.Queryx(query, args...)
|
|
|
|
} else {
|
|
|
|
rows, err = database.DB.Queryx(query, args...)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err != nil && err != sql.ErrNoRows {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
defer rows.Close()
|
|
|
|
|
2019-05-27 19:34:26 +00:00
|
|
|
studios := make([]*Studio, 0)
|
2019-02-09 12:30:49 +00:00
|
|
|
for rows.Next() {
|
2019-05-27 19:34:26 +00:00
|
|
|
studio := Studio{}
|
2019-02-09 12:30:49 +00:00
|
|
|
if err := rows.StructScan(&studio); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2019-05-27 19:34:26 +00:00
|
|
|
studios = append(studios, &studio)
|
2019-02-09 12:30:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := rows.Err(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return studios, nil
|
2019-02-14 22:53:32 +00:00
|
|
|
}
|