@prisma/studio-core 0.0.0-dev.202506240022 → 0.0.0-dev.202506240030
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunk-GSTLSVFG.js +10 -0
- package/dist/chunk-P5LRZ6C2.js +10 -0
- package/dist/chunk-ZB3J55HW.js +10 -0
- package/dist/data/accelerate/index.cjs +2 -0
- package/dist/data/accelerate/index.d.cts +55 -0
- package/dist/data/accelerate/index.d.ts +55 -0
- package/dist/data/accelerate/index.js +10 -0
- package/dist/data/bff/index.cjs +2 -0
- package/dist/data/bff/index.d.cts +62 -0
- package/dist/data/bff/index.d.ts +62 -0
- package/dist/data/bff/index.js +10 -0
- package/dist/data/index.cjs +2 -0
- package/dist/data/index.d.cts +12 -0
- package/dist/data/index.d.ts +12 -0
- package/dist/data/index.js +10 -0
- package/dist/data/pglite/index.cjs +2 -0
- package/dist/data/pglite/index.d.cts +26 -0
- package/dist/data/pglite/index.d.ts +26 -0
- package/dist/data/pglite/index.js +10 -0
- package/dist/data/postgres-core/index.cjs +2 -0
- package/dist/data/postgres-core/index.d.cts +251 -0
- package/dist/data/postgres-core/index.d.ts +251 -0
- package/dist/data/postgres-core/index.js +10 -0
- package/dist/metafile-cjs.json +1 -0
- package/dist/metafile-esm.json +1 -0
- package/dist/prisma-MHPRMNLH.svg +8 -0
- package/dist/query-C7LxjwdN.d.cts +274 -0
- package/dist/query-C7LxjwdN.d.ts +274 -0
- package/dist/ui/index.cjs +419 -0
- package/dist/ui/index.css +3087 -0
- package/dist/ui/index.d.cts +101 -0
- package/dist/ui/index.d.ts +101 -0
- package/dist/ui/index.js +427 -0
- package/package.json +1 -1
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as ___react___ from 'react';
|
|
2
|
+
import * as ___react_dom___ from 'react-dom';
|
|
3
|
+
|
|
4
|
+
function require(mod) {
|
|
5
|
+
if (mod === 'react') return ___react___;
|
|
6
|
+
if (mod === 'react-dom') return ___react_dom___;
|
|
7
|
+
throw new Error(`Unknown module ${mod}`);
|
|
8
|
+
}
|
|
9
|
+
var g=Object.create;var e=Object.defineProperty;var h=Object.getOwnPropertyDescriptor;var i=Object.getOwnPropertyNames;var j=Object.getPrototypeOf,k=Object.prototype.hasOwnProperty;var p=(a=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(a,{get:(b,c)=>(typeof require<"u"?require:b)[c]}):a)(function(a){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+a+'" is not supported')});var l=(a,b)=>()=>(a&&(b=a(a=0)),b);var q=(a,b)=>()=>(b||a((b={exports:{}}).exports,b),b.exports),r=(a,b)=>{for(var c in b)e(a,c,{get:b[c],enumerable:!0})},m=(a,b,c,f)=>{if(b&&typeof b=="object"||typeof b=="function")for(let d of i(b))!k.call(a,d)&&d!==c&&e(a,d,{get:()=>b[d],enumerable:!(f=h(b,d))||f.enumerable});return a};var s=(a,b,c)=>(c=a!=null?g(j(a)):{},m(b||!a||!a.__esModule?e(c,"default",{value:a,enumerable:!0}):c,a));var v,o=l(()=>{v={postgres:{encoded:"ZGF0YXNvdXJjZSBkYiB7CiAgICBwcm92aWRlciA9ICJwb3N0Z3JlcyIKICAgIHVybCAgICAgID0gZW52KCJEQVRBQkFTRV9VUkwiKQp9CiAgICAKZ2VuZXJhdG9yIGNsaWVudCB7CiAgICBwcm92aWRlciA9ICJwcmlzbWEtY2xpZW50LWpzIgp9",hash:"54195896aeafa3318ca33f5a8bb44c6b4d89c368cb15288f3bd5ace35a3f9227"}}});export{p as a,q as b,r as c,s as d,o as e,v as f};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiPGRlZmluZTpBQ0NFTEVSQVRFX1NDSEVNQV9CWV9QUk9WSURFUj4iXSwKICAic291cmNlc0NvbnRlbnQiOiBbIiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7OzIxQkFBQSxJQUFBQSxFQUFBQyxFQUFBQyxFQUFBLEtBQUFGLEVBQUEsQ0FBQyxTQUFXLENBQUMsUUFBVSwyTEFBMkwsS0FBTyxrRUFBa0UsQ0FBQyIsCiAgIm5hbWVzIjogWyJkZWZpbmVfQUNDRUxFUkFURV9TQ0hFTUFfQllfUFJPVklERVJfZGVmYXVsdCIsICJpbml0X2RlZmluZV9BQ0NFTEVSQVRFX1NDSEVNQV9CWV9QUk9WSURFUiIsICJfX2VzbU1pbiJdCn0K
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as ___react___ from 'react';
|
|
2
|
+
import * as ___react_dom___ from 'react-dom';
|
|
3
|
+
|
|
4
|
+
function require(mod) {
|
|
5
|
+
if (mod === 'react') return ___react___;
|
|
6
|
+
if (mod === 'react-dom') return ___react_dom___;
|
|
7
|
+
throw new Error(`Unknown module ${mod}`);
|
|
8
|
+
}
|
|
9
|
+
import{a as d,b as E,c as D,d as S,e as g,f as T,h as R}from"./chunk-GSTLSVFG.js";import{e as p}from"./chunk-P5LRZ6C2.js";p();p();p();function m(n){let{error:s,query:a}=n,e=s;return e.query=a,[e]}p();var B={bool:{group:"boolean"},boolean:{group:"boolean"},bytea:{group:"string"},char:{group:"string"},citext:{group:"string"},date:{group:"datetime"},interval:{group:"string"},name:{group:"string"},varchar:{group:"string"},text:{group:"string"},time:{group:"time"},timestamp:{group:"datetime"},timestamptz:{group:"datetime"},"timestamp without time zone":{group:"datetime"},"timestamp with time zone":{group:"datetime"},timetz:{group:"time"},"time without time zone":{group:"time"},"time with time zone":{group:"datetime"},uuid:{group:"string"},int2:{group:"numeric"},int4:{group:"numeric"},int8:{group:"numeric"},smallint:{group:"numeric"},integer:{group:"numeric"},bigint:{group:"numeric"},decimal:{group:"numeric"},numeric:{group:"numeric"},real:{group:"numeric"},float4:{group:"numeric"},float8:{group:"numeric"},"double precision":{group:"numeric"},json:{group:"json"},jsonb:{group:"json"}};p();p();function y(n){return S({...n,Adapter:D,QueryCompiler:E})}function I(n,s){let{table:a,rows:e}=n,{name:r,schema:t,columns:o}=a,i=y(s),u=Object.keys(o);return g(i.withSchema(t).insertInto(r).values(R("insert",e,o)).returning(u).returning(l=>l.cast("ctid","text").as("ctid")))}function q(n,s){let{pageIndex:a,pageSize:e,sortOrder:r,table:{name:t,schema:o,columns:i},filter:u={kind:"FilterGroup",after:"and",filters:[]}}=n,l=y(s),_=Object.keys(i),h=l.withSchema(o).selectFrom(t).select(c=>c.cast(c.fn.coalesce(c.fn.countAll(),d.lit(0)),"text").as("oid"));return g(l.with("count",()=>h).withSchema(o).selectFrom([t,"count"]).select(d.ref("count.oid").$castTo().as("oid")).select(c=>c.cast("ctid","text").as("ctid")).select(_).$call(c=>r.reduce((b,k)=>b.orderBy(k.column,k.direction),c)).where(O(u.filters,i)).limit(e).offset(d.lit(BigInt(a)*BigInt(e))))}function K(n,s){return n.kind==="ColumnFilter"?a=>{let{column:e,operator:r,value:t}=n,o=d.ref(e),i=s[e]?.datatype.group,u=i==="enum"||i==="string"?a.cast(o,"text"):o;return a(u,r,t)}:O(n.filters,s)}function O(n,s){if(n.length===0)return r=>r.lit(!0);let a=[],e=[];for(let r=0;r<n.length;r++)e.push(K(n[r],s)),(r===n.length-1||n[r].after==="or")&&(a.push(e),e=[]);return r=>{let t=a.map(o=>r.and(o.map(i=>i(r))));return r.or(t)}}function se(){return[{created_at:new Date("2025-01-26T21:56:12.345Z"),ctid:"(0,1)",deleted_at:null,id:1,name:"John Doe",oid:"2",role:"admin",name_role:"Jonn Doe - admin"},{created_at:new Date("2025-01-26T20:56:12.345Z"),ctid:"(0,2)",deleted_at:null,id:2,name:"Jane Doe",oid:"2",role:"poweruser",name_role:"Jane Doe - poweruser"}]}function C(n,s){let{changes:a,row:e,table:{columns:r,name:t,schema:o}}=n,i=y(s),u=Object.keys(r);return g(i.withSchema(o).updateTable(t).set(R("update",a,r)).$call(T([e],r)).returning(u).returning(l=>[l.cast("ctid","text").as("ctid"),l.cast(l.fn("floor",[l(l.fn("extract",[d`epoch from now()`]),"*",1e6)]),"text").as("__ps_updated_at__")]))}function N(n,s){let{rows:a,table:{columns:e,name:r,schema:t}}=n,o=y(s);return g(o.withSchema(t).deleteFrom(r).$call(T(a,e)))}p();p();function F(n){return d`(select coalesce(json_agg(agg), '[]') from ${n} as agg)`}var J="r",v="v",L=[J,v];function z(n){return g(y(n).selectFrom("pg_catalog.pg_class as cls").innerJoin("pg_catalog.pg_namespace as ns","cls.relnamespace","ns.oid").$call(M).where("cls.relkind","in",L).select(s=>["ns.nspname as schema","cls.relname as name",F(s.selectFrom("pg_catalog.pg_attribute as att").innerJoin("pg_catalog.pg_type as typ","typ.oid","att.atttypid").innerJoin("pg_catalog.pg_namespace as tns","tns.oid","typ.typnamespace").leftJoin("pg_catalog.pg_constraint as pk_con",a=>a.on("pk_con.contype","=","p").onRef("pk_con.conrelid","=","cls.oid").on(e=>e("att.attnum","=",e.fn.any("pk_con.conkey")))).leftJoin("pg_catalog.pg_constraint as fk_con",a=>a.on("fk_con.contype","=","f").onRef("fk_con.conrelid","=","cls.oid").on(e=>e("att.attnum","=",e.fn.any("fk_con.conkey")))).leftJoin("pg_catalog.pg_class as fk_cls","fk_cls.oid","fk_con.confrelid").leftJoin("pg_catalog.pg_namespace as fk_ns","fk_ns.oid","fk_cls.relnamespace").leftJoin("pg_catalog.pg_attribute as fk_att",a=>a.onRef("fk_att.attrelid","=","fk_cls.oid").on(e=>e("fk_att.attnum","=",e.fn.any("fk_con.confkey")))).whereRef("att.attrelid","=","cls.oid").where("att.attnum",">=",0).where("att.attisdropped","!=",!0).select(["att.attname as name","typ.typname as datatype","tns.nspname as datatype_schema","fk_ns.nspname as foreign_key_schema","fk_cls.relname as foreign_key_table","fk_att.attname as foreign_key_column"]).select(a=>[a("pk_con.conkey","is not",null).$castTo().as("pk"),a("att.attgenerated","!=","").$castTo().as("computed"),a("att.attnotnull","!=",!0).$castTo().as("nullable"),a.fn.coalesce(a.selectFrom("pg_catalog.pg_enum as enm").whereRef("enm.enumtypid","=","typ.oid").select(e=>e.fn.jsonAgg(e.ref("enm.enumlabel")).as("o")),d`'[]'`).as("options")])).as("columns")]))}function P(){return[{schema:"zoo",name:"animals",columns:[{name:"id",datatype:"int4",datatype_schema:"pg_catalog",pk:!0,computed:!1,options:[],nullable:!1,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null},{name:"name",datatype:"text",datatype_schema:"pg_catalog",pk:!1,computed:!1,options:[],nullable:!0,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null}]},{schema:"public",name:"users",columns:[{name:"id",datatype:"int4",datatype_schema:"pg_catalog",pk:!0,computed:!1,options:[],nullable:!1,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null},{name:"created_at",datatype:"timestamp",datatype_schema:"pg_catalog",pk:!1,computed:!1,options:[],nullable:!0,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null},{name:"deleted_at",datatype:"timestamp",datatype_schema:"pg_catalog",pk:!1,computed:!1,options:[],nullable:!0,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null},{name:"role",datatype:"varchar",datatype_schema:"pg_catalog",pk:!1,computed:!1,options:[],nullable:!0,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null},{name:"name",datatype:"varchar",datatype_schema:"pg_catalog",pk:!1,computed:!1,options:[],nullable:!0,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null},{name:"name_role",datatype:"text",datatype_schema:"pg_catalog",pk:!1,computed:!0,options:[],nullable:!1,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null}]},{schema:"public",name:"composite_pk",columns:[{name:"id",datatype:"uuid",datatype_schema:"pg_catalog",pk:!0,computed:!1,options:[],nullable:!1,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null},{name:"name",datatype:"text",datatype_schema:"pg_catalog",pk:!0,computed:!1,options:[],nullable:!0,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null},{name:"created_at",datatype:"timestamp",datatype_schema:"pg_catalog",pk:!1,computed:!1,options:[],nullable:!0,foreign_key_schema:null,foreign_key_table:null,foreign_key_column:null}]}]}function j(){let n=y();return g(n.selectNoFrom(n.fn("current_setting",[d.lit("timezone")]).as("timezone")))}function G(){return[{timezone:"UTC"}]}function M(n){return n.where("ns.nspname","!~","^pg_").where("ns.nspname","!=","information_schema")}function xe(n){let{executor:s,...a}=n;return{defaultSchema:"public",async introspect(e){try{let r=z(a),t=j(),[[o,i],[u,l]]=await Promise.all([s.execute(r,e),s.execute(t,e)]);if(o)return m({error:o,query:r});if(u)return m({error:u,query:t});let _=l[0]?.timezone;return _?[null,U({tables:i,timezone:_,query:r})]:m({error:new Error("Timezone not found"),query:t})}catch(r){return m({error:r})}},async query(e,r){try{let t=q(e,a),[o,i]=await s.execute(t,r);return o?m({error:o,query:t}):[null,{filteredRowCount:i[0]?.oid||"0",rows:i,query:t}]}catch(t){return m({error:t})}},async insert(e,r){try{let t=I(e,a),[o,i]=await s.execute(t,r);return o?m({error:o,query:t}):[null,{rows:i,query:t}]}catch(t){return m({error:t})}},async update(e,r){try{let t=C(e,a),[o,i]=await s.execute(t,r);if(o)return m({error:o,query:t});let[u]=i;return u?[null,{row:u,query:t}]:m({error:new Error("Update failed"),query:t})}catch(t){return m({error:t})}},async delete(e,r){try{let t=N(e,a),[o]=await s.execute(t,r);return o?m({error:o,query:t}):[null,{...e,query:t}]}catch(t){return m({error:t})}}}}function U(n){let{tables:s,timezone:a,query:e}=n;return s.reduce((r,t)=>{let{schemas:o}=r,{columns:i,name:u,schema:l}=t,_=i.reduce((h,c)=>{let{datatype:b,datatype_schema:k,name:w,options:Q,nullable:$}=c,A=b.startsWith("_"),x=A?b.slice(1):b;return{...h,[w]:{datatype:{...B[x]||{group:Q.length>0?"enum":"raw"},isArray:A,isNative:k==="pg_catalog",name:A?`${x}[]`:x,options:Q,schema:k},isComputed:c.computed,isInPrimaryKey:c.pk,name:w,nullable:$,schema:l,table:u,fkSchema:c.foreign_key_schema,fkTable:c.foreign_key_table,fkColumn:c.foreign_key_column}}},{});return o[l]===void 0&&(o[l]={name:l,tables:{}}),o[l].tables[u]={columns:_,name:u,schema:l},r},{schemas:{public:{tables:{},name:"public"}},timezone:a,filterOperators:W,query:e})}var W=["=","!=",">",">=","<","<=","is","is not","like","not like","ilike","not ilike"];function Te(){let n=P(),[{timezone:s}]=G();return U({tables:n,timezone:s,query:{parameters:[],sql:"<mocked>"}})}export{I as a,q as b,se as c,C as d,N as e,z as f,P as g,j as h,G as i,xe as j,Te as k};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../data/postgres-core/index.ts", "../data/postgres-core/adapter.ts", "../data/adapter.ts", "../data/postgres-core/datatype.ts", "../data/postgres-core/dml.ts", "../data/postgres-core/builder.ts", "../data/postgres-core/introspection.ts", "../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/helpers/postgres.js"],
  "sourcesContent": ["export * from \"./adapter\";\nexport * from \"./dml\";\nexport * from \"./introspection\";\n", "import {\n  type Adapter,\n  type AdapterDeleteResult,\n  type AdapterError,\n  type AdapterInsertResult,\n  type AdapterIntrospectResult,\n  type AdapterQueryResult,\n  type AdapterUpdateResult,\n  type Column,\n  createAdapterError,\n  type FilterOperator,\n  type Table,\n} from \"../adapter\";\nimport type { Executor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { POSTGRESQL_DATA_TYPES_TO_METADATA } from \"./datatype\";\nimport { getDeleteQuery, getInsertQuery, getSelectQuery, getUpdateQuery } from \"./dml\";\nimport { getTablesQuery, getTimezoneQuery, mockTablesQuery, mockTimezoneQuery } from \"./introspection\";\n\nexport interface PostgresAdapterRequirements {\n  executor: Executor;\n  noParameters?: boolean;\n}\n\nexport function createPostgresAdapter(requirements: PostgresAdapterRequirements): Adapter {\n  const { executor, ...otherRequirements } = requirements;\n\n  return {\n    defaultSchema: \"public\",\n    async introspect(options): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n      try {\n        const tablesQuery = getTablesQuery(otherRequirements);\n        const timezoneQuery = getTimezoneQuery();\n\n        const [[tablesError, tables], [timezoneError, timezones]] = await Promise.all([\n          executor.execute(tablesQuery, options),\n          executor.execute(timezoneQuery, options),\n        ]);\n\n        if (tablesError) {\n          return createAdapterError({ error: tablesError, query: tablesQuery });\n        }\n\n        if (timezoneError) {\n          return createAdapterError({ error: timezoneError, query: timezoneQuery });\n        }\n\n        const timezone = timezones[0]?.timezone;\n\n        if (!timezone) {\n          return createAdapterError({ error: new Error(\"Timezone not found\"), query: timezoneQuery });\n        }\n\n        return [null, createIntrospection({ tables, timezone, query: tablesQuery })];\n      } catch (error: unknown) {\n        // TODO: handle properly\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async query(details, options): Promise<Either<AdapterError, AdapterQueryResult>> {\n      try {\n        const query = getSelectQuery(details, otherRequirements);\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { filteredRowCount: results[0]?.oid || \"0\", rows: results, query }];\n      } catch (error: unknown) {\n        // TODO: handle properly\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async insert(details, options): Promise<Either<AdapterError, AdapterInsertResult>> {\n      try {\n        const query = getInsertQuery(details, otherRequirements);\n        const [error, rows] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { rows, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    async update(details, options): Promise<Either<AdapterError, AdapterUpdateResult>> {\n      try {\n        const query = getUpdateQuery(details, otherRequirements);\n        const [error, results] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        const [row] = results;\n\n        if (!row) {\n          // TODO: custom error?\n          return createAdapterError({ error: new Error(\"Update failed\"), query });\n        }\n\n        return [null, { row, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n    async delete(details, options): Promise<Either<AdapterError, AdapterDeleteResult>> {\n      try {\n        const query = getDeleteQuery(details, otherRequirements);\n        const [error] = await executor.execute(query, options);\n\n        if (error) {\n          return createAdapterError({ error, query });\n        }\n\n        return [null, { ...details, query }];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n  };\n}\n\nfunction createIntrospection(args: { tables: QueryResult<typeof getTablesQuery>; timezone: string; query: Query }) {\n  const { tables, timezone, query } = args;\n\n  return tables.reduce(\n    (result, row) => {\n      const { schemas } = result;\n      const { columns, name: tableName, schema } = row;\n\n      const columnsRecord = columns.reduce(\n        (columns, column) => {\n          const { datatype, datatype_schema, name: columnName, options, nullable } = column;\n\n          const isArray = datatype.startsWith(\"_\");\n          const strippedDataType = isArray ? datatype.slice(1) : datatype;\n\n          return {\n            ...columns,\n            [columnName]: {\n              datatype: {\n                ...(POSTGRESQL_DATA_TYPES_TO_METADATA[strippedDataType] || {\n                  group: options.length > 0 ? \"enum\" : \"raw\",\n                }),\n                isArray,\n                isNative: datatype_schema === \"pg_catalog\",\n                name: isArray ? `${strippedDataType}[]` : strippedDataType,\n                options,\n                schema: datatype_schema,\n              },\n              isComputed: column.computed,\n              isInPrimaryKey: column.pk,\n              name: columnName,\n              nullable,\n              schema,\n              table: tableName,\n              fkSchema: column.foreign_key_schema,\n              fkTable: column.foreign_key_table,\n              fkColumn: column.foreign_key_column,\n            } as const satisfies Column,\n          };\n        },\n        {} as Table[\"columns\"],\n      );\n\n      if (schemas[schema] === undefined) {\n        schemas[schema] = {\n          name: schema,\n          tables: {},\n        };\n      }\n\n      schemas[schema].tables[tableName] = {\n        columns: columnsRecord,\n        name: tableName,\n        schema,\n      };\n\n      return result;\n    },\n    {\n      schemas: { public: { tables: {}, name: \"public\" } },\n      timezone,\n      filterOperators,\n      query,\n    } satisfies AdapterIntrospectResult as AdapterIntrospectResult,\n  );\n}\n\nconst filterOperators = [\n  \"=\",\n  \"!=\",\n  \">\",\n  \">=\",\n  \"<\",\n  \"<=\",\n  \"is\",\n  \"is not\",\n  \"like\",\n  \"not like\",\n  \"ilike\",\n  \"not ilike\",\n] satisfies FilterOperator[];\n\n/**\n * For testing purposes.\n */\nexport function mockIntrospect() {\n  const tables = mockTablesQuery();\n  const [{ timezone }] = mockTimezoneQuery();\n  const query = { parameters: [], sql: \"<mocked>\" } as Query;\n\n  return createIntrospection({ tables, timezone, query }) as {\n    // best effort, no need go overboard.\n    schemas: {\n      [K in (typeof tables)[number][\"schema\"]]: {\n        name: K;\n        tables: {\n          [T in (typeof tables)[number][\"name\"]]: Table;\n        };\n      };\n    };\n    timezone: typeof timezone;\n    filterOperators: FilterOperator[];\n    query: Query;\n  } satisfies AdapterIntrospectResult;\n}\n", "import { Query } from \"./query\";\nimport type { BigIntString, Either, NumericString } from \"./type-utils\";\n\nexport interface Adapter {\n  /**\n   * The schema studio will choose by default.\n   *\n   * e.g. `public` for PostgreSQL\n   */\n  readonly defaultSchema?: string;\n\n  /**\n   * Introspects the database and returns structured information about the schemas, tables, etc.\n   *\n   * @param options - Options for the introspection request.\n   */\n  introspect(options: AdapterIntrospectOptions): Promise<Either<AdapterError, AdapterIntrospectResult>>;\n\n  /**\n   * Executes a structured query against the database.\n   */\n  query(details: AdapterQueryDetails, options: AdapterQueryOptions): Promise<Either<AdapterError, AdapterQueryResult>>;\n\n  /**\n   * Inserts a single row into the database.\n   */\n  insert(\n    details: AdapterInsertDetails,\n    options: AdapterInsertOptions,\n  ): Promise<Either<AdapterError, AdapterInsertResult>>;\n\n  /**\n   * Updates a given row in the database with given changes.\n   */\n  update(\n    details: AdapterUpdateDetails,\n    options: AdapterUpdateOptions,\n  ): Promise<Either<AdapterError, AdapterUpdateResult>>;\n\n  /**\n   * Deletes given rows from the database.\n   */\n  delete(\n    details: AdapterDeleteDetails,\n    options: AdapterDeleteOptions,\n  ): Promise<Either<AdapterError, AdapterDeleteResult>>;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterIntrospectOptions extends AdapterBaseOptions {}\n\nexport interface AdapterQueryOptions extends AdapterBaseOptions {\n  abortSignal: AbortSignal;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterInsertOptions extends AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterUpdateOptions extends AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterDeleteOptions extends AdapterBaseOptions {}\n\ntype SchemaName = string;\n\nexport interface AdapterIntrospectResult {\n  schemas: Record<SchemaName, Schema>;\n  timezone: string;\n  filterOperators: FilterOperator[];\n  query: Query;\n}\n\ntype TableName = string;\n\nexport interface Schema {\n  name: string;\n  tables: Record<TableName, Table>;\n}\n\ntype ColumnName = string;\n\nexport interface Table {\n  columns: Record<ColumnName, Column>;\n  name: TableName;\n  schema: SchemaName;\n}\n\nexport interface Column {\n  datatype: DataType;\n  isComputed: boolean;\n  isInPrimaryKey: boolean;\n  name: ColumnName;\n  nullable: boolean;\n  schema: SchemaName;\n  table: TableName;\n  fkSchema: SchemaName | null;\n  fkColumn: ColumnName | null;\n  fkTable: TableName | null;\n}\n\nexport interface DataType {\n  /**\n   * A simplification/normalization for UI usage.\n   *\n   * e.g. varchar and char are strings.\n   */\n  group: DataTypeGroup;\n\n  /**\n   * Is this a native array type?\n   */\n  isArray: boolean;\n\n  /**\n   * Is a native database datatype or a user-defined datatype?\n   *\n   * e.g. PostgreSQL enums are user-defined datatypes, but `int4` is a native datatype.\n   */\n  isNative: boolean;\n\n  /**\n   * Will be displayed as-is.\n   */\n  name: string;\n\n  /**\n   * Enum values for enum types.\n   */\n  options: string[];\n\n  /**\n   * The schema the datatype belongs to.\n   */\n  schema: string;\n}\n\nexport type DataTypeGroup = \"string\" | \"datetime\" | \"boolean\" | \"enum\" | \"time\" | \"raw\" | \"numeric\" | \"json\";\n\nexport interface AdapterQueryDetails {\n  /**\n   * Zero-based index of the page to fetch.\n   */\n  pageIndex: number;\n\n  /**\n   * Maximum number of rows to fetch from the database.\n   */\n  pageSize: number;\n\n  /**\n   * Sort order for the query.\n   */\n  sortOrder: SortOrderItem[];\n\n  /**\n   * The table to select from.\n   */\n  table: Table;\n\n  /**\n   * The filter to be applied.\n   */\n  filter?: FilterGroup;\n}\n\nexport type FilterOperator =\n  | \"=\"\n  | \"!=\"\n  | \">\"\n  | \">=\"\n  | \"<\"\n  | \"<=\"\n  | \"is\"\n  | \"is not\"\n  | \"like\"\n  | \"not like\"\n  | \"ilike\"\n  | \"not ilike\";\n\nexport interface ColumnFilter {\n  kind: \"ColumnFilter\";\n  column: string;\n  operator: FilterOperator;\n  value: unknown;\n  after: \"and\" | \"or\";\n  id: string;\n}\n\nexport interface FilterGroup {\n  kind: \"FilterGroup\";\n  filters: (ColumnFilter | FilterGroup)[];\n  after: \"and\" | \"or\";\n  id: string;\n}\n\nexport interface SortOrderItem {\n  /**\n   * The column to sort by.\n   */\n  column: ColumnName;\n\n  /**\n   * The direction to sort the column by.\n   */\n  direction: SortDirection;\n}\n\nexport type SortDirection = \"asc\" | \"desc\";\n\nexport class AdapterError extends Error {\n  query?: Query;\n}\n\nexport interface AdapterQueryResult {\n  /**\n   * The total number of rows the query would return if not limited.\n   *\n   * If the database does not support counting rows, this should be set to `Infinity`.\n   */\n  filteredRowCount: number | bigint | NumericString | BigIntString;\n\n  /**\n   * The rows returned by the query.\n   */\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterInsertDetails {\n  /**\n   * The table to insert into.\n   */\n  table: Table;\n\n  /**\n   * The values to insert into the table.\n   * - The keys should match the column names in the table.\n   * - The values should be the values to insert into the table.\n   */\n  rows: Record<string, unknown>[];\n}\n\nexport interface AdapterInsertResult {\n  /**\n   * The freshly inserted row data.\n   */\n  rows: Record<string, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterUpdateDetails {\n  /**\n   * Changes to apply to the row.\n   */\n  changes: Record<ColumnName, unknown>;\n\n  /**\n   * The row to update.\n   */\n  row: Record<ColumnName, unknown>;\n\n  /**\n   * The table to update in.\n   */\n  table: Table;\n}\n\nexport interface AdapterUpdateResult {\n  /**\n   * The updated row data.\n   */\n  row: Record<ColumnName, unknown> & {\n    /**\n     * When the changes were applied in database time.\n     */\n    __ps_updated_at__: string | number | Date;\n  };\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterDeleteDetails {\n  /**\n   * The rows to delete.\n   */\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The table to delete from.\n   */\n  table: Table;\n}\n\nexport interface AdapterDeleteResult {\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport function createAdapterError(args: { error: Error; query?: Query }) {\n  const { error, query } = args;\n\n  const adapterError = error as AdapterError;\n\n  adapterError.query = query;\n\n  return [adapterError] as [AdapterError];\n}\n", "import { DataType } from \"../adapter\";\n\nexport const POSTGRESQL_DATA_TYPES_TO_METADATA: Record<string, Pick<DataType, \"group\">> = {\n  bool: {\n    group: \"boolean\",\n  },\n  boolean: {\n    group: \"boolean\",\n  },\n  bytea: {\n    group: \"string\",\n  },\n  char: {\n    group: \"string\",\n  },\n  citext: {\n    group: \"string\",\n  },\n  /**\n   * @example '2025-04-14'\n   */\n  date: {\n    group: \"datetime\",\n  },\n  /**\n   * @example '1 day 2 hours'\n   */\n  interval: {\n    group: \"string\",\n  },\n  name: {\n    group: \"string\",\n  },\n  varchar: {\n    group: \"string\",\n  },\n  text: {\n    group: \"string\",\n  },\n  /**\n   * short form of `time without time zone`.\n   *\n   * @example '14:30:00'\n   */\n  time: {\n    group: \"time\",\n  },\n  /**\n   * short form of `timestamp without time zone`.\n   *\n   * @example '2025-04-14 14:30:00'\n   */\n  timestamp: {\n    group: \"datetime\",\n  },\n  /**\n   * short form of `timestamp with time zone`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  timestamptz: {\n    group: \"datetime\",\n  },\n  /**\n   * long form of `timestamp`.\n   *\n   * @example '2025-04-14 14:30:00'\n   */\n  \"timestamp without time zone\": {\n    group: \"datetime\",\n  },\n  /**\n   * long form of `timestamptz`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  \"timestamp with time zone\": {\n    group: \"datetime\",\n  },\n  /**\n   * short form of `time with time zone`.\n   *\n   * @example '14:30:00+00:00'\n   */\n  timetz: {\n    group: \"time\",\n  },\n  /**\n   * long form of `time`.\n   *\n   * @example '14:30:00'\n   */\n  \"time without time zone\": {\n    group: \"time\",\n  },\n  /**\n   * long form of `timetz`.\n   *\n   * @example '2025-04-14 14:30:00+00'\n   */\n  \"time with time zone\": {\n    group: \"datetime\",\n  },\n  uuid: {\n    group: \"string\",\n  },\n  // Numeric types\n  int2: {\n    group: \"numeric\",\n  },\n  int4: {\n    group: \"numeric\",\n  },\n  int8: {\n    group: \"numeric\",\n  },\n  smallint: {\n    group: \"numeric\",\n  },\n  integer: {\n    group: \"numeric\",\n  },\n  bigint: {\n    group: \"numeric\",\n  },\n  decimal: {\n    group: \"numeric\",\n  },\n  numeric: {\n    group: \"numeric\",\n  },\n  real: {\n    group: \"numeric\",\n  },\n  float4: {\n    group: \"numeric\",\n  },\n  float8: {\n    group: \"numeric\",\n  },\n  \"double precision\": {\n    group: \"numeric\",\n  },\n  json: {\n    group: \"json\",\n  },\n  jsonb: {\n    group: \"json\",\n  },\n};\n", "import { type Expression, type ExpressionBuilder, sql, type SqlBool } from \"kysely\";\n\nimport type {\n  AdapterDeleteDetails,\n  AdapterInsertDetails,\n  AdapterQueryDetails,\n  AdapterUpdateDetails,\n  ColumnFilter,\n  FilterGroup,\n  Table,\n} from \"../adapter\";\nimport { applyInferredRowFilters, applyTransformations, type BuilderRequirements, compile } from \"../query\";\nimport type { BigIntString } from \"../type-utils\";\nimport { getPostgreSQLBuilder } from \"./builder\";\nimport type { mockTablesQuery } from \"./introspection\";\n\n/**\n * `ctid` is a system column that represents the physical location of a row in a table.\n * It is a tuple of two integers: `(blockNumber, tupleIndex)`.\n * It is used to uniquely identify a row in a table, even if the row has no primary key, or other unique constraints.\n *\n * Example: '(0,23)' represents the 24th row in the first block of the table.\n */\nexport type CTIDasText = `(${number},${number})`;\n\n/**\n * Inserts one or more rows into a table and returns the inserted rows along with their `ctid`.\n */\nexport function getInsertQuery(\n  details: AdapterInsertDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const { table, rows } = details;\n  const { name: tableName, schema, columns } = table;\n\n  const builder = getPostgreSQLBuilder<Record<string, { ctid: unknown } & Record<string, unknown>>>(requirements);\n  const cols = Object.keys(columns);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .insertInto(tableName)\n      .values(applyTransformations(\"insert\", rows, columns))\n      .returning(cols)\n      .returning((eb) => eb.cast<CTIDasText>(\"ctid\", \"text\").as(\"ctid\")),\n  );\n}\n\n/**\n * Returns a query that selects all columns from a table, along with the `ctid` column, and unbound row count as `oid` (reserved column name that cannot conflict with user columns).\n */\nexport function getSelectQuery(\n  details: AdapterQueryDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    pageIndex,\n    pageSize,\n    sortOrder,\n    table: { name: tableName, schema, columns },\n    filter = { kind: \"FilterGroup\", after: \"and\", filters: [] },\n  } = details;\n\n  const builder = getPostgreSQLBuilder<Record<string, { ctid: unknown } & Record<string, unknown>>>(requirements);\n  const cols = Object.keys(columns);\n\n  const countQuery = builder\n    .withSchema(schema)\n    .selectFrom(tableName)\n    .select((eb) => eb.cast<BigIntString>(eb.fn.coalesce(eb.fn.countAll(), sql.lit(0)), \"text\").as(\"oid\"));\n\n  return compile(\n    builder\n      .with(\"count\", () => countQuery)\n      .withSchema(schema)\n      .selectFrom([tableName, \"count\"])\n      // `oid` is a reserved column name in PostgreSQL, so we use it as an alias for the row count to not conflict with user columns.\n      .select(sql.ref(\"count.oid\").$castTo<BigIntString>().as(\"oid\"))\n      .select((eb) => eb.cast<CTIDasText>(\"ctid\", \"text\").as(\"ctid\"))\n      .select(cols)\n      .$call((qb) => sortOrder.reduce((qb, item) => qb.orderBy(item.column, item.direction), qb))\n      // TODO: cursor pagination?\n      .where(getSelectFilterExpression(filter.filters, columns))\n      .limit(pageSize)\n      // we're injecting the offset value here to avoid serialization complexity (`bigint` is a no-go for `JSON.stringify`).\n      .offset(sql.lit(BigInt(pageIndex) * BigInt(pageSize))),\n  );\n}\n\n// Helper to build an expression builder for a single filter or a group\nfunction buildBaseExpressionBuilder(\n  spec: ColumnFilter | FilterGroup,\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (spec.kind === \"ColumnFilter\") {\n    return (eb) => {\n      const { column, operator, value } = spec;\n      const columnRef = sql.ref(column);\n      const group = columns[column]?.datatype.group;\n      const lhs = group === \"enum\" || group === \"string\" ? eb.cast(columnRef, \"text\") : columnRef;\n\n      return eb(lhs, operator, value);\n    };\n  } else {\n    return getSelectFilterExpression(spec.filters, columns);\n  }\n}\n\nfunction getSelectFilterExpression(\n  filters: (ColumnFilter | FilterGroup)[],\n  columns: Table[\"columns\"],\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): (eb: ExpressionBuilder<any, any>) => Expression<SqlBool> {\n  if (filters.length === 0) return (eb) => eb.lit(true); // no filters, always true\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const orGroupsOfAndBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[][] = [];\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  let currentAndGroupBuilders: ((eb: ExpressionBuilder<any, any>) => Expression<SqlBool>)[] = [];\n\n  for (let i = 0; i < filters.length; i++) {\n    currentAndGroupBuilders.push(buildBaseExpressionBuilder(filters[i]!, columns));\n\n    // &n AND group ends if it's the last filter, or the item is followed by an 'or'\n    if (i === filters.length - 1 || filters[i]!.after === \"or\") {\n      orGroupsOfAndBuilders.push(currentAndGroupBuilders);\n      currentAndGroupBuilders = []; // start a new group\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return (eb: ExpressionBuilder<any, any>) => {\n    const andExpressions = orGroupsOfAndBuilders.map((group) => {\n      return eb.and(group.map((builder) => builder(eb)));\n    });\n\n    return eb.or(andExpressions);\n  };\n}\n\n/**\n * For testing purposes.\n */\nexport function mockSelectQuery() {\n  return [\n    {\n      created_at: new Date(\"2025-01-26T21:56:12.345Z\"),\n      ctid: \"(0,1)\",\n      deleted_at: null,\n      id: 1,\n      name: \"John Doe\",\n      oid: \"2\",\n      role: \"admin\",\n      name_role: \"Jonn Doe - admin\",\n    },\n    {\n      created_at: new Date(\"2025-01-26T20:56:12.345Z\"),\n      ctid: \"(0,2)\",\n      deleted_at: null,\n      id: 2,\n      name: \"Jane Doe\",\n      oid: \"2\",\n      role: \"poweruser\",\n      name_role: \"Jane Doe - poweruser\",\n    },\n  ] as const satisfies {\n    // best effort no need to go overboard\n    [K in ReturnType<typeof mockTablesQuery>[1][\"columns\"][number][\"name\"] | \"ctid\" | \"oid\"]: unknown;\n  }[];\n}\n\n/**\n * Returns a query that updates a given row in a table with given changes.\n */\nexport function getUpdateQuery(\n  details: AdapterUpdateDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    changes,\n    row,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder = getPostgreSQLBuilder<Record<string, { ctid: unknown } & Record<string, unknown>>>(requirements);\n  const cols = Object.keys(columns);\n\n  return compile(\n    builder\n      .withSchema(schema)\n      .updateTable(tableName)\n      .set(applyTransformations(\"update\", changes, columns))\n      .$call(applyInferredRowFilters([row], columns))\n      .returning(cols)\n      .returning((eb) => [\n        eb.cast<CTIDasText>(\"ctid\", \"text\").as(\"ctid\"),\n        eb\n          .cast<BigIntString>(eb.fn(\"floor\", [eb(eb.fn(\"extract\", [sql`epoch from now()`]), \"*\", 1_000_000)]), \"text\")\n          .as(\"__ps_updated_at__\"),\n      ]),\n  );\n}\n\n/**\n * Returns a query that deletes a given set of rows.\n */\nexport function getDeleteQuery(\n  details: AdapterDeleteDetails,\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n) {\n  const {\n    rows,\n    table: { columns, name: tableName, schema },\n  } = details;\n\n  const builder = getPostgreSQLBuilder<Record<string, { ctid: unknown } & Record<string, unknown>>>(requirements);\n\n  return compile(builder.withSchema(schema).deleteFrom(tableName).$call(applyInferredRowFilters(rows, columns)));\n}\n", "import { type Kysely, PostgresAdapter, PostgresQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getPostgreSQLBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder({ ...requirements, Adapter: PostgresAdapter, QueryCompiler: PostgresQueryCompiler });\n}\n", "import { type SelectQueryBuilder, sql } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/postgres\";\n\nimport { type BuilderRequirements, compile, type QueryResult } from \"../query\";\nimport { getPostgreSQLBuilder } from \"./builder\";\n\nconst REGULAR_TABLE_KIND = \"r\";\nconst VIEW_TABLE_KIND = \"v\";\nconst TABLE_KINDS = [REGULAR_TABLE_KIND, VIEW_TABLE_KIND] as const;\ntype TableKind = (typeof TABLE_KINDS)[number];\n\ninterface Database {\n  /** columns */\n  \"pg_catalog.pg_attribute\": {\n    /** column order number in its table */\n    attnum: number;\n    /** table/view identifier */\n    attrelid: string;\n    /** column name */\n    attname: string;\n    /** was the column dropped. dropped columns might not be 100% removed immediately. */\n    attisdropped: boolean;\n    /** column datatype identifier */\n    atttypid: string;\n    /**\n     * generation flag for computed columns:\n     * '' (empty) for regular columns,\n     * 's' for STORED generated columns (Postgres GENERATED ALWAYS AS).\n     */\n    attgenerated: \"\" | \"s\";\n    /** NOT NULL constraint: true if the column has a NOT NULL constraint */\n    attnotnull: boolean;\n  };\n  /** resources, e.g. tables, sequences, etc. */\n  \"pg_catalog.pg_class\": {\n    /** resource id */\n    oid: number;\n    /** resource name */\n    relname: string;\n    /** schema id */\n    relnamespace: number;\n    /** resource kind: regular table, view */\n    relkind: TableKind;\n  };\n  /** enum types' values */\n  \"pg_catalog.pg_enum\": {\n    /** enum value */\n    enumlabel: string;\n    /** enum's type id */\n    enumtypid: number;\n  };\n  /** schemas */\n  \"pg_catalog.pg_namespace\": {\n    /** schema name */\n    nspname: string;\n    /** schema id */\n    oid: number;\n  };\n  /** datatypes */\n  \"pg_catalog.pg_type\": {\n    /** type id */\n    oid: number;\n    /** type name */\n    typname: string;\n    /** type's schema (aka namespace) id */\n    typnamespace: number;\n    /**\n     * type's kind\n     *\n     * 'e' - enum type\n     */\n    typtype: \"e\" | (string & {});\n  };\n  /** constraints */\n  \"pg_catalog.pg_constraint\": {\n    /** relation (table) id which this constraint was created for */\n    conrelid: number;\n    /**\n     * constraint type.\n     *\n     * `'p'` - primary key constraint.\n     * `'f'` - foreign key constraint.\n     */\n    contype: \"p\" | \"f\" | (string & {});\n    /**\n     * an ordered array of columns included in the constraint.\n     *\n     * the columns are represented by their ordinal number (`attnum`) in their relation (table).\n     *\n     * @example `'{1,3}'` - a constraint with 2 columns, the 1st & 3rd in their table.\n     */\n    conkey: number[];\n    /** if a foreign key, the referenced table */\n    confrelid: number;\n    /** if a foreign key, the referenced columns */\n    confkey: number[];\n  };\n}\n\n/**\n * Returns a query that returns metadata for all user-defined tables and views in the database.\n */\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  return compile(\n    getPostgreSQLBuilder<Database>(requirements)\n      .selectFrom(\"pg_catalog.pg_class as cls\")\n      .innerJoin(\"pg_catalog.pg_namespace as ns\", \"cls.relnamespace\", \"ns.oid\")\n      .$call(excludeSystemTables)\n      // regular tables or views\n      .where(\"cls.relkind\", \"in\", TABLE_KINDS)\n      .select((eb) => [\n        \"ns.nspname as schema\",\n        \"cls.relname as name\",\n        jsonArrayFrom(\n          eb\n            .selectFrom(\"pg_catalog.pg_attribute as att\")\n            .innerJoin(\"pg_catalog.pg_type as typ\", \"typ.oid\", \"att.atttypid\")\n            .innerJoin(\"pg_catalog.pg_namespace as tns\", \"tns.oid\", \"typ.typnamespace\")\n            .leftJoin(\"pg_catalog.pg_constraint as pk_con\", (jb) =>\n              jb\n                .on(\"pk_con.contype\", \"=\", \"p\")\n                .onRef(\"pk_con.conrelid\", \"=\", \"cls.oid\")\n                .on((eb) => eb(\"att.attnum\", \"=\", eb.fn.any(\"pk_con.conkey\"))),\n            )\n            .leftJoin(\"pg_catalog.pg_constraint as fk_con\", (jb) =>\n              jb\n                .on(\"fk_con.contype\", \"=\", \"f\")\n                .onRef(\"fk_con.conrelid\", \"=\", \"cls.oid\")\n                .on((eb) => eb(\"att.attnum\", \"=\", eb.fn.any(\"fk_con.conkey\"))),\n            )\n            .leftJoin(\"pg_catalog.pg_class as fk_cls\", \"fk_cls.oid\", \"fk_con.confrelid\")\n            .leftJoin(\"pg_catalog.pg_namespace as fk_ns\", \"fk_ns.oid\", \"fk_cls.relnamespace\")\n            .leftJoin(\"pg_catalog.pg_attribute as fk_att\", (jb) =>\n              jb\n                .onRef(\"fk_att.attrelid\", \"=\", \"fk_cls.oid\")\n                // Use a callback for the .on() condition to ensure correct context for types\n                .on((on_eb) => on_eb(\"fk_att.attnum\", \"=\", on_eb.fn.any(\"fk_con.confkey\"))),\n            )\n            .whereRef(\"att.attrelid\", \"=\", \"cls.oid\")\n            // exclude system columns\n            .where(\"att.attnum\", \">=\", 0)\n            .where(\"att.attisdropped\", \"!=\", true)\n            .select([\n              \"att.attname as name\",\n              \"typ.typname as datatype\",\n              \"tns.nspname as datatype_schema\",\n              \"fk_ns.nspname as foreign_key_schema\",\n              \"fk_cls.relname as foreign_key_table\",\n              \"fk_att.attname as foreign_key_column\",\n            ])\n            .select((eb) => [\n              eb(\"pk_con.conkey\", \"is not\", null).$castTo<boolean>().as(\"pk\"),\n              eb(\"att.attgenerated\", \"!=\", \"\").$castTo<boolean>().as(\"computed\"),\n              eb(\"att.attnotnull\", \"!=\", true).$castTo<boolean>().as(\"nullable\"),\n              eb.fn\n                .coalesce(\n                  eb\n                    .selectFrom(\"pg_catalog.pg_enum as enm\")\n                    .whereRef(\"enm.enumtypid\", \"=\", \"typ.oid\")\n                    .select((eb) => eb.fn.jsonAgg(eb.ref(\"enm.enumlabel\")).as(\"o\")),\n                  sql<string[]>`'[]'`,\n                )\n                .as(\"options\"),\n            ]),\n        ).as(\"columns\"),\n      ]),\n  );\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTablesQuery() {\n  return [\n    {\n      schema: \"zoo\",\n      name: \"animals\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"int4\",\n          datatype_schema: \"pg_catalog\",\n          pk: true,\n          computed: false,\n          options: [],\n          nullable: false,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n      ],\n    },\n    {\n      schema: \"public\",\n      name: \"users\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"int4\",\n          datatype_schema: \"pg_catalog\",\n          pk: true,\n          computed: false,\n          options: [],\n          nullable: false,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"created_at\",\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"deleted_at\",\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"role\",\n          datatype: \"varchar\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"varchar\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"name_role\",\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: true,\n          options: [],\n          nullable: false,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n      ],\n    },\n    {\n      schema: \"public\",\n      name: \"composite_pk\",\n      columns: [\n        {\n          name: \"id\",\n          datatype: \"uuid\",\n          datatype_schema: \"pg_catalog\",\n          pk: true,\n          computed: false,\n          options: [],\n          nullable: false,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"name\",\n          datatype: \"text\",\n          datatype_schema: \"pg_catalog\",\n          pk: true,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n        {\n          name: \"created_at\",\n          datatype: \"timestamp\",\n          datatype_schema: \"pg_catalog\",\n          pk: false,\n          computed: false,\n          options: [],\n          nullable: true,\n          foreign_key_schema: null,\n          foreign_key_table: null,\n          foreign_key_column: null,\n        },\n      ],\n    },\n  ] as const satisfies QueryResult<typeof getTablesQuery>;\n}\n\n/**\n * Returns a query that returns the current timezone setting of the PostgreSQL database.\n */\nexport function getTimezoneQuery() {\n  const builder = getPostgreSQLBuilder();\n\n  return compile(builder.selectNoFrom(builder.fn<string>(\"current_setting\", [sql.lit(\"timezone\")]).as(\"timezone\")));\n}\n\n/**\n * For testing purposes.\n */\nexport function mockTimezoneQuery() {\n  return [{ timezone: \"UTC\" }] as const satisfies QueryResult<typeof getTimezoneQuery>;\n}\n\n/**\n * We don't want PostgreSQL internals in introspection results. To be used in `$call`.\n */\nfunction excludeSystemTables<\n  T extends SelectQueryBuilder<\n    Database & { ns: Database[\"pg_catalog.pg_namespace\"]; cls: Database[\"pg_catalog.pg_class\"] },\n    \"ns\" | \"cls\",\n    object\n  >,\n>(qb: T): T {\n  return qb.where(`ns.nspname`, `!~`, `^pg_`).where(`ns.nspname`, `!=`, `information_schema`) as never;\n}\n", "/// <reference types=\"./postgres.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\n/**\n * A postgres helper for aggregating a subquery (or other expression) into a JSONB array.\n *\n * ### Examples\n *\n * <!-- siteExample(\"select\", \"Nested array\", 110) -->\n *\n * While kysely is not an ORM and it doesn't have the concept of relations, we do provide\n * helpers for fetching nested objects and arrays in a single query. In this example we\n * use the `jsonArrayFrom` helper to fetch person's pets along with the person's id.\n *\n * Please keep in mind that the helpers under the `kysely/helpers` folder, including\n * `jsonArrayFrom`, are not guaranteed to work with third party dialects. In order for\n * them to work, the dialect must automatically parse the `json` data type into\n * JavaScript JSON values like objects and arrays. Some dialects might simply return\n * the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`\n * to parse the results.\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonArrayFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .orderBy('pet.name')\n *     ).as('pets')\n *   ])\n *   .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", (\n *   select coalesce(json_agg(agg), '[]') from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     order by \"pet\".\"name\"\n *   ) as agg\n * ) as \"pets\"\n * from \"person\"\n * ```\n */\nexport function jsonArrayFrom(expr) {\n    return sql `(select coalesce(json_agg(agg), '[]') from ${expr} as agg)`;\n}\n/**\n * A postgres helper for turning a subquery (or other expression) into a JSON object.\n *\n * The subquery must only return one row.\n *\n * ### Examples\n *\n * <!-- siteExample(\"select\", \"Nested object\", 120) -->\n *\n * While kysely is not an ORM and it doesn't have the concept of relations, we do provide\n * helpers for fetching nested objects and arrays in a single query. In this example we\n * use the `jsonObjectFrom` helper to fetch person's favorite pet along with the person's id.\n *\n * Please keep in mind that the helpers under the `kysely/helpers` folder, including\n * `jsonObjectFrom`, are not guaranteed to work with third-party dialects. In order for\n * them to work, the dialect must automatically parse the `json` data type into\n * JavaScript JSON values like objects and arrays. Some dialects might simply return\n * the data as a JSON string. In these cases you can use the built in `ParseJSONResultsPlugin`\n * to parse the results.\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonObjectFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .where('pet.is_favorite', '=', true)\n *     ).as('favorite_pet')\n *   ])\n *   .execute()\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", (\n *   select to_json(obj) from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     and \"pet\".\"is_favorite\" = $1\n *   ) as obj\n * ) as \"favorite_pet\"\n * from \"person\"\n * ```\n */\nexport function jsonObjectFrom(expr) {\n    return sql `(select to_json(obj) from ${expr} as obj)`;\n}\n/**\n * The PostgreSQL `json_build_object` function.\n *\n * NOTE: This helper is only guaranteed to fully work with the built-in `PostgresDialect`.\n * While the produced SQL is compatible with all PostgreSQL databases, some third-party dialects\n * may not parse the nested JSON into objects. In these cases you can use the built in\n * `ParseJSONResultsPlugin` to parse the results.\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n * import { jsonBuildObject } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonBuildObject({\n *       first: eb.ref('first_name'),\n *       last: eb.ref('last_name'),\n *       full: sql<string>`first_name ||\u00A0' ' || last_name`\n *     }).as('name')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.name.first\n * result[0]?.name.last\n * result[0]?.name.full\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * select \"id\", json_build_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', first_name || ' ' || last_name\n * ) as \"name\"\n * from \"person\"\n * ```\n */\nexport function jsonBuildObject(obj) {\n    return sql `json_build_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;\n}\n/**\n * The PostgreSQL `merge_action` function.\n *\n * This function can be used in a `returning` clause to get the action that was\n * performed in a `mergeInto` query. The function returns one of the following\n * strings: `'INSERT'`, `'UPDATE'`, or `'DELETE'`.\n *\n * ### Examples\n *\n * ```ts\n * import { mergeAction } from 'kysely/helpers/postgres'\n *\n * const result = await db\n *   .mergeInto('person as p')\n *   .using('person_backup as pb', 'p.id', 'pb.id')\n *   .whenMatched()\n *   .thenUpdateSet(({ ref }) => ({\n *     first_name: ref('pb.first_name'),\n *     updated_at: ref('pb.updated_at').$castTo<string | null>(),\n *   }))\n *   .whenNotMatched()\n *   .thenInsertValues(({ ref}) => ({\n *     id: ref('pb.id'),\n *     first_name: ref('pb.first_name'),\n *     created_at: ref('pb.updated_at'),\n *     updated_at: ref('pb.updated_at').$castTo<string | null>(),\n *   }))\n *   .returning([mergeAction().as('action'), 'p.id', 'p.updated_at'])\n *   .execute()\n *\n * result[0].action\n * ```\n *\n * The generated SQL (PostgreSQL):\n *\n * ```sql\n * merge into \"person\" as \"p\"\n * using \"person_backup\" as \"pb\" on \"p\".\"id\" = \"pb\".\"id\"\n * when matched then update set\n *   \"first_name\" = \"pb\".\"first_name\",\n *   \"updated_at\" = \"pb\".\"updated_at\"::text\n * when not matched then insert values (\"id\", \"first_name\", \"created_at\", \"updated_at\")\n * values (\"pb\".\"id\", \"pb\".\"first_name\", \"pb\".\"updated_at\", \"pb\".\"updated_at\")\n * returning merge_action() as \"action\", \"p\".\"id\", \"p\".\"updated_at\"\n * ```\n */\nexport function mergeAction() {\n    return sql `merge_action()`;\n}\n"],
  "mappings": "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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "createAdapterError", "args", "error", "query", "adapterError", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "POSTGRESQL_DATA_TYPES_TO_METADATA", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "getPostgreSQLBuilder", "requirements", "getBuilder", "PostgresAdapter", "PostgresQueryCompiler", "getInsertQuery", "details", "requirements", "table", "rows", "tableName", "schema", "columns", "builder", "getPostgreSQLBuilder", "cols", "compile", "applyTransformations", "eb", "getSelectQuery", "pageIndex", "pageSize", "sortOrder", "filter", "countQuery", "sql", "qb", "item", "getSelectFilterExpression", "buildBaseExpressionBuilder", "spec", "column", "operator", "value", "columnRef", "group", "lhs", "filters", "orGroupsOfAndBuilders", "currentAndGroupBuilders", "i", "andExpressions", "mockSelectQuery", "getUpdateQuery", "changes", "row", "applyInferredRowFilters", "getDeleteQuery", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "jsonArrayFrom", "expr", "sql", "REGULAR_TABLE_KIND", "VIEW_TABLE_KIND", "TABLE_KINDS", "getTablesQuery", "requirements", "compile", "getPostgreSQLBuilder", "excludeSystemTables", "eb", "jsonArrayFrom", "jb", "on_eb", "sql", "mockTablesQuery", "getTimezoneQuery", "builder", "mockTimezoneQuery", "qb", "createPostgresAdapter", "requirements", "executor", "otherRequirements", "options", "tablesQuery", "getTablesQuery", "timezoneQuery", "getTimezoneQuery", "tablesError", "tables", "timezoneError", "timezones", "createAdapterError", "timezone", "createIntrospection", "error", "details", "query", "getSelectQuery", "results", "getInsertQuery", "rows", "getUpdateQuery", "row", "getDeleteQuery", "args", "result", "schemas", "columns", "tableName", "schema", "columnsRecord", "column", "datatype", "datatype_schema", "columnName", "nullable", "isArray", "strippedDataType", "POSTGRESQL_DATA_TYPES_TO_METADATA", "filterOperators", "mockIntrospect", "mockTablesQuery", "mockTimezoneQuery"]
}

|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";var R=Object.defineProperty;var A=Object.getOwnPropertyDescriptor;var x=Object.getOwnPropertyNames;var P=Object.prototype.hasOwnProperty;var S=(e,t)=>{for(var r in t)R(e,r,{get:t[r],enumerable:!0})},C=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of x(t))!P.call(e,o)&&o!==r&&R(e,o,{get:()=>t[o],enumerable:!(n=A(t,o))||n.enumerable});return e};var q=e=>C(R({},"__esModule",{value:!0}),e);var k={};S(k,{createAccelerateHttpClient:()=>E,deserializeRawResult:()=>y});module.exports=q(k);var p={postgres:{encoded:"ZGF0YXNvdXJjZSBkYiB7CiAgICBwcm92aWRlciA9ICJwb3N0Z3JlcyIKICAgIHVybCAgICAgID0gZW52KCJEQVRBQkFTRV9VUkwiKQp9CiAgICAKZ2VuZXJhdG9yIGNsaWVudCB7CiAgICBwcm92aWRlciA9ICJwcmlzbWEtY2xpZW50LWpzIgp9",hash:"54195896aeafa3318ca33f5a8bb44c6b4d89c368cb15288f3bd5ace35a3f9227"}};function y(e,t=T){let{columns:r,rows:n,types:o}=e,a=[],c=H(r);for(let s=0,d=n.length;s<d;s++){let l=n[s],i={...c};for(let u=0,w=l.length;u<w;u++){let m=r[u];i[m]=t(l[u],o[u],m)}a.push(i)}return a}function T(e,t,r){return e}function H(e){let t={};for(let r=0,n=e.length;r<n;r++)t[e[r]]=null;return t}var Q=["postgres"],g="accelerate.prisma-data.net",h=p;function E(e){let{provider:t}=e;if(t!=="postgresql"&&!Q.includes(t))throw new Error(`Invalid provider: ${t}`);let r=O(e);return{execute:D(e,r)}}function O(e){let{host:t,engineHash:r,clientVersion:n,provider:o,apiKey:a}=e,s=`${t===g?"https":"http"}://${t||g}/${n}/${f(o).hash}`,d=e.fetch||fetch,l={Authorization:`Bearer ${a}`,"Prisma-Engine-Hash":r};return i=>d(`${s}/${i.path}`,{body:i.body,headers:l,method:i.method,signal:i.signal})}async function _(e,t,r){let n=await r({body:f(e.provider).encoded,method:"PUT",path:"schema",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to upload schema to query engine: ${n.statusText}`)}}function f(e){return e==="postgresql"?h.postgres:h[e]}async function v(e,t,r){let n=await r({body:JSON.stringify(e),method:"POST",path:"graphql",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to execute query: ${n.statusText}`)}return await n.json()}function D(e,t){let{resultDeserializerFn:r=y}=e,n=null;return async(o,a)=>{try{await(n||=_(e,a,t));let{data:c,errors:s}=await v({action:"queryRaw",query:{arguments:{parameters:o.parameters,query:o.sql},selection:{}}},a,t);return s?[new AggregateError(s,"Errors occurred while executing the query")]:[null,r(c.queryRaw)]}catch(c){return[c]}}}
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/accelerate/index.ts", "<define:ACCELERATE_SCHEMA_BY_PROVIDER>", "../../../data/accelerate/deserializer.ts", "../../../data/accelerate/http-client.ts"],
  "sourcesContent": ["export {\n  type DeserializedResponse,\n  deserializeRawResult,\n  type QueryIntrospectionBuiltinType,\n  type RawResponse,\n} from \"./deserializer\";\nexport {\n  type AccelerateHttpClient,\n  type AccelerateHttpClientParams,\n  createAccelerateHttpClient,\n  type SupportedAccelerateProvider,\n} from \"./http-client\";\n", "", "// ----------------------------------------------------------------------------\n// STOLEN AND ALTERED FROM https://github.com/prisma/prisma/blob/07932ae18132381bb84db889a9dcad0e6c9e6a68/packages/client/src/runtime/utils/deserializeRawResults.ts\n// ----------------------------------------------------------------------------\n\nexport function deserializeRawResult(\n  response: RawResponse,\n  valueDeserializerFn: (\n    value: unknown,\n    type: QueryIntrospectionBuiltinType,\n    column: string,\n  ) => unknown = deserializeValue,\n): DeserializedResponse {\n  const { columns, rows, types } = response;\n\n  const deserializedResponse: DeserializedResponse = [];\n\n  // Performance optimization. See https://github.com/brianc/node-postgres/issues/3042\n  const prebuiltEmptyObject = createPrebuiltEmptyResultObject(columns);\n\n  for (let i = 0, len = rows.length; i < len; i++) {\n    const row = rows[i]!;\n\n    const mappedRow = { ...prebuiltEmptyObject } as Record<string, unknown>;\n\n    for (let j = 0, len = row.length; j < len; j++) {\n      const column = columns[j]!;\n\n      mappedRow[column] = valueDeserializerFn(row[j], types[j]!, column);\n    }\n\n    deserializedResponse.push(mappedRow);\n  }\n\n  return deserializedResponse;\n}\n\nfunction deserializeValue(value: unknown, _type: QueryIntrospectionBuiltinType, _column: string): unknown {\n  return value;\n}\n\nexport type DeserializedResponse = Array<Record<string, unknown>>;\n\nfunction createPrebuiltEmptyResultObject(columns: string[]): Record<string, null> {\n  const row: Record<string, null> = {};\n\n  for (let i = 0, len = columns.length; i < len; i++) {\n    row[columns[i]!] = null;\n  }\n\n  return row;\n}\n\nexport interface RawResponse {\n  columns: string[];\n  types: QueryIntrospectionBuiltinType[];\n  rows: unknown[][];\n}\n\nexport type QueryIntrospectionBuiltinType =\n  | \"int\"\n  | \"bigint\"\n  | \"float\"\n  | \"double\"\n  | \"string\"\n  | \"enum\"\n  | \"bytes\"\n  | \"bool\"\n  | \"char\"\n  | \"decimal\"\n  | \"json\"\n  | \"xml\"\n  | \"uuid\"\n  | \"datetime\"\n  | \"date\"\n  | \"time\"\n  | \"int-array\"\n  | \"bigint-array\"\n  | \"float-array\"\n  | \"double-array\"\n  | \"string-array\"\n  | \"char-array\"\n  | \"bytes-array\"\n  | \"bool-array\"\n  | \"decimal-array\"\n  | \"json-array\"\n  | \"xml-array\"\n  | \"uuid-array\"\n  | \"datetime-array\"\n  | \"date-array\"\n  | \"time-array\"\n  | \"null\"\n  | \"unknown\";\n", "import type { JsonBatchQuery, JsonQuery } from \"@prisma/client/runtime/library\";\n\nimport type { ExecuteOptions, Executor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { deserializeRawResult, type RawResponse } from \"./deserializer\";\n\nexport const SUPPORTED_ACCELERATE_PROVIDERS = [\n  // \"mysql\",\n  \"postgres\",\n] as const;\nexport type SupportedAccelerateProvider = (typeof SUPPORTED_ACCELERATE_PROVIDERS)[number];\n\n/** value injected at build time */\ndeclare const ACCELERATE_SCHEMA_BY_PROVIDER: Record<SupportedAccelerateProvider, { encoded: string; hash: string }>;\n\nexport type JsonRequest = JsonQuery | JsonBatchQuery;\n\nexport interface QueryRawResult {\n  data: {\n    queryRaw: RawResponse;\n  };\n  errors?: unknown[];\n}\n\nconst ACCELERATE_HOST = \"accelerate.prisma-data.net\";\nexport const SCHEMA_BY_PROVIDER = ACCELERATE_SCHEMA_BY_PROVIDER;\n\nexport interface AccelerateHttpClientParams {\n  /**\n   * Accelerate API key.\n   */\n  apiKey: string;\n\n  /**\n   * Optional fetch implementation.\n   */\n  fetch?: typeof globalThis.fetch;\n\n  /**\n   * Optional host.\n   *\n   * Defaults to `accelerate.prisma-data.net`.\n   */\n  host?: string;\n\n  /**\n   * Database provider.\n   */\n  provider: SupportedAccelerateProvider | \"postgresql\";\n\n  /**\n   * Prisma Engine Hash (eg. 173f8d54f8d52e692c7e27e72a88314ec7aeff60)\n   */\n  engineHash: string;\n\n  /**\n   * Prisma Client Version (eg. 6.5.0).\n   */\n  clientVersion: string;\n\n  /**\n   * Function used to deserialize the results of queries.\n   *\n   * By default, the results are passed to `deserializeRawResult`.\n   */\n  resultDeserializerFn?: (this: void, response: RawResponse) => unknown[];\n}\n\nexport interface AccelerateHttpClient extends Executor {\n  execute<Q extends Query>(this: void, query: Q, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Q>>>;\n}\n\nexport function createAccelerateHttpClient(props: AccelerateHttpClientParams): AccelerateHttpClient {\n  const { provider } = props;\n\n  if (provider !== \"postgresql\" && !SUPPORTED_ACCELERATE_PROVIDERS.includes(provider)) {\n    throw new Error(`Invalid provider: ${provider}`);\n  }\n\n  const sendAccelerateRequest = getSendAccelerateRequestFn(props);\n\n  return {\n    execute: getSendQueryRequestFn(props, sendAccelerateRequest),\n  };\n}\n\nfunction getSendAccelerateRequestFn(\n  props: AccelerateHttpClientParams,\n): (request: RequestInit & { path: string; signal?: AbortSignal }) => Promise<Response> {\n  const { host, engineHash, clientVersion, provider, apiKey } = props;\n  const protocol = host === ACCELERATE_HOST ? \"https\" : \"http\";\n  const baseUrl = `${protocol}://${host || ACCELERATE_HOST}/${clientVersion}/${getSchemaByProvider(provider).hash}`;\n\n  const fetchFn = props.fetch || fetch;\n  const headers = {\n    Authorization: `Bearer ${apiKey}`,\n    \"Prisma-Engine-Hash\": engineHash,\n  } as const;\n\n  return (request) =>\n    fetchFn(`${baseUrl}/${request.path}`, {\n      body: request.body,\n      headers,\n      method: request.method,\n      signal: request.signal,\n    });\n}\n\nasync function sendSchemaRequest(\n  props: AccelerateHttpClientParams,\n  options: ExecuteOptions | undefined,\n  sendRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<void> {\n  const response = await sendRequest({\n    body: getSchemaByProvider(props.provider).encoded,\n    method: \"PUT\",\n    path: \"schema\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to upload schema to query engine: ${response.statusText}`);\n  }\n}\n\nfunction getSchemaByProvider(\n  provider: SupportedAccelerateProvider | \"postgresql\",\n): (typeof SCHEMA_BY_PROVIDER)[keyof typeof SCHEMA_BY_PROVIDER] {\n  if (provider === \"postgresql\") {\n    return SCHEMA_BY_PROVIDER[\"postgres\"];\n  }\n\n  return SCHEMA_BY_PROVIDER[provider];\n}\n\nasync function sendPrismaOrmRequest<R>(\n  request: JsonRequest,\n  options: ExecuteOptions | undefined,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<R> {\n  const response = await sendAccelerateRequest({\n    body: JSON.stringify(request),\n    method: \"POST\",\n    path: \"graphql\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to execute query: ${response.statusText}`);\n  }\n\n  return (await response.json()) as R;\n}\n\nfunction getSendQueryRequestFn(\n  props: AccelerateHttpClientParams,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Executor[\"execute\"] {\n  const { resultDeserializerFn = deserializeRawResult } = props;\n  let schemaRequest: Promise<void> | null = null;\n\n  return async (query, options) => {\n    try {\n      await (schemaRequest ||= sendSchemaRequest(props, options, sendAccelerateRequest));\n\n      const { data, errors } = await sendPrismaOrmRequest<QueryRawResult>(\n        {\n          action: \"queryRaw\",\n          query: {\n            arguments: {\n              parameters: query.parameters as never[],\n              query: query.sql,\n            },\n            selection: {},\n          },\n        },\n        options,\n        sendAccelerateRequest,\n      );\n\n      if (errors) {\n        return [new AggregateError(errors, \"Errors occurred while executing the query\")];\n      }\n\n      return [null, resultDeserializerFn(data.queryRaw) as QueryResult<typeof query>];\n    } catch (error: unknown) {\n      // TODO: handle properly\n      return [error as Error];\n    }\n  };\n}\n"],
  "mappings": "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",
  "names": ["accelerate_exports", "__export", "createAccelerateHttpClient", "deserializeRawResult", "__toCommonJS", "define_ACCELERATE_SCHEMA_BY_PROVIDER_default", "deserializeRawResult", "response", "valueDeserializerFn", "deserializeValue", "columns", "rows", "types", "deserializedResponse", "prebuiltEmptyObject", "createPrebuiltEmptyResultObject", "i", "len", "row", "mappedRow", "j", "column", "value", "_type", "_column", "SUPPORTED_ACCELERATE_PROVIDERS", "ACCELERATE_HOST", "SCHEMA_BY_PROVIDER", "define_ACCELERATE_SCHEMA_BY_PROVIDER_default", "createAccelerateHttpClient", "props", "provider", "sendAccelerateRequest", "getSendAccelerateRequestFn", "getSendQueryRequestFn", "host", "engineHash", "clientVersion", "apiKey", "baseUrl", "getSchemaByProvider", "fetchFn", "headers", "request", "sendSchemaRequest", "options", "sendRequest", "response", "sendPrismaOrmRequest", "resultDeserializerFn", "deserializeRawResult", "schemaRequest", "query", "data", "errors", "error"]
}

