2017-05-10 10:31:17 -04:00
|
|
|
mongoose = require('mongoose')
|
2014-02-12 05:23:40 -05:00
|
|
|
Settings = require 'settings-sharelatex'
|
|
|
|
_ = require('underscore')
|
|
|
|
FolderSchema = require('./Folder.js').FolderSchema
|
|
|
|
logger = require('logger-sharelatex')
|
2014-03-31 11:46:28 -04:00
|
|
|
sanitize = require('sanitizer')
|
2014-02-12 05:23:40 -05:00
|
|
|
concreteObjectId = require('mongoose').Types.ObjectId
|
2016-03-23 11:14:49 -04:00
|
|
|
Errors = require "../Features/Errors/Errors"
|
2014-02-12 05:23:40 -05:00
|
|
|
|
|
|
|
Schema = mongoose.Schema
|
|
|
|
ObjectId = Schema.ObjectId
|
|
|
|
|
2014-04-30 06:15:29 -04:00
|
|
|
DeletedDocSchema = new Schema
|
|
|
|
name: String
|
|
|
|
|
2014-02-12 05:23:40 -05:00
|
|
|
ProjectSchema = new Schema
|
|
|
|
name : {type:String, default:'new project'}
|
|
|
|
lastUpdated : {type:Date, default: () -> new Date()}
|
2017-08-21 11:49:08 -04:00
|
|
|
lastOpened : {type:Date}
|
|
|
|
active : { type: Boolean, default: true }
|
2014-02-12 05:23:40 -05:00
|
|
|
owner_ref : {type:ObjectId, ref:'User'}
|
|
|
|
collaberator_refs : [ type:ObjectId, ref:'User' ]
|
|
|
|
readOnly_refs : [ type:ObjectId, ref:'User' ]
|
|
|
|
rootDoc_id : {type: ObjectId}
|
|
|
|
rootFolder : [FolderSchema]
|
|
|
|
publicAccesLevel : {type: String, default: 'private'}
|
2017-08-21 11:49:08 -04:00
|
|
|
compiler : {type:String, default:'pdflatex'}
|
2014-02-12 05:23:40 -05:00
|
|
|
spellCheckLanguage : {type:String, default:'en'}
|
|
|
|
deletedByExternalDataSource : {type: Boolean, default: false}
|
|
|
|
description : {type:String, default:''}
|
2014-04-28 07:53:43 -04:00
|
|
|
archived : { type: Boolean }
|
2014-04-30 06:15:29 -04:00
|
|
|
deletedDocs : [DeletedDocSchema]
|
2016-01-14 11:35:42 -05:00
|
|
|
imageName : { type: String }
|
2017-06-21 08:40:28 -04:00
|
|
|
track_changes : { type: Object }
|
2017-09-18 05:27:28 -04:00
|
|
|
tokens :
|
2017-11-21 05:33:02 -05:00
|
|
|
readOnly : {
|
|
|
|
type: String,
|
|
|
|
index: {
|
|
|
|
unique: true,
|
|
|
|
partialFilterExpression: {'tokens.readOnly': {$exists: true}}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
readAndWrite : {
|
|
|
|
type: String,
|
|
|
|
index: {
|
|
|
|
unique: true,
|
|
|
|
partialFilterExpression: {'tokens.readAndWrite': {$exists: true}}
|
|
|
|
}
|
|
|
|
}
|
2017-09-19 04:27:22 -04:00
|
|
|
tokenAccessReadOnly_refs : [ type:ObjectId, ref:'User' ]
|
|
|
|
tokenAccessReadAndWrite_refs : [ type:ObjectId, ref:'User' ]
|
2017-08-21 11:49:08 -04:00
|
|
|
overleaf :
|
|
|
|
id : { type: Number }
|
2017-08-29 09:21:05 -04:00
|
|
|
imported_at_ver_id : { type: Number }
|
2017-09-05 04:50:39 -04:00
|
|
|
token : { type: String }
|
|
|
|
read_token : { type: String }
|
2017-10-27 10:24:18 -04:00
|
|
|
history :
|
|
|
|
id : { type: Number }
|
2014-02-12 05:23:40 -05:00
|
|
|
|
|
|
|
ProjectSchema.statics.getProject = (project_or_id, fields, callback)->
|
|
|
|
if project_or_id._id?
|
|
|
|
callback null, project_or_id
|
|
|
|
else
|
|
|
|
try
|
|
|
|
concreteObjectId(project_or_id.toString())
|
|
|
|
catch e
|
|
|
|
return callback(new Errors.NotFoundError(e.message))
|
|
|
|
this.findById project_or_id, fields, callback
|
|
|
|
|
|
|
|
applyToAllFilesRecursivly = ProjectSchema.statics.applyToAllFilesRecursivly = (folder, fun)->
|
|
|
|
_.each folder.fileRefs, (file)->
|
|
|
|
fun(file)
|
|
|
|
_.each folder.folders, (folder)->
|
|
|
|
applyToAllFilesRecursivly(folder, fun)
|
|
|
|
|
|
|
|
|
|
|
|
ProjectSchema.methods.getSafeProjectName = ->
|
|
|
|
safeProjectName = this.name.replace(new RegExp("\\W", "g"), '_')
|
2014-03-31 11:46:28 -04:00
|
|
|
return sanitize.escape(safeProjectName)
|
2014-02-12 05:23:40 -05:00
|
|
|
|
|
|
|
conn = mongoose.createConnection(Settings.mongo.url, server: poolSize: Settings.mongo.poolSize || 10)
|
|
|
|
|
|
|
|
Project = conn.model('Project', ProjectSchema)
|
|
|
|
|
|
|
|
mongoose.model 'Project', ProjectSchema
|
|
|
|
exports.Project = Project
|
|
|
|
exports.ProjectSchema = ProjectSchema
|