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