|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Executor, ExecuteOptions } from '../index.cjs';
|
|
2
|
+
import { Q as Query, E as Either, a as QueryResult } from '../../query-C7LxjwdN.cjs';
|
|
3
|
+
import 'kysely';
|
|
4
|
+
|
|
5
|
+
declare function deserializeRawResult(response: RawResponse, valueDeserializerFn?: (value: unknown, type: QueryIntrospectionBuiltinType, column: string) => unknown): DeserializedResponse;
|
|
6
|
+
type DeserializedResponse = Array<Record<string, unknown>>;
|
|
7
|
+
interface RawResponse {
|
|
8
|
+
columns: string[];
|
|
9
|
+
types: QueryIntrospectionBuiltinType[];
|
|
10
|
+
rows: unknown[][];
|
|
11
|
+
}
|
|
12
|
+
type QueryIntrospectionBuiltinType = "int" | "bigint" | "float" | "double" | "string" | "enum" | "bytes" | "bool" | "char" | "decimal" | "json" | "xml" | "uuid" | "datetime" | "date" | "time" | "int-array" | "bigint-array" | "float-array" | "double-array" | "string-array" | "char-array" | "bytes-array" | "bool-array" | "decimal-array" | "json-array" | "xml-array" | "uuid-array" | "datetime-array" | "date-array" | "time-array" | "null" | "unknown";
|
|
13
|
+
|
|
14
|
+
declare const SUPPORTED_ACCELERATE_PROVIDERS: readonly ["postgres"];
|
|
15
|
+
type SupportedAccelerateProvider = (typeof SUPPORTED_ACCELERATE_PROVIDERS)[number];
|
|
16
|
+
interface AccelerateHttpClientParams {
|
|
17
|
+
/**
|
|
18
|
+
* Accelerate API key.
|
|
19
|
+
*/
|
|
20
|
+
apiKey: string;
|
|
21
|
+
/**
|
|
22
|
+
* Optional fetch implementation.
|
|
23
|
+
*/
|
|
24
|
+
fetch?: typeof globalThis.fetch;
|
|
25
|
+
/**
|
|
26
|
+
* Optional host.
|
|
27
|
+
*
|
|
28
|
+
* Defaults to `accelerate.prisma-data.net`.
|
|
29
|
+
*/
|
|
30
|
+
host?: string;
|
|
31
|
+
/**
|
|
32
|
+
* Database provider.
|
|
33
|
+
*/
|
|
34
|
+
provider: SupportedAccelerateProvider | "postgresql";
|
|
35
|
+
/**
|
|
36
|
+
* Prisma Engine Hash (eg. 173f8d54f8d52e692c7e27e72a88314ec7aeff60)
|
|
37
|
+
*/
|
|
38
|
+
engineHash: string;
|
|
39
|
+
/**
|
|
40
|
+
* Prisma Client Version (eg. 6.5.0).
|
|
41
|
+
*/
|
|
42
|
+
clientVersion: string;
|
|
43
|
+
/**
|
|
44
|
+
* Function used to deserialize the results of queries.
|
|
45
|
+
*
|
|
46
|
+
* By default, the results are passed to `deserializeRawResult`.
|
|
47
|
+
*/
|
|
48
|
+
resultDeserializerFn?: (this: void, response: RawResponse) => unknown[];
|
|
49
|
+
}
|
|
50
|
+
interface AccelerateHttpClient extends Executor {
|
|
51
|
+
execute<Q extends Query>(this: void, query: Q, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Q>>>;
|
|
52
|
+
}
|
|
53
|
+
declare function createAccelerateHttpClient(props: AccelerateHttpClientParams): AccelerateHttpClient;
|
|
54
|
+
|
|
55
|
+
export { type AccelerateHttpClient, type AccelerateHttpClientParams, type DeserializedResponse, type QueryIntrospectionBuiltinType, type RawResponse, type SupportedAccelerateProvider, createAccelerateHttpClient, deserializeRawResult };
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Executor, ExecuteOptions } from '../index.js';
|
|
2
|
+
import { Q as Query, E as Either, a as QueryResult } from '../../query-C7LxjwdN.js';
|
|
3
|
+
import 'kysely';
|
|
4
|
+
|
|
5
|
+
declare function deserializeRawResult(response: RawResponse, valueDeserializerFn?: (value: unknown, type: QueryIntrospectionBuiltinType, column: string) => unknown): DeserializedResponse;
|
|
6
|
+
type DeserializedResponse = Array<Record<string, unknown>>;
|
|
7
|
+
interface RawResponse {
|
|
8
|
+
columns: string[];
|
|
9
|
+
types: QueryIntrospectionBuiltinType[];
|
|
10
|
+
rows: unknown[][];
|
|
11
|
+
}
|
|
12
|
+
type QueryIntrospectionBuiltinType = "int" | "bigint" | "float" | "double" | "string" | "enum" | "bytes" | "bool" | "char" | "decimal" | "json" | "xml" | "uuid" | "datetime" | "date" | "time" | "int-array" | "bigint-array" | "float-array" | "double-array" | "string-array" | "char-array" | "bytes-array" | "bool-array" | "decimal-array" | "json-array" | "xml-array" | "uuid-array" | "datetime-array" | "date-array" | "time-array" | "null" | "unknown";
|
|
13
|
+
|
|
14
|
+
declare const SUPPORTED_ACCELERATE_PROVIDERS: readonly ["postgres"];
|
|
15
|
+
type SupportedAccelerateProvider = (typeof SUPPORTED_ACCELERATE_PROVIDERS)[number];
|
|
16
|
+
interface AccelerateHttpClientParams {
|
|
17
|
+
/**
|
|
18
|
+
* Accelerate API key.
|
|
19
|
+
*/
|
|
20
|
+
apiKey: string;
|
|
21
|
+
/**
|
|
22
|
+
* Optional fetch implementation.
|
|
23
|
+
*/
|
|
24
|
+
fetch?: typeof globalThis.fetch;
|
|
25
|
+
/**
|
|
26
|
+
* Optional host.
|
|
27
|
+
*
|
|
28
|
+
* Defaults to `accelerate.prisma-data.net`.
|
|
29
|
+
*/
|
|
30
|
+
host?: string;
|
|
31
|
+
/**
|
|
32
|
+
* Database provider.
|
|
33
|
+
*/
|
|
34
|
+
provider: SupportedAccelerateProvider | "postgresql";
|
|
35
|
+
/**
|
|
36
|
+
* Prisma Engine Hash (eg. 173f8d54f8d52e692c7e27e72a88314ec7aeff60)
|
|
37
|
+
*/
|
|
38
|
+
engineHash: string;
|
|
39
|
+
/**
|
|
40
|
+
* Prisma Client Version (eg. 6.5.0).
|
|
41
|
+
*/
|
|
42
|
+
clientVersion: string;
|
|
43
|
+
/**
|
|
44
|
+
* Function used to deserialize the results of queries.
|
|
45
|
+
*
|
|
46
|
+
* By default, the results are passed to `deserializeRawResult`.
|
|
47
|
+
*/
|
|
48
|
+
resultDeserializerFn?: (this: void, response: RawResponse) => unknown[];
|
|
49
|
+
}
|
|
50
|
+
interface AccelerateHttpClient extends Executor {
|
|
51
|
+
execute<Q extends Query>(this: void, query: Q, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Q>>>;
|
|
52
|
+
}
|
|
53
|
+
declare function createAccelerateHttpClient(props: AccelerateHttpClientParams): AccelerateHttpClient;
|
|
54
|
+
|
|
55
|
+
export { type AccelerateHttpClient, type AccelerateHttpClientParams, type DeserializedResponse, type QueryIntrospectionBuiltinType, type RawResponse, type SupportedAccelerateProvider, createAccelerateHttpClient, deserializeRawResult };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as ___react___ from 'react';
|
|
2
|
+
import * as ___react_dom___ from 'react-dom';
|
|
3
|
+
|
|
4
|
+
function require(mod) {
|
|
5
|
+
if (mod === 'react') return ___react___;
|
|
6
|
+
if (mod === 'react-dom') return ___react_dom___;
|
|
7
|
+
throw new Error(`Unknown module ${mod}`);
|
|
8
|
+
}
|
|
9
|
+
import{e as u,f as y}from"../../chunk-P5LRZ6C2.js";u();u();function R(e,t=w){let{columns:r,rows:n,types:i}=e,s=[],c=A(r);for(let o=0,d=n.length;o<d;o++){let p=n[o],a={...c};for(let l=0,f=p.length;l<f;l++){let m=r[l];a[m]=t(p[l],i[l],m)}s.push(a)}return s}function w(e,t,r){return e}function A(e){let t={};for(let r=0,n=e.length;r<n;r++)t[e[r]]=null;return t}u();var x=["postgres"],g="accelerate.prisma-data.net",h=y;function P(e){let{provider:t}=e;if(t!=="postgresql"&&!x.includes(t))throw new Error(`Invalid provider: ${t}`);let r=S(e);return{execute:b(e,r)}}function S(e){let{host:t,engineHash:r,clientVersion:n,provider:i,apiKey:s}=e,o=`${t===g?"https":"http"}://${t||g}/${n}/${E(i).hash}`,d=e.fetch||fetch,p={Authorization:`Bearer ${s}`,"Prisma-Engine-Hash":r};return a=>d(`${o}/${a.path}`,{body:a.body,headers:p,method:a.method,signal:a.signal})}async function C(e,t,r){let n=await r({body:E(e.provider).encoded,method:"PUT",path:"schema",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to upload schema to query engine: ${n.statusText}`)}}function E(e){return e==="postgresql"?h.postgres:h[e]}async function q(e,t,r){let n=await r({body:JSON.stringify(e),method:"POST",path:"graphql",signal:t?.abortSignal});if(!n.ok){try{console.error(await n.text())}catch{}throw new Error(`Failed to execute query: ${n.statusText}`)}return await n.json()}function b(e,t){let{resultDeserializerFn:r=R}=e,n=null;return async(i,s)=>{try{await(n||=C(e,s,t));let{data:c,errors:o}=await q({action:"queryRaw",query:{arguments:{parameters:i.parameters,query:i.sql},selection:{}}},s,t);return o?[new AggregateError(o,"Errors occurred while executing the query")]:[null,r(c.queryRaw)]}catch(c){return[c]}}}export{P as createAccelerateHttpClient,R as deserializeRawResult};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../data/accelerate/index.ts", "../../../data/accelerate/deserializer.ts", "../../../data/accelerate/http-client.ts"],
  "sourcesContent": ["export {\n  type DeserializedResponse,\n  deserializeRawResult,\n  type QueryIntrospectionBuiltinType,\n  type RawResponse,\n} from \"./deserializer\";\nexport {\n  type AccelerateHttpClient,\n  type AccelerateHttpClientParams,\n  createAccelerateHttpClient,\n  type SupportedAccelerateProvider,\n} from \"./http-client\";\n", "// ----------------------------------------------------------------------------\n// STOLEN AND ALTERED FROM https://github.com/prisma/prisma/blob/07932ae18132381bb84db889a9dcad0e6c9e6a68/packages/client/src/runtime/utils/deserializeRawResults.ts\n// ----------------------------------------------------------------------------\n\nexport function deserializeRawResult(\n  response: RawResponse,\n  valueDeserializerFn: (\n    value: unknown,\n    type: QueryIntrospectionBuiltinType,\n    column: string,\n  ) => unknown = deserializeValue,\n): DeserializedResponse {\n  const { columns, rows, types } = response;\n\n  const deserializedResponse: DeserializedResponse = [];\n\n  // Performance optimization. See https://github.com/brianc/node-postgres/issues/3042\n  const prebuiltEmptyObject = createPrebuiltEmptyResultObject(columns);\n\n  for (let i = 0, len = rows.length; i < len; i++) {\n    const row = rows[i]!;\n\n    const mappedRow = { ...prebuiltEmptyObject } as Record<string, unknown>;\n\n    for (let j = 0, len = row.length; j < len; j++) {\n      const column = columns[j]!;\n\n      mappedRow[column] = valueDeserializerFn(row[j], types[j]!, column);\n    }\n\n    deserializedResponse.push(mappedRow);\n  }\n\n  return deserializedResponse;\n}\n\nfunction deserializeValue(value: unknown, _type: QueryIntrospectionBuiltinType, _column: string): unknown {\n  return value;\n}\n\nexport type DeserializedResponse = Array<Record<string, unknown>>;\n\nfunction createPrebuiltEmptyResultObject(columns: string[]): Record<string, null> {\n  const row: Record<string, null> = {};\n\n  for (let i = 0, len = columns.length; i < len; i++) {\n    row[columns[i]!] = null;\n  }\n\n  return row;\n}\n\nexport interface RawResponse {\n  columns: string[];\n  types: QueryIntrospectionBuiltinType[];\n  rows: unknown[][];\n}\n\nexport type QueryIntrospectionBuiltinType =\n  | \"int\"\n  | \"bigint\"\n  | \"float\"\n  | \"double\"\n  | \"string\"\n  | \"enum\"\n  | \"bytes\"\n  | \"bool\"\n  | \"char\"\n  | \"decimal\"\n  | \"json\"\n  | \"xml\"\n  | \"uuid\"\n  | \"datetime\"\n  | \"date\"\n  | \"time\"\n  | \"int-array\"\n  | \"bigint-array\"\n  | \"float-array\"\n  | \"double-array\"\n  | \"string-array\"\n  | \"char-array\"\n  | \"bytes-array\"\n  | \"bool-array\"\n  | \"decimal-array\"\n  | \"json-array\"\n  | \"xml-array\"\n  | \"uuid-array\"\n  | \"datetime-array\"\n  | \"date-array\"\n  | \"time-array\"\n  | \"null\"\n  | \"unknown\";\n", "import type { JsonBatchQuery, JsonQuery } from \"@prisma/client/runtime/library\";\n\nimport type { ExecuteOptions, Executor } from \"../executor\";\nimport type { Query, QueryResult } from \"../query\";\nimport type { Either } from \"../type-utils\";\nimport { deserializeRawResult, type RawResponse } from \"./deserializer\";\n\nexport const SUPPORTED_ACCELERATE_PROVIDERS = [\n  // \"mysql\",\n  \"postgres\",\n] as const;\nexport type SupportedAccelerateProvider = (typeof SUPPORTED_ACCELERATE_PROVIDERS)[number];\n\n/** value injected at build time */\ndeclare const ACCELERATE_SCHEMA_BY_PROVIDER: Record<SupportedAccelerateProvider, { encoded: string; hash: string }>;\n\nexport type JsonRequest = JsonQuery | JsonBatchQuery;\n\nexport interface QueryRawResult {\n  data: {\n    queryRaw: RawResponse;\n  };\n  errors?: unknown[];\n}\n\nconst ACCELERATE_HOST = \"accelerate.prisma-data.net\";\nexport const SCHEMA_BY_PROVIDER = ACCELERATE_SCHEMA_BY_PROVIDER;\n\nexport interface AccelerateHttpClientParams {\n  /**\n   * Accelerate API key.\n   */\n  apiKey: string;\n\n  /**\n   * Optional fetch implementation.\n   */\n  fetch?: typeof globalThis.fetch;\n\n  /**\n   * Optional host.\n   *\n   * Defaults to `accelerate.prisma-data.net`.\n   */\n  host?: string;\n\n  /**\n   * Database provider.\n   */\n  provider: SupportedAccelerateProvider | \"postgresql\";\n\n  /**\n   * Prisma Engine Hash (eg. 173f8d54f8d52e692c7e27e72a88314ec7aeff60)\n   */\n  engineHash: string;\n\n  /**\n   * Prisma Client Version (eg. 6.5.0).\n   */\n  clientVersion: string;\n\n  /**\n   * Function used to deserialize the results of queries.\n   *\n   * By default, the results are passed to `deserializeRawResult`.\n   */\n  resultDeserializerFn?: (this: void, response: RawResponse) => unknown[];\n}\n\nexport interface AccelerateHttpClient extends Executor {\n  execute<Q extends Query>(this: void, query: Q, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Q>>>;\n}\n\nexport function createAccelerateHttpClient(props: AccelerateHttpClientParams): AccelerateHttpClient {\n  const { provider } = props;\n\n  if (provider !== \"postgresql\" && !SUPPORTED_ACCELERATE_PROVIDERS.includes(provider)) {\n    throw new Error(`Invalid provider: ${provider}`);\n  }\n\n  const sendAccelerateRequest = getSendAccelerateRequestFn(props);\n\n  return {\n    execute: getSendQueryRequestFn(props, sendAccelerateRequest),\n  };\n}\n\nfunction getSendAccelerateRequestFn(\n  props: AccelerateHttpClientParams,\n): (request: RequestInit & { path: string; signal?: AbortSignal }) => Promise<Response> {\n  const { host, engineHash, clientVersion, provider, apiKey } = props;\n  const protocol = host === ACCELERATE_HOST ? \"https\" : \"http\";\n  const baseUrl = `${protocol}://${host || ACCELERATE_HOST}/${clientVersion}/${getSchemaByProvider(provider).hash}`;\n\n  const fetchFn = props.fetch || fetch;\n  const headers = {\n    Authorization: `Bearer ${apiKey}`,\n    \"Prisma-Engine-Hash\": engineHash,\n  } as const;\n\n  return (request) =>\n    fetchFn(`${baseUrl}/${request.path}`, {\n      body: request.body,\n      headers,\n      method: request.method,\n      signal: request.signal,\n    });\n}\n\nasync function sendSchemaRequest(\n  props: AccelerateHttpClientParams,\n  options: ExecuteOptions | undefined,\n  sendRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<void> {\n  const response = await sendRequest({\n    body: getSchemaByProvider(props.provider).encoded,\n    method: \"PUT\",\n    path: \"schema\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to upload schema to query engine: ${response.statusText}`);\n  }\n}\n\nfunction getSchemaByProvider(\n  provider: SupportedAccelerateProvider | \"postgresql\",\n): (typeof SCHEMA_BY_PROVIDER)[keyof typeof SCHEMA_BY_PROVIDER] {\n  if (provider === \"postgresql\") {\n    return SCHEMA_BY_PROVIDER[\"postgres\"];\n  }\n\n  return SCHEMA_BY_PROVIDER[provider];\n}\n\nasync function sendPrismaOrmRequest<R>(\n  request: JsonRequest,\n  options: ExecuteOptions | undefined,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Promise<R> {\n  const response = await sendAccelerateRequest({\n    body: JSON.stringify(request),\n    method: \"POST\",\n    path: \"graphql\",\n    signal: options?.abortSignal,\n  });\n\n  if (!response.ok) {\n    try {\n      console.error(await response.text());\n    } catch {\n      // noop\n    }\n    throw new Error(`Failed to execute query: ${response.statusText}`);\n  }\n\n  return (await response.json()) as R;\n}\n\nfunction getSendQueryRequestFn(\n  props: AccelerateHttpClientParams,\n  sendAccelerateRequest: ReturnType<typeof getSendAccelerateRequestFn>,\n): Executor[\"execute\"] {\n  const { resultDeserializerFn = deserializeRawResult } = props;\n  let schemaRequest: Promise<void> | null = null;\n\n  return async (query, options) => {\n    try {\n      await (schemaRequest ||= sendSchemaRequest(props, options, sendAccelerateRequest));\n\n      const { data, errors } = await sendPrismaOrmRequest<QueryRawResult>(\n        {\n          action: \"queryRaw\",\n          query: {\n            arguments: {\n              parameters: query.parameters as never[],\n              query: query.sql,\n            },\n            selection: {},\n          },\n        },\n        options,\n        sendAccelerateRequest,\n      );\n\n      if (errors) {\n        return [new AggregateError(errors, \"Errors occurred while executing the query\")];\n      }\n\n      return [null, resultDeserializerFn(data.queryRaw) as QueryResult<typeof query>];\n    } catch (error: unknown) {\n      // TODO: handle properly\n      return [error as Error];\n    }\n  };\n}\n"],
  "mappings": "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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "deserializeRawResult", "response", "valueDeserializerFn", "deserializeValue", "columns", "rows", "types", "deserializedResponse", "prebuiltEmptyObject", "createPrebuiltEmptyResultObject", "i", "len", "row", "mappedRow", "j", "column", "value", "_type", "_column", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "SUPPORTED_ACCELERATE_PROVIDERS", "ACCELERATE_HOST", "SCHEMA_BY_PROVIDER", "define_ACCELERATE_SCHEMA_BY_PROVIDER_default", "createAccelerateHttpClient", "props", "provider", "sendAccelerateRequest", "getSendAccelerateRequestFn", "getSendQueryRequestFn", "host", "engineHash", "clientVersion", "apiKey", "baseUrl", "getSchemaByProvider", "fetchFn", "headers", "request", "sendSchemaRequest", "options", "sendRequest", "response", "sendPrismaOrmRequest", "resultDeserializerFn", "deserializeRawResult", "schemaRequest", "query", "data", "errors", "error"]
}

|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";var a=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var f=Object.getOwnPropertyNames;var E=Object.prototype.hasOwnProperty;var x=(e,r)=>{for(var t in r)a(e,t,{get:r[t],enumerable:!0})},F=(e,r,t,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of f(r))!E.call(e,n)&&n!==t&&a(e,n,{get:()=>r[n],enumerable:!(o=y(r,n))||o.enumerable});return e};var w=e=>F(a({},"__esModule",{value:!0}),e);var Q={};x(Q,{createStudioBFFClient:()=>h,deserializeError:()=>c,serializeError:()=>m});module.exports=w(Q);function h(e){let{customHeaders:r,customPayload:t,resultDeserializerFn:o,url:n}=e,i=e.fetch||fetch;return{async execute(p,g){try{let s=await i(n,{body:JSON.stringify({customPayload:t,procedure:"query",query:p}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:g?.abortSignal});if(!s.ok){let u;try{u=await s.text()}catch{u="unknown error"}return[new Error(u)]}let[l,d]=await s.json();return l?[c(l)]:[null,o?.(d)||d]}catch(s){return[s]}}}}function m(e){if(e instanceof AggregateError){let{name:r,message:t}=e,o=e.errors.map(m);return{name:r,message:t,errors:o}}if(e instanceof Error){let{name:r,message:t}=e;return{name:r,message:t}}return{name:"UnknownError",message:JSON.stringify(e)}}function c(e){let{name:r,message:t}=e;if(e.errors!==void 0){let n=e.errors.map(c),i=new AggregateError(n,t);return i.name=e.name,i}let o=new Error(e.message);return e.name=r,o}
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9iZmYvaW5kZXgudHMiLCAiLi4vLi4vLi4vZGF0YS9iZmYvYmZmLWNsaWVudC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiZXhwb3J0ICogZnJvbSBcIi4vYmZmLWNsaWVudFwiO1xuIiwgImltcG9ydCB0eXBlIHsgRXhlY3V0ZU9wdGlvbnMsIEV4ZWN1dG9yIH0gZnJvbSBcIi4uL2V4ZWN1dG9yXCI7XG5pbXBvcnQgdHlwZSB7IFF1ZXJ5LCBRdWVyeVJlc3VsdCB9IGZyb20gXCIuLi9xdWVyeVwiO1xuaW1wb3J0IHR5cGUgeyBFaXRoZXIgfSBmcm9tIFwiLi4vdHlwZS11dGlsc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0dWRpb0JGRkNsaWVudFByb3BzIHtcbiAgLyoqXG4gICAqIEFsbG93cyBwYXNzaW5nIGN1c3RvbSBoZWFkZXJzIHRvIHRoZSBCRkYuXG4gICAqXG4gICAqIGUuZy4gYXV0aG9yaXphdGlvbiB0b2tlbi5cbiAgICovXG4gIGN1c3RvbUhlYWRlcnM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuXG4gIC8qKlxuICAgKiBBbGxvd3MgcGFzc2luZyBjdXN0b20gcGF5bG9hZCB0byB0aGUgQkZGIHZpYSBgYm9keS5jdXN0b21QYXlsb2FkYC5cbiAgICpcbiAgICogZS5nLiB0ZW5hbnQgaWQuXG4gICAqL1xuICBjdXN0b21QYXlsb2FkPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG5cbiAgLyoqXG4gICAqIEFsbG93cyBvdmVycmlkaW5nIHRoZSBmZXRjaCBmdW5jdGlvbiBpbXBsZW1lbnRhdGlvbi5cbiAgICpcbiAgICogZS5nLiBmb3IgdGVzdGluZywgb3Igb2xkZXIgTm9kZS5qcyB2ZXJzaW9ucy5cbiAgICovXG4gIGZldGNoPzogdHlwZW9mIGdsb2JhbFRoaXMuZmV0Y2g7XG5cbiAgLyoqXG4gICAqIEZ1bmN0aW9uIHVzZWQgdG8gZGVzZXJpYWxpemUgdGhlIHJlc3VsdHMgb2YgcXVlcmllcy5cbiAgICpcbiAgICogQnkgZGVmYXVsdCwgdGhlIHJlc3VsdHMgYXJlIHJldHVybmVkIGFzIGlzIHdpdGhvdXQgYW55IGFkZGl0aW9uYWwgcHJvY2Vzc2luZy5cbiAgICovXG4gIHJlc3VsdERlc2VyaWFsaXplckZuPyh0aGlzOiB2b2lkLCByZXN1bHRzOiB1bmtub3duKTogdW5rbm93bltdO1xuXG4gIC8qKlxuICAgKiBCRkYgZW5kcG9pbnQgVVJMLlxuICAgKlxuICAgKiBlLmcuIGBodHRwczovL2FwaS5leGFtcGxlLmNvbS9zdHVkaW9gXG4gICAqL1xuICB1cmw6IHN0cmluZyB8IFVSTDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTdHVkaW9CRkZDbGllbnQgZXh0ZW5kcyBFeGVjdXRvciB7XG4gIC8qKlxuICAgKiBSZXF1ZXN0cyBCRkYgdG8gcXVlcnkgdGhlIGRhdGFiYXNlLlxuICAgKlxuICAgKiBUaGUgcXVlcnkgaXMgc2VudCBhcyBgYm9keS5xdWVyeWAuXG4gICAqL1xuICBleGVjdXRlPFEgZXh0ZW5kcyBRdWVyeT4odGhpczogdm9pZCwgcXVlcnk6IFEsIG9wdGlvbnM/OiBFeGVjdXRlT3B0aW9ucyk6IFByb21pc2U8RWl0aGVyPEVycm9yLCBRdWVyeVJlc3VsdDxRPj4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN0dWRpb0JGRlF1ZXJ5UmVxdWVzdCB7XG4gIGN1c3RvbVBheWxvYWQ/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgcHJvY2VkdXJlOiBcInF1ZXJ5XCI7XG4gIHF1ZXJ5OiBRdWVyeTx1bmtub3duPjtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgU3R1ZGlvIEJGRiBjbGllbnQuIEJGRiBzdGFuZHMgZm9yIFwiQmFja2VuZCBGb3IgRnJvbnRlbmRcIiBidHcuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTdHVkaW9CRkZDbGllbnQocHJvcHM6IFN0dWRpb0JGRkNsaWVudFByb3BzKTogU3R1ZGlvQkZGQ2xpZW50IHtcbiAgY29uc3QgeyBjdXN0b21IZWFkZXJzLCBjdXN0b21QYXlsb2FkLCByZXN1bHREZXNlcmlhbGl6ZXJGbiwgdXJsIH0gPSBwcm9wcztcbiAgY29uc3QgZmV0Y2hGbiA9IHByb3BzLmZldGNoIHx8IGZldGNoO1xuXG4gIHJldHVybiB7XG4gICAgYXN5bmMgZXhlY3V0ZTxRIGV4dGVuZHMgUXVlcnk+KHF1ZXJ5OiBRLCBvcHRpb25zPzogRXhlY3V0ZU9wdGlvbnMpOiBQcm9taXNlPEVpdGhlcjxFcnJvciwgUXVlcnlSZXN1bHQ8UT4+PiB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGZldGNoRm4odXJsLCB7XG4gICAgICAgICAgYm9keTogSlNPTi5zdHJpbmdpZnkoeyBjdXN0b21QYXlsb2FkLCBwcm9jZWR1cmU6IFwicXVlcnlcIiwgcXVlcnkgfSBzYXRpc2ZpZXMgU3R1ZGlvQkZGUXVlcnlSZXF1ZXN0KSxcbiAgICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgICBBY2NlcHQ6IFwiYXBwbGljYXRpb24vanNvblwiLFxuICAgICAgICAgICAgXCJDb250ZW50LVR5cGVcIjogXCJhcHBsaWNhdGlvbi9qc29uXCIsXG4gICAgICAgICAgICAuLi5jdXN0b21IZWFkZXJzLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgbWV0aG9kOiBcIlBPU1RcIixcbiAgICAgICAgICBzaWduYWw6IG9wdGlvbnM/LmFib3J0U2lnbmFsLFxuICAgICAgICB9KTtcblxuICAgICAgICBpZiAoIXJlc3BvbnNlLm9rKSB7XG4gICAgICAgICAgbGV0IGVycm9yVGV4dDogc3RyaW5nO1xuXG4gICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGVycm9yVGV4dCA9IGF3YWl0IHJlc3BvbnNlLnRleHQoKTtcbiAgICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAgIGVycm9yVGV4dCA9IFwidW5rbm93biBlcnJvclwiO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHJldHVybiBbbmV3IEVycm9yKGVycm9yVGV4dCldO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgW2Vycm9yLCByZXN1bHRzXSA9IChhd2FpdCByZXNwb25zZS5qc29uKCkpIGFzIFtTZXJpYWxpemVkRXJyb3IsIHVua25vd25dO1xuXG4gICAgICAgIGlmIChlcnJvcikge1xuICAgICAgICAgIHJldHVybiBbZGVzZXJpYWxpemVFcnJvcihlcnJvcildO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIFtudWxsLCAocmVzdWx0RGVzZXJpYWxpemVyRm4/LihyZXN1bHRzKSB8fCByZXN1bHRzKSBhcyBuZXZlcl07XG4gICAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgICAvLyBUT0RPOiBoYW5kbGUgcHJvcGVybHlcbiAgICAgICAgcmV0dXJuIFtlcnJvciBhcyBFcnJvcl07XG4gICAgICB9XG4gICAgfSxcbiAgfTtcbn1cblxuaW50ZXJmYWNlIFNlcmlhbGl6ZWRFcnJvciB7XG4gIG1lc3NhZ2U6IHN0cmluZztcbiAgbmFtZTogc3RyaW5nO1xuICBlcnJvcnM/OiBTZXJpYWxpemVkRXJyb3JbXTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNlcmlhbGl6ZUVycm9yKGVycm9yOiB1bmtub3duKTogU2VyaWFsaXplZEVycm9yIHtcbiAgaWYgKGVycm9yIGluc3RhbmNlb2YgQWdncmVnYXRlRXJyb3IpIHtcbiAgICBjb25zdCB7IG5hbWUsIG1lc3NhZ2UgfSA9IGVycm9yO1xuICAgIGNvbnN0IGVycm9ycyA9IGVycm9yLmVycm9ycy5tYXAoc2VyaWFsaXplRXJyb3IpO1xuICAgIHJldHVybiB7IG5hbWUsIG1lc3NhZ2UsIGVycm9ycyB9O1xuICB9XG5cbiAgaWYgKGVycm9yIGluc3RhbmNlb2YgRXJyb3IpIHtcbiAgICBjb25zdCB7IG5hbWUsIG1lc3NhZ2UgfSA9IGVycm9yO1xuICAgIHJldHVybiB7IG5hbWUsIG1lc3NhZ2UgfTtcbiAgfVxuXG4gIHJldHVybiB7IG5hbWU6IGBVbmtub3duRXJyb3JgLCBtZXNzYWdlOiBKU09OLnN0cmluZ2lmeShlcnJvcikgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRlc2VyaWFsaXplRXJyb3IoZXJyb3I6IFNlcmlhbGl6ZWRFcnJvcik6IEVycm9yIHtcbiAgY29uc3QgeyBuYW1lLCBtZXNzYWdlIH0gPSBlcnJvcjtcblxuICBpZiAoZXJyb3IuZXJyb3JzICE9PSB1bmRlZmluZWQpIHtcbiAgICBjb25zdCBlcnJvcnMgPSBlcnJvci5lcnJvcnMubWFwKGRlc2VyaWFsaXplRXJyb3IpO1xuICAgIGNvbnN0IGFnZ3JlZ2F0ZUVycm9yID0gbmV3IEFnZ3JlZ2F0ZUVycm9yKGVycm9ycywgbWVzc2FnZSk7XG4gICAgYWdncmVnYXRlRXJyb3IubmFtZSA9IGVycm9yLm5hbWU7XG4gICAgcmV0dXJuIGFnZ3JlZ2F0ZUVycm9yO1xuICB9XG5cbiAgY29uc3QgcmVndWxhckVycm9yID0gbmV3IEVycm9yKGVycm9yLm1lc3NhZ2UpO1xuICBlcnJvci5uYW1lID0gbmFtZTtcbiAgcmV0dXJuIHJlZ3VsYXJFcnJvcjtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICJ5YUFBQSxJQUFBQSxFQUFBLEdBQUFDLEVBQUFELEVBQUEsMkJBQUFFLEVBQUEscUJBQUFDLEVBQUEsbUJBQUFDLElBQUEsZUFBQUMsRUFBQUwsR0MyRE8sU0FBU00sRUFBc0JDLEVBQThDLENBQ2xGLEdBQU0sQ0FBRSxjQUFBQyxFQUFlLGNBQUFDLEVBQWUscUJBQUFDLEVBQXNCLElBQUFDLENBQUksRUFBSUosRUFDOURLLEVBQVVMLEVBQU0sT0FBUyxNQUUvQixNQUFPLENBQ0wsTUFBTSxRQUF5Qk0sRUFBVUMsRUFBa0UsQ0FDekcsR0FBSSxDQUNGLElBQU1DLEVBQVcsTUFBTUgsRUFBUUQsRUFBSyxDQUNsQyxLQUFNLEtBQUssVUFBVSxDQUFFLGNBQUFGLEVBQWUsVUFBVyxRQUFTLE1BQUFJLENBQU0sQ0FBaUMsRUFDakcsUUFBUyxDQUNQLE9BQVEsbUJBQ1IsZUFBZ0IsbUJBQ2hCLEdBQUdMLENBQ0wsRUFDQSxPQUFRLE9BQ1IsT0FBUU0sR0FBUyxXQUNuQixDQUFDLEVBRUQsR0FBSSxDQUFDQyxFQUFTLEdBQUksQ0FDaEIsSUFBSUMsRUFFSixHQUFJLENBQ0ZBLEVBQVksTUFBTUQsRUFBUyxLQUFLLENBQ2xDLE1BQVEsQ0FDTkMsRUFBWSxlQUNkLENBRUEsTUFBTyxDQUFDLElBQUksTUFBTUEsQ0FBUyxDQUFDLENBQzlCLENBRUEsR0FBTSxDQUFDQyxFQUFPQyxDQUFPLEVBQUssTUFBTUgsRUFBUyxLQUFLLEVBRTlDLE9BQUlFLEVBQ0ssQ0FBQ0UsRUFBaUJGLENBQUssQ0FBQyxFQUcxQixDQUFDLEtBQU9QLElBQXVCUSxDQUFPLEdBQUtBLENBQWlCLENBQ3JFLE9BQVNELEVBQWdCLENBRXZCLE1BQU8sQ0FBQ0EsQ0FBYyxDQUN4QixDQUNGLENBQ0YsQ0FDRixDQVFPLFNBQVNHLEVBQWVILEVBQWlDLENBQzlELEdBQUlBLGFBQWlCLGVBQWdCLENBQ25DLEdBQU0sQ0FBRSxLQUFBSSxFQUFNLFFBQUFDLENBQVEsRUFBSUwsRUFDcEJNLEVBQVNOLEVBQU0sT0FBTyxJQUFJRyxDQUFjLEVBQzlDLE1BQU8sQ0FBRSxLQUFBQyxFQUFNLFFBQUFDLEVBQVMsT0FBQUMsQ0FBTyxDQUNqQyxDQUVBLEdBQUlOLGFBQWlCLE1BQU8sQ0FDMUIsR0FBTSxDQUFFLEtBQUFJLEVBQU0sUUFBQUMsQ0FBUSxFQUFJTCxFQUMxQixNQUFPLENBQUUsS0FBQUksRUFBTSxRQUFBQyxDQUFRLENBQ3pCLENBRUEsTUFBTyxDQUFFLEtBQU0sZUFBZ0IsUUFBUyxLQUFLLFVBQVVMLENBQUssQ0FBRSxDQUNoRSxDQUVPLFNBQVNFLEVBQWlCRixFQUErQixDQUM5RCxHQUFNLENBQUUsS0FBQUksRUFBTSxRQUFBQyxDQUFRLEVBQUlMLEVBRTFCLEdBQUlBLEVBQU0sU0FBVyxPQUFXLENBQzlCLElBQU1NLEVBQVNOLEVBQU0sT0FBTyxJQUFJRSxDQUFnQixFQUMxQ0ssRUFBaUIsSUFBSSxlQUFlRCxFQUFRRCxDQUFPLEVBQ3pELE9BQUFFLEVBQWUsS0FBT1AsRUFBTSxLQUNyQk8sQ0FDVCxDQUVBLElBQU1DLEVBQWUsSUFBSSxNQUFNUixFQUFNLE9BQU8sRUFDNUMsT0FBQUEsRUFBTSxLQUFPSSxFQUNOSSxDQUNUIiwKICAibmFtZXMiOiBbImJmZl9leHBvcnRzIiwgIl9fZXhwb3J0IiwgImNyZWF0ZVN0dWRpb0JGRkNsaWVudCIsICJkZXNlcmlhbGl6ZUVycm9yIiwgInNlcmlhbGl6ZUVycm9yIiwgIl9fdG9Db21tb25KUyIsICJjcmVhdGVTdHVkaW9CRkZDbGllbnQiLCAicHJvcHMiLCAiY3VzdG9tSGVhZGVycyIsICJjdXN0b21QYXlsb2FkIiwgInJlc3VsdERlc2VyaWFsaXplckZuIiwgInVybCIsICJmZXRjaEZuIiwgInF1ZXJ5IiwgIm9wdGlvbnMiLCAicmVzcG9uc2UiLCAiZXJyb3JUZXh0IiwgImVycm9yIiwgInJlc3VsdHMiLCAiZGVzZXJpYWxpemVFcnJvciIsICJzZXJpYWxpemVFcnJvciIsICJuYW1lIiwgIm1lc3NhZ2UiLCAiZXJyb3JzIiwgImFnZ3JlZ2F0ZUVycm9yIiwgInJlZ3VsYXJFcnJvciJdCn0K
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { Executor, ExecuteOptions } from '../index.cjs';
|
|
2
|
+
import { Q as Query, E as Either, a as QueryResult } from '../../query-C7LxjwdN.cjs';
|
|
3
|
+
import 'kysely';
|
|
4
|
+
|
|
5
|
+
interface StudioBFFClientProps {
|
|
6
|
+
/**
|
|
7
|
+
* Allows passing custom headers to the BFF.
|
|
8
|
+
*
|
|
9
|
+
* e.g. authorization token.
|
|
10
|
+
*/
|
|
11
|
+
customHeaders?: Record<string, string>;
|
|
12
|
+
/**
|
|
13
|
+
* Allows passing custom payload to the BFF via `body.customPayload`.
|
|
14
|
+
*
|
|
15
|
+
* e.g. tenant id.
|
|
16
|
+
*/
|
|
17
|
+
customPayload?: Record<string, unknown>;
|
|
18
|
+
/**
|
|
19
|
+
* Allows overriding the fetch function implementation.
|
|
20
|
+
*
|
|
21
|
+
* e.g. for testing, or older Node.js versions.
|
|
22
|
+
*/
|
|
23
|
+
fetch?: typeof globalThis.fetch;
|
|
24
|
+
/**
|
|
25
|
+
* Function used to deserialize the results of queries.
|
|
26
|
+
*
|
|
27
|
+
* By default, the results are returned as is without any additional processing.
|
|
28
|
+
*/
|
|
29
|
+
resultDeserializerFn?(this: void, results: unknown): unknown[];
|
|
30
|
+
/**
|
|
31
|
+
* BFF endpoint URL.
|
|
32
|
+
*
|
|
33
|
+
* e.g. `https://api.example.com/studio`
|
|
34
|
+
*/
|
|
35
|
+
url: string | URL;
|
|
36
|
+
}
|
|
37
|
+
interface StudioBFFClient extends Executor {
|
|
38
|
+
/**
|
|
39
|
+
* Requests BFF to query the database.
|
|
40
|
+
*
|
|
41
|
+
* The query is sent as `body.query`.
|
|
42
|
+
*/
|
|
43
|
+
execute<Q extends Query>(this: void, query: Q, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Q>>>;
|
|
44
|
+
}
|
|
45
|
+
interface StudioBFFQueryRequest {
|
|
46
|
+
customPayload?: Record<string, unknown>;
|
|
47
|
+
procedure: "query";
|
|
48
|
+
query: Query<unknown>;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Creates a Studio BFF client. BFF stands for "Backend For Frontend" btw.
|
|
52
|
+
*/
|
|
53
|
+
declare function createStudioBFFClient(props: StudioBFFClientProps): StudioBFFClient;
|
|
54
|
+
interface SerializedError {
|
|
55
|
+
message: string;
|
|
56
|
+
name: string;
|
|
57
|
+
errors?: SerializedError[];
|
|
58
|
+
}
|
|
59
|
+
declare function serializeError(error: unknown): SerializedError;
|
|
60
|
+
declare function deserializeError(error: SerializedError): Error;
|
|
61
|
+
|
|
62
|
+
export { type StudioBFFClient, type StudioBFFClientProps, type StudioBFFQueryRequest, createStudioBFFClient, deserializeError, serializeError };
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { Executor, ExecuteOptions } from '../index.js';
|
|
2
|
+
import { Q as Query, E as Either, a as QueryResult } from '../../query-C7LxjwdN.js';
|
|
3
|
+
import 'kysely';
|
|
4
|
+
|
|
5
|
+
interface StudioBFFClientProps {
|
|
6
|
+
/**
|
|
7
|
+
* Allows passing custom headers to the BFF.
|
|
8
|
+
*
|
|
9
|
+
* e.g. authorization token.
|
|
10
|
+
*/
|
|
11
|
+
customHeaders?: Record<string, string>;
|
|
12
|
+
/**
|
|
13
|
+
* Allows passing custom payload to the BFF via `body.customPayload`.
|
|
14
|
+
*
|
|
15
|
+
* e.g. tenant id.
|
|
16
|
+
*/
|
|
17
|
+
customPayload?: Record<string, unknown>;
|
|
18
|
+
/**
|
|
19
|
+
* Allows overriding the fetch function implementation.
|
|
20
|
+
*
|
|
21
|
+
* e.g. for testing, or older Node.js versions.
|
|
22
|
+
*/
|
|
23
|
+
fetch?: typeof globalThis.fetch;
|
|
24
|
+
/**
|
|
25
|
+
* Function used to deserialize the results of queries.
|
|
26
|
+
*
|
|
27
|
+
* By default, the results are returned as is without any additional processing.
|
|
28
|
+
*/
|
|
29
|
+
resultDeserializerFn?(this: void, results: unknown): unknown[];
|
|
30
|
+
/**
|
|
31
|
+
* BFF endpoint URL.
|
|
32
|
+
*
|
|
33
|
+
* e.g. `https://api.example.com/studio`
|
|
34
|
+
*/
|
|
35
|
+
url: string | URL;
|
|
36
|
+
}
|
|
37
|
+
interface StudioBFFClient extends Executor {
|
|
38
|
+
/**
|
|
39
|
+
* Requests BFF to query the database.
|
|
40
|
+
*
|
|
41
|
+
* The query is sent as `body.query`.
|
|
42
|
+
*/
|
|
43
|
+
execute<Q extends Query>(this: void, query: Q, options?: ExecuteOptions): Promise<Either<Error, QueryResult<Q>>>;
|
|
44
|
+
}
|
|
45
|
+
interface StudioBFFQueryRequest {
|
|
46
|
+
customPayload?: Record<string, unknown>;
|
|
47
|
+
procedure: "query";
|
|
48
|
+
query: Query<unknown>;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Creates a Studio BFF client. BFF stands for "Backend For Frontend" btw.
|
|
52
|
+
*/
|
|
53
|
+
declare function createStudioBFFClient(props: StudioBFFClientProps): StudioBFFClient;
|
|
54
|
+
interface SerializedError {
|
|
55
|
+
message: string;
|
|
56
|
+
name: string;
|
|
57
|
+
errors?: SerializedError[];
|
|
58
|
+
}
|
|
59
|
+
declare function serializeError(error: unknown): SerializedError;
|
|
60
|
+
declare function deserializeError(error: SerializedError): Error;
|
|
61
|
+
|
|
62
|
+
export { type StudioBFFClient, type StudioBFFClientProps, type StudioBFFQueryRequest, createStudioBFFClient, deserializeError, serializeError };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as ___react___ from 'react';
|
|
2
|
+
import * as ___react_dom___ from 'react-dom';
|
|
3
|
+
|
|
4
|
+
function require(mod) {
|
|
5
|
+
if (mod === 'react') return ___react___;
|
|
6
|
+
if (mod === 'react-dom') return ___react_dom___;
|
|
7
|
+
throw new Error(`Unknown module ${mod}`);
|
|
8
|
+
}
|
|
9
|
+
import{e as i}from"../../chunk-P5LRZ6C2.js";i();i();function f(e){let{customHeaders:r,customPayload:t,resultDeserializerFn:n,url:u}=e,s=e.fetch||fetch;return{async execute(m,p){try{let o=await s(u,{body:JSON.stringify({customPayload:t,procedure:"query",query:m}),headers:{Accept:"application/json","Content-Type":"application/json",...r},method:"POST",signal:p?.abortSignal});if(!o.ok){let a;try{a=await o.text()}catch{a="unknown error"}return[new Error(a)]}let[c,l]=await o.json();return c?[d(c)]:[null,n?.(l)||l]}catch(o){return[o]}}}}function y(e){if(e instanceof AggregateError){let{name:r,message:t}=e,n=e.errors.map(y);return{name:r,message:t,errors:n}}if(e instanceof Error){let{name:r,message:t}=e;return{name:r,message:t}}return{name:"UnknownError",message:JSON.stringify(e)}}function d(e){let{name:r,message:t}=e;if(e.errors!==void 0){let u=e.errors.map(d),s=new AggregateError(u,t);return s.name=e.name,s}let n=new Error(e.message);return e.name=r,n}export{f as createStudioBFFClient,d as deserializeError,y as serializeError};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vZGF0YS9iZmYvaW5kZXgudHMiLCAiLi4vLi4vLi4vZGF0YS9iZmYvYmZmLWNsaWVudC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiZXhwb3J0ICogZnJvbSBcIi4vYmZmLWNsaWVudFwiO1xuIiwgImltcG9ydCB0eXBlIHsgRXhlY3V0ZU9wdGlvbnMsIEV4ZWN1dG9yIH0gZnJvbSBcIi4uL2V4ZWN1dG9yXCI7XG5pbXBvcnQgdHlwZSB7IFF1ZXJ5LCBRdWVyeVJlc3VsdCB9IGZyb20gXCIuLi9xdWVyeVwiO1xuaW1wb3J0IHR5cGUgeyBFaXRoZXIgfSBmcm9tIFwiLi4vdHlwZS11dGlsc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFN0dWRpb0JGRkNsaWVudFByb3BzIHtcbiAgLyoqXG4gICAqIEFsbG93cyBwYXNzaW5nIGN1c3RvbSBoZWFkZXJzIHRvIHRoZSBCRkYuXG4gICAqXG4gICAqIGUuZy4gYXV0aG9yaXphdGlvbiB0b2tlbi5cbiAgICovXG4gIGN1c3RvbUhlYWRlcnM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+O1xuXG4gIC8qKlxuICAgKiBBbGxvd3MgcGFzc2luZyBjdXN0b20gcGF5bG9hZCB0byB0aGUgQkZGIHZpYSBgYm9keS5jdXN0b21QYXlsb2FkYC5cbiAgICpcbiAgICogZS5nLiB0ZW5hbnQgaWQuXG4gICAqL1xuICBjdXN0b21QYXlsb2FkPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG5cbiAgLyoqXG4gICAqIEFsbG93cyBvdmVycmlkaW5nIHRoZSBmZXRjaCBmdW5jdGlvbiBpbXBsZW1lbnRhdGlvbi5cbiAgICpcbiAgICogZS5nLiBmb3IgdGVzdGluZywgb3Igb2xkZXIgTm9kZS5qcyB2ZXJzaW9ucy5cbiAgICovXG4gIGZldGNoPzogdHlwZW9mIGdsb2JhbFRoaXMuZmV0Y2g7XG5cbiAgLyoqXG4gICAqIEZ1bmN0aW9uIHVzZWQgdG8gZGVzZXJpYWxpemUgdGhlIHJlc3VsdHMgb2YgcXVlcmllcy5cbiAgICpcbiAgICogQnkgZGVmYXVsdCwgdGhlIHJlc3VsdHMgYXJlIHJldHVybmVkIGFzIGlzIHdpdGhvdXQgYW55IGFkZGl0aW9uYWwgcHJvY2Vzc2luZy5cbiAgICovXG4gIHJlc3VsdERlc2VyaWFsaXplckZuPyh0aGlzOiB2b2lkLCByZXN1bHRzOiB1bmtub3duKTogdW5rbm93bltdO1xuXG4gIC8qKlxuICAgKiBCRkYgZW5kcG9pbnQgVVJMLlxuICAgKlxuICAgKiBlLmcuIGBodHRwczovL2FwaS5leGFtcGxlLmNvbS9zdHVkaW9gXG4gICAqL1xuICB1cmw6IHN0cmluZyB8IFVSTDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTdHVkaW9CRkZDbGllbnQgZXh0ZW5kcyBFeGVjdXRvciB7XG4gIC8qKlxuICAgKiBSZXF1ZXN0cyBCRkYgdG8gcXVlcnkgdGhlIGRhdGFiYXNlLlxuICAgKlxuICAgKiBUaGUgcXVlcnkgaXMgc2VudCBhcyBgYm9keS5xdWVyeWAuXG4gICAqL1xuICBleGVjdXRlPFEgZXh0ZW5kcyBRdWVyeT4odGhpczogdm9pZCwgcXVlcnk6IFEsIG9wdGlvbnM/OiBFeGVjdXRlT3B0aW9ucyk6IFByb21pc2U8RWl0aGVyPEVycm9yLCBRdWVyeVJlc3VsdDxRPj4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN0dWRpb0JGRlF1ZXJ5UmVxdWVzdCB7XG4gIGN1c3RvbVBheWxvYWQ/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgcHJvY2VkdXJlOiBcInF1ZXJ5XCI7XG4gIHF1ZXJ5OiBRdWVyeTx1bmtub3duPjtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgU3R1ZGlvIEJGRiBjbGllbnQuIEJGRiBzdGFuZHMgZm9yIFwiQmFja2VuZCBGb3IgRnJvbnRlbmRcIiBidHcuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTdHVkaW9CRkZDbGllbnQocHJvcHM6IFN0dWRpb0JGRkNsaWVudFByb3BzKTogU3R1ZGlvQkZGQ2xpZW50IHtcbiAgY29uc3QgeyBjdXN0b21IZWFkZXJzLCBjdXN0b21QYXlsb2FkLCByZXN1bHREZXNlcmlhbGl6ZXJGbiwgdXJsIH0gPSBwcm9wcztcbiAgY29uc3QgZmV0Y2hGbiA9IHByb3BzLmZldGNoIHx8IGZldGNoO1xuXG4gIHJldHVybiB7XG4gICAgYXN5bmMgZXhlY3V0ZTxRIGV4dGVuZHMgUXVlcnk+KHF1ZXJ5OiBRLCBvcHRpb25zPzogRXhlY3V0ZU9wdGlvbnMpOiBQcm9taXNlPEVpdGhlcjxFcnJvciwgUXVlcnlSZXN1bHQ8UT4+PiB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGZldGNoRm4odXJsLCB7XG4gICAgICAgICAgYm9keTogSlNPTi5zdHJpbmdpZnkoeyBjdXN0b21QYXlsb2FkLCBwcm9jZWR1cmU6IFwicXVlcnlcIiwgcXVlcnkgfSBzYXRpc2ZpZXMgU3R1ZGlvQkZGUXVlcnlSZXF1ZXN0KSxcbiAgICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgICBBY2NlcHQ6IFwiYXBwbGljYXRpb24vanNvblwiLFxuICAgICAgICAgICAgXCJDb250ZW50LVR5cGVcIjogXCJhcHBsaWNhdGlvbi9qc29uXCIsXG4gICAgICAgICAgICAuLi5jdXN0b21IZWFkZXJzLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgbWV0aG9kOiBcIlBPU1RcIixcbiAgICAgICAgICBzaWduYWw6IG9wdGlvbnM/LmFib3J0U2lnbmFsLFxuICAgICAgICB9KTtcblxuICAgICAgICBpZiAoIXJlc3BvbnNlLm9rKSB7XG4gICAgICAgICAgbGV0IGVycm9yVGV4dDogc3RyaW5nO1xuXG4gICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgIGVycm9yVGV4dCA9IGF3YWl0IHJlc3BvbnNlLnRleHQoKTtcbiAgICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAgIGVycm9yVGV4dCA9IFwidW5rbm93biBlcnJvclwiO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHJldHVybiBbbmV3IEVycm9yKGVycm9yVGV4dCldO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgW2Vycm9yLCByZXN1bHRzXSA9IChhd2FpdCByZXNwb25zZS5qc29uKCkpIGFzIFtTZXJpYWxpemVkRXJyb3IsIHVua25vd25dO1xuXG4gICAgICAgIGlmIChlcnJvcikge1xuICAgICAgICAgIHJldHVybiBbZGVzZXJpYWxpemVFcnJvcihlcnJvcildO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIFtudWxsLCAocmVzdWx0RGVzZXJpYWxpemVyRm4/LihyZXN1bHRzKSB8fCByZXN1bHRzKSBhcyBuZXZlcl07XG4gICAgICB9IGNhdGNoIChlcnJvcjogdW5rbm93bikge1xuICAgICAgICAvLyBUT0RPOiBoYW5kbGUgcHJvcGVybHlcbiAgICAgICAgcmV0dXJuIFtlcnJvciBhcyBFcnJvcl07XG4gICAgICB9XG4gICAgfSxcbiAgfTtcbn1cblxuaW50ZXJmYWNlIFNlcmlhbGl6ZWRFcnJvciB7XG4gIG1lc3NhZ2U6IHN0cmluZztcbiAgbmFtZTogc3RyaW5nO1xuICBlcnJvcnM/OiBTZXJpYWxpemVkRXJyb3JbXTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNlcmlhbGl6ZUVycm9yKGVycm9yOiB1bmtub3duKTogU2VyaWFsaXplZEVycm9yIHtcbiAgaWYgKGVycm9yIGluc3RhbmNlb2YgQWdncmVnYXRlRXJyb3IpIHtcbiAgICBjb25zdCB7IG5hbWUsIG1lc3NhZ2UgfSA9IGVycm9yO1xuICAgIGNvbnN0IGVycm9ycyA9IGVycm9yLmVycm9ycy5tYXAoc2VyaWFsaXplRXJyb3IpO1xuICAgIHJldHVybiB7IG5hbWUsIG1lc3NhZ2UsIGVycm9ycyB9O1xuICB9XG5cbiAgaWYgKGVycm9yIGluc3RhbmNlb2YgRXJyb3IpIHtcbiAgICBjb25zdCB7IG5hbWUsIG1lc3NhZ2UgfSA9IGVycm9yO1xuICAgIHJldHVybiB7IG5hbWUsIG1lc3NhZ2UgfTtcbiAgfVxuXG4gIHJldHVybiB7IG5hbWU6IGBVbmtub3duRXJyb3JgLCBtZXNzYWdlOiBKU09OLnN0cmluZ2lmeShlcnJvcikgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRlc2VyaWFsaXplRXJyb3IoZXJyb3I6IFNlcmlhbGl6ZWRFcnJvcik6IEVycm9yIHtcbiAgY29uc3QgeyBuYW1lLCBtZXNzYWdlIH0gPSBlcnJvcjtcblxuICBpZiAoZXJyb3IuZXJyb3JzICE9PSB1bmRlZmluZWQpIHtcbiAgICBjb25zdCBlcnJvcnMgPSBlcnJvci5lcnJvcnMubWFwKGRlc2VyaWFsaXplRXJyb3IpO1xuICAgIGNvbnN0IGFnZ3JlZ2F0ZUVycm9yID0gbmV3IEFnZ3JlZ2F0ZUVycm9yKGVycm9ycywgbWVzc2FnZSk7XG4gICAgYWdncmVnYXRlRXJyb3IubmFtZSA9IGVycm9yLm5hbWU7XG4gICAgcmV0dXJuIGFnZ3JlZ2F0ZUVycm9yO1xuICB9XG5cbiAgY29uc3QgcmVndWxhckVycm9yID0gbmV3IEVycm9yKGVycm9yLm1lc3NhZ2UpO1xuICBlcnJvci5uYW1lID0gbmFtZTtcbiAgcmV0dXJuIHJlZ3VsYXJFcnJvcjtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7OzRDQUFBQSxJQ0FBQyxJQTJETyxTQUFTQyxFQUFzQkMsRUFBOEMsQ0FDbEYsR0FBTSxDQUFFLGNBQUFDLEVBQWUsY0FBQUMsRUFBZSxxQkFBQUMsRUFBc0IsSUFBQUMsQ0FBSSxFQUFJSixFQUM5REssRUFBVUwsRUFBTSxPQUFTLE1BRS9CLE1BQU8sQ0FDTCxNQUFNLFFBQXlCTSxFQUFVQyxFQUFrRSxDQUN6RyxHQUFJLENBQ0YsSUFBTUMsRUFBVyxNQUFNSCxFQUFRRCxFQUFLLENBQ2xDLEtBQU0sS0FBSyxVQUFVLENBQUUsY0FBQUYsRUFBZSxVQUFXLFFBQVMsTUFBQUksQ0FBTSxDQUFpQyxFQUNqRyxRQUFTLENBQ1AsT0FBUSxtQkFDUixlQUFnQixtQkFDaEIsR0FBR0wsQ0FDTCxFQUNBLE9BQVEsT0FDUixPQUFRTSxHQUFTLFdBQ25CLENBQUMsRUFFRCxHQUFJLENBQUNDLEVBQVMsR0FBSSxDQUNoQixJQUFJQyxFQUVKLEdBQUksQ0FDRkEsRUFBWSxNQUFNRCxFQUFTLEtBQUssQ0FDbEMsTUFBUSxDQUNOQyxFQUFZLGVBQ2QsQ0FFQSxNQUFPLENBQUMsSUFBSSxNQUFNQSxDQUFTLENBQUMsQ0FDOUIsQ0FFQSxHQUFNLENBQUNDLEVBQU9DLENBQU8sRUFBSyxNQUFNSCxFQUFTLEtBQUssRUFFOUMsT0FBSUUsRUFDSyxDQUFDRSxFQUFpQkYsQ0FBSyxDQUFDLEVBRzFCLENBQUMsS0FBT1AsSUFBdUJRLENBQU8sR0FBS0EsQ0FBaUIsQ0FDckUsT0FBU0QsRUFBZ0IsQ0FFdkIsTUFBTyxDQUFDQSxDQUFjLENBQ3hCLENBQ0YsQ0FDRixDQUNGLENBUU8sU0FBU0csRUFBZUgsRUFBaUMsQ0FDOUQsR0FBSUEsYUFBaUIsZUFBZ0IsQ0FDbkMsR0FBTSxDQUFFLEtBQUFJLEVBQU0sUUFBQUMsQ0FBUSxFQUFJTCxFQUNwQk0sRUFBU04sRUFBTSxPQUFPLElBQUlHLENBQWMsRUFDOUMsTUFBTyxDQUFFLEtBQUFDLEVBQU0sUUFBQUMsRUFBUyxPQUFBQyxDQUFPLENBQ2pDLENBRUEsR0FBSU4sYUFBaUIsTUFBTyxDQUMxQixHQUFNLENBQUUsS0FBQUksRUFBTSxRQUFBQyxDQUFRLEVBQUlMLEVBQzFCLE1BQU8sQ0FBRSxLQUFBSSxFQUFNLFFBQUFDLENBQVEsQ0FDekIsQ0FFQSxNQUFPLENBQUUsS0FBTSxlQUFnQixRQUFTLEtBQUssVUFBVUwsQ0FBSyxDQUFFLENBQ2hFLENBRU8sU0FBU0UsRUFBaUJGLEVBQStCLENBQzlELEdBQU0sQ0FBRSxLQUFBSSxFQUFNLFFBQUFDLENBQVEsRUFBSUwsRUFFMUIsR0FBSUEsRUFBTSxTQUFXLE9BQVcsQ0FDOUIsSUFBTU0sRUFBU04sRUFBTSxPQUFPLElBQUlFLENBQWdCLEVBQzFDSyxFQUFpQixJQUFJLGVBQWVELEVBQVFELENBQU8sRUFDekQsT0FBQUUsRUFBZSxLQUFPUCxFQUFNLEtBQ3JCTyxDQUNULENBRUEsSUFBTUMsRUFBZSxJQUFJLE1BQU1SLEVBQU0sT0FBTyxFQUM1QyxPQUFBQSxFQUFNLEtBQU9JLEVBQ05JLENBQ1QiLAogICJuYW1lcyI6IFsiaW5pdF9kZWZpbmVfQUNDRUxFUkFURV9TQ0hFTUFfQllfUFJPVklERVIiLCAiaW5pdF9kZWZpbmVfQUNDRUxFUkFURV9TQ0hFTUFfQllfUFJPVklERVIiLCAiY3JlYXRlU3R1ZGlvQkZGQ2xpZW50IiwgInByb3BzIiwgImN1c3RvbUhlYWRlcnMiLCAiY3VzdG9tUGF5bG9hZCIsICJyZXN1bHREZXNlcmlhbGl6ZXJGbiIsICJ1cmwiLCAiZmV0Y2hGbiIsICJxdWVyeSIsICJvcHRpb25zIiwgInJlc3BvbnNlIiwgImVycm9yVGV4dCIsICJlcnJvciIsICJyZXN1bHRzIiwgImRlc2VyaWFsaXplRXJyb3IiLCAic2VyaWFsaXplRXJyb3IiLCAibmFtZSIsICJtZXNzYWdlIiwgImVycm9ycyIsICJhZ2dyZWdhdGVFcnJvciIsICJyZWd1bGFyRXJyb3IiXQp9Cg==
|