Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

util.lib.lua 7.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. local jid = require "util.jid";
  2. local runner, waiter = require "util.async".runner, require "util.async".waiter;
  3. local muc_domain_prefix
  4. = module:get_option_string("muc_mapper_domain_prefix", "conference");
  5. -- defaults to module.host, the module that uses the utility
  6. local muc_domain_base
  7. = module:get_option_string("muc_mapper_domain_base", module.host);
  8. -- The "real" MUC domain that we are proxying to
  9. local muc_domain = module:get_option_string(
  10. "muc_mapper_domain", muc_domain_prefix.."."..muc_domain_base);
  11. local escaped_muc_domain_base = muc_domain_base:gsub("%p", "%%%1");
  12. local escaped_muc_domain_prefix = muc_domain_prefix:gsub("%p", "%%%1");
  13. -- The pattern used to extract the target subdomain
  14. -- (e.g. extract 'foo' from 'foo.muc.example.com')
  15. local target_subdomain_pattern
  16. = "^"..escaped_muc_domain_prefix..".([^%.]+)%."..escaped_muc_domain_base;
  17. --- Utility function to check and convert a room JID from
  18. -- virtual room1@muc.foo.example.com to real [foo]room1@muc.example.com
  19. -- @param room_jid the room jid to match and rewrite if needed
  20. -- @return returns room jid [foo]room1@muc.example.com when it has subdomain
  21. -- otherwise room1@muc.example.com(the room_jid value untouched)
  22. local function room_jid_match_rewrite(room_jid)
  23. local node, host, resource = jid.split(room_jid);
  24. local target_subdomain = host and host:match(target_subdomain_pattern);
  25. if not target_subdomain then
  26. module:log("debug", "No need to rewrite out 'to' %s", room_jid);
  27. return room_jid;
  28. end
  29. -- Ok, rewrite room_jid address to new format
  30. local new_node, new_host, new_resource
  31. = "["..target_subdomain.."]"..node, muc_domain, resource;
  32. room_jid = jid.join(new_node, new_host, new_resource);
  33. module:log("debug", "Rewrote to %s", room_jid);
  34. return room_jid
  35. end
  36. --- Finds and returns room by its jid
  37. -- @param room_jid the room jid to search in the muc component
  38. -- @return returns room if found or nil
  39. function get_room_from_jid(room_jid)
  40. local _, host = jid.split(room_jid);
  41. local component = hosts[host];
  42. if component then
  43. local muc = component.modules.muc
  44. if muc and rawget(muc,"rooms") then
  45. -- We're running 0.9.x or 0.10 (old MUC API)
  46. return muc.rooms[room_jid];
  47. elseif muc and rawget(muc,"get_room_from_jid") then
  48. -- We're running >0.10 (new MUC API)
  49. return muc.get_room_from_jid(room_jid);
  50. else
  51. return
  52. end
  53. end
  54. end
  55. function wrap_async_run(event,handler)
  56. -- Grab a local response so that we can send the http response when
  57. -- the handler is done.
  58. local response = event.response;
  59. local async_func = runner(function (event)
  60. local result = handler(event);
  61. -- if it is a number, it is a status code, else it is the body
  62. -- result we will return
  63. if (tonumber(result) ~= nil) then
  64. response.status_code = result;
  65. else
  66. response.body = result;
  67. end;
  68. -- Send the response to the waiting http client.
  69. response:send();
  70. end)
  71. async_func:run(event)
  72. -- return true to keep the client http connection open.
  73. return true;
  74. end
  75. function async_handler_wrapper(event, handler)
  76. -- Grab a local response so that we can send the http response when
  77. -- the handler is done.
  78. local response = event.response;
  79. local async_func = runner(
  80. function (event)
  81. local result = handler(event)
  82. -- If there is a status code in the result from the
  83. -- wrapped handler then add it to the response.
  84. if tonumber(result.status_code) ~= nil then
  85. response.status_code = result.status_code
  86. end
  87. -- If there are headers in the result from the
  88. -- wrapped handler then add them to the response.
  89. if result.headers ~= nil then
  90. response.headers = result.headers
  91. end
  92. -- Send the response to the waiting http client with
  93. -- or without the body from the wrapped handler.
  94. if result.body ~= nil then
  95. response:send(result.body)
  96. else
  97. response:send();
  98. end
  99. end
  100. )
  101. async_func:run(event)
  102. -- return true to keep the client http connection open.
  103. return true;
  104. end
  105. --- Updates presence stanza, by adding identity node
  106. -- @param stanza the presence stanza
  107. -- @param user the user to which presence we are updating identity
  108. -- @param group the group of the user to which presence we are updating identity
  109. -- @param creator_user the user who created the user which presence we
  110. -- are updating (this is the poltergeist case, where a user creates
  111. -- a poltergeist), optional.
  112. -- @param creator_group the group of the user who created the user which
  113. -- presence we are updating (this is the poltergeist case, where a user creates
  114. -- a poltergeist), optional.
  115. function update_presence_identity(
  116. stanza, user, group, creator_user, creator_group)
  117. -- First remove any 'identity' element if it already
  118. -- exists, so it cannot be spoofed by a client
  119. stanza:maptags(
  120. function(tag)
  121. for k, v in pairs(tag) do
  122. if k == "name" and v == "identity" then
  123. return nil
  124. end
  125. end
  126. return tag
  127. end
  128. )
  129. module:log("debug",
  130. "Presence after previous identity stripped: %s", tostring(stanza));
  131. stanza:tag("identity"):tag("user");
  132. for k, v in pairs(user) do
  133. stanza:tag(k):text(v):up();
  134. end
  135. stanza:up();
  136. -- Add the group information if it is present
  137. if group then
  138. stanza:tag("group"):text(group):up();
  139. end
  140. -- Add the creator user information if it is present
  141. if creator_user then
  142. stanza:tag("creator_user");
  143. for k, v in pairs(creator_user) do
  144. stanza:tag(k):text(v):up();
  145. end
  146. stanza:up();
  147. -- Add the creator group information if it is present
  148. if creator_group then
  149. stanza:tag("creator_group"):text(creator_group):up();
  150. end
  151. stanza:up();
  152. end
  153. module:log("debug",
  154. "Presence with identity inserted %s", tostring(stanza))
  155. end
  156. -- Utility function to check whether feature is present and enabled. Allow
  157. -- a feature if there are features present in the session(coming from
  158. -- the token) and the value of the feature is true.
  159. -- If features is not present in the token we skip feature detection and allow
  160. -- everything.
  161. function is_feature_allowed(session, feature)
  162. if (session.jitsi_meet_context_features == nil
  163. or session.jitsi_meet_context_features[feature] == "true") then
  164. return true;
  165. else
  166. return false;
  167. end
  168. end
  169. return {
  170. is_feature_allowed = is_feature_allowed;
  171. get_room_from_jid = get_room_from_jid;
  172. wrap_async_run = wrap_async_run;
  173. async_handler_wrapper = async_handler_wrapper;
  174. room_jid_match_rewrite = room_jid_match_rewrite;
  175. update_presence_identity = update_presence_identity;
  176. };