tinybase
Version:
A reactive data store and sync engine.
2 lines (1 loc) • 9.39 kB
JavaScript
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=globalThis,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,d=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),E=a=>a.length,N=()=>{},g=async a=>r.all(a),A=a=>{throw Error(a)},T=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},$=(a,t)=>a.forEach(t),p=(a,t="")=>a.join(t),O=(a,t)=>a.map(t),R=a=>0==E(a),m=(a,t)=>a.filter(t),v=(a,...t)=>a.push(...t),C=a=>a.shift(),I=(a,t)=>a?.has(t)??!1,L=a=>l(a)||0==(a=>a?.size??0)(a),S=a=>[...a?.values()??[]],_=(a,t)=>a?.forEach(t),b=(a,t)=>a?.delete(t),f=Object,D=a=>f.getPrototypeOf(a),P=f.entries,h=f.keys,F=f.freeze,M=(a=[])=>f.fromEntries(a),U=(...a)=>f.assign({},...a),G=(a,t)=>(delete a[t],a),j=(a,t)=>O(P(a),(([a,e])=>t(e,a))),x=(a,t)=>M(j(a,((a,e)=>[e,t(a,e)]))),W=a=>f.values(a),B=a=>E(h(a)),H=a=>(a=>!l(a)&&w(D(a),(a=>a==f.prototype||l(D(a))),(()=>!0)))(a)&&0==B(a),X=JSON.stringify,Y=JSON.parse,k=a=>X(a,((a,t)=>void 0===t?"":t)),q=new c.TextEncoder,z=a=>new Map(a),J=(a,t)=>a?.get(t),K=(a,t)=>O([...a?.entries()??[]],(([a,e])=>t(e,a))),V=(a,t,e)=>l(e)?(b(a,t),a):a?.set(t,e),Q=(a,t,e,n)=>(I(a,t)?n?.(J(a,t)):V(a,t,e()),J(a,t)),Z=(a,t,e,n,s=0)=>w((e?Q:J)(a,t[s],s>E(t)-2?e:z),(i=>{if(s>E(t)-2)return n?.(i)&&V(a,t[s]),i;const o=Z(i,t,e,n,s+1);return L(i)&&V(a,t[s]),o})),aa="_",ta="_id",ea="SELECT",na="WHERE",sa="TABLE",ia="INSERT",oa="DELETE",ra="UPDATE",ca="ALTER "+sa,la="FROM",wa=oa+" "+la,ya=ea+"*"+la,da="CREATE ",ua=da+sa,Ea="OR REPLACE ",Na="FUNCTION",ga="$tableName",Aa=a=>p(O(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${o(a,/"/g,'""')}"`)),"."),Ta=(...a)=>Aa(p(a,"_")),$a=(a,t=[1])=>p(O(a,(()=>"$"+t[0]++)),n),pa=(a,t=i)=>na+`(${o(t,ga,Aa(a))})`,Oa=a=>new Set(d(a)||l(a)?a:[a]),Ra=(a,t)=>a?.add(t),ma="ColumnName",va="store",Ca="json",Ia=va+"TableName",La=va+"Id"+ma,Sa=va+ma,_a="autoLoadIntervalSeconds",ba="rowId"+ma,fa="tableId",Da="tableName",Pa="deleteEmptyColumns",ha="deleteEmptyTable",Fa="condition",Ma={mode:Ca,[_a]:1},Ua={load:0,save:0,[Da]:t+"_values"},Ga=(a,t,e,n,s)=>{const i=z();return x(a,((a,o)=>{const r=u(W(U(t,y(a)?{[e]:a}:a)),0,B(t));l(r[0])||n(o,r[0])||(s(o,r[0]),V(i,o,r))})),i},ja=/^\d+$/,xa=z(),Wa=z(),Ba=(a,t,n,s,i,o,r,c={},y=0,u=[])=>{let N,g,p,O=0,R=0,m=0;Q(xa,u,(()=>0)),Q(Wa,u,(()=>[]));const I=z(),[S,f,D,P,h]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!H(a)||!H(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!H(a)||!H(t),t.setContent]:A("Store type not supported by this Persister"))(r,a,y),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{ja.test(t)&&E(a)<1e3&&v(a,t)}]})(),s=z();return[(n,i,o,r=[],c=()=>[])=>{a??=ta;const l=t(1);return V(s,l,[n,i,o,r,c]),Ra(Z(i,o??[e],Oa),l),l},(t,n,...i)=>$(((a,t=[e])=>{const n=[],s=(a,e)=>e==E(t)?v(n,a):null===t[e]?_(a,(a=>s(a,e+1))):$([t[e],null],(t=>s(J(a,t),e+1)));return s(a,0),n})(t,n),(t=>_(t,(t=>J(s,t)[0](a,...n??[],...i))))),a=>w(J(s,a),(([,t,i])=>(Z(t,i??[e],void 0,(t=>(b(t,a),L(t)?1:0))),V(s,a),n(a),i))),t=>w(J(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const r=E(o);r==E(e)?t(a,...o,...s(o)):l(e[r])?$(n[r]?.(...o)??[],(a=>i(...o,a))):i(...o,e[r])};i()}))]})(),j=a=>{a!=O&&(O=a,U(I,void 0,O))},x=t=>{(S&&d(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},W=async a=>(2!=O&&(j(1),R++,await aa((async()=>{await T((async()=>{const e=await t();d(e)?x(e):a?h(a):A("Content is not an array: "+e)}),(()=>{a&&h(a)})),j(0)}))),ta),B=async a=>(X(),await W(a),await T((async()=>g=await s((async(a,t)=>{t||a?2!=O&&(j(1),R++,x(t??a),j(0)):await W()}))),o),ta),X=async()=>(g&&(await T((()=>i(g)),o),g=void 0),ta),Y=async a=>(1!=O&&(j(2),m++,await aa((async()=>{await T((()=>n(f,a)),o),j(0)}))),ta),k=async()=>(q(),await Y(),p=a.addDidFinishTransactionListener((()=>{const a=D();P(a)&&Y(a)})),ta),q=async()=>(p&&(a.delListener(p),p=void 0),ta),K=async(a=!1)=>{const[t,e]=a?[q,X]:[X,q];return await t(),await e(),ta},aa=async(...a)=>(v(J(Wa,u),...a),await(async()=>{if(!J(xa,u)){for(V(xa,u,1);!l(N=C(J(Wa,u)));)await T(N,o);V(xa,u,0)}})(),ta),ta={load:W,startAutoLoad:B,stopAutoLoad:X,isAutoLoading:()=>!l(g),save:Y,startAutoSave:k,stopAutoSave:q,isAutoSaving:()=>!l(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,B]:[B,k];return await e(a),await n(a),ta},stopAutoPersisting:K,getStatus:()=>O,addStatusListener:a=>M(a,I),delListener:t=>(G(t),a),schedule:aa,getStore:()=>a,destroy:()=>(J(Wa,u).splice(0,void 0),K()),getStats:()=>({loads:R,saves:m}),...c};return F(ta)},Ha=(a,t,e,s,o,r=Xa,c,w)=>{const y=z();return[async()=>{y.clear(),O(await e(a,t),(({tn:a,cn:t})=>Ra(Q(y,a,Oa),t)))},async(t,e,n)=>((a,t)=>I(J(y,a),t))(t,e)?M(m(O(await a(ya+Aa(t)+pa(t,n)),(a=>[a[e],w?x(G(a,e),w):G(a,e)])),(([a,t])=>!l(a)&&!H(t)))):{},async(t,e,s,w,d,u=!1,E=i)=>{const N=Oa();x(s??{},(a=>O(h(a??{}),(a=>Ra(N,a)))));const A=S(N);if(!u&&d&&E==i&&R(A)&&I(y,t))return await a("DROP "+sa+Aa(t)),void V(y,t);const T=J(y,t),$=Oa(S(T));if(R(A)||(I(y,t)?await g(O([e,...A],(async(n,s)=>{b($,n)||(await a(ca+Aa(t)+"ADD"+Aa(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Aa(t)+`(${Aa(e)})`),Ra(T,n))}))):(await a(ua+Aa(t)+`(${Aa(e)}${o} PRIMARY KEY${p(O(A,(a=>n+Aa(a)+o)))});`),V(y,t,Oa([e,...A])))),await g([...!u&&w?O(S($),(async n=>{n!=e&&(await a(ca+Aa(t)+"DROP"+Aa(n)),b(T,n))})):[]]),u)l(s)?await a(wa+Aa(t)+pa(t,E)):await g(j(s,(async(n,s)=>{l(n)?await a(wa+Aa(t)+pa(t,E)+`AND(${Aa(e)}=$1)`,[s]):R(A)||await r(a,t,e,h(n),{[s]:c?O(W(n),c):W(n)},T)})));else if(R(A))I(y,t)&&await a(wa+Aa(t)+pa(t,E));else{const n=m(S(J(y,t)),(a=>a!=e)),i={},o=[];x(s??{},((a,t)=>{i[t]=O(n,(t=>c?c(a?.[t]):a?.[t])),v(o,t)})),await r(a,t,e,n,i),await a(wa+Aa(t)+pa(t,E)+`AND${Aa(e)}NOT IN(${$a(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await T((async()=>e=await t()),s),await a("END"),e}]},Xa=async(a,t,e,s,i)=>{const o=[1];await a(ia+" INTO"+Aa(t)+"("+((...a)=>p(O(a,Aa),n))(e,...s)+")VALUES"+p(j(i,(a=>"($"+o[0]+++","+$a(a,o)+")")),n)+"ON CONFLICT("+Aa(e)+`)DO ${ra} SET`+p(O(s,(a=>Aa(a)+"=excluded."+Aa(a))),n),j(i,((a,t)=>[t,...O(a,(a=>a??null))])).flat())},Ya=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=Ha(t,w,y,s,E,N),p=Ba(a,(()=>$((async()=>{return await g(),a=(await A(r,c))[aa]?.[l]??"null",Y(a,((a,t)=>""===t?void 0:t));var a}))),(a=>$((async()=>{await g(),await T(r,c,{[aa]:{[l]:k(a()??null)}},!0,!0)}))),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},ka=(a,t,e,n,s,i,o,[r,c,[w,y,d]],u,E,N,A,T,$,p,O)=>{const[R,v,C,I]=Ha(t,u,E,s,T,$,p,O),L=(a,t)=>g(K(c,(async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)}))),S=async(a,t)=>y?await C(d,ta,{[aa]:a},!0,!0,t):null,_=Ba(a,(()=>I((async()=>{await R();const a=await(async()=>M(m(await g(K(r,(async([a,t,e],n)=>[a,await v(n,t,e)]))),(a=>!H(a[1])))))(),t=await(async()=>w?(await v(d,ta))[aa]:{})();return H(a)&&l(t)?void 0:[a,t]}))),((a,t)=>I((async()=>{if(await R(),l(t)){const[t,e]=a();await L(t),await S(e)}else await L(t[0],!0),await S(t[1],!0)}))),e,n,s,o,{[A]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},qa=/^([cd]:)(.+)/,za=(a,n,s,r,c,l,d,E,N,A,T="getDb")=>{const R=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[m,,v,C]=(a=>{const e=(a=>U(Ma,y(a)?{[Ia]:a}:a??{}))(a),n=e[_a];if(e.mode==Ca){const a=e[Ia]??t;return[1,n,[a,e[La]??ta,e[Sa]??va],Oa(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=u(W(U(Ua,r)),0,B(Ua)),l=c[2],w=Oa(l),d=Oa(l),E=Ga(s,{[fa]:null,[ba]:ta,[Fa]:i},fa,(a=>I(d,a)),(a=>Ra(w,a))),N=Ga(o,{[Da]:null,[ba]:ta,[Pa]:0,[ha]:0,[Fa]:null},Da,((a,t)=>I(d,t)),((a,t)=>Ra(w,t)));var g;return g=(a,t)=>t[4]??=J(E,t[0])?.[2]??i,_(N,((a,t)=>g(0,a))),[0,n,[E,N,c],w]})(n),L=e+(a=>{let t=2166136261;return $(q.encode(a),(a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)})),t>>>0})(k(v)),b=t+"_"+L,f=async(a,e,n="",s="")=>{const i=Ta(t,a,L);return await R(da+Ea+Na+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},D=async(a,t,e,n)=>(await R(da+a+"TRIGGER"+t+e+"EXECUTE "+Na+n+"()"),t),P=a=>`PERFORM pg_notify('${b}',${a});`,h=(a,t)=>m?i:2===t?h(a,0)+" OR "+h(a,1):o(J(v[0],a)?.[2]??i,ga,0==t?"NEW":"OLD"),F=(a,e)=>g(O([ia,oa,ra],((n,s)=>D(Ea,Ta(t,"d",L,a,n),`AFTER ${n} ON${Aa(a)}FOR EACH ROW WHEN(${h(a,s)})`,e))));return(m?Ya:ka)(a,R,(async a=>{const e=await f("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${na} command_tag='${ua}' LOOP ${P("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await D("EVENT ",Ta(t,"c",L),`ON ddl_command_end WHEN TAG IN('${ua}')`,e);const n=await f("d",P("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await g(O(S(C),(async a=>(await R(ua+` IF NOT EXISTS${Aa(a)}("_id"text PRIMARY KEY)`),await F(a,n))))),[await r(b,(t=>{return w((e=t,s=qa,e?.match(s)),(async([,t,e])=>{I(C,e)&&("c:"==t&&await F(e,n),a())}));var e,s})),[e,n]]}),(async([a,t])=>{c(a),await R(`DROP FUNCTION IF EXISTS${p(t,",")}CASCADE`)}),d,E,N,v,S(C),(async(a,t)=>await a(ea+` table_name tn,column_name cn FROM information_schema.columns ${na} table_schema='public'AND table_name IN(${$a(t)})`,t)),A,T,"text",void 0,(a=>X(a)),(a=>Y(a)))},Ja=async(a,t,e,n,s)=>za(a,e,(async(a,e=[])=>(await t.query(a,e)).rows),((a,e)=>t.listen(a,e)),(a=>T(a,s)),n,s,N,3,t,"getPglite");export{Ja as createPglitePersister};