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.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  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. this.isGuest = true;
  59. if(!jwt)
  60. return;
  61. this.isGuest = config.enableUserRolesBasedOnToken !== true;
  62. this.jwt = jwt;
  63. //External API settings
  64. this.externalAPISettings = {
  65. forceEnable: true,
  66. enabledEvents: ["video-conference-joined", "video-conference-left"]
  67. };
  68. this._decode();
  69. // Use JWT param as token if there is not other token set and if the
  70. // iss field is not anonymous. If you want to pass data with JWT token
  71. // but you don't want to pass the JWT token for verification the iss
  72. // field should be set to "anonymous"
  73. if(!config.token && this.payload && this.payload.iss !== "anonymous")
  74. config.token = jwt;
  75. }
  76. /**
  77. * Decodes the JWT token and sets the decoded data to properties.
  78. */
  79. _decode() {
  80. this.decodedJWT = jws.decode(jwt);
  81. if(!this.decodedJWT || !this.decodedJWT.payload)
  82. return;
  83. this.payload = this.decodedJWT.payload;
  84. if(!this.payload.context)
  85. return;
  86. let callerData = this.payload.context.user;
  87. let calleeData = this.payload.context.callee;
  88. if(callerData)
  89. this.caller = new User(callerData.name, callerData.email,
  90. callerData.avatarUrl);
  91. if(calleeData)
  92. this.callee = new User(calleeData.name, calleeData.email,
  93. calleeData.avatarUrl);
  94. }
  95. }
  96. /**
  97. * Stores the TokenData instance.
  98. */
  99. let data = null;
  100. /**
  101. * Returns the data variable. Creates new TokenData instance if <tt>data</tt>
  102. * variable is null.
  103. */
  104. export default function getTokenData() {
  105. if(!data)
  106. data = new TokenData(jwt);
  107. return data;
  108. }