Merge pull request #16003 from overleaf/jpa-real-time-remove-join-project

[real-time] remove legacy joinProject rpc and require auto-join-project

GitOrigin-RevId: 2b610c83a34e516e0da0fa8a17858ec5c98c5bdd
This commit is contained in:
Jakob Ackermann 2023-11-29 15:50:42 +01:00 committed by Copybot
parent 5520f9eed9
commit 78c1687f3b
3 changed files with 39 additions and 71 deletions

View file

@ -169,21 +169,32 @@ module.exports = Router = {
}
return
}
const joinProjectAutomatically = !!client.handshake?.query?.projectId
// send positive confirmation that the client has a valid connection
client.publicId = 'P.' + base64id.generateId()
if (!joinProjectAutomatically) {
client.emit('connectionAccepted', null, client.publicId)
const projectId = client.handshake?.query?.projectId
try {
Joi.assert(projectId, JOI_OBJECT_ID)
} catch (error) {
metrics.inc('socket-io.connection', 1, {
status: client.transport,
method: projectId ? 'bad-project-id' : 'missing-project-id',
})
client.emit('connectionRejected', {
message: 'missing/bad ?projectId=... query flag on handshake',
})
client.disconnect()
return
}
// The client.id is security sensitive. Generate a publicId for sending to other clients.
client.publicId = 'P.' + base64id.generateId()
client.remoteIp = websocketAddressManager.getRemoteIp(client.handshake)
const headers = client.handshake && client.handshake.headers
client.userAgent = headers && headers['user-agent']
metrics.inc('socket-io.connection', 1, {
status: client.transport,
method: joinProjectAutomatically ? 'auto-join-project' : undefined,
method: 'auto-join-project',
})
metrics.gauge('socket-io.clients', io.sockets.clients().length)
@ -195,7 +206,8 @@ module.exports = Router = {
} else if (session && session.user) {
;({ user } = session)
} else {
user = { _id: 'anonymous-user' }
const anonymousAccessToken = session?.anonTokenAccess?.[projectId]
user = { _id: 'anonymous-user', anonymousAccessToken }
}
if (settings.exposeHostname) {
@ -211,46 +223,7 @@ module.exports = Router = {
})
}
const joinProject = function (data, callback) {
data = data || {}
if (typeof callback !== 'function') {
return Router._handleInvalidArguments(
client,
'joinProject',
arguments
)
}
try {
Joi.assert(
data,
Joi.object({
project_id: JOI_OBJECT_ID,
anonymousAccessToken: Joi.string(),
})
)
} catch (error) {
return Router._handleError(callback, error, client, 'joinProject', {
disconnect: 1,
})
}
const { project_id: projectId, anonymousAccessToken } = data
// only allow connection to a single project
if (
client.ol_current_project_id &&
projectId !== client.ol_current_project_id
) {
return Router._handleError(
callback,
new Error('cannot join multiple projects'),
client,
'joinProject',
{ disconnect: 1 }
)
}
client.ol_current_project_id = projectId
if (anonymousAccessToken) {
user.anonymousAccessToken = anonymousAccessToken
}
const joinProject = function (callback) {
WebsocketController.joinProject(
client,
user,
@ -267,7 +240,6 @@ module.exports = Router = {
}
)
}
client.on('joinProject', joinProject)
client.on('disconnect', function () {
metrics.inc('socket-io.disconnect', 1, { status: client.transport })
@ -463,26 +435,19 @@ module.exports = Router = {
)
})
if (joinProjectAutomatically) {
const { projectId } = client.handshake.query
const anonymousAccessToken = session?.anonTokenAccess?.[projectId]
joinProject(
{ project_id: projectId, anonymousAccessToken },
(err, project, permissionsLevel, protocolVersion) => {
if (err) {
client.emit('connectionRejected', err)
client.disconnect()
return
}
client.emit('joinProjectResponse', {
publicId: client.publicId,
project,
permissionsLevel,
protocolVersion,
})
}
)
}
joinProject((err, project, permissionsLevel, protocolVersion) => {
if (err) {
client.emit('connectionRejected', err)
client.disconnect()
return
}
client.emit('joinProjectResponse', {
publicId: client.publicId,
project,
permissionsLevel,
protocolVersion,
})
})
})
},
}

View file

@ -9,7 +9,6 @@ const ChannelManager = require('./ChannelManager')
const ConnectedUsersManager = require('./ConnectedUsersManager')
const RESTRICTED_USER_MESSAGE_TYPE_PASS_LIST = [
'connectionAccepted',
'otUpdateApplied',
'otUpdateError',
'joinDoc',

View file

@ -371,7 +371,9 @@ describe('joinProject', function () {
})
it('should return an invalid id error', function () {
this.error.message.should.equal('invalid id')
this.error.message.should.equal(
'missing/bad ?projectId=... query flag on handshake'
)
})
it('should not call to web', function () {
@ -809,7 +811,9 @@ describe('joinProject', function () {
})
it('should return an invalid id error', function () {
this.error.message.should.equal('invalid id')
this.error.message.should.equal(
'missing/bad ?projectId=... query flag on handshake'
)
})
it('should not call to web', function () {