@webex/plugin-meetings 3.8.1-web-workers-keepalive.1 → 3.9.0-webinar5k.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. package/dist/breakouts/breakout.js +1 -1
  2. package/dist/breakouts/index.js +1 -1
  3. package/dist/constants.js +8 -2
  4. package/dist/constants.js.map +1 -1
  5. package/dist/hashTree/constants.js +23 -0
  6. package/dist/hashTree/constants.js.map +1 -0
  7. package/dist/hashTree/hashTree.js +516 -0
  8. package/dist/hashTree/hashTree.js.map +1 -0
  9. package/dist/hashTree/hashTreeParser.js +521 -0
  10. package/dist/hashTree/hashTreeParser.js.map +1 -0
  11. package/dist/interpretation/index.js +1 -1
  12. package/dist/interpretation/siLanguage.js +1 -1
  13. package/dist/locus-info/index.js +301 -59
  14. package/dist/locus-info/index.js.map +1 -1
  15. package/dist/meeting/brbState.js +14 -12
  16. package/dist/meeting/brbState.js.map +1 -1
  17. package/dist/meeting/index.js +110 -12
  18. package/dist/meeting/index.js.map +1 -1
  19. package/dist/meeting/muteState.js +2 -5
  20. package/dist/meeting/muteState.js.map +1 -1
  21. package/dist/meeting/request.js +19 -0
  22. package/dist/meeting/request.js.map +1 -1
  23. package/dist/meeting/request.type.js.map +1 -1
  24. package/dist/meeting/util.js +8 -11
  25. package/dist/meeting/util.js.map +1 -1
  26. package/dist/meetings/index.js +6 -2
  27. package/dist/meetings/index.js.map +1 -1
  28. package/dist/member/index.js.map +1 -1
  29. package/dist/member/types.js.map +1 -1
  30. package/dist/members/collection.js +13 -0
  31. package/dist/members/collection.js.map +1 -1
  32. package/dist/members/index.js +44 -23
  33. package/dist/members/index.js.map +1 -1
  34. package/dist/members/request.js +3 -3
  35. package/dist/members/request.js.map +1 -1
  36. package/dist/members/util.js +18 -6
  37. package/dist/members/util.js.map +1 -1
  38. package/dist/multistream/sendSlotManager.js +32 -2
  39. package/dist/multistream/sendSlotManager.js.map +1 -1
  40. package/dist/types/constants.d.ts +6 -0
  41. package/dist/types/hashTree/constants.d.ts +8 -0
  42. package/dist/types/hashTree/hashTree.d.ts +128 -0
  43. package/dist/types/hashTree/hashTreeParser.d.ts +152 -0
  44. package/dist/types/locus-info/index.d.ts +93 -3
  45. package/dist/types/meeting/brbState.d.ts +0 -1
  46. package/dist/types/meeting/index.d.ts +29 -3
  47. package/dist/types/meeting/request.d.ts +9 -1
  48. package/dist/types/meeting/request.type.d.ts +74 -0
  49. package/dist/types/meeting/util.d.ts +3 -3
  50. package/dist/types/member/types.d.ts +1 -0
  51. package/dist/types/members/collection.d.ts +6 -0
  52. package/dist/types/members/index.d.ts +15 -3
  53. package/dist/types/members/request.d.ts +1 -1
  54. package/dist/types/members/util.d.ts +5 -2
  55. package/dist/types/multistream/sendSlotManager.d.ts +16 -0
  56. package/dist/webinar/index.js +1 -1
  57. package/package.json +24 -23
  58. package/src/constants.ts +7 -0
  59. package/src/hashTree/constants.ts +12 -0
  60. package/src/hashTree/hashTree.ts +460 -0
  61. package/src/hashTree/hashTreeParser.ts +556 -0
  62. package/src/locus-info/index.ts +393 -58
  63. package/src/meeting/brbState.ts +9 -7
  64. package/src/meeting/index.ts +104 -6
  65. package/src/meeting/muteState.ts +2 -6
  66. package/src/meeting/request.ts +16 -0
  67. package/src/meeting/request.type.ts +64 -0
  68. package/src/meeting/util.ts +17 -20
  69. package/src/meetings/index.ts +17 -3
  70. package/src/member/index.ts +1 -0
  71. package/src/member/types.ts +1 -0
  72. package/src/members/collection.ts +11 -0
  73. package/src/members/index.ts +33 -7
  74. package/src/members/request.ts +2 -2
  75. package/src/members/util.ts +14 -3
  76. package/src/multistream/sendSlotManager.ts +34 -2
  77. package/test/unit/spec/hashTree/hashTree.ts +394 -0
  78. package/test/unit/spec/hashTree/hashTreeParser.ts +156 -0
  79. package/test/unit/spec/locus-info/index.js +506 -55
  80. package/test/unit/spec/meeting/brbState.ts +9 -9
  81. package/test/unit/spec/meeting/index.js +475 -42
  82. package/test/unit/spec/meeting/request.js +71 -0
  83. package/test/unit/spec/members/index.js +33 -10
  84. package/test/unit/spec/members/request.js +2 -2
  85. package/test/unit/spec/members/utils.js +27 -7
  86. package/test/unit/spec/multistream/sendSlotManager.ts +59 -0
  87. package/test/unit/spec/reachability/index.ts +3 -1
