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