您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

jsync_lib.js 34KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617
  1. "use strict";
  2. // makestache template info
  3. // the following string tells my make scripts its fine to overwtite this the library would have had a template str in the middle of the str
  4. // BUILT_FILE_OVERWRITE_ALLOWED
  5. // ... C:\ws\repos\jitsi_main\jsync\jsyncdb\js_client\jsync_lib.js
  6. // /* */
  7. (function (){
  8. var isProxy,tlu,msto_z
  9. var pf,msto_prx
  10. // jsync:dep.js
  11. // ------------------------------------------------------------------------------------------------
  12. // window.w = window.w || {}
  13. // w.clog = console.log
  14. var clog = console.log
  15. // var clog = w.clog
  16. // clog("??")
  17. function nop(){}
  18. window.glob_u = window.glob_u || {
  19. cb:{},
  20. fns:{},
  21. cls:{},
  22. tvar:{},
  23. data:{},
  24. prom:{},
  25. rrefs:{},
  26. xj:{},
  27. templates:{},
  28. }
  29. glob_u.fns.gen_sort_attr = function gen_sort_attr(attr){
  30. return function gsort(a0,a1){
  31. if (a0[attr] > a1[attr]){
  32. return 1
  33. } else if (a0[attr] < a1[attr]){
  34. return -1
  35. } else {
  36. return 0
  37. }
  38. }
  39. }
  40. glob_u.fns.find_attr = function find_attr(elm,indx,arr){
  41. if (elm && elm[this.attr] == this.val){
  42. return 1
  43. }
  44. }
  45. glob_u.fns.splice_out = function splice_out(arr,elm){
  46. let i = arr.indexOf(elm)
  47. if (i != -1){
  48. return arr.splice(i,1)
  49. }
  50. }
  51. function jclone(obj){
  52. return Array.isArray(obj) ? $.extend(true,[],obj) : $.extend(true,{},obj)
  53. }
  54. function jx(obj){
  55. return JSON.parse(JSON.stringify(obj))
  56. }
  57. function jclone_rval(obj){
  58. if (typeof(obj) != "object"){
  59. return obj
  60. } else if (Array.isArray(obj)) {
  61. return $.extend(true,[],obj)
  62. } else {
  63. return $.extend(true,{},obj)
  64. }
  65. }
  66. // window.jc = jclone
  67. window.jc = jclone_rval
  68. // TODO:JFI eventually merge
  69. // j9\dev_dep\misc_dev.js
  70. glob_u.fns.gen_ord_decs = function(ord,cb_prefix){
  71. var reg_cb = function(cb,key_name,cb_name,override_level,push){
  72. return ord.reg_cb(cb,cb_prefix+key_name,cb_name,override_level,push)
  73. }
  74. var run_cbs_lz = function(key,arg_obj,lazy=1){
  75. if (lazy && cb_prefix+key in ord.cb_sto){
  76. return ord.run_cbs(cb_prefix+key,arg_obj)
  77. }
  78. }
  79. var run_cbs = function(key,arg_obj){
  80. return ord.run_cbs(cb_prefix+key,arg_obj)
  81. // split out later maybe?
  82. }
  83. function req_batch_run(key,arg_obj,combine){
  84. return ord.req_batch_run(cb_prefix+key,arg_obj)
  85. }
  86. reg_cb.ord = ord
  87. reg_cb.cb_prefix = cb_prefix
  88. run_cbs.ord = ord
  89. run_cbs.cb_prefix = cb_prefix
  90. run_cbs_lz.ord = ord
  91. run_cbs_lz.cb_prefix = cb_prefix
  92. return {reg_cb,run_cbs,run_cbs_lz,req_batch_run}
  93. }
  94. // duplicated in jdev0
  95. glob_u.fns.merge_partial_template = function merge_partial_template(main,template){
  96. let t = $.extend(true,{},template,main)
  97. return $.extend(true,main,t)
  98. }
  99. // jsync:ord.js
  100. // ------------------------------------------------------------------------------------------------
  101. {
  102. var dflt_opts = {
  103. // sort_fn:gen_sort_attr("override_level"),
  104. sort_fn:glob_u.fns.gen_sort_attr("override_level"),
  105. log_level:0,
  106. // ns:"",
  107. }
  108. class BoundObj{
  109. constructor(){
  110. this.init()
  111. }
  112. init(){
  113. let k,v,i,j
  114. for ([k,v] of Object.entries(Object.getOwnPropertyDescriptors(this.__proto__))){
  115. if (k.endsWith("_ub") && typeof(v.value) == "function"){
  116. // clog("UB",k,k.slice(1,-3))
  117. j = v.value.bind(this)
  118. j.meta_str = "bound_fn"
  119. this[k.slice(1,-3)] = j
  120. }
  121. }
  122. }
  123. /*
  124. mx2_ub(){
  125. clog("Mx2")
  126. }
  127. */
  128. }
  129. function resolveNow(){}
  130. async function resolveSoon(){}
  131. // class reg_cb_ord{
  132. class reg_cb_ord extends BoundObj{
  133. // con
  134. constructor(opts){
  135. super()
  136. this.opts = Object.assign({},dflt_opts,opts)
  137. this.r = Object.assign(this,dflt_opts,opts)
  138. // this.sort_fn = this.opts
  139. this.cb_sto = {}
  140. this.batch = {}
  141. this._orig_opts = opts
  142. // clog("v2 ",this)
  143. }
  144. _promise_test_ub(arg1){
  145. // clog()
  146. console.log("promise_test",{that:this,arg1})
  147. // console.log("promise_test",{that:this,opts:this.opts,arg1})
  148. }
  149. promise_test_init(){
  150. var p = new Promise((resolve,reject)=>{
  151. resolve("Promise.~")
  152. })
  153. p.then(this.promise_test)
  154. console.log("promise_test_init",{that:this,opts:this.opts})
  155. }
  156. _batch_run_ub(){
  157. this.batch.WillRun = false
  158. var batched_events = this.batch.batched_events
  159. var i,k,v
  160. for ([k,v] of Object.entries(batched_events.combinable)){
  161. this.run_cbs(v.key,v.arg_obj)
  162. }
  163. for ([k,v] of Object.entries(batched_events.unique)){
  164. this.run_cbs(v.key,v.arg_obj)
  165. }
  166. this.batch.batched_events = {
  167. combinable:{},
  168. unique:[],
  169. }
  170. }
  171. _req_batch_run_ub(key,arg_obj,combine){
  172. if (this.batch.WillRun != true) {
  173. this.batch.WillRun = true
  174. this.batch.batched_events = {
  175. combinable:{},
  176. unique:[],
  177. }
  178. new Promise((resolve,reject)=>{
  179. resolve("Promise.~")
  180. }).then(this.batch_run)
  181. }
  182. if (this.batch.WillRun == true){
  183. if (combine){
  184. this.batch.batched_events.combinable[key] = {key,arg_obj,combine}
  185. } else {
  186. this.batch.batched_events.unique.push({key,arg_obj,combine})
  187. }
  188. }
  189. if (!(this.batch.WillRun == true ||this.batch.WillRun == false )){
  190. console.error("::")
  191. throw "req_batch_run err"
  192. }
  193. }
  194. _reg_cb_ub(cb,key_name,cb_name,override_level = 100,push=1){
  195. if (typeof(cb) != "function"){
  196. console.error("callback is not a function. setting push=r","\ncb:",cb)
  197. push = "r"
  198. // console.error("callback:",cb," is not a function")
  199. }
  200. // var this.cb_sto = {}
  201. var cb_sort = nop
  202. if (!this.cb_sto[key_name]){
  203. this.cb_sto[key_name] = []
  204. }
  205. // this.cb_sto[key_name].find(find_html_cb,{fn_key:cb_name})
  206. // splice_out_ti(this.cb_sto[key_name],this.cb_sto[key_name].find(find_html_cb,{fn_key:cb_name}))
  207. // var cbo0= this.cb_sto[key_name].find(glob_td.fn.find_html_cb,{fn_key:cb_name})
  208. // var cbo0= this.cb_sto[key_name].find(find_attr,{fn_key:cb_name})
  209. var cbo0= this.cb_sto[key_name].find(glob_u.fns.find_attr,{attr:"fn_key",val:cb_name})
  210. // clog(cbo0)
  211. glob_u.fns.splice_out(this.cb_sto[key_name],cbo0)
  212. // tn2t.arr.
  213. // splice_out_cb
  214. let cb_obj = {
  215. cb,
  216. hkey:key_name,
  217. fn_key:cb_name,
  218. override_level,
  219. }
  220. if (push=="r"){
  221. } else if (push){
  222. this.cb_sto[key_name].push(cb_obj)
  223. } else {
  224. this.cb_sto[key_name].unshift(cb_obj)
  225. }
  226. this.cb_sto[key_name].sort(this.sort_fn)
  227. }
  228. _run_cbs_ub(key,arg_obj){
  229. var k,v
  230. var o = {
  231. // html_key:key,cbs:glob_mx.html_cb[key],
  232. }
  233. // dlog("RUN_HOOK_CB??",key,glob_mx.hook_cb[key])
  234. // clog("ORD:RUN",key,arg_obj)
  235. try {
  236. this.opts.log_level ? clog("run_cbs",arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key]}) : 0
  237. var rmv_fns = []
  238. for ([k,v] of Object.entries(this.cb_sto[key]|| {}) ) {
  239. // dlog("RUN_HOOK_CB:",k)
  240. // clog("run_html_cbs:",k,v)
  241. this.opts.log_level > 1 ? clog("run_cbs_e",arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key],k,v}) : 0
  242. v.cb(arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key],k,v})
  243. if (v.remove_after_exe){
  244. rmv_fns.push(v)
  245. }
  246. // v(o)
  247. }
  248. for ([k,v] of Object.entries(rmv_fns|| {}) ) {
  249. glob_u.fns.splice_out(this.cb_sto[key],v)
  250. }
  251. // return {arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key]}}
  252. return {arg_obj,o,info:{that:this,hkey:key,cbs:this.cb_sto[key],rmv_fns}}
  253. } catch(err){
  254. console.error("ti_v_cb err:",err)
  255. }
  256. }
  257. }
  258. window.glob_u.cls.reg_cb_ord = reg_cb_ord
  259. }
  260. // jsync:ws.js
  261. // ------------------------------------------------------------------------------------------------
  262. // FILE:WS0
  263. // TODO:JFI this file probably causes memory leaks
  264. window.glob_u.ws = window.glob_u.ws || {
  265. sockets:{},
  266. fns:{},
  267. flags:{},
  268. }
  269. window.glob_u.trc = window.glob_u.trc || {
  270. arr:[],
  271. }
  272. // TODO:JFI I should factor out my development junk
  273. function trc_sto(s,o){
  274. if (!glob_u?.prom?.init_db_resolve?.resolved){
  275. var elm = {name:s,o,timestamp:Date.now()}
  276. glob_u.trc.arr.push(elm)
  277. // clog("_trc:sto",s,o.sto_event_type,elm.timestamp,o)
  278. }
  279. }
  280. window.glob_u.ws.fns.reconnect = function reconnect(o,close_event){
  281. connect_ws(o.params)
  282. }
  283. // TODO:JFI These event handlers are less generic now
  284. window.glob_u.ws.fns.onclose = function onclose(event){
  285. clog("WS_CLOSE",{that:this,readyState:this.readyState,args:[...arguments]})
  286. // glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_CLOSE:",{event,that:this})
  287. glob_u.ws.sockets[this.params.socket_name].params.ord.run_cbs("WS_CLOSE:",{event,that:this})
  288. setTimeout(this.params.fns.reconnect,1000)
  289. }
  290. window.glob_u.ws.fns.onmessage = function onmessage(event){
  291. // clog("WS_MESSAGE",{that:this,args:[...arguments]})
  292. // glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_MESSAGE:",{event,that:this})
  293. glob_u.ws.sockets[this.params.socket_name].params.ord.run_cbs("WS_MESSAGE:",{event,that:this})
  294. }
  295. window.glob_u.ws.fns.onerror = function onerror(event){
  296. // clog("WS_ERROR",{that:this,args:[...arguments]})
  297. // glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_ERROR:",{event,that:this})
  298. glob_u.ws.sockets[this.params.socket_name].params.ord.run_cbs("WS_ERROR:",{event,that:this})
  299. }
  300. window.glob_u.ws.fns.onopen = function onopen(event){
  301. // clog("WS_OPEN???",{that:this,args:[...arguments]},{on_open_once:this.on_open_once,on_open_cbs:this.params.on_open_cbs})
  302. // glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_OPEN:",{event,that:this})
  303. glob_u.ws.sockets[this.params.socket_name].params.ord.run_cbs("WS_OPEN:",{event,that:this})
  304. return
  305. var cb
  306. if (this.on_open_once){
  307. for (cb of this.on_open_once){
  308. cb(event,this)
  309. }
  310. if (this?.params?.on_open_cbs){
  311. for (cb of this?.params?.on_open_cbs){
  312. cb(event,this)
  313. }
  314. }
  315. }
  316. }
  317. window.glob_u.ws.fns.ws_fns_factory = function ws_fns_factory(socket_opts){
  318. var socket_name = socket_opts.socket_name
  319. // const sockets =
  320. var v1 = "init"
  321. var fns = {
  322. get_socket(o){
  323. return glob_u.ws.sockets[socket_name]
  324. },
  325. reconnect(){
  326. var socket = fns.get_socket()
  327. clog("RECONNECT",socket_opts,socket,socket?.DoNotReconnect)
  328. // if (socket.DoNotReconnect || socket.params.DoNotReconnect || glob_u.ws?.flags?.DoNotReconnect){
  329. if (socket.DoNotReconnect || !socket.params.AutoReconnect || glob_u.ws?.flags?.DoNotReconnect){
  330. clog("RECONNECTION NOT ATTEMPTED",socket_opts)
  331. return
  332. } else {
  333. }
  334. connect_ws(socket_opts)
  335. },
  336. log_var(o){
  337. clog("var:",v1)
  338. return v1
  339. },
  340. set_var(val){
  341. v1 = val
  342. return v1
  343. },
  344. send_text(o){
  345. var socket = fns.get_socket()
  346. clog("send_text",{that:this,fns})
  347. socket.send(JSON.stringify(o));
  348. },
  349. jsend(o){
  350. var socket = fns.get_socket()
  351. // clog("!!!",{that:this,fns})
  352. socket.send(JSON.stringify(o));
  353. },
  354. }
  355. return fns
  356. }
  357. function connect_ws(o= {}){
  358. // clog("connect_ws:",o,jc(o))
  359. glob_u.fns.merge_partial_template(o,{on_open_cbs:[]})
  360. var sockets = window.glob_u.ws.sockets
  361. var old_socket = sockets[o.socket_name]
  362. if (old_socket && old_socket.readyState == 1){
  363. clog(`WS ${o.socket_name} is already CONNECTED:`,old_socket , o)
  364. return
  365. } else if (old_socket && (old_socket.readyState != 3 && old_socket.readyState != undefined )){
  366. clog(`WS ${o.socket_name} exsists and in not closed:`,old_socket , o)
  367. return
  368. }
  369. var socket = new WebSocket(o.url)
  370. socket.on_open_once = []
  371. socket.pre_init_msgs = []
  372. socket.params = o
  373. // if ()
  374. Object.assign(o.fns, window.glob_u.ws.fns.ws_fns_factory(o))
  375. // Object.assign(o.fns2, window.glob_u.ws.fns.ws_fns_factory(o))
  376. Object.assign(socket,o.methods)
  377. sockets[o.socket_name]=socket
  378. // o.jsend ? socket.jsend = o.jsend: 0
  379. // clog("CONNECTING WS:",{o,socket})
  380. return [socket,old_socket]
  381. }
  382. // FILE:WS1
  383. function create_ws_ord(){
  384. if (!glob_u.cb.ws){
  385. var ord = new glob_u.cls.reg_cb_ord()
  386. glob_u.cb.ws = ord
  387. glob_u.cb.ws.reg_cb = ord.reg_cb
  388. glob_u.cb.ws.run_cbs = ord.run_cbs
  389. glob_u.cb.ws.STO_EVENT = glob_u.fns.gen_ord_decs(glob_u.cb.ws,"STO_EVENT:")
  390. // glob_u.cb.ord_v1.estr = glob_u.fns.gen_ord_decs(glob_u.cb.ord_v1.ord,"")
  391. // glob_u.cb.ord_v1.run_cbs_lz = glob_u.cb.ord_v1.estr.run_cbs_lz
  392. // glob_u.cb.ord_v1.ord.run_cbs_lz = glob_u.cb.ord_v1.run_cbs_lz
  393. }
  394. }
  395. window.glob_u.ws.fns.dispatch = function dispatch(o,obj_x,info){
  396. var event = o.event
  397. // socket = o.that
  398. var data = JSON.parse(event.data)
  399. // clog("WS_dispatch",data,socket.params.ord,data["CLIENT_KEY"])
  400. // clog("trc:sto:ws_rec",data.CLIENT_KEY,data.sto_event_type,data)
  401. trc_sto("ws_rec",data)
  402. glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_MESSAGE:"+data["CLIENT_KEY"],{event,that:this,data})
  403. return
  404. if (e.arguments[0].type == "message"){
  405. var data = JSON.parse(e.arguments[0].data)
  406. if ("type" in data && ws_handlers[data.type]){
  407. ws_handlers[data.type](data,{that:e.that,event:e.arguments[0]})
  408. } else {
  409. clog("NO HANDLER FOR",data.type)
  410. }
  411. clog("~WS",data,e)
  412. } else if (e.arguments[0].type == "open") {
  413. ws_handlers.on_open(e)
  414. }
  415. }
  416. function ws_reload(){
  417. try{
  418. if ((!glob_u.ws.sockets.ws1 || glob_u.ws.sockets.ws1.readyState == 3 || glob_u.ws.sockets.ws1.readyState == undefined)){
  419. ws_helper()
  420. } else {
  421. glob_u.ws.sockets.ws1.close()
  422. clog(glob_u.ws.sockets.ws1,glob_u.ws.sockets.ws1.readyState)
  423. glob_u.ws.sockets.ws1.onclose = ws_helper
  424. }
  425. } catch (err){
  426. clog(err)
  427. }
  428. }
  429. function get_room_name(){
  430. var room_name=location.pathname.match(/\/loc.([^\/]*)\//)
  431. if (room_name){
  432. room_name = room_name[1]
  433. } else {
  434. room_name = location.pathname.split("/").pop()
  435. }
  436. return room_name
  437. }
  438. function ws_helper(){
  439. clog("WS_HELPER")
  440. var fns = window.glob_u.ws.fns
  441. var o = {
  442. include_participants_data:1,
  443. include_ws_channel_data:1, // required for participants_data to work
  444. // msto.participants and masto.ws_channels will be defined in either case so we don't need to handle cases where some users enable this and some don't
  445. AutoReconnect:false,
  446. AutoReconnect:true,
  447. url:'wss://' + window.location.hostname +`/djc_srv/ws/chat/${get_room_name()}`,
  448. socket_name:"ws1",
  449. ord:glob_u.cb.ws,
  450. methods:{
  451. onmessage:fns.dispatch,
  452. onclose:fns.onclose,
  453. onerror:fns.onerror,
  454. onopen:fns.onopen,
  455. },
  456. methods:{
  457. onmessage:fns.onmessage,
  458. onclose:fns.onclose,
  459. onerror:fns.onerror,
  460. onopen:fns.onopen,
  461. },
  462. fns:{
  463. // reconnect:fns.reconnect,
  464. },
  465. }
  466. /*
  467. if (window.glob_u.ws.ws1 && window.glob_u.ws.ws1.readyState == 1){
  468. clog("WS ws1 is CONNECTED:",window.glob_u.ws.ws1)
  469. return
  470. }
  471. */
  472. var socket = connect_ws(o)
  473. // clog({socket})
  474. }
  475. window.glob_u.fns.connect_ws = connect_ws
  476. glob_u.fns.get_room_name=get_room_name
  477. create_ws_ord()
  478. glob_u.cb.ws.reg_cb(window.glob_u.ws.fns.dispatch,"WS_MESSAGE:","WS_MESSAGE")
  479. // jsync:sto.js
  480. // ------------------------------------------------------------------------------------------------
  481. // FILE:DS0
  482. var Proxy_Permissions,Proxy_Factory
  483. function mhndlr_rld_2(_o,scope,info){
  484. var dlog =nop
  485. try {
  486. var parsed = _o.data
  487. var o = parsed.payload
  488. // clog("mhndlr_rld",parsed.sto_event_type,parsed,{_o,scope,info})
  489. if (window.mhndlr_rld_dbg){
  490. mhndlr_rld_dbg({m,that,n,parsed,ai,o,arguments})
  491. }
  492. switch (parsed.sto_event_type){
  493. case "set_msg":
  494. // if (!glob_u.prom.init_db_resolve.resolved){
  495. if (!glob_u.prom.init_db_resolve.resolved_inited){
  496. _o.event.target.pre_init_msgs.push(_o)
  497. }
  498. pf._set_recv(o.path,o.key,o.val)
  499. // clog("msto_evh?ord")
  500. glob_u.fns.msto_evh ? glob_u.fns.msto_evh(o,parsed) : 0
  501. break;
  502. case "group_count":
  503. // clog("mhndlr_rld group_count",parsed)
  504. if (parsed.group_count < 2){
  505. // clog("mhndlr_rld group_count RESOLVE")
  506. glob_u.prom.init_db_resolve(glob_u.prom.init_db_resolve_timeout_arg)
  507. }
  508. break;
  509. case "event":
  510. /*
  511. dlog("~event~",parsed)
  512. if (window.dispatch_events){
  513. dispatch_events({parsed,ai,m,that})
  514. }
  515. */
  516. break;
  517. case "msg_test":
  518. dlog("msg_test",parsed)
  519. break;
  520. case "db_sync_request":
  521. // tmsgx4({sto_event_type:"db_sync_response",payload:pf.root,"CLIENT_KEY":"ws_sto"})
  522. // if (glob_u.prom.init_db_resolve.resolved){
  523. if (glob_u.prom.init_db_resolve.resolved_inited == 2){
  524. tmsgx4({sto_event_type:"db_sync_response",payload:jc(pf.root),request_from:parsed.from,request_rn_from:parsed.request_rn,"CLIENT_KEY":"ws_sto"})
  525. }
  526. break;
  527. case "db_sync_response":
  528. if (glob_u.prom.init_db_resolve && parsed.request_rn_from == glob_u.prom.init_db_resolve.rn){
  529. glob_u.prom.init_db_resolve({aaa:"dsr",pl:parsed.payload})
  530. }
  531. // clog("db_sync_response",parsed)
  532. break;
  533. }
  534. } catch (err) {
  535. clog("mhndlr err:",err)
  536. }
  537. }
  538. glob_u.fns.msto_evh = function(o,parsed,ai,id){
  539. // clog("ord_msto_evh")
  540. if (o.path[0]!="conference" || o.path[1]!="events"){
  541. return
  542. }
  543. glob_u.cb.ws.STO_EVENT.run_cbs(":STO_EVENT",{o,parsed,ai,id})
  544. if (typeof(o.val) == "object"){
  545. glob_u.cb.ws.STO_EVENT.run_cbs(o.val.type,{o,parsed,ai,id})
  546. }
  547. }
  548. glob_u.cb.ws.reg_cb(mhndlr_rld_2,"WS_MESSAGE:ws_sto","WS_MESSAGE:ws_sto")
  549. // FILE:DS1
  550. var dlog = nop
  551. function tmsgx4(m){
  552. var socket = glob_u.ws.sockets.ws1
  553. var jsend = socket.params.fns.jsend
  554. var t = {
  555. key:"tmp_dev_sto",
  556. }
  557. glob_u.fns.merge_partial_template(m,t)
  558. // clog("tmsgx4",{key:m.key,sto_event_type:m.sto_event_type,CLIENT_KEY:m.CLIENT_KEY},{m,t})
  559. trc_sto("tmsgx4",m)
  560. jsend(m)
  561. }
  562. isProxy = Symbol("isProxy")
  563. tlu = {
  564. object:"",
  565. string:true,
  566. number:true,
  567. undefined:true,
  568. boolean:true,
  569. }
  570. function type_info(o){
  571. try {
  572. var t
  573. var flags = {
  574. leaf:false,
  575. deep_not_prx:false,
  576. prx:false,
  577. isObj:false,
  578. isArr:false,
  579. els:false,
  580. }
  581. t = typeof(o)
  582. flags.t=t
  583. if (!(o === null)){
  584. flags.isArr = Array.isArray(o)
  585. flags.isObj = Object.prototype == o.__proto__
  586. }
  587. if (tlu[t] === true || o === null){
  588. flags.leaf = true
  589. } else if (t == "object" && o.__prx){
  590. flags.prx = true
  591. } else if (t == "object" && (flags.isArr || flags.isObj)){
  592. flags.prx = false
  593. flags.deep_not_prx = true
  594. } else {
  595. clog("ELSE")
  596. flags.els = true
  597. }
  598. return flags
  599. } catch (err){
  600. clog("type_info err:",err,{flags,o})
  601. }
  602. }
  603. function deep_prop_v0(o,p){
  604. try {
  605. var arr = jc(p)
  606. var ret = o
  607. while (arr.length){
  608. ret = ret[arr.shift()]
  609. }
  610. return ret
  611. } catch(err){console.error("DEEP_PROP ERR:",err)}
  612. }
  613. // delete Proxy_Factory
  614. // {
  615. Proxy_Factory = class Proxy_Factory {
  616. constructor(o,n="dflt"){
  617. this.db = o
  618. this.n = n
  619. this.hidden_props = ["add_proxy","_set","walker","walker_start","prxy"]
  620. this._pub_cb =[]
  621. this.__prx = true
  622. this.SymPrx = Symbol("SymPrx")
  623. }
  624. init(o){
  625. this.root = o
  626. }
  627. sync(o){
  628. this.root = jc(o.root)
  629. o._pub_cb.push(this._set_recv.bind(this))
  630. }
  631. get prxy(){
  632. return this
  633. }
  634. _set(o,k,v,prx,a0){
  635. this.obj[k]=prx
  636. }
  637. set_pub(obj, prop, val,receiver){
  638. this._set_pub(obj.__path_arr, prop, jx(val))
  639. }
  640. _set_pub(path,key,val){
  641. var k,v
  642. var arg = {
  643. "CLIENT_KEY":"ws_sto",
  644. "sto_event_type":"set_msg",
  645. "payload":{path,key,val},}
  646. tmsgx4(arg,
  647. )
  648. for (v of this._pub_cb){
  649. v(path,key,val)
  650. }
  651. }
  652. _set_recv(path,prop,val,id){
  653. var p = path
  654. var nprop = deep_prop_v0(this.root,p)
  655. var dpth = nprop.__dpth
  656. if (tlu[typeof(val)]){
  657. nprop._set(nprop,prop,val,val)
  658. } else {
  659. nprop._set(nprop,prop,val,new Proxy(val,this))
  660. nprop[prop].add_proxy(nprop,prop,val,dpth+1)
  661. }
  662. this.walker(nprop[prop],{},dpth+2)
  663. }
  664. set(obj, prop, val,receiver){
  665. if (obj[prop] === val){
  666. return Reflect.set(...arguments)
  667. }
  668. this.set_pub(obj, prop, val,receiver)
  669. this.event_proc("set")
  670. if ("__prx" == prop){
  671. this.__prx=val
  672. return this.__prx
  673. }
  674. if (typeof(val) === "object" && val != null && !(val.__prx)){
  675. var ret = Reflect.set(...arguments)
  676. this.set_obj(obj, prop, val,receiver)
  677. return ret
  678. }
  679. return Reflect.set(...arguments)
  680. }
  681. get(obj, prop,receiver){
  682. if (this.hidden_props.includes(prop)){
  683. switch (prop){
  684. case "add_proxy":
  685. return this.add_proxy.bind(this)
  686. break;
  687. case "prxy":
  688. return this
  689. case "_set":
  690. return this._set.bind({that:this,obj, prop,receiver})
  691. case "walker_start":
  692. return this.walker_start
  693. case "walker":
  694. return this.walker
  695. break;
  696. }
  697. }
  698. if (isProxy == prop){ return true }
  699. if ("__prx" == prop){ return this.__prx }
  700. return Reflect.get(...arguments)
  701. }
  702. add_proxy(o,k,v,dpth){
  703. var xpath = o.__path
  704. var apath = o.__path_arr
  705. this.event_proc("add_proxy")
  706. if (!apath){
  707. apath=[]
  708. }
  709. if (!xpath){
  710. xpath="ROOT!"
  711. }
  712. Object.defineProperty(v,"__path_arr",Object.assign({value:apath.concat(k),},this.baseProp))
  713. Object.defineProperty(v,"__path",Object.assign({value:xpath+":"+k,},this.baseProp))
  714. Object.defineProperty(v,"__dpth",Object.assign({value:dpth,},this.baseProp))
  715. // Object.defineProperty(v,"__dbg",Object.assign({value:{},},this.baseProp))
  716. }
  717. set_obj(obj, prop, val,receiver){
  718. var dpth = obj.__dpth
  719. var tf = {}
  720. var dbg_obj = {}
  721. this.walker(receiver,tf,dpth,dbg_obj)
  722. if (dbg_obj.depth_err){
  723. clog("MAX DEPTH?",dbg_obj,{obj, prop, val,receiver})
  724. }
  725. }
  726. walker(o,tfo,dpth=0,dbg_obj={"t":"unused"}){
  727. // if (dpth > 7){
  728. if (dpth > 15){
  729. dbg_obj.depth_err=1
  730. console.error("MAX DEPTH",{o,tfo,dpth,dbg_obj})
  731. return
  732. }
  733. var k,v
  734. var tf
  735. for ([k,v] of Object.entries(o)){
  736. tf = type_info(v)
  737. if (tf.deep_not_prx){
  738. o._set(o,k,v,new Proxy(v,this.prxy))
  739. o[k].add_proxy(o,k,v,dpth)
  740. this.walker(o[k],tf,dpth+1,dbg_obj)
  741. }
  742. }
  743. }
  744. walker_start(o,dpth){
  745. var tf = type_info(o)
  746. o.add_proxy({},[],o,-1)
  747. this.walker(o,tf,0)
  748. }
  749. event_proc(e){}
  750. }
  751. window.Proxy_Factory = Proxy_Factory
  752. Proxy_Factory.prototype.baseProp={
  753. writable: true,
  754. enumerable: false,
  755. // enumerable: true,
  756. configurable: true,
  757. }
  758. // }
  759. function arr_match(m,o){
  760. var k,v
  761. var r = 0
  762. for ([k,v] of Object.entries(m || {})){
  763. if (o[k] != v.valueOf()){
  764. r += 1
  765. return !r
  766. }
  767. }
  768. return !r
  769. }
  770. // permissions_def = {
  771. window.permissions_def = window.permissions_def || {
  772. participants:{
  773. m:["participants"],
  774. fn(set_scope,match){
  775. if (match.fp[1] == "rejx")
  776. throw "permission err"
  777. return
  778. },
  779. }
  780. }
  781. // {
  782. Proxy_Permissions = class Proxy_Permissions extends Proxy_Factory {
  783. constructor(a,a1){
  784. super(...arguments)
  785. }
  786. set(obj, prop, val,receiver){
  787. var k,v
  788. var r
  789. var matched
  790. var fp = obj.__path_arr.concat(prop)
  791. for ([k,v] of Object.entries(permissions_def)){
  792. matched = arr_match(v.m,fp)
  793. if (matched){
  794. r = v.fn({that:this,obj, prop, val,receiver},{fp,k,v}) || {}
  795. }
  796. }
  797. return super.set(obj, prop, val,receiver)
  798. }
  799. _set(){
  800. super._set(...arguments)
  801. }
  802. }
  803. window.Proxy_Permissions = Proxy_Permissions
  804. // }
  805. // clog("???")
  806. // jsync:init.js
  807. // ------------------------------------------------------------------------------------------------
  808. function pfnf(o){
  809. return function(resolve, reject){
  810. o.resolve=resolve
  811. o.reject=reject
  812. }
  813. }
  814. msto_z = {
  815. conference:{
  816. events:{},
  817. },
  818. participants:{},
  819. ws_channels:{},
  820. }
  821. var DBL_Proxy0 = {
  822. set(obj, prop, val,receiver){
  823. clog({obj, prop, val,receiver})
  824. // return Reflect.set(...arguments)
  825. if (Object.getOwnPropertyNames(obj).includes(prop)){
  826. return Reflect.set(...arguments)
  827. } else {
  828. return obj._wrapped_proxy[prop]=val
  829. // return Reflect.set(...arguments)
  830. }
  831. },
  832. get(obj, prop,receiver){
  833. clog({obj, prop,receiver},Object.getOwnPropertyNames(obj))
  834. if (Object.getOwnPropertyNames(obj).includes(prop)){
  835. return Reflect.get(...arguments)
  836. } else {
  837. return obj._wrapped_proxy[prop]
  838. // return Reflect.get(...arguments)
  839. }
  840. },
  841. }
  842. var DBL_Proxy1 = {
  843. set(obj, prop, val,receiver){
  844. // clog({obj, prop, val,receiver})
  845. // return Reflect.set(...arguments)
  846. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  847. // if (Object.getOwnPropertyNames(obj).includes(prop)){
  848. return pf.dbl_proxy_obj[prop]=val
  849. } else {
  850. return Reflect.set(...arguments)
  851. // return Reflect.set(...arguments)
  852. }
  853. },
  854. get(obj, prop,receiver){
  855. // clog({obj, prop,receiver},Object.getOwnPropertyNames(obj))
  856. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  857. return pf.dbl_proxy_obj[prop]
  858. } else {
  859. return Reflect.get(...arguments)
  860. // return Reflect.get(...arguments)
  861. }
  862. },
  863. }
  864. var DBL_Proxy = {
  865. set(obj, prop, val,receiver){
  866. // clog({obj, prop, val,receiver})
  867. // return Reflect.set(...arguments)
  868. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  869. // if (Object.getOwnPropertyNames(obj).includes(prop)){
  870. return pf.dbl_proxy_obj[prop]=val
  871. } else {
  872. return obj[prop] = val
  873. // TODO: make sure this proxy doesn't cause other similar bugs
  874. // return Reflect.set(...arguments)
  875. }
  876. },
  877. getOwnPropertyDescriptor(obj, prop){
  878. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  879. return Reflect.getOwnPropertyDescriptor(pf.dbl_proxy_obj, prop)
  880. } else {
  881. return Reflect.getOwnPropertyDescriptor(obj, prop)
  882. }
  883. },
  884. get(obj, prop,receiver){
  885. // clog({obj, prop,receiver},Object.getOwnPropertyNames(obj))
  886. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  887. return pf.dbl_proxy_obj[prop]
  888. } else {
  889. return Reflect.get(...arguments)
  890. // return Reflect.get(...arguments)
  891. }
  892. },
  893. ownKeys(target) {
  894. var target_keys = Reflect.ownKeys(target);
  895. var extra_keys = Reflect.ownKeys(pf.dbl_proxy_obj);
  896. // clog("ownKeys",{target_keys,extra_keys})
  897. return [...target_keys,...extra_keys]
  898. },
  899. }
  900. function init_db(objx){
  901. // clog("init_db~")
  902. trc_sto("init_db",{})
  903. glob_u.prom.init_db_resolve.resolved=1
  904. var glob_mx = glob_u.data
  905. var obj
  906. // clog("init_dbx",objx,{arguments,that:this})
  907. if (objx.participants){
  908. obj = objx
  909. } else {
  910. obj = objx.pl
  911. }
  912. // clog("INIT DB...",objx,obj,jc({obj,objx}))
  913. pf = new Proxy_Permissions({},"pf")
  914. msto_prx = new Proxy(obj,pf)
  915. window.msto_prx=msto_prx
  916. // window.msto_prx0 =msto_prx
  917. pf.init(msto_prx)
  918. msto_prx.walker_start(msto_prx)
  919. glob_mx.init_db=true
  920. // TODO:JFI make msto a class instance maybe
  921. /*
  922. window.msto = {
  923. ...pf.root,
  924. // participants:pf.root.participants,
  925. // conference:pf.root.conference,
  926. // my_data:pf.root.participants[glob_mx.local_id],
  927. get my_channel(){
  928. return msto.ws_channels[get_ws_channel_name()]
  929. // my_data("pfx get k1")
  930. },
  931. set my_channel(val){
  932. clog("pfx set my_channel")
  933. msto.ws_channels[get_ws_channel_name()] = val
  934. },
  935. get my_data(){
  936. return msto.participants[get_local_sto_id()]
  937. },
  938. set my_data(val){
  939. clog("pfx set my_data")
  940. msto.participants[get_local_sto_id()] = val
  941. },
  942. private_local:{},
  943. }
  944. // */
  945. // window.msto
  946. var dbl_proxy_obj = {
  947. // _wrapped_proxy:pf.root,
  948. // _wrapped_proxy2:pf.root,
  949. get my_channel(){
  950. return msto.ws_channels[get_ws_channel_name()]
  951. // my_data("pfx get k1")
  952. },
  953. set my_channel(val){
  954. clog("pfx set my_channel")
  955. msto.ws_channels[get_ws_channel_name()] = val
  956. },
  957. get my_data(){
  958. return msto.participants[get_local_sto_id()]
  959. },
  960. set my_data(val){
  961. clog("pfx set my_data")
  962. msto.participants[get_local_sto_id()] = val
  963. },
  964. private_local:{},
  965. }
  966. pf.dbl_proxy_obj=dbl_proxy_obj
  967. // window.dbl_proxy=new Proxy(dbl_proxy_obj, DBL_Proxy)
  968. // window.msto=new Proxy(dbl_proxy_obj, DBL_Proxy)
  969. window.msto=new Proxy(msto_prx, DBL_Proxy)
  970. }
  971. function handle_pre_init_msgs(){
  972. // clog("handle_pre_init_msgs")
  973. var k,v,i
  974. var _o
  975. glob_u.prom.init_db_resolve.resolved_inited = 1
  976. for (v of glob_u.ws.sockets.ws1.pre_init_msgs){
  977. if (v.data.sto_event_type == "set_msg"){
  978. msto.my_data.rehandle=1
  979. _o={...v,data:jc(v.data)}
  980. mhndlr_rld_2(_o,{type:"rehandle"})
  981. }
  982. }
  983. glob_u.prom.init_db_resolve.resolved_inited = 2
  984. }
  985. function ws_sto_connected(a,b){
  986. glob_u.cb.ws.run_cbs("WS_MSTO_INITED")
  987. handle_pre_init_msgs()
  988. // clog("ws_sto_connected",a,b,this)
  989. }
  990. function init_mu(){
  991. var k,v
  992. var rr = {}
  993. var prom1 = new Promise(pfnf(rr));
  994. prom1.then(init_db).then(ws_sto_connected)
  995. glob_u.prom.init_db_resolve_timeout_arg = {aaa:"timedout",pl:msto_z}
  996. setTimeout(rr.resolve,5000,glob_u.prom.init_db_resolve_timeout_arg)
  997. var rn = ((Math.random()+"").replace("0.","") - 0).toString(16)
  998. tmsgx4({sto_event_type:"db_sync_request","CLIENT_KEY":"ws_sto",request_rn:rn})
  999. glob_u.prom.init_db_resolve = rr.resolve
  1000. glob_u.prom.init_db_resolve.rn = rn
  1001. }
  1002. function ord_init_once(o,scope,info){
  1003. // clog("ord_init_once:",{o,scope,info})
  1004. init_mu()
  1005. // info.cbs[info.k].remove_after_exe = 1
  1006. }
  1007. glob_u.cb.ws.reg_cb(ord_init_once,"WS_OPEN:","ord_init_once")
  1008. function ds_test(){
  1009. glob_u.cb.ws.reg_cb(ord_init_once,"WS_OPEN:","ord_init_once")
  1010. ws_reload()
  1011. }
  1012. glob_u.fns.ds_test=ds_test
  1013. // jsync:test.js
  1014. // ------------------------------------------------------------------------------------------------
  1015. // clog("/////////")
  1016. // msto_sc_proxy
  1017. // permissions_def
  1018. // connection_info_handler
  1019. // /*
  1020. function get_local_sto_id(){
  1021. return glob_u.data.jsync_local_id
  1022. }
  1023. function get_session_sto_id(){
  1024. return glob_u.data.jsync_session_id
  1025. }
  1026. function get_ws_channel_name(){
  1027. return glob_u.data.channel_name
  1028. }
  1029. function gen_djc_srv_id(){
  1030. // I don't know how often this will generate duplicates
  1031. var djc_srv_id = localStorage.djc_srv_id
  1032. var djc_srv_id_vers = localStorage.djc_srv_id_vers
  1033. const current_id_vers = 0.0
  1034. if (Number(djc_srv_id_vers) < current_id_vers || !(djc_srv_id)){
  1035. clog("????")
  1036. localStorage.djc_srv_id = ((Math.random()+"").replace("0.","") - 0).toString(16)
  1037. localStorage.djc_srv_id_vers = current_id_vers
  1038. }
  1039. glob_u.data.djc_srv_id = localStorage.djc_srv_id
  1040. clog("djc_srv_id:",{version:localStorage.djc_srv_id_vers,id:localStorage.djc_srv_id})
  1041. }
  1042. function init_msto_user_data(o,scope,info){
  1043. var ws_channel_name = get_ws_channel_name()
  1044. var local_sto_id = get_local_sto_id()
  1045. // clog("init_msto_user_data???",{local_sto_id,ws_channel_name,o,scope,info})
  1046. if (!glob_u.ws.sockets.ws1.params.include_ws_channel_data){return}
  1047. msto.ws_channels[ws_channel_name]=msto.ws_channels[ws_channel_name] || {id:local_sto_id}
  1048. if (!glob_u.ws.sockets.ws1.params.include_participants_data){return}
  1049. msto.participants[local_sto_id]=msto.participants[local_sto_id] || {}
  1050. // clog("init_msto_user_dataw???")
  1051. }
  1052. glob_u.cb.ws.reg_cb(init_msto_user_data,"WS_MSTO_INITED","init_msto_user_data")
  1053. window.permissions_def = window.permissions_def || {
  1054. participants:{
  1055. m:["participants"],
  1056. fn(set_scope,match){
  1057. if (match.fp[1] == "rejx")
  1058. throw "permission err"
  1059. return
  1060. },
  1061. }
  1062. }
  1063. // */
  1064. // jsync_local_id
  1065. // jsync_local_vers
  1066. // jsync_session_id
  1067. // jsync_session_vers
  1068. // jsync_id
  1069. // jsync_vers
  1070. window.permissions_def = {
  1071. participants:{
  1072. m:["participants"],
  1073. fn(set_scope,match){
  1074. if (match.fp[1] != get_local_sto_id()){
  1075. console.error("permission err:participants",set_scope,match)
  1076. // console.trace("permission err:participants")
  1077. throw "permission err"
  1078. }
  1079. return
  1080. },
  1081. },
  1082. ws_channels:{
  1083. m:["ws_channels"],
  1084. fn(set_scope,match){
  1085. if (match.fp[1] != get_ws_channel_name()){
  1086. console.error("permission err:ws_channels",set_scope,match)
  1087. throw "permission err"
  1088. }
  1089. }
  1090. },
  1091. }
  1092. window.permissions_def0 = {
  1093. /*
  1094. ws_channels:{
  1095. m:["ws_channels"],
  1096. fn(set_scope,match){
  1097. if (match.fp[1] != window.glob_u.data.channel_name){
  1098. console.error("permission err:ws_channels",set_scope,match)
  1099. throw "permission err"
  1100. }
  1101. }
  1102. },
  1103. */
  1104. user_channels:{
  1105. m:["user_channels"],
  1106. fn(set_scope,match){
  1107. if (match.fp[1] != get_ws_channel_name()){
  1108. console.error("permission err:user_channels",set_scope,match)
  1109. throw "permission err"
  1110. }
  1111. }
  1112. },
  1113. user_data_sessions:{
  1114. m:["user_data_sessions"],
  1115. fn(set_scope,match){
  1116. if (match.fp[1] != get_session_sto_id()){
  1117. console.error("permission err:user_data_sessions",set_scope,match)
  1118. // console.trace("permission err:participants")
  1119. throw "permission err"
  1120. }
  1121. return
  1122. },
  1123. },
  1124. user_data_local:{
  1125. m:["user_data_local"],
  1126. fn(set_scope,match){
  1127. if (match.fp[1] != get_local_sto_id()){
  1128. console.error("permission err:user_data_local",set_scope,match)
  1129. // console.trace("permission err:participants")
  1130. throw "permission err"
  1131. }
  1132. return
  1133. },
  1134. },
  1135. /*
  1136. participants:{
  1137. m:["participants"],
  1138. fn(set_scope,match){
  1139. if (match.fp[1] != window.glob_u.data.djc_srv_id){
  1140. console.error("permission err:participants",set_scope,match)
  1141. // console.trace("permission err:participants")
  1142. throw "permission err"
  1143. }
  1144. return
  1145. },
  1146. }
  1147. */
  1148. }
  1149. function ensure_jsync_id_is_set(storage_,base_name){
  1150. var storage = storage_
  1151. var id_name = base_name + "_id"
  1152. var vers_name = base_name + "_vers"
  1153. var djc_srv_id = storage[id_name]
  1154. var djc_srv_id_vers = storage[vers_name]
  1155. const current_id_vers = 0.0
  1156. if (Number(djc_srv_id_vers) < current_id_vers || !(djc_srv_id)){
  1157. storage[id_name] = ((Math.random()+"").replace("0.","") - 0).toString(16)
  1158. storage[vers_name] = current_id_vers
  1159. }
  1160. glob_u.data[id_name] = storage[id_name]
  1161. // clog("djc_srv_id:",{version:localStorage.djc_srv_id_vers,id:localStorage.djc_srv_id})
  1162. }
  1163. ensure_jsync_id_is_set(localStorage,"jsync_local")
  1164. ensure_jsync_id_is_set(sessionStorage,"jsync_session")
  1165. // function user_disconnected_compatibility_handler(o,scope,info){
  1166. // TODO:Fix bug caused by a user disconnecting before the connection is properly established
  1167. function connection_info_handler(o,scope,info){
  1168. if (o.data.sto_event_type=="connection_info"){
  1169. // clog("connection_info_handler:",o,scope,info)
  1170. glob_u.data.group_name = o.data.group_name
  1171. glob_u.data.channel_name = o.data.channel_name
  1172. clog("jsyncdb connected","room name:",glob_u.data.group_name)
  1173. } else if (o.data.sto_event_type=="user_disconnected"){
  1174. var last_conn =1
  1175. var k,v
  1176. var ws_conn_data = jc(msto.ws_channels[o.data.channel_name])
  1177. delete msto.ws_channels[o.data.channel_name]
  1178. for ([k,v] of Object.entries(msto.ws_channels)){
  1179. if (v.id == ws_conn_data.id){
  1180. last_conn = 0
  1181. }
  1182. }
  1183. if (last_conn){
  1184. // clog("DELlast_conn" ,ws_conn_data.id)
  1185. delete msto.participants[ws_conn_data.id]
  1186. }
  1187. clog("user_disconnected:",o.data.channel_name)
  1188. return
  1189. if (msto.user_channels){
  1190. delete msto.user_channels[o.data.channel_name]
  1191. }
  1192. if (msto.user_channels){
  1193. for ([k,v] of Object.entries(msto.user_channels)){
  1194. if (v.id == ws_conn_data.id){
  1195. last_conn = 0
  1196. }
  1197. }
  1198. }
  1199. if (last_conn){
  1200. clog("DELlast_conn" ,ws_conn_data.id)
  1201. delete msto.user_data_local[ws_conn_data.id]
  1202. }
  1203. }
  1204. }
  1205. glob_u.cb.ws.reg_cb(connection_info_handler,"WS_MESSAGE:ws_sto","connection_info_handler")
  1206. function ds_test3(){
  1207. glob_u.cb.ws.reg_cb(ord_init_once,"WS_OPEN:","ord_init_once")
  1208. ws_reload()
  1209. }
  1210. glob_u.fns.get_local_sto_id = get_local_sto_id
  1211. glob_u.fns.get_ws_channel_name = get_ws_channel_name
  1212. glob_u.fns.get_session_sto_id = get_session_sto_id
  1213. // console.log("??...")
  1214. // clog("???")
  1215. //
  1216. // glob_u.fns.get_room_name=get_room_name
  1217. // window.ds_test=ds_test
  1218. // glob_u.fns.ds_test=ds_test
  1219. // window.msto_prx=msto_prx
  1220. })()