56 lines
1.5 KiB
TypeScript
56 lines
1.5 KiB
TypeScript
import newid from "./newid"
|
|
import { Row, View, Document } from "@budibase/types"
|
|
|
|
// bypass the main application db config
|
|
// use in memory pouchdb directly
|
|
import { db as dbCore } from "@budibase/backend-core"
|
|
const Pouch = dbCore.getPouch({ inMemory: true })
|
|
|
|
export async function runView(
|
|
view: View,
|
|
calculation: string,
|
|
group: boolean,
|
|
data: Row[]
|
|
) {
|
|
// use a different ID each time for the DB, make sure they
|
|
// are always unique for each query, don't want overlap
|
|
// which could cause 409s
|
|
const db = new Pouch(newid())
|
|
try {
|
|
// write all the docs to the in memory Pouch (remove revs)
|
|
await db.bulkDocs(
|
|
data.map(row => ({
|
|
...row,
|
|
_rev: undefined,
|
|
}))
|
|
)
|
|
let fn = (doc: Document, emit: any) => emit(doc._id)
|
|
eval("fn = " + view?.map?.replace("function (doc)", "function (doc, emit)"))
|
|
const queryFns: any = {
|
|
meta: view.meta,
|
|
map: fn,
|
|
}
|
|
if (view.reduce) {
|
|
queryFns.reduce = view.reduce
|
|
}
|
|
const response: { rows: Row[] } = await db.query(queryFns, {
|
|
include_docs: !calculation,
|
|
group: !!group,
|
|
})
|
|
// need to fix the revs to be totally accurate
|
|
for (let row of response.rows) {
|
|
if (!row._rev || !row._id) {
|
|
continue
|
|
}
|
|
const found = data.find(possible => possible._id === row._id)
|
|
if (found) {
|
|
row._rev = found._rev
|
|
}
|
|
}
|
|
return response
|
|
} finally {
|
|
await db.destroy()
|
|
await dbCore.closePouchDB(db)
|
|
}
|
|
}
|