/* eslint-disable
    camelcase,
    no-return-assign,
*/
// TODO: This file was created by bulk-decaffeinate.
// Fix any style issues and re-enable lint.
/*
 * decaffeinate suggestions:
 * DS101: Remove unnecessary use of Array.from
 * DS102: Remove unnecessary code created because of implicit returns
 * DS207: Consider shorter variations of null checks
 * Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
 */
let SnapshotManager
const { db, ObjectId } = require('./mongodb')

module.exports = SnapshotManager = {
  recordSnapshot(
    project_id,
    doc_id,
    version,
    pathname,
    lines,
    ranges,
    callback
  ) {
    try {
      project_id = ObjectId(project_id)
      doc_id = ObjectId(doc_id)
    } catch (error) {
      return callback(error)
    }
    db.docSnapshots.insertOne(
      {
        project_id,
        doc_id,
        version,
        lines,
        pathname,
        ranges: SnapshotManager.jsonRangesToMongo(ranges),
        ts: new Date(),
      },
      callback
    )
  },
  // Suggested indexes:
  //   db.docSnapshots.createIndex({project_id:1, doc_id:1})
  //   db.docSnapshots.createIndex({ts:1},{expiresAfterSeconds: 30*24*3600)) # expires after 30 days

  jsonRangesToMongo(ranges) {
    if (ranges == null) {
      return null
    }

    const updateMetadata = function (metadata) {
      if ((metadata != null ? metadata.ts : undefined) != null) {
        metadata.ts = new Date(metadata.ts)
      }
      if ((metadata != null ? metadata.user_id : undefined) != null) {
        return (metadata.user_id = SnapshotManager._safeObjectId(
          metadata.user_id
        ))
      }
    }

    for (const change of Array.from(ranges.changes || [])) {
      change.id = SnapshotManager._safeObjectId(change.id)
      updateMetadata(change.metadata)
    }
    for (const comment of Array.from(ranges.comments || [])) {
      comment.id = SnapshotManager._safeObjectId(comment.id)
      if ((comment.op != null ? comment.op.t : undefined) != null) {
        comment.op.t = SnapshotManager._safeObjectId(comment.op.t)
      }
      updateMetadata(comment.metadata)
    }
    return ranges
  },

  _safeObjectId(data) {
    try {
      return ObjectId(data)
    } catch (error) {
      return data
    }
  },
}