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

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. var data = JSON.parse(event.data)
  411. // clog("WS_dispatch",data,socket.params.ord,data["CLIENT_KEY"])
  412. // clog("trc:sto:ws_rec",data.CLIENT_KEY,data.sto_event_type,data)
  413. trc_sto("ws_rec",data)
  414. glob_u.ws.sockets.ws1.params.ord.run_cbs("WS_MESSAGE:"+data["CLIENT_KEY"],{event,that:this,data})
  415. return
  416. if (e.arguments[0].type == "message"){
  417. var data = JSON.parse(e.arguments[0].data)
  418. if ("type" in data && ws_handlers[data.type]){
  419. ws_handlers[data.type](data,{that:e.that,event:e.arguments[0]})
  420. } else {
  421. clog("NO HANDLER FOR",data.type)
  422. }
  423. clog("~WS",data,e)
  424. } else if (e.arguments[0].type == "open") {
  425. ws_handlers.on_open(e)
  426. }
  427. }
  428. function ws_reload(){
  429. try{
  430. if ((!glob_u.ws.sockets.ws1 || glob_u.ws.sockets.ws1.readyState == 3 || glob_u.ws.sockets.ws1.readyState == undefined)){
  431. ws_helper()
  432. } else {
  433. glob_u.ws.sockets.ws1.close()
  434. clog(glob_u.ws.sockets.ws1,glob_u.ws.sockets.ws1.readyState)
  435. glob_u.ws.sockets.ws1.onclose = ws_helper
  436. }
  437. } catch (err){
  438. clog(err)
  439. }
  440. }
  441. function get_room_name(){
  442. // return
  443. var s=location.search
  444. // if s[0]=="?"){}
  445. s[0]=="?" ? s = s.slice(1):0
  446. var param
  447. for (param of s.split("&")){
  448. let kv = param.split("=")
  449. if (kv[0]=="room"){
  450. return kv[1]
  451. }
  452. clog("::",param,kv)
  453. // clog("::",param,kv,"")
  454. }
  455. // var
  456. return "room_name"
  457. var room_name=location.pathname.match(/\/loc.([^\/]*)\//)
  458. if (room_name){
  459. room_name = room_name[1]
  460. } else {
  461. room_name = location.pathname.split("/").pop()
  462. }
  463. return room_name
  464. }
  465. // function get_room_name(){
  466. function get_room_name_old(){
  467. var room_name=location.pathname.match(/\/loc.([^\/]*)\//)
  468. if (room_name){
  469. room_name = room_name[1]
  470. } else {
  471. room_name = location.pathname.split("/").pop()
  472. }
  473. return room_name
  474. }
  475. function ws_helper(){
  476. clog("WS_HELPER")
  477. var fns = window.glob_u.ws.fns
  478. var o = {
  479. include_participants_data:1,
  480. include_ws_channel_data:1, // required for participants_data to work
  481. // 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
  482. AutoReconnect:false,
  483. AutoReconnect:true,
  484. url:'wss://' + window.location.hostname +`/djc_srv/ws/chat/${get_room_name()}`,
  485. socket_name:"ws1",
  486. ord:glob_u.cb.ws,
  487. methods:{
  488. onmessage:fns.dispatch,
  489. onclose:fns.onclose,
  490. onerror:fns.onerror,
  491. onopen:fns.onopen,
  492. },
  493. methods:{
  494. onmessage:fns.onmessage,
  495. onclose:fns.onclose,
  496. onerror:fns.onerror,
  497. onopen:fns.onopen,
  498. },
  499. fns:{
  500. // reconnect:fns.reconnect,
  501. },
  502. }
  503. /*
  504. if (window.glob_u.ws.ws1 && window.glob_u.ws.ws1.readyState == 1){
  505. clog("WS ws1 is CONNECTED:",window.glob_u.ws.ws1)
  506. return
  507. }
  508. */
  509. var socket = connect_ws(o)
  510. // clog({socket})
  511. }
  512. window.glob_u.fns.connect_ws = connect_ws
  513. glob_u.fns.get_room_name=get_room_name
  514. create_ws_ord()
  515. glob_u.cb.ws.reg_cb(window.glob_u.ws.fns.dispatch,"WS_MESSAGE:","WS_MESSAGE")
  516. // jsync:sto.js
  517. // ------------------------------------------------------------------------------------------------
  518. // FILE:DS0
  519. var Proxy_Permissions,Proxy_Factory
  520. function mhndlr_rld_2(_o,scope,info){
  521. var dlog =nop
  522. try {
  523. var parsed = _o.data
  524. var o = parsed.payload
  525. // clog("mhndlr_rld",parsed.sto_event_type,parsed,{_o,scope,info})
  526. if (window.mhndlr_rld_dbg){
  527. mhndlr_rld_dbg({m,that,n,parsed,ai,o,arguments})
  528. }
  529. switch (parsed.sto_event_type){
  530. case "set_msg":
  531. // if (!glob_u.prom.init_db_resolve.resolved){
  532. if (!glob_u.prom.init_db_resolve.resolved_inited && _o?.event?.target?.pre_init_msgs){
  533. _o.event.target.pre_init_msgs.push(_o)
  534. }
  535. pf._set_recv(o.path,o.key,o.val)
  536. // clog("msto_evh?ord")
  537. glob_u.fns.msto_evh ? glob_u.fns.msto_evh(o,parsed) : 0
  538. break;
  539. case "group_count":
  540. // clog("mhndlr_rld group_count",parsed)
  541. if (parsed.group_count < 2){
  542. // clog("mhndlr_rld group_count RESOLVE")
  543. glob_u.prom.init_db_resolve(glob_u.prom.init_db_resolve_timeout_arg)
  544. }
  545. break;
  546. case "event":
  547. /*
  548. dlog("~event~",parsed)
  549. if (window.dispatch_events){
  550. dispatch_events({parsed,ai,m,that})
  551. }
  552. */
  553. break;
  554. case "msg_test":
  555. dlog("msg_test",parsed)
  556. break;
  557. case "db_sync_request":
  558. // tmsgx4({sto_event_type:"db_sync_response",payload:pf.root,"CLIENT_KEY":"ws_sto"})
  559. // if (glob_u.prom.init_db_resolve.resolved){
  560. if (glob_u.prom.init_db_resolve.resolved_inited == 2){
  561. 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"})
  562. }
  563. break;
  564. case "db_sync_response":
  565. if (glob_u.prom.init_db_resolve && parsed.request_rn_from == glob_u.prom.init_db_resolve.rn){
  566. glob_u.prom.init_db_resolve({aaa:"dsr",pl:parsed.payload})
  567. }
  568. // clog("db_sync_response",parsed)
  569. break;
  570. }
  571. } catch (err) {
  572. clog("mhndlr err:",err)
  573. }
  574. }
  575. glob_u.fns.msto_evh = function(o,parsed,ai,id){
  576. // clog("ord_msto_evh")
  577. if (o.path[0]!="conference" || o.path[1]!="events"){
  578. return
  579. }
  580. glob_u.cb.ws.STO_EVENT.run_cbs(":STO_EVENT",{o,parsed,ai,id})
  581. if (typeof(o.val) == "object"){
  582. glob_u.cb.ws.STO_EVENT.run_cbs(o.val.type,{o,parsed,ai,id})
  583. }
  584. }
  585. glob_u.cb.ws.reg_cb(mhndlr_rld_2,"WS_MESSAGE:ws_sto","WS_MESSAGE:ws_sto")
  586. // FILE:DS1
  587. var dlog = nop
  588. function tmsgx4(m){
  589. var socket = glob_u.ws.sockets.ws1
  590. var jsend = socket.params.fns.jsend
  591. var t = {
  592. key:"tmp_dev_sto",
  593. }
  594. glob_u.fns.merge_partial_template(m,t)
  595. // clog("tmsgx4",{key:m.key,sto_event_type:m.sto_event_type,CLIENT_KEY:m.CLIENT_KEY},{m,t})
  596. trc_sto("tmsgx4",m)
  597. jsend(m)
  598. }
  599. isProxy = Symbol("isProxy")
  600. tlu = {
  601. object:"",
  602. string:true,
  603. number:true,
  604. undefined:true,
  605. boolean:true,
  606. }
  607. function type_info(o){
  608. try {
  609. var t
  610. var flags = {
  611. leaf:false,
  612. deep_not_prx:false,
  613. prx:false,
  614. isObj:false,
  615. isArr:false,
  616. els:false,
  617. }
  618. t = typeof(o)
  619. flags.t=t
  620. if (!(o === null)){
  621. flags.isArr = Array.isArray(o)
  622. flags.isObj = Object.prototype == o.__proto__
  623. }
  624. if (tlu[t] === true || o === null){
  625. flags.leaf = true
  626. } else if (t == "object" && o.__prx){
  627. flags.prx = true
  628. } else if (t == "object" && (flags.isArr || flags.isObj)){
  629. flags.prx = false
  630. flags.deep_not_prx = true
  631. } else {
  632. clog("ELSE")
  633. flags.els = true
  634. }
  635. return flags
  636. } catch (err){
  637. clog("type_info err:",err,{flags,o})
  638. }
  639. }
  640. function deep_prop_v0(o,p){
  641. try {
  642. var arr = jc(p)
  643. var ret = o
  644. while (arr.length){
  645. ret = ret[arr.shift()]
  646. }
  647. return ret
  648. } catch(err){console.error("DEEP_PROP ERR:",err)}
  649. }
  650. // delete Proxy_Factory
  651. // {
  652. Proxy_Factory = class Proxy_Factory {
  653. constructor(o,n="dflt"){
  654. this.db = o
  655. this.n = n
  656. this.hidden_props = ["add_proxy","_set","walker","walker_start","prxy"]
  657. this._pub_cb =[]
  658. this.__prx = true
  659. this.SymPrx = Symbol("SymPrx")
  660. }
  661. init(o){
  662. this.root = o
  663. }
  664. sync(o){
  665. this.root = jc(o.root)
  666. o._pub_cb.push(this._set_recv.bind(this))
  667. }
  668. get prxy(){
  669. return this
  670. }
  671. _set(o,k,v,prx,a0){
  672. this.obj[k]=prx
  673. }
  674. set_pub(obj, prop, val,receiver){
  675. this._set_pub(obj.__path_arr, prop, jx(val))
  676. }
  677. _set_pub(path,key,val){
  678. var k,v
  679. var arg = {
  680. "CLIENT_KEY":"ws_sto",
  681. "sto_event_type":"set_msg",
  682. "payload":{path,key,val},}
  683. tmsgx4(arg,
  684. )
  685. for (v of this._pub_cb){
  686. v(path,key,val)
  687. }
  688. }
  689. _set_recv(path,prop,val,id){
  690. console.trace("_set_recv",{path,prop,val,id})
  691. var p = path
  692. var nprop = deep_prop_v0(this.root,p)
  693. var dpth = nprop.__dpth
  694. if (tlu[typeof(val)]){
  695. nprop._set(nprop,prop,val,val)
  696. } else {
  697. nprop._set(nprop,prop,val,new Proxy(val,this))
  698. nprop[prop].add_proxy(nprop,prop,val,dpth+1)
  699. }
  700. this.walker(nprop[prop],{},dpth+2)
  701. }
  702. set(obj, prop, val,receiver){
  703. if (obj[prop] === val){
  704. return Reflect.set(...arguments)
  705. }
  706. this.set_pub(obj, prop, val,receiver)
  707. this.event_proc("set")
  708. if ("__prx" == prop){
  709. this.__prx=val
  710. return this.__prx
  711. }
  712. if (typeof(val) === "object" && val != null && !(val.__prx)){
  713. var ret = Reflect.set(...arguments)
  714. this.set_obj(obj, prop, val,receiver)
  715. return ret
  716. }
  717. return Reflect.set(...arguments)
  718. }
  719. get(obj, prop,receiver){
  720. if (this.hidden_props.includes(prop)){
  721. switch (prop){
  722. case "add_proxy":
  723. return this.add_proxy.bind(this)
  724. break;
  725. case "prxy":
  726. return this
  727. case "_set":
  728. return this._set.bind({that:this,obj, prop,receiver})
  729. case "walker_start":
  730. return this.walker_start
  731. case "walker":
  732. return this.walker
  733. break;
  734. }
  735. }
  736. if (isProxy == prop){ return true }
  737. if ("__prx" == prop){ return this.__prx }
  738. return Reflect.get(...arguments)
  739. }
  740. add_proxy(o,k,v,dpth){
  741. var xpath = o.__path
  742. var apath = o.__path_arr
  743. this.event_proc("add_proxy")
  744. if (!apath){
  745. apath=[]
  746. }
  747. if (!xpath){
  748. xpath="ROOT!"
  749. }
  750. Object.defineProperty(v,"__path_arr",Object.assign({value:apath.concat(k),},this.baseProp))
  751. Object.defineProperty(v,"__path",Object.assign({value:xpath+":"+k,},this.baseProp))
  752. Object.defineProperty(v,"__dpth",Object.assign({value:dpth,},this.baseProp))
  753. // Object.defineProperty(v,"__dbg",Object.assign({value:{},},this.baseProp))
  754. }
  755. set_obj(obj, prop, val,receiver){
  756. var dpth = obj.__dpth
  757. var tf = {}
  758. var dbg_obj = {}
  759. this.walker(receiver,tf,dpth,dbg_obj)
  760. if (dbg_obj.depth_err){
  761. clog("MAX DEPTH?",dbg_obj,{obj, prop, val,receiver})
  762. }
  763. }
  764. walker(o,tfo,dpth=0,dbg_obj={"t":"unused"}){
  765. // if (dpth > 7){
  766. if (dpth > 15){
  767. dbg_obj.depth_err=1
  768. console.error("MAX DEPTH",{o,tfo,dpth,dbg_obj})
  769. return
  770. }
  771. var k,v
  772. var tf
  773. for ([k,v] of Object.entries(o)){
  774. tf = type_info(v)
  775. if (tf.deep_not_prx){
  776. o._set(o,k,v,new Proxy(v,this.prxy))
  777. o[k].add_proxy(o,k,v,dpth)
  778. this.walker(o[k],tf,dpth+1,dbg_obj)
  779. }
  780. }
  781. }
  782. walker_start(o,dpth){
  783. var tf = type_info(o)
  784. o.add_proxy({},[],o,-1)
  785. this.walker(o,tf,0)
  786. }
  787. event_proc(e){}
  788. }
  789. window.Proxy_Factory = Proxy_Factory
  790. Proxy_Factory.prototype.baseProp={
  791. writable: true,
  792. enumerable: false,
  793. // enumerable: true,
  794. configurable: true,
  795. }
  796. // }
  797. function arr_match(m,o){
  798. var k,v
  799. var r = 0
  800. for ([k,v] of Object.entries(m || {})){
  801. if (o[k] != v.valueOf()){
  802. r += 1
  803. return !r
  804. }
  805. }
  806. return !r
  807. }
  808. // permissions_def = {
  809. window.permissions_def = window.permissions_def || {
  810. participants:{
  811. m:["participants"],
  812. fn(set_scope,match){
  813. if (match.fp[1] == "rejx")
  814. throw "permission err"
  815. return
  816. },
  817. }
  818. }
  819. // {
  820. Proxy_Permissions = class Proxy_Permissions extends Proxy_Factory {
  821. constructor(a,a1){
  822. super(...arguments)
  823. }
  824. set(obj, prop, val,receiver){
  825. var k,v
  826. var r
  827. var matched
  828. var fp = obj.__path_arr.concat(prop)
  829. for ([k,v] of Object.entries(permissions_def)){
  830. matched = arr_match(v.m,fp)
  831. if (matched){
  832. r = v.fn({that:this,obj, prop, val,receiver},{fp,k,v}) || {}
  833. }
  834. }
  835. return super.set(obj, prop, val,receiver)
  836. }
  837. _set(){
  838. super._set(...arguments)
  839. }
  840. }
  841. window.Proxy_Permissions = Proxy_Permissions
  842. // }
  843. // clog("???")
  844. // jsync:init.js
  845. // ------------------------------------------------------------------------------------------------
  846. function pfnf(o){
  847. return function(resolve, reject){
  848. o.resolve=resolve
  849. o.reject=reject
  850. }
  851. }
  852. msto_z = {
  853. conference:{
  854. events:{},
  855. },
  856. participants:{},
  857. ws_channels:{},
  858. }
  859. var DBL_Proxy0 = {
  860. set(obj, prop, val,receiver){
  861. clog({obj, prop, val,receiver})
  862. // return Reflect.set(...arguments)
  863. if (Object.getOwnPropertyNames(obj).includes(prop)){
  864. return Reflect.set(...arguments)
  865. } else {
  866. return obj._wrapped_proxy[prop]=val
  867. // return Reflect.set(...arguments)
  868. }
  869. },
  870. get(obj, prop,receiver){
  871. clog({obj, prop,receiver},Object.getOwnPropertyNames(obj))
  872. if (Object.getOwnPropertyNames(obj).includes(prop)){
  873. return Reflect.get(...arguments)
  874. } else {
  875. return obj._wrapped_proxy[prop]
  876. // return Reflect.get(...arguments)
  877. }
  878. },
  879. }
  880. var DBL_Proxy1 = {
  881. set(obj, prop, val,receiver){
  882. // clog({obj, prop, val,receiver})
  883. // return Reflect.set(...arguments)
  884. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  885. // if (Object.getOwnPropertyNames(obj).includes(prop)){
  886. return pf.dbl_proxy_obj[prop]=val
  887. } else {
  888. return Reflect.set(...arguments)
  889. // return Reflect.set(...arguments)
  890. }
  891. },
  892. get(obj, prop,receiver){
  893. // clog({obj, prop,receiver},Object.getOwnPropertyNames(obj))
  894. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  895. return pf.dbl_proxy_obj[prop]
  896. } else {
  897. return Reflect.get(...arguments)
  898. // return Reflect.get(...arguments)
  899. }
  900. },
  901. }
  902. var DBL_Proxy = {
  903. set(obj, prop, val,receiver){
  904. // clog({obj, prop, val,receiver})
  905. // return Reflect.set(...arguments)
  906. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  907. // if (Object.getOwnPropertyNames(obj).includes(prop)){
  908. return pf.dbl_proxy_obj[prop]=val
  909. } else {
  910. return obj[prop] = val
  911. // TODO: make sure this proxy doesn't cause other similar bugs
  912. // return Reflect.set(...arguments)
  913. }
  914. },
  915. getOwnPropertyDescriptor(obj, prop){
  916. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  917. return Reflect.getOwnPropertyDescriptor(pf.dbl_proxy_obj, prop)
  918. } else {
  919. return Reflect.getOwnPropertyDescriptor(obj, prop)
  920. }
  921. },
  922. get(obj, prop,receiver){
  923. // clog({obj, prop,receiver},Object.getOwnPropertyNames(obj))
  924. if (Object.getOwnPropertyNames(pf.dbl_proxy_obj).includes(prop)){
  925. return pf.dbl_proxy_obj[prop]
  926. } else {
  927. return Reflect.get(...arguments)
  928. // return Reflect.get(...arguments)
  929. }
  930. },
  931. ownKeys(target) {
  932. var target_keys = Reflect.ownKeys(target);
  933. var extra_keys = Reflect.ownKeys(pf.dbl_proxy_obj);
  934. // clog("ownKeys",{target_keys,extra_keys})
  935. return [...target_keys,...extra_keys]
  936. },
  937. }
  938. function init_db(objx){
  939. clog("init_db~",arguments,this)
  940. console.trace("init_db")
  941. trc_sto("init_db",{})
  942. glob_u.prom.init_db_resolve.resolved=1
  943. var glob_mx = glob_u.data
  944. var obj
  945. // clog("init_dbx",objx,{arguments,that:this})
  946. if (objx.participants){
  947. obj = objx
  948. } else {
  949. obj = objx.pl
  950. }
  951. // clog("INIT DB...",objx,obj,jc({obj,objx}))
  952. pf = new Proxy_Permissions({},"pf")
  953. msto_prx = new Proxy(obj,pf)
  954. window.msto_prx=msto_prx
  955. // window.msto_prx0 =msto_prx
  956. pf.init(msto_prx)
  957. msto_prx.walker_start(msto_prx)
  958. glob_mx.init_db=true
  959. // TODO:JFI make msto a class instance maybe
  960. /*
  961. window.msto = {
  962. ...pf.root,
  963. // participants:pf.root.participants,
  964. // conference:pf.root.conference,
  965. // my_data:pf.root.participants[glob_mx.local_id],
  966. get my_channel(){
  967. return msto.ws_channels[get_ws_channel_name()]
  968. // my_data("pfx get k1")
  969. },
  970. set my_channel(val){
  971. clog("pfx set my_channel")
  972. msto.ws_channels[get_ws_channel_name()] = val
  973. },
  974. get my_data(){
  975. return msto.participants[get_local_sto_id()]
  976. },
  977. set my_data(val){
  978. clog("pfx set my_data")
  979. msto.participants[get_local_sto_id()] = val
  980. },
  981. private_local:{},
  982. }
  983. // */
  984. // window.msto
  985. var dbl_proxy_obj = {
  986. // _wrapped_proxy:pf.root,
  987. // _wrapped_proxy2:pf.root,
  988. get my_channel(){
  989. return msto.ws_channels[get_ws_channel_name()]
  990. // my_data("pfx get k1")
  991. },
  992. set my_channel(val){
  993. clog("pfx set my_channel")
  994. msto.ws_channels[get_ws_channel_name()] = val
  995. },
  996. get my_data(){
  997. return msto.participants[get_local_sto_id()]
  998. },
  999. set my_data(val){
  1000. clog("pfx set my_data")
  1001. msto.participants[get_local_sto_id()] = val
  1002. },
  1003. private_local:{},
  1004. }
  1005. pf.dbl_proxy_obj=dbl_proxy_obj
  1006. // window.dbl_proxy=new Proxy(dbl_proxy_obj, DBL_Proxy)
  1007. // window.msto=new Proxy(dbl_proxy_obj, DBL_Proxy)
  1008. window.msto=new Proxy(msto_prx, DBL_Proxy)
  1009. }
  1010. function handle_pre_init_msgs(){
  1011. // clog("handle_pre_init_msgs")
  1012. var k,v,i
  1013. var _o
  1014. glob_u.prom.init_db_resolve.resolved_inited = 1
  1015. // TODOL FIX HARDCODEING
  1016. for (v of glob_u.ws.sockets.ws1?.pre_init_msgs || []){
  1017. if (v.data.sto_event_type == "set_msg"){
  1018. msto.my_data.rehandle=1
  1019. _o={...v,data:jc(v.data)}
  1020. mhndlr_rld_2(_o,{type:"rehandle"})
  1021. }
  1022. }
  1023. glob_u.prom.init_db_resolve.resolved_inited = 2
  1024. }
  1025. function ws_sto_connected(a,b){
  1026. glob_u.cb.ws.run_cbs("WS_MSTO_INITED")
  1027. handle_pre_init_msgs()
  1028. // clog("ws_sto_connected",a,b,this)
  1029. }
  1030. function init_mu(){
  1031. var k,v
  1032. var rr = {}
  1033. console.trace("init_mu")
  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. })()