You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

dev_sto.native.js 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641
  1. var NS = {
  2. // set_msg:"update_query"
  3. UPDATE_QUERY:"set_msg",
  4. // UPDATE_QUERY:"update_query",
  5. JOIN_DB:"connect_jdb",
  6. // JOIN_DB:"update_query",
  7. }
  8. function log_a1(lstr,o={}){
  9. try {
  10. tglob_au.run_dev_cbs("sto_log",{lstr,...o})
  11. } catch (err) {
  12. console.log("err:sto_log_dflt",lstr)
  13. }
  14. }
  15. function pfnf(o){
  16. return function(resolve, reject){
  17. o.resolve=resolve
  18. o.reject=reject
  19. // clog(arguments)
  20. }
  21. }
  22. var isProxy = Symbol("isProxy")
  23. var tlu = {
  24. object:"",
  25. string:true,
  26. number:true,
  27. undefined:true,
  28. boolean:true,
  29. }
  30. function arr_match(m,o){
  31. var k,v
  32. var r = 0
  33. for ([k,v] of Object.entries(m || {})){
  34. if (o[k] != v.valueOf()){
  35. r += 1
  36. return !r
  37. }
  38. // for ([k,v] in m){
  39. // case
  40. // dlog(k,v)
  41. }
  42. return !r
  43. }
  44. function type_info(o){
  45. try {
  46. var t
  47. var flags = {
  48. leaf:false,
  49. deep_not_prx:false,
  50. prx:false,
  51. isObj:false,
  52. isArr:false,
  53. els:false,
  54. }
  55. t = typeof(o)
  56. flags.t=t
  57. // window?.glob_mx?.flags?.type_info_dbg ? clog("type_info") : 0
  58. if (!(o === null)){
  59. flags.isArr = Array.isArray(o)
  60. flags.isObj = Object.prototype == o.__proto__
  61. }
  62. if (tlu[t] === true || o === null){
  63. flags.leaf = true
  64. } else if (t == "object" && o.__prx){
  65. flags.prx = true
  66. } else if (t == "object" && (flags.isArr || flags.isObj)){
  67. flags.prx = false
  68. flags.deep_not_prx = true
  69. } else {
  70. clog("ELSE")
  71. flags.els = true
  72. }
  73. return flags
  74. // !window?.glob_mx?.flags?.type_info_dbg ? clog("type_info") : 0
  75. } catch (err){
  76. clog("type_info err:",err,{flags,o})
  77. }
  78. // clog(t,flags)
  79. }
  80. function deep_prop_v0(o,p){
  81. try {
  82. var arr = jc(p)
  83. var ret = o
  84. while (arr.length){
  85. // clog("deep_prop",arr,ret)
  86. ret = ret[arr.shift()]
  87. }
  88. // clog("deep_prop ret",ret)
  89. return ret
  90. } catch(err){console.error("DEEP_PROP ERR:",err)}
  91. }
  92. class Proxy_Factory {
  93. constructor(o,n="dflt",base_n="dflt",full_n="dflt-dflt",socket_name=""){
  94. // log_a1("Proxy_Factory")
  95. this.db = o
  96. this.n = n
  97. this.socket_name = socket_name
  98. this.base_n = base_n
  99. this.full_n = full_n
  100. this.hidden_props = ["add_proxy","_set","walker","walker_start","prxy","_sett","_sett2"]
  101. this._pub_cb =[]
  102. this.__prx = true
  103. this.SymPrx = Symbol("SymPrx")
  104. // clog("mx Proxy_Factory")
  105. // clog("pfx",{o,n,that:this})
  106. }
  107. constructor_x(){
  108. // o,n="dflt",base_n="dflt",full_n="dflt-dflt",socket_name=""
  109. // this.constructor_m(...arguments)
  110. clog("Proxy_Factory constructor")
  111. Proxy_Factory.prototype.constructor_m.call(this,...arguments)
  112. }
  113. mx1(){
  114. // clog(("mx1: Proxy_Factory"))
  115. }
  116. init(o){
  117. // dlog("BP",this,this.baseProp,this.__proto__.baseProp,window.baseProp)
  118. // clog("pfx init",{o,that:this})
  119. this.root = o
  120. }
  121. sync(o){
  122. this.root = jc(o.root)
  123. o._pub_cb.push(this._set_recv.bind(this))
  124. }
  125. get prxy(){
  126. return this
  127. }
  128. _set(o,k,v,prx,a0){
  129. this.obj[k]=prx
  130. }
  131. _sett(o,k,v,prx,a0){
  132. dlog("_SETT",this,arguments)
  133. }
  134. _sett2(o,k,v,prx,a0){
  135. dlog("_SETT2",this,arguments)
  136. }
  137. set_pub(obj, prop, val,receiver){
  138. // dlog("qia_pub",obj, prop, val,receiver)
  139. // dlog("qia_pub2",this.n,obj.__path_arr, prop, jx(val))
  140. this._set_pub(obj.__path_arr, prop, jx(val))
  141. }
  142. // dev_glob.fns.tmp_send
  143. _connect_db(){
  144. /*
  145. dev_glob.fns.tmp_send({
  146. "key":"connect_jdb",
  147. // ,
  148. init_obj:this.db,
  149. "payload":{},
  150. db_id:this.db_conn.db_id,
  151. },this.socket_name)
  152. // */
  153. this._wssto_send({
  154. // "key":"connect_jdb",
  155. "key":NS.JOIN_DB,
  156. // ,
  157. tx:["abc",,2],
  158. init_obj:this.db,
  159. "payload":{},
  160. })
  161. }
  162. get db_conn(){
  163. return {db_id:{n:this.n,base_n:this.base_n,full_n:this.full_n},socket_name:this.socket_name}
  164. }
  165. // _req_sync(){}
  166. _wssto_send(o){
  167. // clog("wssto: m0")
  168. if (!o.wssto_key){
  169. o.wssto_key = o.key
  170. o.key = "wssto"
  171. }
  172. // o.key = "_wssto_" + o.key
  173. this.send(o)
  174. }
  175. send(o){
  176. // dev_glob.fns.tmp_send({
  177. glob_vhook.fns.tmp_send({
  178. db_id:this.db_conn.db_id,
  179. ...o,
  180. },this.socket_name)
  181. }
  182. send_raw(){
  183. clog("DBQ")
  184. }
  185. _set_pub(path,key,val){
  186. var k,v
  187. // clog("dev_sto","_set_pub")
  188. /*
  189. tmsgx({
  190. "type":"set_msg",
  191. "payload":{path,key,val},
  192. },"code")
  193. // */
  194. //
  195. this._wssto_send({
  196. // "type":"set_msg",
  197. "type":NS.UPDATE_QUERY,
  198. "key":NS.UPDATE_QUERY,
  199. "payload":{path,key,val},
  200. })
  201. /*
  202. dev_glob.fns.tmp_send({
  203. // tmsgx3({
  204. // })
  205. "type":"set_msg",
  206. "key":"set_msg",
  207. db_id:this.db_conn.db_id,
  208. // "payload":{path,key,val,db_id:{n:this.n,base_n:this.base_n}},},this.socket_name
  209. "payload":{path,key,val},},this.socket_name
  210. // window.tmsgx_to || {}
  211. // {to:"nl4qbyiz61z-mce1@specplot.com/FlUkwrLs"},
  212. // {to:"maf@conference.i.specplot.com/0695c1e4"},
  213. // {},
  214. )
  215. */
  216. for (v of this._pub_cb){
  217. v(path,key,val)
  218. }
  219. }
  220. _set_recv(path,prop,val){
  221. // return
  222. var p = path
  223. var nprop = deep_prop_v0(this.root,p)
  224. // clog("_set_recv:",nprop)
  225. var dpth = nprop.__dpth
  226. if (tlu[typeof(val)]){
  227. nprop._set(nprop,prop,val,val)
  228. } else {
  229. nprop._set(nprop,prop,val,new Proxy(val,this))
  230. nprop[prop].add_proxy(nprop,prop,val,dpth+1)
  231. }
  232. // var tf = {}
  233. // this.walker(nprop[prop],tf,dpth+2)
  234. this.walker(nprop[prop],{},dpth+2)
  235. }
  236. set(obj, prop, val,receiver){
  237. // dlog("prx_db set ",this,obj, prop, val,receiver,val.__prx)
  238. // clog("prx_db set ",{that:this,obj, prop, val,receiver},val.__prx)
  239. // clog("prx_db set ",obj.__path_arr)
  240. if (obj[prop] === val){
  241. return Reflect.set(...arguments)
  242. }
  243. this.set_pub(obj, prop, val,receiver)
  244. this.event_proc("set")
  245. if ("__prx" == prop){
  246. this.__prx=val
  247. return this.__prx
  248. }
  249. if (typeof(val) === "object" && val != null && !(val.__prx)){
  250. var ret = Reflect.set(...arguments)
  251. this.set_obj(obj, prop, val,receiver)
  252. return ret
  253. }
  254. return Reflect.set(...arguments)
  255. }
  256. get(obj, prop,receiver){
  257. // dlog("prx_db get ...",prop==isProxy,this,obj, prop,receiver)
  258. if (this.hidden_props.includes(prop)){
  259. switch (prop){
  260. case "add_proxy":
  261. return this.add_proxy.bind(this)
  262. break;
  263. case "prxy":
  264. return this
  265. case "_set":
  266. // dlog("_SET")
  267. // return this._set.bind({this})
  268. return this._set.bind({that:this,obj, prop,receiver})
  269. case "_sett":
  270. return this._sett.bind({that:this,obj, prop,receiver})
  271. case "_sett2":
  272. return this._sett2.bind({that:this})
  273. case "walker_start":
  274. return this.walker_start
  275. case "walker":
  276. return this.walker
  277. break;
  278. }
  279. }
  280. if (isProxy == prop){ return true }
  281. if ("__prx" == prop){ return this.__prx }
  282. return Reflect.get(...arguments)
  283. }
  284. add_proxy(o,k,v,dpth){
  285. // clog("~add_proxy~",o,k,v,dpth)
  286. // clog("~add_proxy~",o.__prx,o,k,v,dpth,xpath)
  287. var xpath = o.__path
  288. var apath = o.__path_arr
  289. this.event_proc("add_proxy")
  290. if (!apath){
  291. apath=[]
  292. }
  293. if (!xpath){
  294. xpath="ROOT!"
  295. }
  296. Object.defineProperty(v,"__path_arr",Object.assign({value:apath.concat(k),},this.baseProp))
  297. Object.defineProperty(v,"__path",Object.assign({value:xpath+":"+k,},this.baseProp))
  298. Object.defineProperty(v,"__dpth",Object.assign({value:dpth,},this.baseProp))
  299. // Object.defineProperty(v,"__dbg",Object.assign({value:{},},this.baseProp))
  300. }
  301. set_obj(obj, prop, val,receiver){
  302. var dpth = obj.__dpth
  303. var tf = {}
  304. this.walker(receiver,tf,dpth)
  305. }
  306. walker(o,tfo,dpth=0){
  307. // dlog("qia WALK",this)
  308. if (dpth > 7){
  309. console.error("MAX DEPTH")
  310. return
  311. }
  312. var k,v
  313. var tf
  314. for ([k,v] of Object.entries(o)){
  315. tf = type_info(v)
  316. if (tf.deep_not_prx){
  317. o._set(o,k,v,new Proxy(v,this.prxy))
  318. o[k].add_proxy(o,k,v,dpth)
  319. this.walker(o[k],tf,dpth+1)
  320. }
  321. }
  322. }
  323. walker_start(o,dpth){
  324. var tf = type_info(o)
  325. o.add_proxy({},[],o,-1)
  326. this.walker(o,tf,0)
  327. }
  328. event_proc(e){}
  329. }
  330. var permissions_def = {
  331. participants:{
  332. m:["participants"],
  333. fn(set_scope,match){
  334. // clog("FN....",match.fp,match.fp[1] == window.glob_mx.local_id)
  335. return
  336. /*
  337. if (match.fp[1] != window.glob_mx.local_id)
  338. throw "permission err"
  339. return
  340. */
  341. },
  342. }
  343. }
  344. class Proxy_Permissions extends Proxy_Factory {
  345. // constructor_m(a,a1){
  346. constructor(a,a1){
  347. // clog("mx Proxy_Permissions")
  348. super(...arguments)
  349. }
  350. constructor_x(){
  351. // o,n="dflt",base_n="dflt",full_n="dflt-dflt",socket_name=""
  352. super.constructor_x(...arguments)
  353. this.constructor_m(...arguments)
  354. // Proxy_Permissions.prototype.constructor_m.call(this,...arguments)
  355. // this.prototype.constructor_m.call(this,...arguments)
  356. }
  357. mx1(){
  358. // clog(("mx1: Proxy_Permissions"))
  359. }
  360. set(obj, prop, val,receiver){
  361. // clog("PRX_PERM",obj.__path_arr,prop)
  362. var k,v
  363. var r
  364. var matched
  365. var fp = obj.__path_arr.concat(prop)
  366. for ([k,v] of Object.entries(permissions_def)){
  367. matched = arr_match(v.m,fp)
  368. if (matched){
  369. r = v.fn({that:this,obj, prop, val,receiver},{fp,k,v}) || {}
  370. }
  371. // if (r.return)
  372. }
  373. // case
  374. // if (obj.__path_arr && obj.__path_arr.length){}
  375. return super.set(obj, prop, val,receiver)
  376. }
  377. _set(){
  378. // clog("Proxy_Permissions _set")
  379. super._set(...arguments)
  380. }
  381. }
  382. function splice_out(arr,elm){
  383. let i = arr.indexOf(elm)
  384. // var r = ""
  385. if (i != -1){
  386. return arr.splice(i,1)
  387. }
  388. // return
  389. }
  390. function gen_sort_attr(attr){
  391. return function gsort(a0,a1){
  392. // clog("z",a0,a1)
  393. if (a0[attr] > a1[attr]){
  394. return 1
  395. } else if (a0[attr] < a1[attr]){
  396. return -1
  397. } else {
  398. return 0
  399. }
  400. }
  401. }
  402. function find_attr(elm,indx,arr){
  403. // this.attr
  404. // this.val
  405. // clog("F",{that:this,elm,indx,arr})
  406. // if ( elm[this.attr] == this.val){
  407. if (elm && elm[this.attr] == this.val){
  408. return 1
  409. }
  410. }
  411. var dflt_opts = {
  412. sort_fn:gen_sort_attr("override_level"),
  413. log_level:0,
  414. // ns:"",
  415. }
  416. class BoundObj{
  417. constructor(){
  418. this.init()
  419. }
  420. init(){
  421. let k,v,i,j
  422. for ([k,v] of Object.entries(Object.getOwnPropertyDescriptors(this.__proto__))){
  423. if (k.endsWith("_ub") && typeof(v.value) == "function"){
  424. // clog("UB",k,k.slice(1,-3))
  425. j = v.value.bind(this)
  426. j.meta_str = "bound_fn"
  427. this[k.slice(1,-3)] = j
  428. }
  429. }
  430. }
  431. /*
  432. mx2_ub(){
  433. clog("Mx2")
  434. }
  435. */
  436. }
  437. // class reg_cb_ord{
  438. class reg_cb_ord extends BoundObj{
  439. // con
  440. constructor(opts){
  441. super()
  442. this.opts = Object.assign({},dflt_opts,opts)
  443. this.r = Object.assign(this,dflt_opts,opts)
  444. // this.sort_fn = this.opts
  445. this.cb_sto = {}
  446. this._orig_opts = opts
  447. clog("v2 ",this)
  448. }
  449. _reg_cb_ub(cb,key_name,cb_name,override_level = 100,push=1){
  450. if (typeof(cb) != "function"){
  451. console.error("callback is not a function. setting push=r","\ncb:",cb)
  452. push = "r"
  453. // console.error("callback:",cb," is not a function")
  454. }
  455. // var this.cb_sto = {}
  456. var cb_sort = nop
  457. if (!this.cb_sto[key_name]){
  458. this.cb_sto[key_name] = []
  459. }
  460. // this.cb_sto[key_name].find(find_html_cb,{fn_key:cb_name})
  461. // splice_out_ti(this.cb_sto[key_name],this.cb_sto[key_name].find(find_html_cb,{fn_key:cb_name}))
  462. // var cbo0= this.cb_sto[key_name].find(glob_td.fn.find_html_cb,{fn_key:cb_name})
  463. // var cbo0= this.cb_sto[key_name].find(find_attr,{fn_key:cb_name})
  464. var cbo0= this.cb_sto[key_name].find(find_attr,{attr:"fn_key",val:cb_name})
  465. // clog(cbo0)
  466. splice_out(this.cb_sto[key_name],cbo0)
  467. // tn2t.arr.
  468. // splice_out_cb
  469. let cb_obj = {
  470. cb,
  471. hkey:key_name,
  472. fn_key:cb_name,
  473. override_level,
  474. }
  475. if (push=="r"){
  476. } else if (push){
  477. this.cb_sto[key_name].push(cb_obj)
  478. } else {
  479. this.cb_sto[key_name].unshift(cb_obj)
  480. }
  481. this.cb_sto[key_name].sort(this.sort_fn)
  482. }
  483. _run_cbs_ub(key,arg_obj){
  484. // if (!key in this.cb_sto){return}
  485. clog("_run_cbs_ub:",key)
  486. var k,v
  487. var o = {
  488. // html_key:key,cbs:glob_mx.html_cb[key],
  489. }
  490. // dlog("RUN_HOOK_CB??",key,glob_mx.hook_cb[key])
  491. try {
  492. this.opts.log_level ? clog("run_cbs",arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key]}) : 0
  493. for ([k,v] of Object.entries(this.cb_sto[key]|| {}) ) {
  494. // dlog("RUN_HOOK_CB:",k)
  495. // clog("run_html_cbs:",k,v)
  496. this.opts.log_level > 1 ? clog("run_cbs_e",arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key],k,v}) : 0
  497. v.cb(
  498. arg_obj,o,{that:this,hkey:key,cbs:this.cb_sto[key],k,v}
  499. )
  500. // v(o)
  501. }
  502. return {
  503. arg_obj,o,ord_that:{that:this,hkey:key,cbs:this.cb_sto[key],k,v}
  504. }
  505. } catch(err){
  506. console.error("ti_v_cb err:",err)
  507. console.log("ti_v_cb err:",err)
  508. }
  509. }
  510. /* fn1(){
  511. clog("fn1",{that:this,args:[...arguments]})
  512. }*/
  513. }
  514. window.tmp_dev_sto = {
  515. Proxy_Factory,Proxy_Permissions,reg_cb_ord,BoundObj
  516. }
  517. // Proxy_Factory