diff options
| -rw-r--r-- | backend.js | 10 | ||||
| -rwxr-xr-x | index.js | 1 | ||||
| -rw-r--r-- | socket.js | 34 | 
3 files changed, 45 insertions, 0 deletions
| diff --git a/backend.js b/backend.js index 817ce1d..dea4429 100644 --- a/backend.js +++ b/backend.js @@ -701,6 +701,8 @@ export default class Backend extends EventEmitter { this.alwaysStartPaused = false this.waitWhenDonePlaying = false + this.hasAnnouncedJoin = false + this.recordStore = new RecordStore() this.throttleMetadata = throttlePromise(10) this.metadataDictionary = {} @@ -889,6 +891,14 @@ export default class Backend extends EventEmitter { this.emit('log message', messageInfo) } + announceJoinParty() { + this.emit('announce join party') + } + + setHasAnnouncedJoin(hasAnnouncedJoin) { + this.hasAnnouncedJoin = hasAnnouncedJoin + } + loadPartyGrouplike(socketId, partyGrouplike) { this.emit('got party grouplike', socketId, partyGrouplike) } diff --git a/index.js b/index.js index 21bd80a..79b940e 100755 --- a/index.js +++ b/index.js @@ -210,6 +210,7 @@ async function main() { nickname = options['socket-name'] } socketClient.setNickname(nickname) + backend.announceJoinParty() } if (options['stress-test']) { diff --git a/socket.js b/socket.js index 42f4057..1cd6c35 100644 --- a/socket.js +++ b/socket.js @@ -111,6 +111,8 @@ function validateCommand(command) { // clients too. case 'client': switch (command.code) { + case 'announce-join': + return true case 'clear-queue': return typeof command.queuePlayer === 'string' case 'clear-queue-past': @@ -252,6 +254,7 @@ export function makeSocketServer() { socketMap[socketId] = socket + let hasAnnouncedJoin = false let nickname = DEFAULT_NICKNAME socket.on('close', () => { @@ -278,6 +281,18 @@ export function makeSocketServer() { return } + // If the socket hasn't announced its joining yet, it only has access to + // a few commands. + + if (!hasAnnouncedJoin) { + if (![ + 'announce-join', + 'set-nickname' + ].includes(command.code)) { + return + } + } + // If it's a status command, respond appropriately, and return so that it // is not relayed. @@ -357,6 +372,13 @@ export function makeSocketServer() { nickname = command.nickname } + // If the socket hasn't announced its joining yet - and this isn't the + // command where it does so - don't relay the command. + + if (!hasAnnouncedJoin && command.code !== 'announce-join') { + return + } + // Relay the command to client sockets besides the sender. const otherSockets = Object.values(socketMap).filter(s => s !== socket) @@ -439,6 +461,8 @@ export function attachBackendToSocketClient(backend, client, { // All actual logic for instances of the mtui backend interacting with each // other through commands lives here. + let hasAnnouncedJoin = false + const partyGrouplike = { name: `Party Sources - ${client.nickname}`, isPartySources: true, @@ -447,6 +471,7 @@ export function attachBackendToSocketClient(backend, client, { const partyGrouplikeMap = Object.create(null) + backend.setHasAnnouncedJoin(false) backend.setAlwaysStartPaused(true) backend.setWaitWhenDonePlaying(true) @@ -467,6 +492,9 @@ export function attachBackendToSocketClient(backend, client, { let isVerbose = false switch (command.code) { + case 'announce-join': + actionmsg = `joined the party` + break case 'clear-queue': actionmsg = 'cleared the queue' break @@ -777,6 +805,12 @@ export function attachBackendToSocketClient(backend, client, { }) }) + backend.on('announce join party', () => { + client.sendCommand({ + code: 'announce-join' + }) + }) + backend.on('share with party', origItem => { let newItem = { ...origItem, | 
