2021-06-10 07:43:55 -05:00
|
|
|
import { QueryTypes, Sequelize, Transaction } from 'sequelize'
|
|
|
|
|
2021-06-10 09:57:13 -05:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* Abstact builder to run video SQL queries
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2021-06-10 07:43:55 -05:00
|
|
|
export class AbstractVideosQueryBuilder {
|
|
|
|
protected sequelize: Sequelize
|
|
|
|
|
|
|
|
protected query: string
|
|
|
|
protected replacements: any = {}
|
|
|
|
|
2021-06-11 07:09:33 -05:00
|
|
|
protected runQuery (options: { transaction?: Transaction, logging?: boolean } = {}) {
|
|
|
|
const queryOptions = {
|
|
|
|
transaction: options.transaction,
|
|
|
|
logging: options.logging,
|
2021-06-10 07:43:55 -05:00
|
|
|
replacements: this.replacements,
|
|
|
|
type: QueryTypes.SELECT as QueryTypes.SELECT,
|
2021-06-11 03:59:27 -05:00
|
|
|
next: false
|
2021-06-10 07:43:55 -05:00
|
|
|
}
|
|
|
|
|
2021-06-11 07:09:33 -05:00
|
|
|
return this.sequelize.query<any>(this.query, queryOptions)
|
2021-06-10 07:43:55 -05:00
|
|
|
}
|
|
|
|
}
|