@@ -1 +1 @@
1
- {"version":3,"names":["_uuid","_interopRequireDefault","require","_constants","ownKeys","e","r","t","_Object$keys","_Object$getOwnPropertySymbols","o","filter","_Object$getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","Object","forEach","_defineProperty2","default","_Object$getOwnPropertyDescriptors","_Object$defineProperties","_Object$defineProperty","MembersUtil","generateAddMemberOptions","invitee","locusUrl","alertIfActive","generateAdmitMemberOptions","memberIds","getAddMemberBody","options","invitees","address","emailAddress","email","phoneNumber","roles","getAdmitMemberRequestBody","sessionLocusUrls","body","admit","participantIds","authorizingLocusUrl","getAdmitMemberRequestParams","format","baseUrl","mainLocusUrl","uri","concat","CONTROLS","method","HTTP_VERBS","PUT","getAddMemberRequestParams","requestParams","isInvalidInvitee","DIALER_REGEX","E164_FORMAT","test","VALID_EMAIL_ADDRESS","SIP_ADDRESS","getRemoveMemberRequestParams","reason","PARTICIPANT","memberId","LEAVE","generateTransferHostMemberOptions","transfer","moderator","generateRemoveMemberOptions","removal","_FORCED_","generateMuteMemberOptions","status","isAudio","muted","generateRaiseHandMemberOptions","raised","generateRoleAssignmentMemberOptions","generateLowerAllHandsMemberOptions","requestingParticipantId","undefined","generateEditDisplayNameMemberOptions","alias","getMuteMemberRequestParams","property","PATCH","getMoveMemberToLobbyRequestBody","moveToLobby","getMoveMemberToLobbyRequestParams","getAddedRoleShape","role","roleShape","type","hasRole","hostKey","getRoleAssignmentMemberRequestParams","getRaiseHandMemberRequestParams","hand","getLowerAllHandsMemberRequestParams","editDisplayNameMemberRequestParams","aliasValue","ALIAS","POST","getTransferHostToMemberRequestParams","genderateSendDTMFOptions","url","tones","generateSendDTMFRequestParams","_ref","device","dtmf","correlationId","uuid","v4","direction","SEND_DTMF_ENDPOINT","cancelPhoneInviteOptions","generateCancelInviteRequestParams","actionType","_REMOVE_","cancelSIPInviteOptions","generateCancelSIPInviteRequestParams","_default","exports"],"sources":["util.ts"],"sourcesContent":["import uuid from 'uuid';\nimport {\n HTTP_VERBS,\n CONTROLS,\n _FORCED_,\n LEAVE,\n PARTICIPANT,\n VALID_EMAIL_ADDRESS,\n DIALER_REGEX,\n SEND_DTMF_ENDPOINT,\n _REMOVE_,\n ALIAS,\n} from '../constants';\n\nimport {RoleAssignmentOptions, RoleAssignmentRequest, ServerRoleShape} from './types';\n\nconst MembersUtil = {\n /**\n * @param {Object} invitee with emailAddress, email or phoneNumber\n * @param {String} locusUrl\n * @param {Boolean} alertIfActive\n * @returns {Object} the format object\n */\n generateAddMemberOptions: (invitee: object, locusUrl: string, alertIfActive: boolean) => ({\n invitee,\n locusUrl,\n alertIfActive,\n }),\n\n /**\n * @param {Array} memberIds\n * @param {String} locusUrl\n * @returns {Object} the format object\n */\n generateAdmitMemberOptions: (memberIds: Array<any>, locusUrl: string) => ({\n locusUrl,\n memberIds,\n }),\n\n /**\n * @param {Object} options with {invitee: {emailAddress, email, phoneNumber}, alertIfActive}\n * @returns {Object} with {invitees: [{address}], alertIfActive}\n */\n getAddMemberBody: (options: any) => ({\n invitees: [\n {\n address:\n options.invitee.emailAddress || options.invitee.email || options.invitee.phoneNumber,\n ...(options.invitee.roles ? {roles: options.invitee.roles} : {}),\n },\n ],\n alertIfActive: options.alertIfActive,\n }),\n\n /**\n * @param {Object} options with {memberIds, authorizingLocusUrl}\n * @returns {Object} admit with {memberIds}\n */\n getAdmitMemberRequestBody: (options: any) => {\n const {memberIds, sessionLocusUrls} = options;\n const body: any = {admit: {participantIds: memberIds}};\n if (sessionLocusUrls) {\n const {authorizingLocusUrl} = sessionLocusUrls;\n\n return {authorizingLocusUrl, ...body};\n }\n\n return body;\n },\n\n /**\n * @param {Object} format with {memberIds, locusUrl, sessionLocusUrls}\n * @returns {Object} the request parameters (method, uri, body) needed to make a admitMember request\n * if a host/cohost is in a breakout session, the locus url should be the main session locus url\n */\n getAdmitMemberRequestParams: (format: any) => {\n const body = MembersUtil.getAdmitMemberRequestBody(format);\n const {locusUrl, sessionLocusUrls} = format;\n const baseUrl = sessionLocusUrls?.mainLocusUrl || locusUrl;\n const uri = `${baseUrl}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PUT,\n uri,\n body,\n };\n },\n\n /**\n * @param {Object} format with {invitee {emailAddress, email, phoneNumber}, locusUrl, alertIfActive}\n * @returns {Object} the request parameters (method, uri, body) needed to make a addMember request\n */\n getAddMemberRequestParams: (format: any) => {\n const body = MembersUtil.getAddMemberBody(format);\n const requestParams = {\n method: HTTP_VERBS.PUT,\n uri: format.locusUrl,\n body,\n };\n\n return requestParams;\n },\n\n isInvalidInvitee: (invitee) => {\n if (!(invitee && (invitee.email || invitee.emailAddress || invitee.phoneNumber))) {\n return true;\n }\n\n if (invitee.phoneNumber) {\n return !DIALER_REGEX.E164_FORMAT.test(invitee.phoneNumber);\n }\n\n return !(\n VALID_EMAIL_ADDRESS.test(invitee.email || invitee.emailAddress) ||\n DIALER_REGEX.SIP_ADDRESS.test(invitee.email || invitee.emailAddress)\n );\n },\n\n getRemoveMemberRequestParams: (options) => {\n const body = {\n reason: options.reason,\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${LEAVE}`;\n\n return {\n method: HTTP_VERBS.PUT,\n uri,\n body,\n };\n },\n\n generateTransferHostMemberOptions: (transfer, moderator, locusUrl) => ({\n moderator,\n locusUrl,\n memberId: transfer,\n }),\n\n generateRemoveMemberOptions: (removal, locusUrl) => ({\n reason: _FORCED_,\n memberId: removal,\n locusUrl,\n }),\n\n generateMuteMemberOptions: (memberId, status, locusUrl, isAudio) => ({\n memberId,\n muted: status,\n locusUrl,\n isAudio,\n }),\n\n generateRaiseHandMemberOptions: (memberId, status, locusUrl) => ({\n memberId,\n raised: status,\n locusUrl,\n }),\n\n /**\n * @param {String} memberId\n * @param {[ServerRoleShape]} roles\n * @param {String} locusUrl\n * @returns {RoleAssignmentOptions}\n */\n generateRoleAssignmentMemberOptions: (\n memberId: string,\n roles: Array<ServerRoleShape>,\n locusUrl: string\n ): RoleAssignmentOptions => ({\n memberId,\n roles,\n locusUrl,\n }),\n\n generateLowerAllHandsMemberOptions: (requestingParticipantId, locusUrl, roles) => ({\n requestingParticipantId,\n locusUrl,\n ...(roles !== undefined && {roles}),\n }),\n\n /**\n * @param {String} memberId id of the participant who is receiving request\n * @param {String} requestingParticipantId id of the participant who is sending request (optional)\n * @param {String} alias alias name\n * @param {String} locusUrl url\n * @returns {Object} consists of {memberID: string, requestingParticipantId: string, alias: string, locusUrl: string}\n */\n generateEditDisplayNameMemberOptions: (memberId, requestingParticipantId, alias, locusUrl) => ({\n memberId,\n requestingParticipantId,\n alias,\n locusUrl,\n }),\n\n getMuteMemberRequestParams: (options) => {\n const property = options.isAudio === false ? 'video' : 'audio';\n const body = {\n [property]: {\n muted: options.muted,\n },\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n getMoveMemberToLobbyRequestBody: (memberId: string) => ({\n moveToLobby: {\n participantIds: [memberId],\n },\n }),\n\n getMoveMemberToLobbyRequestParams: (options: {memberId: string; locusUrl: string}, body) => {\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n /**\n * @param {ServerRoleShape} role\n * @returns {ServerRoleShape} the role shape to be added to the body\n */\n getAddedRoleShape: (role: ServerRoleShape): ServerRoleShape => {\n const roleShape: ServerRoleShape = {type: role.type, hasRole: role.hasRole};\n\n if (role.hostKey) {\n roleShape.hostKey = role.hostKey;\n }\n\n return roleShape;\n },\n\n /**\n * @param {RoleAssignmentOptions} options\n * @returns {RoleAssignmentRequest} the request parameters (method, uri, body) needed to make a addMember request\n */\n getRoleAssignmentMemberRequestParams: (options: RoleAssignmentOptions): RoleAssignmentRequest => {\n const body = {role: {roles: []}};\n options.roles.forEach((role) => {\n body.role.roles.push(MembersUtil.getAddedRoleShape(role));\n });\n\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n getRaiseHandMemberRequestParams: (options) => {\n const body = {\n hand: {\n raised: options.raised,\n },\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n getLowerAllHandsMemberRequestParams: (options) => {\n const body = {\n hand: {\n raised: false,\n ...(options.roles !== undefined && {roles: options.roles}),\n },\n requestingParticipantId: options.requestingParticipantId,\n };\n const uri = `${options.locusUrl}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n /**\n * @param {Object} options with format of {locusUrl: string, requestingParticipantId: string}\n * @returns {Object} request parameters (method, uri, body) needed to make a editDisplayName request\n */\n editDisplayNameMemberRequestParams: (options) => {\n const body = {\n aliasValue: options.alias,\n requestingParticipantId: options.requestingParticipantId,\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${ALIAS}`;\n\n return {\n method: HTTP_VERBS.POST,\n uri,\n body,\n };\n },\n\n getTransferHostToMemberRequestParams: (options) => {\n const body = {\n role: {\n moderator: options.moderator,\n },\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n genderateSendDTMFOptions: (url, tones, memberId, locusUrl) => ({\n url,\n tones,\n memberId,\n locusUrl,\n }),\n\n generateSendDTMFRequestParams: ({url, tones, memberId, locusUrl}) => {\n const body = {\n device: {\n url,\n },\n memberId,\n dtmf: {\n correlationId: uuid.v4(),\n tones,\n direction: 'transmit',\n },\n };\n const uri = `${locusUrl}/${PARTICIPANT}/${memberId}/${SEND_DTMF_ENDPOINT}`;\n\n return {\n method: HTTP_VERBS.POST,\n uri,\n body,\n };\n },\n\n cancelPhoneInviteOptions: (invitee, locusUrl) => ({\n invitee,\n locusUrl,\n }),\n\n generateCancelInviteRequestParams: (options) => {\n const body = {\n actionType: _REMOVE_,\n invitees: [\n {\n address: options.invitee.phoneNumber,\n },\n ],\n };\n const requestParams = {\n method: HTTP_VERBS.PUT,\n uri: options.locusUrl,\n body,\n };\n\n return requestParams;\n },\n\n cancelSIPInviteOptions: (invitee, locusUrl) => ({\n invitee,\n locusUrl,\n }),\n\n generateCancelSIPInviteRequestParams: (options) => {\n const body = {\n actionType: _REMOVE_,\n invitees: [\n {\n address: options.invitee.memberId,\n },\n ],\n };\n const requestParams = {\n method: HTTP_VERBS.PUT,\n uri: options.locusUrl,\n body,\n };\n\n return requestParams;\n },\n};\n\nexport default MembersUtil;\n"],"mappings":"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"}
1
+ {"version":3,"names":["_uuid","_interopRequireDefault","require","_lodash","_constants","ownKeys","e","r","t","_Object$keys","_Object$getOwnPropertySymbols","o","filter","_Object$getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","Object","forEach","_defineProperty2","default","_Object$getOwnPropertyDescriptors","_Object$defineProperties","_Object$defineProperty","MembersUtil","generateAddMemberOptions","invitee","locusUrl","alertIfActive","generateAdmitMemberOptions","memberIds","getAddMemberBody","options","invitees","address","emailAddress","email","phoneNumber","roles","has","isInternalNumber","getAdmitMemberRequestBody","sessionLocusUrls","body","admit","participantIds","authorizingLocusUrl","getAdmitMemberRequestParams","format","baseUrl","mainLocusUrl","uri","concat","CONTROLS","method","HTTP_VERBS","PUT","getAddMemberRequestParams","requestParams","isInvalidInvitee","DIALER_REGEX","INTERNAL_NUMBER","test","E164_FORMAT","VALID_EMAIL_ADDRESS","SIP_ADDRESS","getRemoveMemberRequestParams","reason","PARTICIPANT","memberId","LEAVE","generateTransferHostMemberOptions","transfer","moderator","generateRemoveMemberOptions","removal","_FORCED_","generateMuteMemberOptions","status","isAudio","muted","generateRaiseHandMemberOptions","raised","generateRoleAssignmentMemberOptions","generateLowerAllHandsMemberOptions","requestingParticipantId","undefined","generateEditDisplayNameMemberOptions","alias","getMuteMemberRequestParams","property","PATCH","getMoveMemberToLobbyRequestBody","moveToLobby","getMoveMemberToLobbyRequestParams","getAddedRoleShape","role","roleShape","type","hasRole","hostKey","getRoleAssignmentMemberRequestParams","getRaiseHandMemberRequestParams","hand","getLowerAllHandsMemberRequestParams","editDisplayNameMemberRequestParams","aliasValue","ALIAS","POST","getTransferHostToMemberRequestParams","genderateSendDTMFOptions","url","tones","generateSendDTMFRequestParams","_ref","device","dtmf","correlationId","uuid","v4","direction","SEND_DTMF_ENDPOINT","cancelPhoneInviteOptions","generateCancelInviteRequestParams","actionType","_REMOVE_","cancelInviteByMemberIdOptions","generateCancelInviteByMemberIdRequestParams","_options$invitee","hasIsInternalNumberProp","_default","exports"],"sources":["util.ts"],"sourcesContent":["import uuid from 'uuid';\nimport {has} from 'lodash';\nimport {\n HTTP_VERBS,\n CONTROLS,\n _FORCED_,\n LEAVE,\n PARTICIPANT,\n VALID_EMAIL_ADDRESS,\n DIALER_REGEX,\n SEND_DTMF_ENDPOINT,\n _REMOVE_,\n ALIAS,\n} from '../constants';\n\nimport {RoleAssignmentOptions, RoleAssignmentRequest, ServerRoleShape} from './types';\n\nconst MembersUtil = {\n /**\n * @param {Object} invitee with emailAddress, email or phoneNumber\n * @param {String} locusUrl\n * @param {Boolean} alertIfActive\n * @returns {Object} the format object\n */\n generateAddMemberOptions: (invitee: object, locusUrl: string, alertIfActive: boolean) => ({\n invitee,\n locusUrl,\n alertIfActive,\n }),\n\n /**\n * @param {Array} memberIds\n * @param {String} locusUrl\n * @returns {Object} the format object\n */\n generateAdmitMemberOptions: (memberIds: Array<any>, locusUrl: string) => ({\n locusUrl,\n memberIds,\n }),\n\n /**\n * @param {Object} options with {invitee: {emailAddress, email, phoneNumber}, alertIfActive}\n * @returns {Object} with {invitees: [{address}], alertIfActive}\n */\n getAddMemberBody: (options: any) => ({\n invitees: [\n {\n address:\n options.invitee.emailAddress || options.invitee.email || options.invitee.phoneNumber,\n ...(options.invitee.roles ? {roles: options.invitee.roles} : {}),\n ...(has(options.invitee, 'isInternalNumber')\n ? {isInternalNumber: options.invitee.isInternalNumber}\n : {}),\n },\n ],\n alertIfActive: options.alertIfActive,\n }),\n\n /**\n * @param {Object} options with {memberIds, authorizingLocusUrl}\n * @returns {Object} admit with {memberIds}\n */\n getAdmitMemberRequestBody: (options: any) => {\n const {memberIds, sessionLocusUrls} = options;\n const body: any = {admit: {participantIds: memberIds}};\n if (sessionLocusUrls) {\n const {authorizingLocusUrl} = sessionLocusUrls;\n\n return {authorizingLocusUrl, ...body};\n }\n\n return body;\n },\n\n /**\n * @param {Object} format with {memberIds, locusUrl, sessionLocusUrls}\n * @returns {Object} the request parameters (method, uri, body) needed to make a admitMember request\n * if a host/cohost is in a breakout session, the locus url should be the main session locus url\n */\n getAdmitMemberRequestParams: (format: any) => {\n const body = MembersUtil.getAdmitMemberRequestBody(format);\n const {locusUrl, sessionLocusUrls} = format;\n const baseUrl = sessionLocusUrls?.mainLocusUrl || locusUrl;\n const uri = `${baseUrl}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PUT,\n uri,\n body,\n };\n },\n\n /**\n * @param {Object} format with {invitee {emailAddress, email, phoneNumber}, locusUrl, alertIfActive}\n * @returns {Object} the request parameters (method, uri, body) needed to make a addMember request\n */\n getAddMemberRequestParams: (format: any) => {\n const body = MembersUtil.getAddMemberBody(format);\n const requestParams = {\n method: HTTP_VERBS.PUT,\n uri: format.locusUrl,\n body,\n };\n\n return requestParams;\n },\n\n isInvalidInvitee: (invitee) => {\n if (!(invitee && (invitee.email || invitee.emailAddress || invitee.phoneNumber))) {\n return true;\n }\n\n if (invitee.phoneNumber) {\n if (invitee.isInternalNumber) {\n return !DIALER_REGEX.INTERNAL_NUMBER.test(invitee.phoneNumber);\n }\n\n return !DIALER_REGEX.E164_FORMAT.test(invitee.phoneNumber);\n }\n\n return !(\n VALID_EMAIL_ADDRESS.test(invitee.email || invitee.emailAddress) ||\n DIALER_REGEX.SIP_ADDRESS.test(invitee.email || invitee.emailAddress)\n );\n },\n\n getRemoveMemberRequestParams: (options) => {\n const body = {\n reason: options.reason,\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${LEAVE}`;\n\n return {\n method: HTTP_VERBS.PUT,\n uri,\n body,\n };\n },\n\n generateTransferHostMemberOptions: (transfer, moderator, locusUrl) => ({\n moderator,\n locusUrl,\n memberId: transfer,\n }),\n\n generateRemoveMemberOptions: (removal, locusUrl) => ({\n reason: _FORCED_,\n memberId: removal,\n locusUrl,\n }),\n\n generateMuteMemberOptions: (memberId, status, locusUrl, isAudio) => ({\n memberId,\n muted: status,\n locusUrl,\n isAudio,\n }),\n\n generateRaiseHandMemberOptions: (memberId, status, locusUrl) => ({\n memberId,\n raised: status,\n locusUrl,\n }),\n\n /**\n * @param {String} memberId\n * @param {[ServerRoleShape]} roles\n * @param {String} locusUrl\n * @returns {RoleAssignmentOptions}\n */\n generateRoleAssignmentMemberOptions: (\n memberId: string,\n roles: Array<ServerRoleShape>,\n locusUrl: string\n ): RoleAssignmentOptions => ({\n memberId,\n roles,\n locusUrl,\n }),\n\n generateLowerAllHandsMemberOptions: (requestingParticipantId, locusUrl, roles) => ({\n requestingParticipantId,\n locusUrl,\n ...(roles !== undefined && {roles}),\n }),\n\n /**\n * @param {String} memberId id of the participant who is receiving request\n * @param {String} requestingParticipantId id of the participant who is sending request (optional)\n * @param {String} alias alias name\n * @param {String} locusUrl url\n * @returns {Object} consists of {memberID: string, requestingParticipantId: string, alias: string, locusUrl: string}\n */\n generateEditDisplayNameMemberOptions: (memberId, requestingParticipantId, alias, locusUrl) => ({\n memberId,\n requestingParticipantId,\n alias,\n locusUrl,\n }),\n\n getMuteMemberRequestParams: (options) => {\n const property = options.isAudio === false ? 'video' : 'audio';\n const body = {\n [property]: {\n muted: options.muted,\n },\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n getMoveMemberToLobbyRequestBody: (memberId: string) => ({\n moveToLobby: {\n participantIds: [memberId],\n },\n }),\n\n getMoveMemberToLobbyRequestParams: (options: {memberId: string; locusUrl: string}, body) => {\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n /**\n * @param {ServerRoleShape} role\n * @returns {ServerRoleShape} the role shape to be added to the body\n */\n getAddedRoleShape: (role: ServerRoleShape): ServerRoleShape => {\n const roleShape: ServerRoleShape = {type: role.type, hasRole: role.hasRole};\n\n if (role.hostKey) {\n roleShape.hostKey = role.hostKey;\n }\n\n return roleShape;\n },\n\n /**\n * @param {RoleAssignmentOptions} options\n * @returns {RoleAssignmentRequest} the request parameters (method, uri, body) needed to make a addMember request\n */\n getRoleAssignmentMemberRequestParams: (options: RoleAssignmentOptions): RoleAssignmentRequest => {\n const body = {role: {roles: []}};\n options.roles.forEach((role) => {\n body.role.roles.push(MembersUtil.getAddedRoleShape(role));\n });\n\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n getRaiseHandMemberRequestParams: (options) => {\n const body = {\n hand: {\n raised: options.raised,\n },\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n getLowerAllHandsMemberRequestParams: (options) => {\n const body = {\n hand: {\n raised: false,\n ...(options.roles !== undefined && {roles: options.roles}),\n },\n requestingParticipantId: options.requestingParticipantId,\n };\n const uri = `${options.locusUrl}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n /**\n * @param {Object} options with format of {locusUrl: string, requestingParticipantId: string}\n * @returns {Object} request parameters (method, uri, body) needed to make a editDisplayName request\n */\n editDisplayNameMemberRequestParams: (options) => {\n const body = {\n aliasValue: options.alias,\n requestingParticipantId: options.requestingParticipantId,\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${ALIAS}`;\n\n return {\n method: HTTP_VERBS.POST,\n uri,\n body,\n };\n },\n\n getTransferHostToMemberRequestParams: (options) => {\n const body = {\n role: {\n moderator: options.moderator,\n },\n };\n const uri = `${options.locusUrl}/${PARTICIPANT}/${options.memberId}/${CONTROLS}`;\n\n return {\n method: HTTP_VERBS.PATCH,\n uri,\n body,\n };\n },\n\n genderateSendDTMFOptions: (url, tones, memberId, locusUrl) => ({\n url,\n tones,\n memberId,\n locusUrl,\n }),\n\n generateSendDTMFRequestParams: ({url, tones, memberId, locusUrl}) => {\n const body = {\n device: {\n url,\n },\n memberId,\n dtmf: {\n correlationId: uuid.v4(),\n tones,\n direction: 'transmit',\n },\n };\n const uri = `${locusUrl}/${PARTICIPANT}/${memberId}/${SEND_DTMF_ENDPOINT}`;\n\n return {\n method: HTTP_VERBS.POST,\n uri,\n body,\n };\n },\n\n cancelPhoneInviteOptions: (invitee, locusUrl) => ({\n invitee,\n locusUrl,\n }),\n\n generateCancelInviteRequestParams: (options) => {\n const body = {\n actionType: _REMOVE_,\n invitees: [\n {\n address: options.invitee.phoneNumber,\n },\n ],\n };\n const requestParams = {\n method: HTTP_VERBS.PUT,\n uri: options.locusUrl,\n body,\n };\n\n return requestParams;\n },\n\n cancelInviteByMemberIdOptions: (invitee, locusUrl) => ({\n invitee,\n locusUrl,\n }),\n\n generateCancelInviteByMemberIdRequestParams: (options) => {\n const {memberId, isInternalNumber} = options.invitee;\n const hasIsInternalNumberProp = has(options.invitee, 'isInternalNumber');\n const body = {\n actionType: _REMOVE_,\n invitees: [\n {\n address: memberId,\n ...(hasIsInternalNumberProp ? {isInternalNumber} : {}),\n },\n ],\n };\n const requestParams = {\n method: HTTP_VERBS.PUT,\n uri: options.locusUrl,\n body,\n };\n\n return requestParams;\n },\n};\n\nexport default MembersUtil;\n"],"mappings":"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"}
@@ -13,11 +13,21 @@ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs2/he
13
13
  var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/createClass"));
