Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

jsync_lib.js 35KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662
  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. let timeout0 = this.params.timeout0 || 100
  290. let timeout_multi = this.params.timeout_multi || 3000
  291. let t =timeout_multi
  292. // let now = Date.now()
  293. if (this.params.HAS_OPENED && timeout_multi<Date.now()-this.params.OPEN_TIME){
  294. t=timeout0
  295. }
  296. // clog(":TIME:",now,this.params.OPEN_TIME,now-this.params.OPEN_TIME)
  297. this.params.HAS_OPENED = 0
  298. setTimeout(this.params.fns.reconnect,t)
  299. }
  300. window.glob_u.ws.fns.onmessage = function onmessage(event){
  301. // clog("WS_MESSAGE",{that:this,args:[...arguments]})
  302. // glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_MESSAGE:",{event,that:this})
  303. glob_u.ws.sockets[this.params.socket_name].params.ord.run_cbs("WS_MESSAGE:",{event,that:this})
  304. }
  305. window.glob_u.ws.fns.onerror = function onerror(event){
  306. // clog("WS_ERROR",{that:this,args:[...arguments]})
  307. // glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_ERROR:",{event,that:this})
  308. glob_u.ws.sockets[this.params.socket_name].params.ord.run_cbs("WS_ERROR:",{event,that:this})
  309. }
  310. window.glob_u.ws.fns.onopen = function onopen(event){
  311. this.params.HAS_OPENED = 1
  312. this.params.OPEN_TIME = Date.now()
  313. // clog("WS_OPEN???",{that:this,args:[...arguments]},{on_open_once:this.on_open_once,on_open_cbs:this.params.on_open_cbs})
  314. // glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_OPEN:",{event,that:this})
  315. glob_u.ws.sockets[this.params.socket_name].params.ord.run_cbs("WS_OPEN:",{event,that:this})
  316. return
  317. var cb
  318. if (this.on_open_once){
  319. for (cb of this.on_open_once){
  320. cb(event,this)
  321. }
  322. if (this?.params?.on_open_cbs){
  323. for (cb of this?.params?.on_open_cbs){
  324. cb(event,this)
  325. }
  326. }
  327. }
  328. }
  329. window.glob_u.ws.fns.ws_fns_factory = function ws_fns_factory(socket_opts){
  330. var socket_name = socket_opts.socket_name
  331. // const sockets =
  332. var v1 = "init"
  333. var fns = {
  334. get_socket(o){
  335. return glob_u.ws.sockets[socket_name]
  336. },
  337. reconnect(){
  338. var socket = fns.get_socket()
  339. clog("RECONNECT",socket_opts,socket,socket?.DoNotReconnect)
  340. // if (socket.DoNotReconnect || socket.params.DoNotReconnect || glob_u.ws?.flags?.DoNotReconnect){
  341. if (socket.DoNotReconnect || !socket.params.AutoReconnect || glob_u.ws?.flags?.DoNotReconnect){
  342. clog("RECONNECTION NOT ATTEMPTED",socket_opts)
  343. return
  344. } else {
  345. }
  346. connect_ws(socket_opts)
  347. },
  348. log_var(o){
  349. clog("var:",v1)
  350. return v1
  351. },
  352. set_var(val){
  353. v1 = val
  354. return v1
  355. },
  356. send_text(o){
  357. var socket = fns.get_socket()
  358. clog("send_text",{that:this,fns})
  359. socket.send(JSON.stringify(o));
  360. },
  361. jsend(o){
  362. var socket = fns.get_socket()
  363. // clog("!!!",{that:this,fns})
  364. socket.send(JSON.stringify(o));
  365. },
  366. }
  367. return fns
  368. }
  369. function connect_ws(o= {}){
  370. // clog("connect_ws:",o,jc(o))
  371. glob_u.fns.merge_partial_template(o,{on_open_cbs:[]})
  372. var sockets = window.glob_u.ws.sockets
  373. var old_socket = sockets[o.socket_name]
  374. if (old_socket && old_socket.readyState == 1){
  375. clog(`WS ${o.socket_name} is already CONNECTED:`,old_socket , o)
  376. return
  377. } else if (old_socket && (old_socket.readyState != 3 && old_socket.readyState != undefined )){
  378. clog(`WS ${o.socket_name} exsists and in not closed:`,old_socket , o)
  379. return
  380. }
  381. var socket = new WebSocket(o.url)
  382. socket.on_open_once = []
  383. socket.pre_init_msgs = []
  384. socket.params = o
  385. // if ()
  386. Object.assign(o.fns, window.glob_u.ws.fns.ws_fns_factory(o))
  387. // Object.assign(o.fns2, window.glob_u.ws.fns.ws_fns_factory(o))
  388. Object.assign(socket,o.methods)
  389. sockets[o.socket_name]=socket
  390. // o.jsend ? socket.jsend = o.jsend: 0
  391. // clog("CONNECTING WS:",{o,socket})
  392. return [socket,old_socket]
  393. }
  394. // FILE:WS1
  395. function create_ws_ord(){
  396. if (!glob_u.cb.ws){
  397. var ord = new glob_u.cls.reg_cb_ord()
  398. glob_u.cb.ws = ord
  399. glob_u.cb.ws.reg_cb = ord.reg_cb
  400. glob_u.cb.ws.run_cbs = ord.run_cbs
  401. glob_u.cb.ws.STO_EVENT = glob_u.fns.gen_ord_decs(glob_u.cb.ws,"STO_EVENT:")
  402. // glob_u.cb.ord_v1.estr = glob_u.fns.gen_ord_decs(glob_u.cb.ord_v1.ord,"")
  403. // glob_u.cb.ord_v1.run_cbs_lz = glob_u.cb.ord_v1.estr.run_cbs_lz
  404. // glob_u.cb.ord_v1.ord.run_cbs_lz = glob_u.cb.ord_v1.run_cbs_lz
  405. }
  406. }
  407. window.glob_u.ws.fns.dispatch = function dispatch(o,obj_x,info){
  408. var event = o.event
  409. // socket = o.that
  410. // clog("jtx dispatch",{o,obj_x,info,that:this})
  411. var data = JSON.parse(event.data)
  412. // clog("WS_dispatch",data,socket.params.ord,data["CLIENT_KEY"])
  413. // clog("trc:sto:ws_rec",data.CLIENT_KEY,data.sto_event_type,data)
  414. trc_sto("ws_rec",data)
  415. glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_MESSAGE:"+data["CLIENT_KEY"],{event,that:this,data})
  416. return
  417. if (e.arguments[0].type == "message"){
  418. var data = JSON.parse(e.arguments[0].data)
  419. if ("type" in data && ws_handlers[data.type]){
  420. ws_handlers[data.type](data,{that:e.that,event:e.arguments[0]})
  421. } else {
  422. clog("NO HANDLER FOR",data.type)
  423. }
  424. clog("~WS",data,e)
  425. } else if (e.arguments[0].type == "open") {
  426. ws_handlers.on_open(e)
  427. }
  428. }
  429. function ws_reload(){
  430. try{
  431. if ((!glob_u.ws.sockets.ws1 || glob_u.ws.sockets.ws1.readyState == 3 || glob_u.ws.sockets.ws1.readyState == undefined)){
  432. ws_helper()
  433. } else {
  434. glob_u.ws.sockets.ws1.close()
  435. clog(glob_u.ws.sockets.ws1,glob_u.ws.sockets.ws1.readyState)
  436. glob_u.ws.sockets.ws1.onclose = ws_helper
  437. }
  438. } catch (err){
  439. clog(err)
  440. }
  441. }
  442. function get_room_name(){
  443. // return
  444. var s=location.search
  445. // if s[0]=="?"){}
  446. s[0]=="?" ? s = s.slice(1):0
  447. var param
  448. for (param of s.split("&")){
  449. let kv = param.split("=")
  450. if (kv[0]=="room"){
  451. return kv[1]
  452. }
  453. clog("::",param,kv)
  454. // clog("::",param,kv,"")
  455. }
  456. // var
  457. return "room_name"
  458. var room_name=location.pathname.match(/\/loc.([^\/]*)\//)
  459. if (room_name){
  460. room_name = room_name[1]
  461. } else {
  462. room_name = location.pathname.split("/").pop()
  463. }
  464. return room_name
  465. }
  466. // function get_room_name(){
  467. function get_room_name_old(){
  468. var room_name=location.pathname.match(/\/loc.([^\/]*)\//)
  469. if (room_name){
  470. room_name = room_name[1]
  471. } else {
  472. room_name = location.pathname.split("/").pop()
  473. }
  474. return room_name
  475. }
  476. function ws_helper(){
  477. clog("WS_HELPER")
  478. var fns = window.glob_u.ws.fns
  479. var o = {
  480. include_participants_data:1,
  481. include_ws_channel_data:1, // required for participants_data to work
  482. // 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
  483. AutoReconnect:false,
  484. AutoReconnect:true,
  485. url:'wss://' + window.location.hostname +`/djc_srv/ws/chat/${get_room_name()}`,
  486. socket_name:"ws1",
  487. ord:glob_u.cb.ws,
  488. methods:{
  489. onmessage:fns.dispatch,
  490. onclose:fns.onclose,
  491. onerror:fns.onerror,
  492. onopen:fns.onopen,
  493. },
  494. methods:{
  495. onmessage:fns.onmessage,
  496. onclose:fns.onclose,
  497. onerror:fns.onerror,
  498. onopen:fns.onopen,
  499. },
  500. fns:{
  501. // reconnect:fns.reconnect,
  502. },
  503. }
  504. /*
  505. if (window.glob_u.ws.ws1 && window.glob_u.ws.ws1.readyState == 1){
  506. clog("WS ws1 is CONNECTED:",window.glob_u.ws.ws1)
  507. return
  508. }
  509. */
  510. var socket = connect_ws(o)
  511. // clog({socket})
  512. }
  513. window.glob_u.fns.connect_ws = connect_ws
  514. glob_u.fns.get_room_name=get_room_name
  515. create_ws_ord()
  516. glob_u.cb.ws.reg_cb(window.glob_u.ws.fns.dispatch,"WS_MESSAGE:","WS_MESSAGE")
  517. // jsync:sto.js
  518. // ------------------------------------------------------------------------------------------------
  519. // FILE:DS0
  520. var Proxy_Permissions,Proxy_Factory
  521. function mhndlr_rld_2(_o,scope,info){
  522. // clog("jtx mhndlr_rld_2",{_o,scope,info,that:this})
  523. var dlog =nop
  524. try {
  525. var parsed = _o.data
  526. var o = parsed.payload
  527. // clog("mhndlr_rld",parsed.sto_event_type,parsed,{_o,scope,info})
  528. if (window.mhndlr_rld_dbg){
  529. mhndlr_rld_dbg({m,that,n,parsed,ai,o,arguments})
  530. }
  531. switch (parsed.sto_event_type){
  532. case "set_msg":
  533. // if (!glob_u.prom.init_db_resolve.resolved){
  534. // if (!glob_u.prom.init_db_resolve.resolved_inited){
  535. if (!glob_u.prom.init_db_resolve.resolved_inited && _o?.event?.target?.pre_init_msgs){
  536. _o.event.target.pre_init_msgs.push(_o)
  537. }
  538. pf._set_recv(o.path,o.key,o.val)
  539. // clog("msto_evh?ord")
  540. glob_u.fns.msto_evh ? glob_u.fns.msto_evh(o,parsed) : 0
  541. break;
  542. case "group_count":
  543. // clog("mhndlr_rld group_count",parsed)
  544. if (parsed.group_count < 2){
  545. // clog("mhndlr_rld group_count RESOLVE")
  546. glob_u.prom.init_db_resolve(glob_u.prom.init_db_resolve_timeout_arg)
  547. }
  548. break;
  549. case "event":
  550. /*
  551. dlog("~event~",parsed)
  552. if (window.dispatch_events){
  553. dispatch_events({parsed,ai,m,that})
  554. }
  555. */
  556. break;
  557. case "msg_test":
  558. dlog("msg_test",parsed)
  559. break;
  560. case "db_sync_request":
  561. // tmsgx4({sto_event_type:"db_sync_response",payload:pf.root,"CLIENT_KEY":"ws_sto"})
  562. // if (glob_u.prom.init_db_resolve.resolved){
  563. if (glob_u.prom.init_db_resolve.resolved_inited == 2){
  564. 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"})
  565. }
  566. break;
  567. case "db_sync_response":
  568. if (glob_u.prom.init_db_resolve && parsed.request_rn_from == glob_u.prom.init_db_resolve.rn){
  569. glob_u.prom.init_db_resolve({aaa:"dsr",pl:parsed.payload})
  570. }
  571. // clog("db_sync_response",parsed)
  572. break;
  573. }
  574. } catch (err) {
  575. clog("mhndlr err:",err)
  576. }
  577. }
  578. glob_u.fns.msto_evh = function(o,parsed,ai,id){
  579. // clog("ord_msto_evh")
  580. if (o.path[0]!="conference" || o.path[1]!="events"){
  581. return
  582. }
  583. glob_u.cb.ws.STO_EVENT.run_cbs(":STO_EVENT",{o,parsed,ai,id})
  584. if (typeof(o.val) == "object"){
  585. glob_u.cb.ws.STO_EVENT.run_cbs(o.val.type,{o,parsed,ai,id})
  586. }
  587. }
  588. glob_u.cb.ws.reg_cb(mhndlr_rld_2,"WS_MESSAGE:ws_sto","WS_MESSAGE:ws_sto")
  589. // FILE:DS1
  590. var dlog = nop
  591. function tmsgx4(m){
  592. var socket = glob_u.ws.sockets.ws1
  593. var jsend = socket.params.fns.jsend
  594. var t = {
  595. key:"tmp_dev_sto",
  596. }
  597. glob_u.fns.merge_partial_template(m,t)
  598. // clog("tmsgx4",{key:m.key,sto_event_type:m.sto_event_type,CLIENT_KEY:m.CLIENT_KEY},{m,t})
  599. trc_sto("tmsgx4",m)
  600. jsend(m)
  601. }
  602. isProxy = Symbol("isProxy")
  603. tlu = {
  604. object:"",
  605. string:true,
  606. number:true,
  607. undefined:true,
  608. boolean:true,
  609. }
  610. function type_info(o){
  611. try {
  612. var t
  613. var flags = {
  614. leaf:false,
  615. deep_not_prx:false,
  616. prx:false,
  617. isObj:false,
  618. isArr:false,
  619. els:false,
  620. }
  621. t = typeof(o)
  622. flags.t=t
  623. if (!(o === null)){
  624. flags.isArr = Array.isArray(o)
  625. flags.isObj = Object.prototype == o.__proto__
  626. }
  627. if (tlu[t] === true || o === null){
  628. flags.leaf = true
  629. } else if (t == "object" && o.__prx){
  630. flags.prx = true
  631. } else if (t == "object" && (flags.isArr || flags.isObj)){
  632. flags.prx = false
  633. flags.deep_not_prx = true
  634. } else {
  635. clog("ELSE")
  636. flags.els = true
  637. }
  638. return flags
  639. } catch (err){
  640. clog("type_info err:",err,{flags,o})
  641. }
  642. }
  643. function deep_prop_v0(o,p){
  644. try {
  645. var arr = jc(p)
  646. var ret = o
  647. while (arr.length){
  648. ret = ret[arr.shift()]
  649. }
  650. return ret
  651. } catch(err){console.error("DEEP_PROP ERR:",err)}
  652. }
  653. // delete Proxy_Factory
  654. // {
  655. Proxy_Factory = class Proxy_Factory {
  656. constructor(o,n="dflt"){
  657. this.db = o
  658. this.n = n
  659. this.hidden_props = ["add_proxy","_set","walker","walker_start","prxy"]
  660. this._pub_cb =[]
  661. this.__prx = true
  662. this.SymPrx = Symbol("SymPrx")
  663. }
  664. init(o){
  665. this.root = o
  666. }
  667. sync(o){
  668. this.root = jc(o.root)
  669. o._pub_cb.push(this._set_recv.bind(this))
  670. }
  671. get prxy(){
  672. return this
  673. }
  674. _set(o,k,v,prx,a0){
  675. this.obj[k]=prx
  676. }
  677. set_pub(obj, prop, val,receiver){
  678. this._set_pub(obj.__path_arr, prop, jx(val))
  679. }
  680. _set_pub(path,key,val){
  681. var k,v
  682. var arg = {
  683. "CLIENT_KEY":"ws_sto",
  684. "sto_event_type":"set_msg",
  685. "payload":{path,key,val},}
  686. tmsgx4(arg,
  687. )
  688. for (v of this._pub_cb){
  689. v(path,key,val)
  690. }
  691. }
  692. _set_recv(path,prop,val,id){
  693. var p = path
  694. var nprop = deep_prop_v0(this.root,p)
  695. var dpth = nprop.__dpth
  696. if (tlu[typeof(val)]){
  697. nprop._set(nprop,prop,val,val)
  698. } else {
  699. nprop._set(nprop,prop,val,new Proxy(val,this))
  700. nprop[prop].add_proxy(nprop,prop,val,dpth+1)
  701. }
  702. this.walker(nprop[prop],{},dpth+2)
  703. }
  704. set(obj, prop, val,receiver){
  705. if (obj[prop] === val){
  706. return Reflect.set(...arguments)
  707. }
  708. this.set_pub(obj, prop, val,receiver)
  709. this.event_proc("set")
  710. if ("__prx" == prop){
  711. this.__prx=val
  712. return this.__prx
  713. }
  714. if (typeof(val) === "object" && val != null && !(val.__prx)){
  715. var ret = Reflect.set(...arguments)
  716. this.set_obj(obj, prop, val,receiver)
  717. return ret
  718. }
  719. return Reflect.set(...arguments)
  720. }
  721. get(obj, prop,receiver){
  722. if (this.hidden_props.includes(prop)){
  723. switch (prop){
  724. case "add_proxy":
  725. return this.add_proxy.bind(this)
  726. break;
  727. case "prxy":
  728. return this
  729. case "_set":
  730. return this._set.bind({that:this,obj, prop,receiver})
  731. case "walker_start":
  732. return this.walker_start
  733. case "walker":
  734. return this.walker
  735. break;
  736. }
  737. }
  738. if (isProxy == prop){ return true }
  739. if ("__prx" == prop){ return this.__prx }
  740. return Reflect.get(...arguments)
  741. }
  742. add_proxy(o,k,v,dpth){
  743. var xpath = o.__path
  744. var apath = o.__path_arr
  745. this.event_proc("add_proxy")
  746. if (!apath){
  747. apath=[]
  748. }
  749. if (!xpath){
  750. xpath="ROOT!"
  751. }
  752. Object.defineProperty(v,"__path_arr",Object.assign({value:apath.concat(k),},this.baseProp))
  753. Object.defineProperty(v,"__path",Object.assign({value:xpath+":"+k,},this.baseProp))
  754. Object.defineProperty(v,"__dpth",Object.assign({value:dpth,},this.baseProp))
  755. // Object.defineProperty(v,"__dbg",Object.assign({value:{},},this.baseProp))
  756. }
  757. set_obj(obj, prop, val,receiver){
  758. var dpth = obj.__dpth
  759. var tf = {}
  760. var dbg_obj = {}
  761. this.walker(receiver,tf,dpth,dbg_obj)
  762. if (dbg_obj.depth_err){
  763. clog("MAX DEPTH?",dbg_obj,{obj, prop, val,receiver})
  764. }
  765. }
  766. walker(o,tfo,dpth=0,dbg_obj={"t":"unused"}){
  767. // if (dpth > 7){
  768. if (dpth > 15){
  769. dbg_obj.depth_err=1
  770. console.error("MAX DEPTH",{o,tfo,dpth,dbg_obj})
  771. return
  772. }
  773. var k,v
  774. var tf
  775. for ([k,v] of Object.entries(o)){
  776. tf = type_info(v)
  777. if (tf.deep_not_prx){
  778. o._set(o,k,v,new Proxy(v,this.prxy))
  779. o[k].add_proxy(o,k,v,dpth)
  780. this.walker(o[k],tf,dpth+1,dbg_obj)
  781. }
  782. }
  783. }
  784. walker_start(o,dpth){
  785. var tf = type_info(o)
  786. o.add_proxy({},[],o,-1)
  787. this.walker(o,tf,0)
  788. }
  789. event_proc(e){}
  790. }
  791. window.Proxy_Factory = Proxy_Factory
  792. Proxy_Factory.prototype.baseProp={
  793. writable: true,
  794. enumerable: false,
  795. // enumerable: true,
  796. configurable: true,
  797. }
  798. // }
  799. function arr_match(m,o){
  800. var k,v
  801. var r = 0
  802. for ([k,v] of Object.entries(m || {})){
  803. if (o[k] != v.valueOf()){
  804. r += 1
  805. return !r
  806. }
  807. }
  808. return !r
  809. }
  810. // permissions_def = {
  811. window.permissions_def = window.permissions_def || {
  812. participants:{
  813. m:["participants"],
  814. fn(set_scope,match){
  815. if (match.fp[1] == "rejx")
  816. throw "permission err"
  817. return
  818. },
  819. }
  820. }
  821. // {
  822. Proxy_Permissions = class Proxy_Permissions extends Proxy_Factory {
  823. constructor(a,a1){
  824. super(...arguments)
  825. }
  826. set(obj, prop, val,receiver){
  827. var k,v
  828. var r
  829. var matched
  830. var fp = obj.__path_arr.concat(prop)
  831. for ([k,v] of Object.entries(permissions_def)){
  832. matched = arr_match(v.m,fp)
  833. if (matched){
  834. r = v.fn({that:this,obj, prop, val,receiver},{fp,k,v}) || {}
  835. }
  836. }
  837. return super.set(obj, prop, val,receiver)
  838. }
  839. _set(){
  840. super._set(...arguments)
  841. }
  842. }
  843. window.Proxy_Permissions = Proxy_Permissions
  844. // }
  845. // clog("???")
  846. // jsync:init.js
  847. // ------------------------------------------------------------------------------------------------
  848. function pfnf(o){
  849. return function(resolve, reject){
  850. o.resolve=resolve
  851. o.reject=reject
  852. }
  853. }
  854. msto_z = {
  855. conference:{
  856. events:{},
  857. },
  858. participants:{},
  859. ws_channels:{},
  860. }
  861. var DBL_Proxy0 = {
  862. set(obj, prop, val,receiver){
  863. clog({obj, prop, val,receiver})
  864. // return Reflect.set(...arguments)
  865. if (Object.getOwnPropertyNames(obj).includes(prop)){
  866. return Reflect.set(...arguments)
  867. } else {
  868. return obj._wrapped_proxy[prop]=val
  869. // return Reflect.set(...arguments)
  870. }
  871. },
  872. get(obj, prop,receiver){
  873. clog({obj, prop,receiver},Object.getOwnPropertyNames(obj))
  874. if (Object.getOwnPropertyNames(obj).includes(prop)){
  875. return Reflect.get(...arguments)
  876. } else {
  877. return obj._wrapped_proxy[prop]
  878. // return Reflect.get(...arguments)
  879. }
  880. },
  881. }
  882. var DBL_Proxy1 = {
  883. set(obj, prop, val,receiver){
  884. // clog({obj, prop, val,receiver})
  885. // return Reflect.set(...arguments)
  886. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  887. // if (Object.getOwnPropertyNames(obj).includes(prop)){
  888. return pf.dbl_proxy_obj[prop]=val
  889. } else {
  890. return Reflect.set(...arguments)
  891. // return Reflect.set(...arguments)
  892. }
  893. },
  894. get(obj, prop,receiver){
  895. // clog({obj, prop,receiver},Object.getOwnPropertyNames(obj))
  896. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  897. return pf.dbl_proxy_obj[prop]
  898. } else {
  899. return Reflect.get(...arguments)
  900. // return Reflect.get(...arguments)
  901. }
  902. },
  903. }
  904. var DBL_Proxy = {
  905. set(obj, prop, val,receiver){
  906. // clog({obj, prop, val,receiver})
  907. // return Reflect.set(...arguments)
  908. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  909. // if (Object.getOwnPropertyNames(obj).includes(prop)){
  910. return pf.dbl_proxy_obj[prop]=val
  911. } else {
  912. return obj[prop] = val
  913. // TODO: make sure this proxy doesn't cause other similar bugs
  914. // return Reflect.set(...arguments)
  915. }
  916. },
  917. getOwnPropertyDescriptor(obj, prop){
  918. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  919. return Reflect.getOwnPropertyDescriptor(pf.dbl_proxy_obj, prop)
  920. } else {
  921. return Reflect.getOwnPropertyDescriptor(obj, prop)
  922. }
  923. },
  924. get(obj, prop,receiver){
  925. // clog({obj, prop,receiver},Object.getOwnPropertyNames(obj))
  926. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  927. return pf.dbl_proxy_obj[prop]
  928. } else {
  929. return Reflect.get(...arguments)
  930. // return Reflect.get(...arguments)
  931. }
  932. },
  933. ownKeys(target) {
  934. var target_keys = Reflect.ownKeys(target);
  935. var extra_keys = Reflect.ownKeys(pf.dbl_proxy_obj);
  936. // clog("ownKeys",{target_keys,extra_keys})
  937. return [...target_keys,...extra_keys]
  938. },
  939. }
  940. function init_db(objx){
  941. // clog("init_db~")
  942. console.trace("init_db")
  943. trc_sto("init_db",{})
  944. glob_u.prom.init_db_resolve.resolved=1
  945. var glob_mx = glob_u.data
  946. var obj
  947. // clog("init_dbx",objx,{arguments,that:this})
  948. if (objx.participants){
  949. obj = objx
  950. } else {
  951. obj = objx.pl
  952. }
  953. // clog("INIT DB...",objx,obj,jc({obj,objx}))
  954. pf = new Proxy_Permissions({},"pf")
  955. msto_prx = new Proxy(obj,pf)
  956. window.msto_prx=msto_prx
  957. // window.msto_prx0 =msto_prx
  958. pf.init(msto_prx)
  959. msto_prx.walker_start(msto_prx)
  960. glob_mx.init_db=true
  961. // TODO:JFI make msto a class instance maybe
  962. /*
  963. window.msto = {
  964. ...pf.root,
  965. // participants:pf.root.participants,
  966. // conference:pf.root.conference,
  967. // my_data:pf.root.participants[glob_mx.local_id],
  968. get my_channel(){
  969. return msto.ws_channels[get_ws_channel_name()]
  970. // my_data("pfx get k1")
  971. },
  972. set my_channel(val){
  973. clog("pfx set my_channel")
  974. msto.ws_channels[get_ws_channel_name()] = val
  975. },
  976. get my_data(){
  977. return msto.participants[get_local_sto_id()]
  978. },
  979. set my_data(val){
  980. clog("pfx set my_data")
  981. msto.participants[get_local_sto_id()] = val
  982. },
  983. private_local:{},
  984. }
  985. // */
  986. // window.msto
  987. var dbl_proxy_obj = {
  988. // _wrapped_proxy:pf.root,
  989. // _wrapped_proxy2:pf.root,
  990. get my_channel(){
  991. return msto.ws_channels[get_ws_channel_name()]
  992. // my_data("pfx get k1")
  993. },
  994. set my_channel(val){
  995. clog("pfx set my_channel")
  996. msto.ws_channels[get_ws_channel_name()] = val
  997. },
  998. get my_data(){
  999. return msto.participants[get_local_sto_id()]
  1000. },
  1001. set my_data(val){
  1002. clog("pfx set my_data")
  1003. msto.participants[get_local_sto_id()] = val
  1004. },
  1005. private_local:{},
  1006. }
  1007. pf.dbl_proxy_obj=dbl_proxy_obj
  1008. // window.dbl_proxy=new Proxy(dbl_proxy_obj, DBL_Proxy)
  1009. // window.msto=new Proxy(dbl_proxy_obj, DBL_Proxy)
  1010. window.msto=new Proxy(msto_prx, DBL_Proxy)
  1011. }
  1012. function handle_pre_init_msgs(){
  1013. clog("handle_pre_init_msgs")
  1014. var k,v,i
  1015. var _o
  1016. glob_u.prom.init_db_resolve.resolved_inited = 1
  1017. for (v of glob_u.ws.sockets.ws1.pre_init_msgs){
  1018. if (v.data.sto_event_type == "set_msg"){
  1019. msto.my_data.rehandle=1
  1020. _o={...v,data:jc(v.data)}
  1021. mhndlr_rld_2(_o,{type:"rehandle"})
  1022. }
  1023. }
  1024. glob_u.prom.init_db_resolve.resolved_inited = 2
  1025. }
  1026. function ws_sto_connected(a,b){
  1027. glob_u.cb.ws.run_cbs("WS_MSTO_INITED")
  1028. handle_pre_init_msgs()
  1029. // clog("ws_sto_connected",a,b,this)
  1030. }
  1031. function init_mu(){
  1032. var k,v
  1033. var rr = {}
  1034. var prom1 = new Promise(pfnf(rr));
  1035. prom1.then(init_db).then(ws_sto_connected)
  1036. glob_u.prom.init_db_resolve_timeout_arg = {aaa:"timedout",pl:msto_z}
  1037. setTimeout(rr.resolve,5000,glob_u.prom.init_db_resolve_timeout_arg)
  1038. var rn = ((Math.random()+"").replace("0.","") - 0).toString(16)
  1039. tmsgx4({sto_event_type:"db_sync_request","CLIENT_KEY":"ws_sto",request_rn:rn})
  1040. glob_u.prom.init_db_resolve = rr.resolve
  1041. glob_u.prom.init_db_resolve.rn = rn
  1042. }
  1043. function ord_init_once(o,scope,info){
  1044. // clog("ord_init_once:",{o,scope,info})
  1045. init_mu()
  1046. // info.cbs[info.k].remove_after_exe = 1
  1047. }
  1048. glob_u.cb.ws.reg_cb(ord_init_once,"WS_OPEN:","ord_init_once")
  1049. function ds_test(){
  1050. glob_u.cb.ws.reg_cb(ord_init_once,"WS_OPEN:","ord_init_once")
  1051. ws_reload()
  1052. }
  1053. glob_u.fns.ds_test=ds_test
  1054. // jsync:test.js
  1055. // ------------------------------------------------------------------------------------------------
  1056. // clog("/////////")
  1057. // msto_sc_proxy
  1058. // permissions_def
  1059. // connection_info_handler
  1060. // /*
  1061. function get_local_sto_id(){
  1062. return glob_u.data.jsync_local_id
  1063. }
  1064. function get_session_sto_id(){
  1065. return glob_u.data.jsync_session_id
  1066. }
  1067. function get_ws_channel_name(){
  1068. return glob_u.data.channel_name
  1069. }
  1070. function gen_djc_srv_id(){
  1071. // I don't know how often this will generate duplicates
  1072. var djc_srv_id = localStorage.djc_srv_id
  1073. var djc_srv_id_vers = localStorage.djc_srv_id_vers
  1074. const current_id_vers = 0.0
  1075. if (Number(djc_srv_id_vers) < current_id_vers || !(djc_srv_id)){
  1076. clog("????")
  1077. localStorage.djc_srv_id = ((Math.random()+"").replace("0.","") - 0).toString(16)
  1078. localStorage.djc_srv_id_vers = current_id_vers
  1079. }
  1080. glob_u.data.djc_srv_id = localStorage.djc_srv_id
  1081. clog("djc_srv_id:",{version:localStorage.djc_srv_id_vers,id:localStorage.djc_srv_id})
  1082. }
  1083. function init_msto_user_data(o,scope,info){
  1084. var ws_channel_name = get_ws_channel_name()
  1085. var local_sto_id = get_local_sto_id()
  1086. // clog("init_msto_user_data???",{local_sto_id,ws_channel_name,o,scope,info})
  1087. if (!glob_u.ws.sockets.ws1.params.include_ws_channel_data){return}
  1088. msto.ws_channels[ws_channel_name]=msto.ws_channels[ws_channel_name] || {id:local_sto_id}
  1089. if (!glob_u.ws.sockets.ws1.params.include_participants_data){return}
  1090. msto.participants[local_sto_id]=msto.participants[local_sto_id] || {}
  1091. // clog("init_msto_user_dataw???")
  1092. }
  1093. glob_u.cb.ws.reg_cb(init_msto_user_data,"WS_MSTO_INITED","init_msto_user_data")
  1094. window.permissions_def = window.permissions_def || {
  1095. participants:{
  1096. m:["participants"],
  1097. fn(set_scope,match){
  1098. if (match.fp[1] == "rejx")
  1099. throw "permission err"
  1100. return
  1101. },
  1102. }
  1103. }
  1104. // */
  1105. // jsync_local_id
  1106. // jsync_local_vers
  1107. // jsync_session_id
  1108. // jsync_session_vers
  1109. // jsync_id
  1110. // jsync_vers
  1111. window.permissions_def = {
  1112. participants:{
  1113. m:["participants"],
  1114. fn(set_scope,match){
  1115. if (match.fp[1] != get_local_sto_id()){
  1116. console.error("permission err:participants",set_scope,match)
  1117. // console.trace("permission err:participants")
  1118. throw "permission err"
  1119. }
  1120. return
  1121. },
  1122. },
  1123. ws_channels:{
  1124. m:["ws_channels"],
  1125. fn(set_scope,match){
  1126. if (match.fp[1] != get_ws_channel_name()){
  1127. console.error("permission err:ws_channels",set_scope,match)
  1128. throw "permission err"
  1129. }
  1130. }
  1131. },
  1132. }
  1133. window.permissions_def0 = {
  1134. /*
  1135. ws_channels:{
  1136. m:["ws_channels"],
  1137. fn(set_scope,match){
  1138. if (match.fp[1] != window.glob_u.data.channel_name){
  1139. console.error("permission err:ws_channels",set_scope,match)
  1140. throw "permission err"
  1141. }
  1142. }
  1143. },
  1144. */
  1145. user_channels:{
  1146. m:["user_channels"],
  1147. fn(set_scope,match){
  1148. if (match.fp[1] != get_ws_channel_name()){
  1149. console.error("permission err:user_channels",set_scope,match)
  1150. throw "permission err"
  1151. }
  1152. }
  1153. },
  1154. user_data_sessions:{
  1155. m:["user_data_sessions"],
  1156. fn(set_scope,match){
  1157. if (match.fp[1] != get_session_sto_id()){
  1158. console.error("permission err:user_data_sessions",set_scope,match)
  1159. // console.trace("permission err:participants")
  1160. throw "permission err"
  1161. }
  1162. return
  1163. },
  1164. },
  1165. user_data_local:{
  1166. m:["user_data_local"],
  1167. fn(set_scope,match){
  1168. if (match.fp[1] != get_local_sto_id()){
  1169. console.error("permission err:user_data_local",set_scope,match)
  1170. // console.trace("permission err:participants")
  1171. throw "permission err"
  1172. }
  1173. return
  1174. },
  1175. },
  1176. /*
  1177. participants:{
  1178. m:["participants"],
  1179. fn(set_scope,match){
  1180. if (match.fp[1] != window.glob_u.data.djc_srv_id){
  1181. console.error("permission err:participants",set_scope,match)
  1182. // console.trace("permission err:participants")
  1183. throw "permission err"
  1184. }
  1185. return
  1186. },
  1187. }
  1188. */
  1189. }
  1190. function ensure_jsync_id_is_set(storage_,base_name){
  1191. var storage = storage_
  1192. var id_name = base_name + "_id"
  1193. var vers_name = base_name + "_vers"
  1194. var djc_srv_id = storage[id_name]
  1195. var djc_srv_id_vers = storage[vers_name]
  1196. const current_id_vers = 0.0
  1197. if (Number(djc_srv_id_vers) < current_id_vers || !(djc_srv_id)){
  1198. storage[id_name] = ((Math.random()+"").replace("0.","") - 0).toString(16)
  1199. storage[vers_name] = current_id_vers
  1200. }
  1201. glob_u.data[id_name] = storage[id_name]
  1202. // clog("djc_srv_id:",{version:localStorage.djc_srv_id_vers,id:localStorage.djc_srv_id})
  1203. }
  1204. ensure_jsync_id_is_set(localStorage,"jsync_local")
  1205. ensure_jsync_id_is_set(sessionStorage,"jsync_session")
  1206. // function user_disconnected_compatibility_handler(o,scope,info){
  1207. // TODO:Fix bug caused by a user disconnecting before the connection is properly established
  1208. function connection_info_handler(o,scope,info){
  1209. if (o.data.sto_event_type=="connection_info"){
  1210. // clog("connection_info_handler:",o,scope,info)
  1211. glob_u.data.group_name = o.data.group_name
  1212. glob_u.data.channel_name = o.data.channel_name
  1213. clog("jsyncdb connected","room name:",glob_u.data.group_name)
  1214. } else if (o.data.sto_event_type=="user_disconnected"){
  1215. var last_conn =1
  1216. var k,v
  1217. var ws_conn_data = jc(msto.ws_channels[o.data.channel_name])
  1218. delete msto.ws_channels[o.data.channel_name]
  1219. for ([k,v] of Object.entries(msto.ws_channels)){
  1220. if (v.id == ws_conn_data.id){
  1221. last_conn = 0
  1222. }
  1223. }
  1224. if (last_conn){
  1225. // clog("DELlast_conn" ,ws_conn_data.id)
  1226. delete msto.participants[ws_conn_data.id]
  1227. }
  1228. clog("user_disconnected:",o.data.channel_name)
  1229. return
  1230. if (msto.user_channels){
  1231. delete msto.user_channels[o.data.channel_name]
  1232. }
  1233. if (msto.user_channels){
  1234. for ([k,v] of Object.entries(msto.user_channels)){
  1235. if (v.id == ws_conn_data.id){
  1236. last_conn = 0
  1237. }
  1238. }
  1239. }
  1240. if (last_conn){
  1241. clog("DELlast_conn" ,ws_conn_data.id)
  1242. delete msto.user_data_local[ws_conn_data.id]
  1243. }
  1244. }
  1245. }
  1246. glob_u.cb.ws.reg_cb(connection_info_handler,"WS_MESSAGE:ws_sto","connection_info_handler")
  1247. function ds_test3(){
  1248. glob_u.cb.ws.reg_cb(ord_init_once,"WS_OPEN:","ord_init_once")
  1249. ws_reload()
  1250. }
  1251. glob_u.fns.get_local_sto_id = get_local_sto_id
  1252. glob_u.fns.get_ws_channel_name = get_ws_channel_name
  1253. glob_u.fns.get_session_sto_id = get_session_sto_id
  1254. // console.log("??...")
  1255. // clog("???")
  1256. //
  1257. // glob_u.fns.get_room_name=get_room_name
  1258. // window.ds_test=ds_test
  1259. // glob_u.fns.ds_test=ds_test
  1260. // window.msto_prx=msto_prx
  1261. })()