mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-24 07:13:53 +00:00
b69cc6ce77
Log Errors in fetchV1Data GitOrigin-RevId: 4b709430c2ad97ca369e93eaa4c4edf5ad7f3f52
33 lines
1.2 KiB
CoffeeScript
33 lines
1.2 KiB
CoffeeScript
mongoose = require 'mongoose'
|
|
Schema = mongoose.Schema
|
|
ObjectId = Schema.ObjectId
|
|
settings = require 'settings-sharelatex'
|
|
logger = require 'logger-sharelatex'
|
|
request = require 'request'
|
|
|
|
InstitutionSchema = new Schema
|
|
v1Id: { type: Number, required: true }
|
|
managerIds: [ type:ObjectId, ref:'User' ]
|
|
|
|
# fetch institution's data from v1 API. Errors are ignored
|
|
InstitutionSchema.method 'fetchV1Data', (callback = (error, institution)->) ->
|
|
url = "#{settings.apis.v1.url}/universities/list/#{this.v1Id}"
|
|
request.get url, (error, response, body) =>
|
|
try
|
|
parsedBody = JSON.parse(body)
|
|
catch error # log error and carry on without v1 data
|
|
logger.err { model: 'Institution', v1Id: this.v1Id, error }, '[fetchV1DataError]'
|
|
this.name = parsedBody?.name
|
|
this.countryCode = parsedBody?.country_code
|
|
this.departments = parsedBody?.departments
|
|
this.portalSlug = parsedBody?.portal_slug
|
|
callback(null, this)
|
|
|
|
conn = mongoose.createConnection(settings.mongo.url, {
|
|
server: {poolSize: settings.mongo.poolSize || 10},
|
|
config: {autoIndex: false}
|
|
})
|
|
|
|
Institution = conn.model 'Institution', InstitutionSchema
|
|
exports.Institution = Institution
|
|
exports.InstitutionSchema = InstitutionSchema
|