UNPKG

bajo-db-knex

Version:

Bajo DB Knex/SQL driver for Bajo Framework

30 lines (28 loc) 1.48 kB
async function common ({ handler, schema, filter, options = {} }) { const { importPkg, error } = this.bajo.helper const { getInfo, prepPagination } = this.bajoDb.helper const { instance } = getInfo(schema) const mongoKnex = await importPkg('bajoDb:@tryghost/mongo-knex') const { limit, skip, sort, page } = await prepPagination(filter, schema, { allowSortUnindexed: true }) let cursor = instance.client(schema.collName) const [field] = options.fields ?? [] if (!field) throw error('Base field for histogram must be provided') const prop = schema.properties.find(p => p.name === field) if (!prop) throw error('Unknown base field for histogram \'%s\'', field) if (!['datetime', 'date'].includes(prop.type)) throw error('Field type \'%s@%s\' must be a datetime field', field, schema.name) const aggregate = options.aggregate ?? 'count' const group = aggregate === 'count' ? '*' : options.group if (filter.query) cursor = mongoKnex(cursor, filter.query) if (!options.noLimit) cursor.limit(limit, { skipBinding: true }).offset(skip) if (sort) { // const f = Object.keys(sort)[0] // let d = sort[f] // d = d <= 0 ? 'desc' : 'asc' // cursor.orderBy(f, d) } const item = cursor.toSQL().toNative() await handler.call(this, { field, item, schema, aggregate, group }) const result = await instance.client.raw(item.sql, item.bindings) return { data: result[0], page, limit } } export default common