14
14
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs2/helpers/defineProperty"));
15
15
  var _internalMediaCore = require("@webex/internal-media-core");
16
+ /**
17
+ * This class is used to manage the sendSlots for the given media types.
18
+ */
16
19
  var SendSlotManager = exports.default = /*#__PURE__*/function () {
20
+ /**
21
+ * Constructor for SendSlotManager
22
+ *
23
+ * @param {any} LoggerProxy is used to log the messages
24
+ * @constructor
25
+ */
17
26
  function SendSlotManager(LoggerProxy) {
18
27
  (0, _classCallCheck2.default)(this, SendSlotManager);
19
28
  (0, _defineProperty2.default)(this, "slots", new _map.default());
20
29
  (0, _defineProperty2.default)(this, "LoggerProxy", void 0);
30
+ (0, _defineProperty2.default)(this, "sourceStateOverrides", new _map.default());
21
31
  this.LoggerProxy = LoggerProxy;
22
32
  }
23
33
 
@@ -87,18 +97,38 @@ var SendSlotManager = exports.default = /*#__PURE__*/function () {
87
97
  key: "setSourceStateOverride",
88
98
  value: function setSourceStateOverride(mediaType, state) {
89
99
  if (mediaType !== _internalMediaCore.MediaType.VideoMain) {
90
- throw new Error("sendSlotManager cannot set source state override which media type is ".concat(mediaType));
100
+ throw new Error("Invalid media type '".concat(mediaType, "'. Source state overrides are only applicable to ").concat(_internalMediaCore.MediaType.VideoMain, "."));
91
101
  }
92
102
  var slot = this.slots.get(mediaType);
93
103
  if (!slot) {
94
104
  throw new Error("Slot for ".concat(mediaType, " does not exist"));
95
105
  }
106
+ var currentStateOverride = this.getSourceStateOverride(mediaType);
107
+ if (currentStateOverride === state) {
108
+ return;
109
+ }
96
110
  if (state) {
97
111
  slot.setSourceStateOverride(state);
112
+ this.sourceStateOverrides.set(mediaType, state);
98
113
  } else {
99
114
  slot.clearSourceStateOverride();
115
+ this.sourceStateOverrides.delete(mediaType);
116
+ }
117
+ this.LoggerProxy.logger.info("SendSlotManager->setSourceStateOverride#set source state override for ".concat(mediaType, " to ").concat(state));
118
+ }
119
+
120
+ /**
121
+ * Gets the source state override for the given media type.
122
+ * @param {MediaType} mediaType - The type of media to get the source state override for.
123
+ * @returns {StreamState | null} - The current source state override or null if not set.
124
+ */
125
+ }, {
126
+ key: "getSourceStateOverride",
127
+ value: function getSourceStateOverride(mediaType) {
128
+ if (mediaType !== _internalMediaCore.MediaType.VideoMain) {
129
+ throw new Error("Invalid media type '".concat(mediaType, "'. Source state overrides are only applicable to ").concat(_internalMediaCore.MediaType.VideoMain, "."));
100
130
  }
101
- this.LoggerProxy.logger.info("SendSlotsManager->setSourceStateOverride#set source state override for ".concat(mediaType, " to ").concat(state));
131
+ return this.sourceStateOverrides.get(mediaType) || null;
102
132
  }
103
133
 
104
134
  /**
@@ -1 +1 @@
1
- {"version":3,"names":["_internalMediaCore","require","SendSlotManager","exports","default","LoggerProxy","_classCallCheck2","_defineProperty2","_map","_createClass2","key","value","createSlot","mediaConnection","mediaType","active","arguments","length","undefined","slots","has","Error","concat","slot","createSendSlot","set","logger","info","getSlot","get","setNamedMediaGroups","namedMediaGroups","MediaType","AudioMain","setSourceStateOverride","state","VideoMain","clearSourceStateOverride","_publishStream","_asyncToGenerator2","_regenerator","mark","_callee","stream","wrap","_callee$","_context","prev","next","publishStream","label","muted","stop","_x","_x2","apply","_unpublishStream","_callee2","_callee2$","_context2","unpublishStream","_x3","setActive","_setCodecParameters","_callee3","codecParameters","_callee3$","_context3","setCodecParameters","_x4","_x5","_deleteCodecParameters","_callee4","parameters","_callee4$","_context4","deleteCodecParameters","_x6","_x7","reset","clear"],"sources":["sendSlotManager.ts"],"sourcesContent":["import {\n SendSlot,\n MediaType,\n LocalStream,\n MultistreamRoapMediaConnection,\n NamedMediaGroup,\n StreamState,\n} from '@webex/internal-media-core';\n\nexport default class SendSlotManager {\n private readonly slots: Map<MediaType, SendSlot> = new Map();\n private readonly LoggerProxy: any;\n\n constructor(LoggerProxy: any) {\n this.LoggerProxy = LoggerProxy;\n }\n\n /**\n * This method is used to create a sendSlot for the given mediaType and returns the created sendSlot\n * @param {MultistreamRoapMediaConnection} mediaConnection MultistreamRoapMediaConnection for which a sendSlot needs to be created\n * @param {MediaType} mediaType MediaType for which a sendSlot needs to be created (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {boolean} active This is optional boolean to set the active state of the sendSlot. Default is true\n * @returns {SendSlot} slot The created sendSlot\n */\n public createSlot(\n mediaConnection: MultistreamRoapMediaConnection,\n mediaType: MediaType,\n active = true\n ): SendSlot {\n if (this.slots.has(mediaType)) {\n throw new Error(`Slot for ${mediaType} already exists`);\n }\n\n const slot: SendSlot = mediaConnection.createSendSlot(mediaType, active);\n\n this.slots.set(mediaType, slot);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->createSlot#Created slot for ${mediaType} with active ${active}`\n );\n\n return slot;\n }\n\n /**\n * This method is used to retrieve the sendSlot for the given mediaType\n * @param {MediaType} mediaType of which the slot needs to be retrieved\n * @returns {SendSlot}\n */\n public getSlot(mediaType: MediaType): SendSlot {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n return slot;\n }\n\n /**\n * Allow users to specify 'namedMediaGroups' to indicate which named media group its audio should be sent to.\n * @param {MediaType} mediaType MediaType of the sendSlot to which the audio stream needs to be send to the media group\n * @param {[]}namedMediaGroups - Allow users to specify 'namedMediaGroups'.If the value of 'namedMediaGroups' is zero,\n * named media group will be canceled and the audio stream will be sent to the floor.\n * @returns {void}\n */\n public setNamedMediaGroups(mediaType: MediaType, namedMediaGroups: NamedMediaGroup[]) {\n if (mediaType !== MediaType.AudioMain) {\n throw new Error(\n `sendSlotManager cannot set named media group which media type is ${mediaType}`\n );\n }\n\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n slot.setNamedMediaGroups(namedMediaGroups);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->setNamedMediaGroups#set named media group ${namedMediaGroups}`\n );\n }\n\n /**\n * Sets the source state override for the given media type.\n * @param {MediaType} mediaType - The type of media (must be MediaType.VideoMain to apply source state changes).\n * @param {StreamState | null} state - The state to set or null to clear the override value.\n * @returns {void}\n */\n public setSourceStateOverride(mediaType: MediaType, state: StreamState | null) {\n if (mediaType !== MediaType.VideoMain) {\n throw new Error(\n `sendSlotManager cannot set source state override which media type is ${mediaType}`\n );\n }\n\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n if (state) {\n slot.setSourceStateOverride(state);\n } else {\n slot.clearSourceStateOverride();\n }\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->setSourceStateOverride#set source state override for ${mediaType} to ${state}`\n );\n }\n\n /**\n * This method publishes the given stream to the sendSlot for the given mediaType\n * @param {MediaType} mediaType MediaType of the sendSlot to which a stream needs to be published (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {LocalStream} stream LocalStream to be published\n * @returns {Promise<void>}\n */\n public async publishStream(mediaType: MediaType, stream: LocalStream): Promise<void> {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n await slot.publishStream(stream);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->publishStream#Published stream for ${mediaType} and stream with label ${stream.label} and muted ${stream.muted}`\n );\n }\n\n /**\n * This method unpublishes the stream from the sendSlot of the given mediaType\n * @param {MediaType} mediaType MediaType of the sendSlot from which a stream needs to be unpublished (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @returns {Promise<void>}\n */\n public async unpublishStream(mediaType: MediaType): Promise<void> {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n await slot.unpublishStream();\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->unpublishStream#Unpublished stream for ${mediaType}`\n );\n }\n\n /**\n * This method is used to set the active state of the sendSlot for the given mediaType\n * @param {MediaType} mediaType The MediaType of the sendSlot for which the active state needs to be set (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {boolean} active The boolean to set the active state of the sendSlot. Default is true\n * @returns {void}\n */\n public setActive(mediaType: MediaType, active = true): void {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n slot.active = active;\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->setActive#Set active for ${mediaType} to ${active}`\n );\n }\n\n /**\n * This method is used to set the codec parameters for the sendSlot of the given mediaType\n * @param {MediaType} mediaType MediaType of the sendSlot for which the codec parameters needs to be set (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {Object} codecParameters\n * @returns {Promise<void>}\n */\n public async setCodecParameters(\n mediaType: MediaType,\n codecParameters: {\n [key: string]: string | undefined; // As per ts-sdp undefined is considered as a valid value to be used for codec parameters\n }\n ): Promise<void> {\n // These codec parameter changes underneath are SDP value changes that are taken care by WCME automatically. So no need for any change in streams from the web sdk side\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n await slot.setCodecParameters(codecParameters);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->setCodecParameters#Set codec parameters for ${mediaType} to ${codecParameters}`\n );\n }\n\n /**\n * This method is used to delete the codec parameters for the sendSlot of the given mediaType\n * @param {MediaType} mediaType MediaType of the sendSlot for which the codec parameters needs to be deleted (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {Array<String>} parameters Array of keys of the codec parameters to be deleted\n * @returns {Promise<void>}\n */\n public async deleteCodecParameters(mediaType: MediaType, parameters: string[]): Promise<void> {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n await slot.deleteCodecParameters(parameters);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->deleteCodecParameters#Deleted the following codec parameters -> ${parameters} for ${mediaType}`\n );\n }\n\n /**\n * This method is used to reset the SendSlotsManager by deleting all the sendSlots\n * @returns {undefined}\n */\n public reset(): void {\n this.slots.clear();\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["_internalMediaCore","require","SendSlotManager","exports","default","LoggerProxy","_classCallCheck2","_defineProperty2","_map","_createClass2","key","value","createSlot","mediaConnection","mediaType","active","arguments","length","undefined","slots","has","Error","concat","slot","createSendSlot","set","logger","info","getSlot","get","setNamedMediaGroups","namedMediaGroups","MediaType","AudioMain","setSourceStateOverride","state","VideoMain","currentStateOverride","getSourceStateOverride","sourceStateOverrides","clearSourceStateOverride","delete","_publishStream","_asyncToGenerator2","_regenerator","mark","_callee","stream","wrap","_callee$","_context","prev","next","publishStream","label","muted","stop","_x","_x2","apply","_unpublishStream","_callee2","_callee2$","_context2","unpublishStream","_x3","setActive","_setCodecParameters","_callee3","codecParameters","_callee3$","_context3","setCodecParameters","_x4","_x5","_deleteCodecParameters","_callee4","parameters","_callee4$","_context4","deleteCodecParameters","_x6","_x7","reset","clear"],"sources":["sendSlotManager.ts"],"sourcesContent":["import {\n SendSlot,\n MediaType,\n LocalStream,\n MultistreamRoapMediaConnection,\n NamedMediaGroup,\n StreamState,\n} from '@webex/internal-media-core';\n\n/**\n * This class is used to manage the sendSlots for the given media types.\n */\nexport default class SendSlotManager {\n private readonly slots: Map<MediaType, SendSlot> = new Map();\n private readonly LoggerProxy: any;\n private readonly sourceStateOverrides: Map<MediaType, StreamState> = new Map();\n\n /**\n * Constructor for SendSlotManager\n *\n * @param {any} LoggerProxy is used to log the messages\n * @constructor\n */\n constructor(LoggerProxy: any) {\n this.LoggerProxy = LoggerProxy;\n }\n\n /**\n * This method is used to create a sendSlot for the given mediaType and returns the created sendSlot\n * @param {MultistreamRoapMediaConnection} mediaConnection MultistreamRoapMediaConnection for which a sendSlot needs to be created\n * @param {MediaType} mediaType MediaType for which a sendSlot needs to be created (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {boolean} active This is optional boolean to set the active state of the sendSlot. Default is true\n * @returns {SendSlot} slot The created sendSlot\n */\n public createSlot(\n mediaConnection: MultistreamRoapMediaConnection,\n mediaType: MediaType,\n active = true\n ): SendSlot {\n if (this.slots.has(mediaType)) {\n throw new Error(`Slot for ${mediaType} already exists`);\n }\n\n const slot: SendSlot = mediaConnection.createSendSlot(mediaType, active);\n\n this.slots.set(mediaType, slot);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->createSlot#Created slot for ${mediaType} with active ${active}`\n );\n\n return slot;\n }\n\n /**\n * This method is used to retrieve the sendSlot for the given mediaType\n * @param {MediaType} mediaType of which the slot needs to be retrieved\n * @returns {SendSlot}\n */\n public getSlot(mediaType: MediaType): SendSlot {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n return slot;\n }\n\n /**\n * Allow users to specify 'namedMediaGroups' to indicate which named media group its audio should be sent to.\n * @param {MediaType} mediaType MediaType of the sendSlot to which the audio stream needs to be send to the media group\n * @param {[]}namedMediaGroups - Allow users to specify 'namedMediaGroups'.If the value of 'namedMediaGroups' is zero,\n * named media group will be canceled and the audio stream will be sent to the floor.\n * @returns {void}\n */\n public setNamedMediaGroups(mediaType: MediaType, namedMediaGroups: NamedMediaGroup[]) {\n if (mediaType !== MediaType.AudioMain) {\n throw new Error(\n `sendSlotManager cannot set named media group which media type is ${mediaType}`\n );\n }\n\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n slot.setNamedMediaGroups(namedMediaGroups);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->setNamedMediaGroups#set named media group ${namedMediaGroups}`\n );\n }\n\n /**\n * Sets the source state override for the given media type.\n * @param {MediaType} mediaType - The type of media (must be MediaType.VideoMain to apply source state changes).\n * @param {StreamState | null} state - The state to set or null to clear the override value.\n * @returns {void}\n */\n public setSourceStateOverride(mediaType: MediaType, state: StreamState | null) {\n if (mediaType !== MediaType.VideoMain) {\n throw new Error(\n `Invalid media type '${mediaType}'. Source state overrides are only applicable to ${MediaType.VideoMain}.`\n );\n }\n\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n const currentStateOverride = this.getSourceStateOverride(mediaType);\n if (currentStateOverride === state) {\n return;\n }\n\n if (state) {\n slot.setSourceStateOverride(state);\n this.sourceStateOverrides.set(mediaType, state);\n } else {\n slot.clearSourceStateOverride();\n this.sourceStateOverrides.delete(mediaType);\n }\n\n this.LoggerProxy.logger.info(\n `SendSlotManager->setSourceStateOverride#set source state override for ${mediaType} to ${state}`\n );\n }\n\n /**\n * Gets the source state override for the given media type.\n * @param {MediaType} mediaType - The type of media to get the source state override for.\n * @returns {StreamState | null} - The current source state override or null if not set.\n */\n private getSourceStateOverride(mediaType: MediaType): StreamState | null {\n if (mediaType !== MediaType.VideoMain) {\n throw new Error(\n `Invalid media type '${mediaType}'. Source state overrides are only applicable to ${MediaType.VideoMain}.`\n );\n }\n\n return this.sourceStateOverrides.get(mediaType) || null;\n }\n\n /**\n * This method publishes the given stream to the sendSlot for the given mediaType\n * @param {MediaType} mediaType MediaType of the sendSlot to which a stream needs to be published (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {LocalStream} stream LocalStream to be published\n * @returns {Promise<void>}\n */\n public async publishStream(mediaType: MediaType, stream: LocalStream): Promise<void> {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n await slot.publishStream(stream);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->publishStream#Published stream for ${mediaType} and stream with label ${stream.label} and muted ${stream.muted}`\n );\n }\n\n /**\n * This method unpublishes the stream from the sendSlot of the given mediaType\n * @param {MediaType} mediaType MediaType of the sendSlot from which a stream needs to be unpublished (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @returns {Promise<void>}\n */\n public async unpublishStream(mediaType: MediaType): Promise<void> {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n await slot.unpublishStream();\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->unpublishStream#Unpublished stream for ${mediaType}`\n );\n }\n\n /**\n * This method is used to set the active state of the sendSlot for the given mediaType\n * @param {MediaType} mediaType The MediaType of the sendSlot for which the active state needs to be set (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {boolean} active The boolean to set the active state of the sendSlot. Default is true\n * @returns {void}\n */\n public setActive(mediaType: MediaType, active = true): void {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n slot.active = active;\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->setActive#Set active for ${mediaType} to ${active}`\n );\n }\n\n /**\n * This method is used to set the codec parameters for the sendSlot of the given mediaType\n * @param {MediaType} mediaType MediaType of the sendSlot for which the codec parameters needs to be set (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {Object} codecParameters\n * @returns {Promise<void>}\n */\n public async setCodecParameters(\n mediaType: MediaType,\n codecParameters: {\n [key: string]: string | undefined; // As per ts-sdp undefined is considered as a valid value to be used for codec parameters\n }\n ): Promise<void> {\n // These codec parameter changes underneath are SDP value changes that are taken care by WCME automatically. So no need for any change in streams from the web sdk side\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n await slot.setCodecParameters(codecParameters);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->setCodecParameters#Set codec parameters for ${mediaType} to ${codecParameters}`\n );\n }\n\n /**\n * This method is used to delete the codec parameters for the sendSlot of the given mediaType\n * @param {MediaType} mediaType MediaType of the sendSlot for which the codec parameters needs to be deleted (AUDIO_MAIN/VIDEO_MAIN/AUDIO_SLIDES/VIDEO_SLIDES)\n * @param {Array<String>} parameters Array of keys of the codec parameters to be deleted\n * @returns {Promise<void>}\n */\n public async deleteCodecParameters(mediaType: MediaType, parameters: string[]): Promise<void> {\n const slot = this.slots.get(mediaType);\n\n if (!slot) {\n throw new Error(`Slot for ${mediaType} does not exist`);\n }\n\n await slot.deleteCodecParameters(parameters);\n\n this.LoggerProxy.logger.info(\n `SendSlotsManager->deleteCodecParameters#Deleted the following codec parameters -> ${parameters} for ${mediaType}`\n );\n }\n\n /**\n * This method is used to reset the SendSlotsManager by deleting all the sendSlots\n * @returns {undefined}\n */\n public reset(): void {\n this.slots.clear();\n }\n}\n"],"mappings":"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"}
@@ -145,6 +145,7 @@ export declare const DIALER_REGEX: {
145
145
  SIP_ADDRESS: RegExp;
146
146
  PHONE_NUMBER: RegExp;
147
147
  E164_FORMAT: RegExp;
148
+ INTERNAL_NUMBER: RegExp;
148
149
  };
149
150
  export declare const IPV4_REGEX: RegExp;
150
151
  export declare const VALID_EMAIL_ADDRESS: RegExp;
@@ -1117,3 +1118,8 @@ export declare const INITIAL_REGISTRATION_STATUS: {
1117
1118
  mercuryConnect: boolean;
1118
1119
  checkH264Support: boolean;
1119
1120
  };
1121
+ export declare const STAGE_MANAGER_TYPE: {
1122
+ LOGO: number;
1123
+ BACKGROUND: number;
1124
+ NAME_LABEL: number;
1125
+ };
@@ -0,0 +1,8 @@
1
+ export declare const EMPTY_HASH = "99aa06d3014798d86001c324468d497f";
2
+ export declare const DataSetNames: {
3
+ MAIN: string;
4
+ ATTENDEES: string;
5
+ ATD_ACTIVE: string;
6
+ ATD_UNMUTED: string;
7
+ SELF: string;
8
+ };
@@ -0,0 +1,128 @@
1
+ export type LeafDataItem = {
2
+ type: string;
3
+ id: number;
4
+ version: number;
5
+ };
6
+ /**
7
+ * HashTree is a data structure that organizes items into leaves based on their IDs,
8
+ */
9
+ declare class HashTree {
10
+ leaves: Array<Record<string, Record<number, LeafDataItem>>>;
11
+ leafHashes: Array<string>;
12
+ readonly numLeaves: number;
13
+ /**
14
+ * Constructs a new HashTree.
15
+ * @param {LeafDataItem[]} leafData Initial data to populate the tree.
16
+ * @param {number} numLeaves The number of leaf nodes in the tree. Must be 0 or a power of 2.
17
+ * @throws {Error} If numLeaves is not 0 or a power of 2.
18
+ */
19
+ constructor(leafData: LeafDataItem[], numLeaves: number);
20
+ /**
21
+ * Internal logic for adding or updating an item, without computing the leaf hash.
22
+ * @param {LeafDataItem} item The item to add or update.
23
+ * @returns {{put: boolean, index: (number|null)}} Object indicating if put and the leaf index.
24
+ * @private
25
+ */
26
+ private _putItemInternal;
27
+ /**
28
+ * Adds or updates a single item in the hash tree.
29
+ * @param {LeafDataItem} item The item to add or update.
30
+ * @returns {boolean} True if the item was added or updated, false otherwise (e.g., older version or tree has 0 leaves).
31
+ */
32
+ putItem(item: LeafDataItem): boolean;
33
+ /**
34
+ * Adds or updates multiple items in the hash tree.
35
+ * @param {LeafDataItem[]} items The array of items to add or update.
36
+ * @returns {boolean[]} An array of booleans indicating success for each item.
37
+ */
38
+ putItems(items: LeafDataItem[]): boolean[];
39
+ /**
40
+ * Internal logic for removing an item, without computing the leaf hash.
41
+ * @param {LeafDataItem} item The item to remove.
42
+ * @returns {{removed: boolean, index: (number|null)}} Object indicating if removed and the leaf index.
43
+ * @private
44
+ */
45
+ private _removeItemInternal;
46
+ /**
47
+ * Removes a single item from the hash tree.
48
+ * The removal is based on matching type, id, and the provided item's version
49
+ * being greater than or equal to the existing item's version.
50
+ * @param {LeafDataItem} item The item to remove.
51
+ * @returns {boolean} True if the item was removed, false otherwise.
52
+ */
53
+ removeItem(item: LeafDataItem): boolean;
54
+ /**
55
+ * Removes multiple items from the hash tree.
56
+ * @param {LeafDataItem[]} items The array of items to remove.
57
+ * @returns {boolean[]} An array of booleans indicating success for each item.
58
+ */
59
+ removeItems(items: LeafDataItem[]): boolean[];
60
+ /**
61
+ * Updates multiple items in the hash tree.
62
+ * This method can handle both adding and removing items based on the `operation` flag.
63
+ *
64
+ * @param {object[]} itemUpdates An array of objects containing `operation` flag and the `item` to update.
65
+ * @returns {boolean[]} An array of booleans indicating success for each operation.
66
+ */
67
+ updateItems(itemUpdates: {
68
+ operation: 'update' | 'remove';
69
+ item: LeafDataItem;
70
+ }[]): boolean[];
71
+ /**
72
+ * Computes the hash for a specific leaf.
73
+ * The hash is based on the sorted items within the leaf.
74
+ * @param {number} index The index of the leaf to compute the hash for.
75
+ * @returns {void}
76
+ */
77
+ computeLeafHash(index: number): void;
78
+ /**
79
+ * Computes all internal and leaf node hashes of the tree.
80
+ * Internal node hashes are computed bottom-up from the leaf hashes.
81
+ * @returns {string[]} An array of hash strings, with internal node hashes first, followed by leaf hashes.
82
+ * Returns `[EMPTY_HASH]` if the tree has 0 leaves.
83
+ */
84
+ computeTreeHashes(): string[];
85
+ /**
86
+ * Returns all hashes in the tree (internal nodes then leaf nodes).
87
+ * @returns {string[]} An array of hash strings.
88
+ */
89
+ getHashes(): string[];
90
+ /**
91
+ * Computes and returns the hash value of the root node.
92
+ * @returns {string} The root hash of the entire tree. Returns `EMPTY_HASH` if the tree has 0 leaves.
93
+ */
94
+ getRootHash(): string;
95
+ /**
96
+ * Gets the number of leaves in the tree.
97
+ * @returns {number} The number of leaves.
98
+ */
99
+ getLeafCount(): number;
100
+ /**
101
+ * Calculates the total number of items stored in the tree.
102
+ * @returns {number} The total number of items.
103
+ */
104
+ getTotalItemCount(): number;
105
+ /**
106
+ * Retrieves all data items from a specific leaf.
107
+ * @param {number} leafIndex The index of the leaf.
108
+ * @returns {LeafDataItem[]} An array of LeafDataItem in the specified leaf, sorted by ID,
109
+ * or an empty array if the index is invalid or leaf is empty.
110
+ */
111
+ getLeafData(leafIndex: number): LeafDataItem[];
112
+ /**
113
+ * Resizes the HashTree to have a new number of leaf nodes, redistributing all existing items.
114
+ * @param {number} newNumLeaves The new number of leaf nodes (must be 0 or a power of 2).
115
+ * @returns {boolean} true if the tree was resized, false if the size didn't change.
116
+ * @throws {Error} if newNumLeaves is not 0 or a power of 2.
117
+ */
118
+ resize(newNumLeaves: number): boolean;
119
+ /**
120
+ * Compares the tree's leaf hashes with an external set of hashes and returns the indices of differing leaf nodes.
121
+ * The externalHashes array is expected to contain all node hashes (internal followed by leaves),
122
+ * similar to the output of getHashes().
123
+ * @param {string[]} externalHashes An array of hash strings (internal node hashes then leaf hashes).
124
+ * @returns {number[]} An array of indices of the leaf nodes that have different hashes.
125
+ */
126
+ diffHashes(externalHashes: string[]): number[];
127
+ }
128
+ export default HashTree;
@@ -0,0 +1,152 @@
1
+ import HashTree from './hashTree';
2
+ import { Enum } from '../constants';
3
+ export interface DataSet {
4
+ url: string;
5
+ root: string;
6
+ version: number;
7
+ leafCount: number;
8
+ name: string;
9
+ idleMs: number;
10
+ backoff: {
11
+ maxMs: number;
12
+ exponent: number;
13
+ };
14
+ }
15
+ export declare const ObjectType: {
16
+ readonly participant: "participant";
17
+ readonly self: "self";
18
+ readonly locus: "locus";
19
+ };
20
+ export type ObjectType = Enum<typeof ObjectType>;
21
+ export interface HtMeta {
22
+ elementId: {
23
+ type: ObjectType;
24
+ id: number;
25
+ version: number;
26
+ };
27
+ dataSetNames: string[];
28
+ }
29
+ export interface HashTreeObject {
30
+ htMeta: HtMeta;
31
+ data: Record<string, any>;
32
+ }
33
+ export interface RootHashMessage {
34
+ dataSets: Array<DataSet>;
35
+ }
36
+ export interface HashTreeMessage {
37
+ dataSets: Array<DataSet>;
38
+ locusStateElements?: Array<HashTreeObject>;
39
+ locusSessionId?: string;
40
+ locusUrl?: string;
41
+ }
42
+ interface InternalDataSet extends DataSet {
43
+ hashTree: HashTree;
44
+ timer?: ReturnType<typeof setTimeout>;
45
+ }
46
+ type WebexRequestMethod = (options: Record<string, any>) => Promise<any>;
47
+ export declare const LocusInfoUpdateType: {
48
+ readonly OBJECTS_UPDATED: "OBJECTS_UPDATED";
49
+ readonly MEETING_ENDED: "MEETING_ENDED";
50
+ };
51
+ export type LocusInfoUpdateType = Enum<typeof LocusInfoUpdateType>;
52
+ export type LocusInfoUpdateCallback = (updateType: LocusInfoUpdateType, data?: {
53
+ updatedObjects: HashTreeObject[];
54
+ }) => void;
55
+ /**
56
+ * Parses hash tree eventing locus data
57
+ */
58
+ declare class HashTreeParser {
59
+ dataSets: Record<string, InternalDataSet>;
60
+ webexRequest: WebexRequestMethod;
61
+ locusInfoUpdateCallback: LocusInfoUpdateCallback;
62
+ debugId: string;
63
+ /**
64
+ * Constructor for HashTreeParser
65
+ * @param {Object} options
66
+ * @param {Object} options.initialLocus The initial locus data containing the hash tree information
67
+ */
68
+ constructor(options: {
69
+ initialLocus: {
70
+ dataSets: Array<DataSet>;
71
+ locus: any;
72
+ };
73
+ webexRequest: WebexRequestMethod;
74
+ locusInfoUpdateCallback: LocusInfoUpdateCallback;
75
+ debugId: string;
76
+ });
77
+ /**
78
+ * Each dataset exists at a different place in the dto
79
+ * iterate recursively over the locus and if it has a htMeta key,
80
+ * create an object with the type, id and version and add it to the appropriate leafData array
81
+ *
82
+ * @param {any} locus - The current part of the locus being processed
83
+ * @returns {any} - An object mapping dataset names to arrays of leaf data
84
+ */
85
+ private analyzeLocusHtMeta;
86
+ /**
87
+ * Checks if the provided hash tree message indicates the end of the meeting and that there won't be any more updates.
88
+ *
89
+ * @param {HashTreeMessage} message - The hash tree message to check
90
+ * @returns {boolean} - Returns true if the message indicates the end of the meeting, false otherwise
91
+ */
92
+ private isEndMessage;
93
+ /**
94
+ * Handles the root hash heartbeat message
95
+ *
96
+ * @param {RootHashMessage} message - The root hash heartbeat message
97
+ * @returns {void}
98
+ */
99
+ handleRootHashHeartBeatMessage(message: RootHashMessage): void;
100
+ /**
101
+ * This method should be called when we receive a partial locus DTO that contains dataSets and htMeta information
102
+ * It updates the hash trees with the new leaf data based on the received Locus
103
+ *
104
+ * @param {Object} update - The locus update containing data sets and locus information
105
+ * @returns {void}
106
+ */
107
+ handleLocusUpdate(update: {
108
+ dataSets?: Array<DataSet>;
109
+ locus: any;
110
+ }): void;
111
+ /**
112
+ * Handles incoming hash tree messages, updates the hash trees and calls locusInfoUpdateCallback
113
+ *
114
+ * @param {HashTreeMessage} message - The hash tree message containing data sets and objects to be processed
115
+ * @returns {void}
116
+ */
117
+ handleMessage(message: HashTreeMessage): void;
118
+ /**
119
+ * Calculates a weighted backoff time that should be used for syncs
120
+ *
121
+ * @param {Object} backoff - The backoff configuration containing maxMs and exponent
122
+ * @returns {number} - A weighted backoff time based on the provided configuration, using algorithm supplied by Locus team
123
+ */
124
+ private getWeightedBackoffTime;
125
+ /**
126
+ * Runs the sync algorithm for the given data set.
127
+ *
128
+ * @param {DataSet} receivedDataSet - The data set to run the sync algorithm for.
129
+ * @returns {void}
130
+ */
131
+ private runSyncAlgorithm;
132
+ /**
133
+ * Stops all timers for the data sets to prevent any further sync attempts.
134
+ * @returns {void}
135
+ */
136
+ stopAllTimers(): void;
137
+ /**
138
+ * Gets the current hashes from the locus for a specific data set.
139
+ * @param {string} dataSetName
140
+ * @returns {string[]}
141
+ */
142
+ private getHashesFromLocus;
143
+ /**
144
+ * Sends a sync request to Locus for the specified data set.
145
+ *
146
+ * @param {InternalDataSet} dataSet The data set to sync.
147
+ * @param {Record<number, LeafDataItem[]>} mismatchedLeavesData The mismatched leaves data to include in the sync request.
148
+ * @returns {Promise<HashTreeObject[]>}
149
+ */
150
+ private sendSyncRequestToLocus;
151
+ }
152
+ export default HashTreeParser;