You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

TokenData.js 2.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. /* global getConfigParamsFromUrl, config */
  2. /**
  3. * Parses and handles JWT tokens. Sets config.token.
  4. */
  5. import * as jws from "jws";
  6. /**
  7. * Get the JWT token from the URL.
  8. */
  9. let params = getConfigParamsFromUrl("search", true);
  10. let jwt = params.jwt;
  11. /**
  12. * Implements a user of conference.
  13. */
  14. class User {
  15. /**
  16. * @param name {string} the name of the user.
  17. * @param email {string} the email of the user.
  18. * @param avatarUrl {string} the URL for the avatar of the user.
  19. */
  20. constructor(name, email, avatarUrl) {
  21. this._name = name;
  22. this._email = email;
  23. this._avatarUrl = avatarUrl;
  24. }
  25. /**
  26. * GETERS START.
  27. */
  28. /**
  29. * Returns the name property
  30. */
  31. getName() {
  32. return this._name;
  33. }
  34. /**
  35. * Returns the email property
  36. */
  37. getEmail() {
  38. return this._email;
  39. }
  40. /**
  41. * Returns the URL of the avatar
  42. */
  43. getAvatarUrl() {
  44. return this._avatarUrl;
  45. }
  46. /**
  47. * GETERS END.
  48. */
  49. }
  50. /**
  51. * Represent the data parsed from the JWT token
  52. */
  53. class TokenData{
  54. /**
  55. * @param {string} the JWT token
  56. */
  57. constructor(jwt) {
  58. if(!jwt)
  59. return;
  60. this.jwt = jwt;
  61. //External API settings
  62. this.externalAPISettings = {
  63. forceEnable: true,
  64. enabledEvents: ["video-conference-joined", "video-conference-left"]
  65. };
  66. this._decode();
  67. // Use JWT param as token if there is not other token set and if the
  68. // iss field is not anonymous. If you want to pass data with JWT token
  69. // but you don't want to pass the JWT token for verification the iss
  70. // field should be set to "anonymous"
  71. if(!config.token && this.payload && this.payload.iss !== "anonymous")
  72. config.token = jwt;
  73. }
  74. /**
  75. * Decodes the JWT token and sets the decoded data to properties.
  76. */
  77. _decode() {
  78. this.decodedJWT = jws.decode(jwt);
  79. if(!this.decodedJWT || !this.decodedJWT.payload)
  80. return;
  81. this.payload = this.decodedJWT.payload;
  82. if(!this.payload.context)
  83. return;
  84. let callerData = this.payload.context.user;
  85. let calleeData = this.payload.context.callee;
  86. if(callerData)
  87. this.caller = new User(callerData.name, callerData.email,
  88. callerData.avatarUrl);
  89. if(calleeData)
  90. this.callee = new User(calleeData.name, calleeData.email,
  91. calleeData.avatarUrl);
  92. }
  93. }
  94. /**
  95. * Stores the TokenData instance.
  96. */
  97. let data = null;
  98. /**
  99. * Returns the data variable. Creates new TokenData instance if <tt>data</tt>
  100. * variable is null.
  101. */
  102. export default function getTokenData() {
  103. if(!data)
  104. data = new TokenData(jwt);
  105. return data;
  106. }