2021-09-20 19:24:09 +02:00
|
|
|
const PouchDB = require("pouchdb")
|
|
|
|
const memory = require("pouchdb-adapter-memory")
|
2021-09-21 16:59:50 +02:00
|
|
|
const newid = require("./newid")
|
2021-09-20 19:24:09 +02:00
|
|
|
|
|
|
|
PouchDB.plugin(memory)
|
|
|
|
const Pouch = PouchDB.defaults({
|
|
|
|
prefix: undefined,
|
|
|
|
adapter: "memory",
|
|
|
|
})
|
|
|
|
|
2021-09-21 16:59:50 +02:00
|
|
|
exports.runView = async (view, calculation, group, data) => {
|
|
|
|
// 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())
|
2021-09-20 20:21:04 +02:00
|
|
|
// write all the docs to the in memory Pouch (remove revs)
|
|
|
|
await db.bulkDocs(
|
|
|
|
data.map(row => ({
|
|
|
|
...row,
|
|
|
|
_rev: undefined,
|
|
|
|
}))
|
|
|
|
)
|
2021-09-21 16:59:50 +02:00
|
|
|
let fn = (doc, emit) => emit(doc._id)
|
|
|
|
eval("fn = " + view.map.replace("function (doc)", "function (doc, emit)"))
|
|
|
|
const queryFns = {
|
|
|
|
meta: view.meta,
|
|
|
|
map: fn,
|
|
|
|
}
|
|
|
|
if (view.reduce) {
|
|
|
|
queryFns.reduce = view.reduce
|
|
|
|
}
|
|
|
|
const response = await db.query(queryFns, {
|
2021-09-20 19:24:09 +02:00
|
|
|
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
|
|
|
|
}
|
|
|
|
}
|
|
|
|
await db.destroy()
|
|
|
|
return response
|
|
|
|
}
|