Server : nginx/1.18.0 System : Linux localhost 6.14.3-x86_64-linode168 #1 SMP PREEMPT_DYNAMIC Mon Apr 21 19:47:55 EDT 2025 x86_64 User : www-data ( 33) PHP Version : 8.0.16 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /var/www/ecommerce/node_modules/pusher-js/src/core/channels/ |
import PrivateChannel from './private_channel';
import Logger from '../logger';
import Members from './members';
import Pusher from '../pusher';
import UrlStore from 'core/utils/url_store';
import { PusherEvent } from '../connection/protocol/message-types';
import Metadata from './metadata';
import { AuthData } from '../auth/options';
export default class PresenceChannel extends PrivateChannel {
members: Members;
/** Adds presence channel functionality to private channels.
*
* @param {String} name
* @param {Pusher} pusher
*/
constructor(name: string, pusher: Pusher) {
super(name, pusher);
this.members = new Members();
}
/** Authenticates the connection as a member of the channel.
*
* @param {String} socketId
* @param {Function} callback
*/
authorize(socketId: string, callback: Function) {
super.authorize(socketId, (error, authData) => {
if (!error) {
authData = authData as AuthData;
if (authData.channel_data === undefined) {
let suffix = UrlStore.buildLogSuffix('authenticationEndpoint');
Logger.error(
`Invalid auth response for channel '${this.name}',` +
`expected 'channel_data' field. ${suffix}`
);
callback('Invalid auth response');
return;
}
var channelData = JSON.parse(authData.channel_data);
this.members.setMyID(channelData.user_id);
}
callback(error, authData);
});
}
/** Handles presence and subscription events. For internal use only.
*
* @param {PusherEvent} event
*/
handleEvent(event: PusherEvent) {
var eventName = event.event;
if (eventName.indexOf('pusher_internal:') === 0) {
this.handleInternalEvent(event);
} else {
var data = event.data;
var metadata: Metadata = {};
if (event.user_id) {
metadata.user_id = event.user_id;
}
this.emit(eventName, data, metadata);
}
}
handleInternalEvent(event: PusherEvent) {
var eventName = event.event;
var data = event.data;
switch (eventName) {
case 'pusher_internal:subscription_succeeded':
this.handleSubscriptionSucceededEvent(event);
break;
case 'pusher_internal:member_added':
var addedMember = this.members.addMember(data);
this.emit('pusher:member_added', addedMember);
break;
case 'pusher_internal:member_removed':
var removedMember = this.members.removeMember(data);
if (removedMember) {
this.emit('pusher:member_removed', removedMember);
}
break;
}
}
handleSubscriptionSucceededEvent(event: PusherEvent) {
this.subscriptionPending = false;
this.subscribed = true;
if (this.subscriptionCancelled) {
this.pusher.unsubscribe(this.name);
} else {
this.members.onSubscription(event.data);
this.emit('pusher:subscription_succeeded', this.members);
}
}
/** Resets the channel state, including members map. For internal use only. */
disconnect() {
this.members.reset();
super.disconnect();
}
}