首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >CustomPouchError 409冲突文档更新冲突

CustomPouchError 409冲突文档更新冲突
EN

Stack Overflow用户
提问于 2016-11-09 01:59:05
回答 1查看 437关注 0票数 2

我不太擅长承诺(第一次使用它们)。在其他一些帮助下,我对代码进行了一些修改,但在readFileThenAttach()方法中的putAttachment()方法上仍然出现了409冲突错误。所以,我需要另一双眼睛来帮我看这个。我一直收到这个错误,然后我今天早上进来并再次尝试。它工作了两次(我没有得到错误)。我停止了程序,然后当我再次运行它时,我再次得到错误。我不知道出了什么问题。修改似乎还可以,所以我不确定是不是时间问题,或者我的代码中的承诺是什么。这段代码的执行路径从importProject()方法开始,然后从那里调用importInspectionPhotos()。有没有人可以看看他们是否能看到什么突出的东西?谢谢。

代码语言:javascript
复制
function buildReinspectionLinks(db: InspectionDb) {
    return db.allObservations()
        .then(([points, lines]) => {
            let observations = new Map([...points, ...lines]
                .filter(obs => (<any>obs).access_original)
                .map<[string, Observation]>(obs => [(<any>obs).access_id, obs]))
            let changed = new Set()
            for (let obs of observations.values()) {
                let doc = (<any>obs).access_original
                if (doc.Inspect_ID != doc.Original_ID) {
                    let reinspected = observations.get(doc.Original_ID)
                    doc.reinspected_id = reinspected._id
                    reinspected.reinspected = true
                    if (!reinspected.reinspection_ids) {
                        reinspected.reinspection_ids = []
                    }
                    reinspected.reinspection_ids.push(obs._id)
                    changed.add(obs)
                    changed.add(reinspected)
                }
            }
            // TODO: Recurse the relationships?
            return Promise.all([...changed].map(obs => db.post(obs)))
        })
}

function importInspectionPhotos(db: InspectionDb, directoryBase: string) {

const observations = db.allObservations().then(([points, lines]) => new Map([...points, ...lines].filter(obs => (<any>obs).access_original).map<[string, Observation]>(obs => [(<any>obs).access_id, obs])))
const filenames = globP("**/*.{jpg, jpeg, gif, png}", { cwd: directoryBase })

return Promise.all([observations, filenames]).then(([obs, names]: [Map<string, Observation>, string[]]) => {

    const fileObservations: FileObservation[] = names.map(file => {
        const filename = basename(file)
        const accessID = getAccessObservationId(filename)
        return {
            file,
            path: `${directoryBase}/${file}`,
            observation: obs.get(accessID)
        } as FileObservation
    }).filter((fileOb: FileObservation) => !!fileOb.observation)

    return fileObservations.reduce((lastPromise, fileOb) => lastPromise.then(() => readFileThenAttach(db, fileOb)), Promise.resolve())
  })
}

function getAccessObservationId(filename: string): string {

return filename.substr(0, filename.lastIndexOf('_'))
}

function readFileThenAttach(db: InspectionDb, fileOb: FileObservation): Promise<any> {

return readFileP(fileOb.path)
    .then((data: Buffer) => blobUtil.arrayBufferToBlob(data.buffer, contentType(extname(fileOb.path))))
    .then(blob => ({ content_type: blob.type, data: blob }) as PouchAttachment)
    .then(pa => db.putAttachment(fileOb.observation._id, (fileOb.observation as any)._rev, fileOb.filename, pa.data, pa.content_type))
    .then(update => ((fileOb.observation as any)._rev = update.rev))
}

function importData(filename: string, db: InspectionDb, table: string, importer: (db: InspectionDb, doc: any) => Promise<any>) {
return new Promise((resolve, reject) => {
    let trader = spawn(TraderPath, ['select', `-f="${filename}"`, `-t=${table}`])

    trader.stderr.on('data', reject)
    trader.on('error', reject)

    let outstream = []
    trader.stdout.on('data', data => outstream.push(data))

    var imports = []
    trader.on('close', code => {
        if (code > 0) reject('Trader returned non-zero exit code')
        safeLoadAll(''.concat(...outstream), (doc: any) => imports.push(importer(db, doc))) // safeLoadAll is synchronous
        Promise.all(imports).then(resolve)
    })
})
}

export function importProject(filename: string, project_id: string) {
let db: InspectionDb

return Promise.resolve()
    .then(() => {        
        db = new InspectionDb(project_id)

        return Promise.all([
            importData(filename, db, 'Project_Inspections', importInspection),
            importData(filename, db, 'Inspection', importObservation),
        ])
    })
    .then(() => buildReinspectionLinks(db))
    .then(() => importInspectionPhotos(db, join(dirname(filename), '../Inspection_Projects')))
}
EN

回答 1

Stack Overflow用户

发布于 2016-11-10 04:04:53

这个问题的解决方案最终变得非常简单和愚蠢。项目中的PouchDB类型是wrong...it,putAttachment()的rev和filename参数应该是先的,然后才是rev.更改这个类型就解决了这个问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40493550

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档