mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
Merge pull request #10 from sharelatex/hof-history-apis
Add User and Project endpoints by overleaf ids
This commit is contained in:
commit
a9b18e4435
4 changed files with 78 additions and 22 deletions
|
@ -9,7 +9,7 @@ Errors = require("../Errors/Errors")
|
||||||
|
|
||||||
module.exports = ProjectDetailsHandler =
|
module.exports = ProjectDetailsHandler =
|
||||||
getDetails: (project_id, callback)->
|
getDetails: (project_id, callback)->
|
||||||
ProjectGetter.getProject project_id, {name:true, description:true, compiler:true, features:true, owner_ref:true}, (err, project)->
|
ProjectGetter.getProject project_id, {name:true, description:true, compiler:true, features:true, owner_ref:true, overleaf:true}, (err, project)->
|
||||||
if err?
|
if err?
|
||||||
logger.err err:err, project_id:project_id, "error getting project"
|
logger.err err:err, project_id:project_id, "error getting project"
|
||||||
return callback(err)
|
return callback(err)
|
||||||
|
@ -21,7 +21,11 @@ module.exports = ProjectDetailsHandler =
|
||||||
description: project.description
|
description: project.description
|
||||||
compiler: project.compiler
|
compiler: project.compiler
|
||||||
features: user.features
|
features: user.features
|
||||||
logger.log project_id:project_id, details:details, "getting project details"
|
|
||||||
|
if project.overleaf?
|
||||||
|
details.overleaf = project.overleaf
|
||||||
|
|
||||||
|
logger.log project_id:project_id, details: details, "getting project details"
|
||||||
callback(err, details)
|
callback(err, details)
|
||||||
|
|
||||||
getProjectDescription: (project_id, callback)->
|
getProjectDescription: (project_id, callback)->
|
||||||
|
|
|
@ -4,6 +4,7 @@ UserDeleter = require("./UserDeleter")
|
||||||
UserUpdater = require("./UserUpdater")
|
UserUpdater = require("./UserUpdater")
|
||||||
sanitize = require('sanitizer')
|
sanitize = require('sanitizer')
|
||||||
AuthenticationController = require('../Authentication/AuthenticationController')
|
AuthenticationController = require('../Authentication/AuthenticationController')
|
||||||
|
ObjectId = require("mongojs").ObjectId
|
||||||
|
|
||||||
module.exports = UserController =
|
module.exports = UserController =
|
||||||
getLoggedInUsersPersonalInfo: (req, res, next = (error) ->) ->
|
getLoggedInUsersPersonalInfo: (req, res, next = (error) ->) ->
|
||||||
|
@ -19,8 +20,17 @@ module.exports = UserController =
|
||||||
UserController.sendFormattedPersonalInfo(user, res, next)
|
UserController.sendFormattedPersonalInfo(user, res, next)
|
||||||
|
|
||||||
getPersonalInfo: (req, res, next = (error) ->) ->
|
getPersonalInfo: (req, res, next = (error) ->) ->
|
||||||
UserGetter.getUser req.params.user_id, { _id: true, first_name: true, last_name: true, email: true}, (error, user) ->
|
{user_id} = req.params
|
||||||
logger.log user_id: req.params.user_id, "reciving request for getting users personal info"
|
|
||||||
|
if user_id.match(/^\d+$/)
|
||||||
|
query = { "overleaf.id": parseInt(user_id, 10) }
|
||||||
|
else if user_id.match(/^[a-f0-9]{24}$/)
|
||||||
|
query = { _id: ObjectId(user_id) }
|
||||||
|
else
|
||||||
|
return res.send(400)
|
||||||
|
|
||||||
|
UserGetter.getUser query, { _id: true, first_name: true, last_name: true, email: true}, (error, user) ->
|
||||||
|
logger.log user_id: req.params.user_id, "receiving request for getting users personal info"
|
||||||
return next(error) if error?
|
return next(error) if error?
|
||||||
return res.send(404) if !user?
|
return res.send(404) if !user?
|
||||||
UserController.sendFormattedPersonalInfo(user, res, next)
|
UserController.sendFormattedPersonalInfo(user, res, next)
|
||||||
|
|
|
@ -50,6 +50,13 @@ describe 'ProjectDetailsHandler', ->
|
||||||
assert.equal(details.something, undefined)
|
assert.equal(details.something, undefined)
|
||||||
done()
|
done()
|
||||||
|
|
||||||
|
it "should find overleaf metadata if it exists", (done)->
|
||||||
|
@project.overleaf = { id: 'id' }
|
||||||
|
@handler.getDetails @project_id, (err, details)=>
|
||||||
|
details.overleaf.should.equal @project.overleaf
|
||||||
|
assert.equal(details.something, undefined)
|
||||||
|
done()
|
||||||
|
|
||||||
it "should return an error for a non-existent project", (done)->
|
it "should return an error for a non-existent project", (done)->
|
||||||
@ProjectGetter.getProject.callsArg(2, null, null)
|
@ProjectGetter.getProject.callsArg(2, null, null)
|
||||||
err = new Errors.NotFoundError("project not found")
|
err = new Errors.NotFoundError("project not found")
|
||||||
|
|
|
@ -50,23 +50,47 @@ describe "UserInfoController", ->
|
||||||
.should.equal true
|
.should.equal true
|
||||||
|
|
||||||
describe "getPersonalInfo", ->
|
describe "getPersonalInfo", ->
|
||||||
|
describe "when the user exists with sharelatex id", ->
|
||||||
beforeEach ->
|
beforeEach ->
|
||||||
@user_id = ObjectId().toString()
|
@user_id = ObjectId().toString()
|
||||||
@user =
|
@user =
|
||||||
_id: ObjectId(@user_id)
|
_id: ObjectId(@user_id)
|
||||||
@req.params = user_id: @user_id
|
@req.params = user_id: @user_id
|
||||||
|
|
||||||
describe "when the user exists", ->
|
|
||||||
beforeEach ->
|
|
||||||
@UserGetter.getUser = sinon.stub().callsArgWith(2, null, @user)
|
@UserGetter.getUser = sinon.stub().callsArgWith(2, null, @user)
|
||||||
@UserInfoController.sendFormattedPersonalInfo = sinon.stub()
|
@UserInfoController.sendFormattedPersonalInfo = sinon.stub()
|
||||||
@UserInfoController.getPersonalInfo(@req, @res, @next)
|
@UserInfoController.getPersonalInfo(@req, @res, @next)
|
||||||
|
|
||||||
it "should look up the user in the database", ->
|
it "should look up the user in the database", ->
|
||||||
@UserGetter.getUser
|
@UserGetter.getUser
|
||||||
.calledWith(@user_id, { _id: true, first_name: true, last_name: true, email: true })
|
.calledWith(
|
||||||
|
{ _id: ObjectId(@user_id) },
|
||||||
|
{ _id: true, first_name: true, last_name: true, email: true }
|
||||||
|
).should.equal true
|
||||||
|
|
||||||
|
it "should send the formatted details back to the client", ->
|
||||||
|
@UserInfoController.sendFormattedPersonalInfo
|
||||||
|
.calledWith(@user, @res, @next)
|
||||||
.should.equal true
|
.should.equal true
|
||||||
|
|
||||||
|
describe "when the user exists with overleaf id", ->
|
||||||
|
beforeEach ->
|
||||||
|
@user_id = 12345
|
||||||
|
@user =
|
||||||
|
_id: ObjectId()
|
||||||
|
overleaf:
|
||||||
|
id: @user_id
|
||||||
|
@req.params = user_id: @user_id.toString()
|
||||||
|
@UserGetter.getUser = sinon.stub().callsArgWith(2, null, @user)
|
||||||
|
@UserInfoController.sendFormattedPersonalInfo = sinon.stub()
|
||||||
|
@UserInfoController.getPersonalInfo(@req, @res, @next)
|
||||||
|
|
||||||
|
it "should look up the user in the database", ->
|
||||||
|
@UserGetter.getUser
|
||||||
|
.calledWith(
|
||||||
|
{ "overleaf.id": @user_id },
|
||||||
|
{ _id: true, first_name: true, last_name: true, email: true }
|
||||||
|
).should.equal true
|
||||||
|
|
||||||
it "should send the formatted details back to the client", ->
|
it "should send the formatted details back to the client", ->
|
||||||
@UserInfoController.sendFormattedPersonalInfo
|
@UserInfoController.sendFormattedPersonalInfo
|
||||||
.calledWith(@user, @res, @next)
|
.calledWith(@user, @res, @next)
|
||||||
|
@ -74,13 +98,24 @@ describe "UserInfoController", ->
|
||||||
|
|
||||||
describe "when the user does not exist", ->
|
describe "when the user does not exist", ->
|
||||||
beforeEach ->
|
beforeEach ->
|
||||||
|
@user_id = ObjectId().toString()
|
||||||
|
@req.params = user_id: @user_id
|
||||||
@UserGetter.getUser = sinon.stub().callsArgWith(2, null, null)
|
@UserGetter.getUser = sinon.stub().callsArgWith(2, null, null)
|
||||||
@UserInfoController.sendFormattedPersonalInfo = sinon.stub()
|
|
||||||
@UserInfoController.getPersonalInfo(@req, @res, @next)
|
@UserInfoController.getPersonalInfo(@req, @res, @next)
|
||||||
|
|
||||||
it "should return 404 to the client", ->
|
it "should return 404 to the client", ->
|
||||||
@res.statusCode.should.equal 404
|
@res.statusCode.should.equal 404
|
||||||
|
|
||||||
|
describe "when the user id is invalid", ->
|
||||||
|
beforeEach ->
|
||||||
|
@user_id = "invalid"
|
||||||
|
@req.params = user_id: @user_id
|
||||||
|
@UserGetter.getUser = sinon.stub().callsArgWith(2, null, null)
|
||||||
|
@UserInfoController.getPersonalInfo(@req, @res, @next)
|
||||||
|
|
||||||
|
it "should return 400 to the client", ->
|
||||||
|
@res.statusCode.should.equal 400
|
||||||
|
|
||||||
describe "sendFormattedPersonalInfo", ->
|
describe "sendFormattedPersonalInfo", ->
|
||||||
beforeEach ->
|
beforeEach ->
|
||||||
@user =
|
@user =
|
||||||
|
|
Loading…
Reference in a new issue