@sqrzro/server 4.0.0-alpha.3 → 4.0.0-alpha.31
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-BA3BC4CD.js +2 -0
- package/dist/chunk-BA3BC4CD.js.map +1 -0
- package/dist/chunk-UCMLSO7F.js +3 -0
- package/dist/chunk-UCMLSO7F.js.map +1 -0
- package/dist/csv/index.d.ts +7 -0
- package/dist/csv/index.js +2 -0
- package/dist/csv/index.js.map +1 -0
- package/dist/database/index.d.ts +57 -36
- package/dist/database/index.js +1 -1
- package/dist/database/index.js.map +1 -1
- package/dist/forms/index.d.ts +33 -4
- package/dist/forms/index.js +1 -1
- package/dist/forms/index.js.map +1 -1
- package/dist/{interfaces-BheedaEI.d.ts → interfaces-DTUqy5Oj.d.ts} +4 -3
- package/dist/json/index.d.ts +3 -1
- package/dist/json/index.js +1 -1
- package/dist/json/index.js.map +1 -1
- package/dist/mail/index.d.ts +25 -0
- package/dist/mail/index.js +3 -0
- package/dist/mail/index.js.map +1 -0
- package/dist/proxy/index.d.ts +10 -0
- package/dist/proxy/index.js +2 -0
- package/dist/proxy/index.js.map +1 -0
- package/dist/storage/index.d.ts +32 -0
- package/dist/storage/index.js +2 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/utility/index.d.ts +8 -5
- package/dist/utility/index.js +1 -1
- package/dist/utility/index.js.map +1 -1
- package/package.json +27 -32
- package/dist/auth/index.d.ts +0 -49
- package/dist/auth/index.js +0 -2
- package/dist/auth/index.js.map +0 -1
- package/dist/auth/utility/schema.d.ts +0 -348
- package/dist/auth/utility/schema.js +0 -2
- package/dist/auth/utility/schema.js.map +0 -1
- package/dist/chunk-37TYQL5Y.js +0 -2
- package/dist/chunk-37TYQL5Y.js.map +0 -1
- package/dist/chunk-AGS5PPG2.js +0 -2
- package/dist/chunk-AGS5PPG2.js.map +0 -1
- package/dist/chunk-JI2U2EMD.js +0 -2
- package/dist/chunk-JI2U2EMD.js.map +0 -1
- package/dist/chunk-QE347FVL.js +0 -2
- package/dist/chunk-QE347FVL.js.map +0 -1
- package/dist/chunk-XSJ4OEIH.js +0 -2
- package/dist/chunk-XSJ4OEIH.js.map +0 -1
- package/dist/cli/index.d.ts +0 -1
- package/dist/cli/index.js +0 -3
- package/dist/cli/index.js.map +0 -1
- package/dist/cli/scripts/db-generate.ts +0 -31
- package/dist/cli/scripts/db-reset.ts +0 -56
- package/dist/cli/scripts/db-seed.ts +0 -32
- package/dist/cli/static/drizzle.config.js +0 -19
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {filterNull}from'@sqrzro/utility';function s(n,r){return Array.isArray(n)?filterNull(n.map(t=>s(t,r))):n?.startsWith(r)?n:null}var e=s;function g(n,r){let t=e(n,r);if(!t)throw new Error(`Could not ensure ID. '${n}' is not a valid ID with prefix '${r}'.`);return t}var T=g;function o(n,r){let t=r.match(/^([^\[]+)\[(\d+)\]$/);if(t){let[,i,u]=t;return Array.isArray(n[i])?n[i][Number(u)]:null}return Array.isArray(n[r])?n[r][0]:n[r]}async function d(n,r,t){if(!t)return null;let i=t instanceof Promise?await t:t,u=o(i,n);return e(u,r)}var D=d;export{e as a,T as b,D as c};//# sourceMappingURL=chunk-BA3BC4CD.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-BA3BC4CD.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/utility/guard-id.ts","../src/utility/ensure-id.ts","../src/utility/get-id-from-params.ts"],"names":["guardID","id","prefix","filterNull","item","guard_id_default","ensureID","guardedID","ensure_id_default","getParamsValue","params","key","match","field","index","getIDFromParams","awaitedParams","value","get_id_from_params_default"],"mappings":"yCAKA,SAASA,EACLC,CAAAA,CACAC,CAAAA,CACc,CACd,OAAI,KAAA,CAAM,OAAA,CAAQD,CAAE,CAAA,CACTE,WAAWF,CAAAA,CAAG,GAAA,CAAKG,CAAAA,EAASJ,CAAAA,CAAWI,CAAAA,CAAMF,CAAM,CAAC,CAAC,EAG3DD,CAAAA,EAAI,UAAA,CAAWC,CAAM,CAAA,CAInBD,EAHI,IAIf,CAEA,IAAOI,CAAAA,CAAQL,EClBf,SAASM,CAAAA,CAA2BL,CAAAA,CAA+BC,CAAAA,CAAmB,CAClF,IAAMK,CAAAA,CAAYF,CAAAA,CAAWJ,EAAIC,CAAM,CAAA,CAEvC,GAAI,CAACK,CAAAA,CACD,MAAM,IAAI,KAAA,CAAM,yBAAyBN,CAAE,CAAA,iCAAA,EAAoCC,CAAM,CAAA,EAAA,CAAI,CAAA,CAG7F,OAAOK,CACX,KAEOC,CAAAA,CAAQF,ECVf,SAASG,CAAAA,CAAeC,EAA2CC,CAAAA,CAA4B,CAC3F,IAAMC,CAAAA,CAAQD,EAAI,KAAA,CAAM,qBAAqB,CAAA,CAE7C,GAAIC,CAAAA,CAAO,CACP,GAAM,EAAGC,CAAAA,CAAOC,CAAK,CAAA,CAAIF,CAAAA,CACzB,OAAO,KAAA,CAAM,OAAA,CAAQF,CAAAA,CAAOG,CAAK,CAAC,CAAA,CAAIH,CAAAA,CAAOG,CAAK,CAAA,CAAE,MAAA,CAAOC,CAAK,CAAC,EAAI,IACzE,CAEA,OAAO,KAAA,CAAM,QAAQJ,CAAAA,CAAOC,CAAG,CAAC,CAAA,CAAID,EAAOC,CAAG,CAAA,CAAE,CAAC,CAAA,CAAID,CAAAA,CAAOC,CAAG,CACnE,CAEA,eAAeI,CAAAA,CACXJ,CAAAA,CACAT,CAAAA,CACAQ,CAAAA,CACiB,CACjB,GAAI,CAACA,CAAAA,CACD,OAAO,KAGX,IAAMM,CAAAA,CAAgBN,CAAAA,YAAkB,OAAA,CAAU,MAAMA,CAAAA,CAASA,CAAAA,CAC3DO,CAAAA,CAAQR,EAAeO,CAAAA,CAAeL,CAAG,CAAA,CAE/C,OAAON,EAAWY,CAAAA,CAAOf,CAAM,CACnC,KAEOgB,CAAAA,CAAQH","file":"chunk-BA3BC4CD.js","sourcesContent":["import { filterNull } from '@sqrzro/utility';\n\nfunction guardID<T extends string>(id: (string | null | undefined)[], prefix: string): T[];\nfunction guardID<T extends string>(id: string | null | undefined, prefix: string): T | null;\n\nfunction guardID<T extends string>(\n id: (string | null | undefined)[] | string | null | undefined,\n prefix: string\n): T[] | T | null {\n if (Array.isArray(id)) {\n return filterNull(id.map((item) => guardID<T>(item, prefix)));\n }\n\n if (!id?.startsWith(prefix)) {\n return null;\n }\n\n return id as T;\n}\n\nexport default guardID;\n","import guardID from './guard-id';\n\nfunction ensureID<T extends string>(id: string | null | undefined, prefix: string): T {\n const guardedID = guardID<T>(id, prefix);\n\n if (!guardedID) {\n throw new Error(`Could not ensure ID. '${id}' is not a valid ID with prefix '${prefix}'.`);\n }\n\n return guardedID;\n}\n\nexport default ensureID;\n","import guardID from './guard-id';\n\nfunction getParamsValue(params: Record<string, string[] | string>, key: string): string | null {\n const match = key.match(/^([^\\[]+)\\[(\\d+)\\]$/);\n\n if (match) {\n const [, field, index] = match;\n return Array.isArray(params[field]) ? params[field][Number(index)] : null;\n }\n\n return Array.isArray(params[key]) ? params[key][0] : params[key];\n}\n\nasync function getIDFromParams<T extends string>(\n key: string,\n prefix: string,\n params?: Promise<Record<string, string[] | string>> | Record<string, string[] | string> | null\n): Promise<T | null> {\n if (!params) {\n return null;\n }\n\n const awaitedParams = params instanceof Promise ? await params : params;\n const value = getParamsValue(awaitedParams, key);\n\n return guardID<T>(value, prefix);\n}\n\nexport default getIDFromParams;\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {parse}from'csv/sync';function p(s){let t=[],n=s.split(`
|
|
2
|
+
`).filter(r=>r.trim()!=="");for(let r of n){let i=parse(r,{skip_empty_lines:true});t.push(i[0].map(e=>e.trim()));}return t}var f=p;export{f as a};//# sourceMappingURL=chunk-UCMLSO7F.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-UCMLSO7F.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/csv/parse-csv.ts"],"names":["parseCSV","csv","records","lines","item","line","record","parse","parse_csv_default"],"mappings":"6BAEA,SAASA,CAAAA,CAASC,CAAAA,CAAyB,CACvC,IAAMC,CAAAA,CAAsB,EAAC,CACvBC,CAAAA,CAAQF,EAAI,KAAA,CAAM;AAAA,CAAI,EAAE,MAAA,CAAQG,CAAAA,EAASA,CAAAA,CAAK,IAAA,KAAW,EAAE,CAAA,CAEjE,IAAA,IAAWC,CAAAA,IAAQF,EAAO,CACtB,IAAMG,EAASC,KAAAA,CAAMF,CAAAA,CAAM,CACvB,gBAAA,CAAkB,IACtB,CAAC,CAAA,CAEDH,EAAQ,IAAA,CAAKI,CAAAA,CAAO,CAAC,CAAA,CAAE,IAAKF,CAAAA,EAASA,CAAAA,CAAK,IAAA,EAAM,CAAC,EACrD,CAEA,OAAOF,CACX,KAEOM,CAAAA,CAAQR","file":"chunk-UCMLSO7F.js","sourcesContent":["import { parse } from 'csv/sync';\n\nfunction parseCSV(csv: string): string[][] {\n const records: string[][] = [];\n const lines = csv.split('\\n').filter((item) => item.trim() !== '');\n\n for (const line of lines) {\n const record = parse(line, {\n skip_empty_lines: true,\n }) as string[][];\n\n records.push(record[0].map((item) => item.trim()));\n }\n\n return records;\n}\n\nexport default parseCSV;\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export{a as parseCSV}from'../chunk-UCMLSO7F.js';import {stringify}from'csv/sync';function n(e){return stringify(e)}var t=n;function a(e){return new Blob([t(e)],{type:"text/csv"})}var f=a;export{t as generateCSV,f as generateCSVBlob};//# sourceMappingURL=index.js.map
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/csv/generate-csv.ts","../../src/csv/generate-csv-blob.ts"],"names":["generateCSV","data","stringify","generate_csv_default","generateCSVBlob","generate_csv_blob_default"],"mappings":"iFAEA,SAASA,EAAYC,CAAAA,CAA0B,CAC3C,OAAOC,SAAAA,CAAUD,CAAI,CACzB,CAEA,IAAOE,CAAAA,CAAQH,ECJf,SAASI,CAAAA,CAAgBH,CAAAA,CAAwB,CAC7C,OAAO,IAAI,IAAA,CAAK,CAACE,EAAYF,CAAI,CAAC,CAAA,CAAG,CAAE,KAAM,UAAW,CAAC,CAC7D,KAEOI,CAAAA,CAAQD","file":"index.js","sourcesContent":["import { stringify } from 'csv/sync';\n\nfunction generateCSV(data: string[][]): string {\n return stringify(data);\n}\n\nexport default generateCSV;\n","import generateCSV from './generate-csv';\n\nfunction generateCSVBlob(data: string[][]): Blob {\n return new Blob([generateCSV(data)], { type: 'text/csv' });\n}\n\nexport default generateCSVBlob;\n"]}
|
package/dist/database/index.d.ts
CHANGED
|
@@ -1,50 +1,71 @@
|
|
|
1
1
|
import { SQL } from 'drizzle-orm';
|
|
2
2
|
import { PgColumn } from 'drizzle-orm/pg-core';
|
|
3
|
-
import { P as Paginated } from '../interfaces-
|
|
3
|
+
import { P as Paginated } from '../interfaces-DTUqy5Oj.js';
|
|
4
4
|
|
|
5
|
+
type QueryConditions = SQL[];
|
|
6
|
+
type UnwrapColumnType<T> = T extends PgColumn<infer C, any, any> ? C['data'] : never;
|
|
7
|
+
type UnwrapInsert<TConfig> = TConfig extends {
|
|
8
|
+
makeInsertMutation: (values: infer Data) => Promise<infer Model>;
|
|
9
|
+
} ? {
|
|
10
|
+
data: Data;
|
|
11
|
+
model: Model;
|
|
12
|
+
} : never;
|
|
13
|
+
type UnwrapFilters<TConfig extends RepositoryConfig> = TConfig['applyFilters'] extends (filters: infer TFilters) => any ? TFilters : never;
|
|
14
|
+
type UnwrapGuards<TConfig extends RepositoryConfig> = TConfig['applyGuards'] extends (guards: infer TGuards) => any ? TGuards : never;
|
|
15
|
+
type UnwrapID<TConfig extends RepositoryConfig> = TConfig extends {
|
|
16
|
+
indexes: {
|
|
17
|
+
id: infer IDColumn;
|
|
18
|
+
};
|
|
19
|
+
} ? UnwrapColumnType<IDColumn> : never;
|
|
20
|
+
type UnwrapModel<TConfig extends RepositoryConfig> = TConfig['makeQuery'] extends (...args: any) => Promise<(infer U)[]> ? U : never;
|
|
21
|
+
type UnwrapUpdate<TConfig> = TConfig extends {
|
|
22
|
+
makeUpdateMutation: (values: infer Data) => Promise<infer Model>;
|
|
23
|
+
} ? {
|
|
24
|
+
data: Data;
|
|
25
|
+
model: Model;
|
|
26
|
+
} : never;
|
|
5
27
|
interface QueryConfig {
|
|
6
28
|
limit: number;
|
|
7
29
|
offset: number;
|
|
8
30
|
}
|
|
9
|
-
interface SelectFunctionConfig<
|
|
10
|
-
filters?:
|
|
11
|
-
guards?:
|
|
31
|
+
interface SelectFunctionConfig<TFilters, TGuards> extends Partial<QueryConfig> {
|
|
32
|
+
filters?: TFilters;
|
|
33
|
+
guards?: TGuards;
|
|
12
34
|
}
|
|
13
|
-
interface
|
|
35
|
+
interface PaginatedFunctionConfig<TFilters, TGuards> extends SelectFunctionConfig<TFilters, TGuards> {
|
|
14
36
|
page?: number | null;
|
|
15
37
|
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
makeMetaQuery?: (conditions: SQL[]) => Promise<{
|
|
27
|
-
count: number;
|
|
28
|
-
}>;
|
|
29
|
-
makeQuery?: (conditions: SQL[], config: QueryConfig) => Promise<Model[]>;
|
|
30
|
-
makeUpdateMutation?: (values: Partial<Data> & {
|
|
31
|
-
id: ID;
|
|
32
|
-
}) => Promise<Model>;
|
|
38
|
+
type RepositoryConfig<TIndexes extends Record<string, PgColumn<any>> = Record<string, PgColumn<any>>, TFilters = never, TGuards = never> = {
|
|
39
|
+
indexes?: TIndexes;
|
|
40
|
+
makeCountQuery?: (conditions: QueryConditions) => Promise<number>;
|
|
41
|
+
makeDeleteMutation?: (id: any) => Promise<void>;
|
|
42
|
+
makeInsertMutation?: (values: any) => Promise<any>;
|
|
43
|
+
makeQuery?: (conditions: QueryConditions, config: QueryConfig) => Promise<any[]>;
|
|
44
|
+
makeUndeleteMutation?: (id: any) => Promise<void>;
|
|
45
|
+
makeUpdateMutation?: (values: any) => Promise<any>;
|
|
46
|
+
applyFilters?: (filters: TFilters) => Promise<QueryConditions>;
|
|
47
|
+
applyGuards?: (guards: TGuards) => Promise<QueryConditions>;
|
|
33
48
|
paramKey?: string;
|
|
34
49
|
prefix?: string;
|
|
35
|
-
}
|
|
36
|
-
interface RepositoryObject<ID, Model, Filters = null, Guards = null, Data = {}> {
|
|
37
|
-
create: (data: Data) => Promise<Model>;
|
|
38
|
-
getAll: (config?: SelectFunctionConfig<Filters, Guards>) => Promise<Model[]>;
|
|
39
|
-
getByID: (id: ID, config?: SelectFunctionConfig<Filters, Guards>) => Promise<Model | null>;
|
|
40
|
-
getFromParams: (params?: Promise<Record<string, string>> | null) => Promise<Model>;
|
|
41
|
-
getFromSession: () => Promise<Model>;
|
|
42
|
-
getPaginated: (config?: PaginatedSelectFunctionConfig<Filters, Guards>) => Promise<Paginated<Model>>;
|
|
43
|
-
update: (data: Partial<Data> & {
|
|
44
|
-
id: ID;
|
|
45
|
-
}) => Promise<Model>;
|
|
46
|
-
}
|
|
50
|
+
};
|
|
47
51
|
|
|
48
|
-
declare function createRepository<
|
|
52
|
+
declare function createRepository<TConfig extends RepositoryConfig<TIndexes, any, any>, TIndexes extends Record<string, PgColumn<any>> = Record<string, PgColumn<any>>>(config: TConfig): {
|
|
53
|
+
create: (data: UnwrapInsert<TConfig>["data"]) => Promise<UnwrapInsert<TConfig>["model"]>;
|
|
54
|
+
delete: (id: UnwrapID<TConfig>) => Promise<void>;
|
|
55
|
+
ensureByID: (id: UnwrapID<TConfig>) => Promise<UnwrapModel<TConfig>>;
|
|
56
|
+
ensureByIndex: <K extends keyof TIndexes>(key: K, value: UnwrapColumnType<TIndexes[K]>, fnConfig?: SelectFunctionConfig<UnwrapFilters<TConfig>, UnwrapGuards<TConfig>> | undefined) => Promise<UnwrapModel<TConfig>>;
|
|
57
|
+
ensureFromParams: (params?: Promise<Record<string, string>> | Record<string, string> | null) => Promise<UnwrapModel<TConfig>>;
|
|
58
|
+
ensureID: (id: string | null | undefined) => UnwrapID<TConfig>;
|
|
59
|
+
ensureIDFromParams: (params?: Promise<Record<string, string>> | Record<string, string> | null) => Promise<UnwrapID<TConfig>>;
|
|
60
|
+
getAll: (fnConfig?: SelectFunctionConfig<UnwrapFilters<TConfig>, UnwrapGuards<TConfig>>) => Promise<UnwrapModel<TConfig>[]>;
|
|
61
|
+
getByID: (id: UnwrapID<TConfig>) => Promise<UnwrapModel<TConfig> | null>;
|
|
62
|
+
getByIndex: <K extends keyof TIndexes>(key: K, value: UnwrapColumnType<TIndexes[K]>, fnConfig?: SelectFunctionConfig<UnwrapFilters<TConfig>, UnwrapGuards<TConfig>>) => Promise<UnwrapModel<TConfig> | null>;
|
|
63
|
+
getFromParams: (params?: Promise<Record<string, string>> | Record<string, string> | null) => Promise<UnwrapModel<TConfig> | null>;
|
|
64
|
+
getIDFromParams: (params?: Promise<Record<string, string>> | Record<string, string> | null) => Promise<UnwrapID<TConfig> | null>;
|
|
65
|
+
getPaginated: (fnConfig?: PaginatedFunctionConfig<UnwrapFilters<TConfig>, UnwrapGuards<TConfig>>) => Promise<Paginated<UnwrapModel<TConfig>>>;
|
|
66
|
+
guardID: (id: (string | null | undefined)[] | string | null | undefined) => UnwrapID<TConfig> | UnwrapID<TConfig>[] | null;
|
|
67
|
+
undelete: (id: UnwrapID<TConfig>) => Promise<void>;
|
|
68
|
+
update: (data: UnwrapUpdate<TConfig>["data"]) => Promise<UnwrapUpdate<TConfig>["model"]>;
|
|
69
|
+
};
|
|
49
70
|
|
|
50
|
-
export { type QueryConfig, createRepository };
|
|
71
|
+
export { type PaginatedFunctionConfig, type QueryConditions, type QueryConfig, type RepositoryConfig, type SelectFunctionConfig, type UnwrapColumnType, type UnwrapFilters, type UnwrapGuards, type UnwrapID, type UnwrapInsert, type UnwrapModel, type UnwrapUpdate, createRepository };
|
package/dist/database/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import {a,b,c}from'../chunk-BA3BC4CD.js';import {eq}from'drizzle-orm';import {notFound}from'next/navigation';import {cache}from'react';async function B(r,d,u){let l=await c(r,d,u);return b(l,d)}var P=B;function o(r,d){for(let u of d)if(r[u]===void 0||r[u]===null)throw new Error(`Repository config is missing required field: "${String(u)}"`);return r}function G(r){function d(n){let{prefix:e}=o(r,["prefix"]);return Array.isArray(n)?a(n,e):a(n,e)}function u(n){let{prefix:e}=o(r,["prefix"]);return b(n,e)}async function l(n){let{paramKey:e,prefix:t}=o(r,["paramKey","prefix"]);return c(e,t,n)}async function w(n){let{paramKey:e,prefix:t}=o(r,["paramKey","prefix"]);try{return await P(e,t,n)}catch{notFound();}}async function D(n){let{makeQuery:e}=o(r,["makeQuery"]),t=[],i=await r.applyFilters?.(n?.filters??null);t.push(...i||[]);let a=await r.applyGuards?.(n?.guards??null);return t.push(...a||[]),e(t,{limit:n?.limit??-1,offset:n?.offset??0})}async function F(n){let{makeCountQuery:e,makeQuery:t}=o(r,["makeCountQuery","makeQuery"]),i=[],a=await r.applyFilters?.(n?.filters??null);i.push(...a||[]);let g=await r.applyGuards?.(n?.guards??null);i.push(...g||[]);let f=await e(i);return {data:await t(i,{limit:n?.limit??10,offset:((n?.page??1)-1)*(n?.limit??10)}),meta:{limit:n?.limit??10,page:n?.page??1,total:f}}}async function c$1(n,e,t){let{makeQuery:i}=o(r,["makeQuery"]);if(!r.indexes?.[n])throw new Error(`'Could not \`getByIndex\`. Index ${String(n)} is not defined in the repository configuration.`);let a=[],g=await r.applyFilters?.(t?.filters??null);a.push(...g||[]);let f=await r.applyGuards?.(t?.guards??null);a.push(...f||[]),a.push(eq(r.indexes[n],e));let[U]=await i(a,{limit:1,offset:0});return U??null}async function T(...n){let e=await c$1(...n);return e||notFound()}async function C(n){return c$1("id",n)}async function I(n){return T("id",n)}async function h(n){let e=await l(n);return e?C(e):null}async function k(n){let e=await w(n);return I(e)}async function R(n){let{makeInsertMutation:e}=o(r,["makeInsertMutation"]);return e(n)}async function K(n){let{makeUpdateMutation:e}=o(r,["makeUpdateMutation"]);return e(n)}async function M(n){let{makeDeleteMutation:e}=o(r,["makeDeleteMutation"]);return e(n)}async function Q(n){let{makeUndeleteMutation:e}=o(r,["makeUndeleteMutation"]);return e(n)}return {create:R,delete:M,ensureByID:cache(I),ensureByIndex:cache(T),ensureFromParams:cache(k),ensureID:u,ensureIDFromParams:w,getAll:cache(D),getByID:cache(C),getByIndex:cache(c$1),getFromParams:cache(h),getIDFromParams:l,getPaginated:cache(F),guardID:d,undelete:Q,update:K}}var S=G;export{S as createRepository};//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/database/create-repository.ts"],"names":["createRepository","repoConfig","uncached_getAll","config","conditions","filters","guards","uncached_getPaginated","meta","uncached_getByID","id","eq","results","uncached_getFromParams","params","get_id_from_params_default","result","notFound","uncached_getFromSession","user","ensure_session_user_default","ensure_id_default","create","data","values","generate_id_default","pick","update","args","cache","create_repository_default"],"mappings":"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","file":"index.js","sourcesContent":["import { cache } from 'react';\n\nimport { pick } from '@sqrzro/utility';\nimport { eq } from 'drizzle-orm';\nimport type { SQL } from 'drizzle-orm';\nimport { notFound } from 'next/navigation';\n\nimport ensureSessionUser from '../auth/users/ensure-session-user';\n\nimport ensureID from '../utility/ensure-id';\nimport generateID from '../utility/generate-id';\nimport getIDFromParams from '../utility/get-id-from-params';\nimport type { Paginated } from '../utility/interfaces';\n\nimport type {\n PaginatedSelectFunctionConfig,\n RepositoryConfig,\n RepositoryObject,\n SelectFunctionConfig,\n} from './utility/interfaces';\n\nexport function createRepository<\n ID extends string,\n Model,\n Filters = null,\n Guards = null,\n Data extends object = {},\n>(\n repoConfig: RepositoryConfig<ID, Model, Filters, Guards, Data>\n): RepositoryObject<ID, Model, Filters, Guards, Data> {\n async function uncached_getAll(\n config?: SelectFunctionConfig<Filters, Guards>\n ): Promise<Model[]> {\n if (!repoConfig.makeQuery) {\n throw new Error('Could not `getAll`. `makeQuery` function is not defined.');\n }\n\n const conditions: SQL[] = [];\n\n const filters = await repoConfig.applyFilters?.(config?.filters ?? null);\n conditions.push(...(filters || []));\n\n const guards = await repoConfig.applyGuards?.(config?.guards ?? null);\n conditions.push(...(guards || []));\n\n return repoConfig.makeQuery(conditions, {\n limit: config?.limit ?? -1,\n offset: config?.offset ?? 0,\n });\n }\n\n async function uncached_getPaginated(\n config?: PaginatedSelectFunctionConfig<Filters, Guards>\n ): Promise<Paginated<Model>> {\n if (!repoConfig.makeMetaQuery) {\n throw new Error('Could not `getPaginated`. `makeMetaQuery` function is not defined.');\n }\n\n if (!repoConfig.makeQuery) {\n throw new Error('Could not `getPaginated`. `makeQuery` function is not defined.');\n }\n\n const conditions: SQL[] = [];\n\n const filters = await repoConfig.applyFilters?.(config?.filters ?? null);\n conditions.push(...(filters || []));\n\n const guards = await repoConfig.applyGuards?.(config?.guards ?? null);\n conditions.push(...(guards || []));\n\n const meta = await repoConfig.makeMetaQuery(conditions);\n const data = await repoConfig.makeQuery(conditions, {\n limit: config?.limit ?? 10,\n offset: ((config?.page ?? 1) - 1) * (config?.limit ?? 10),\n });\n\n return {\n data,\n meta: { limit: config?.limit ?? 10, page: config?.page ?? 1, total: meta.count },\n };\n }\n\n async function uncached_getByID(\n id: ID,\n config?: SelectFunctionConfig<Filters, Guards>\n ): Promise<Model | null> {\n if (!repoConfig.idColumn) {\n throw new Error('Could not `getByID`. `idColumn` is not defined.');\n }\n\n if (!repoConfig.makeQuery) {\n throw new Error('Could not `getByID`. `makeQuery` function is not defined.');\n }\n\n const conditions: SQL[] = [];\n\n const guards = await repoConfig.applyGuards?.(config?.guards ?? null);\n conditions.push(...(guards || []));\n\n const filters = await repoConfig.applyFilters?.(config?.filters ?? null);\n conditions.push(...(filters || []));\n\n conditions.push(eq(repoConfig.idColumn, id));\n\n const [results] = await repoConfig.makeQuery(conditions, { limit: 1, offset: 0 });\n return results || null;\n }\n\n async function uncached_getFromParams(\n params?: Promise<Record<string, string>> | null\n ): Promise<Model> {\n if (!repoConfig.paramKey) {\n throw new Error('Could not `getFromParams`. `paramKey` is not defined.');\n }\n\n if (!repoConfig.prefix) {\n throw new Error('Could not `getFromParams`. `prefix` is not defined.');\n }\n\n const id = await getIDFromParams<ID>(repoConfig.paramKey, repoConfig.prefix, params);\n const result = await uncached_getByID(id);\n\n if (!result) {\n return notFound();\n }\n\n return result;\n }\n\n async function uncached_getFromSession(): Promise<Model> {\n if (!repoConfig.prefix) {\n throw new Error('Could not `getFromSession`. `prefix` is not defined.');\n }\n\n const user = await ensureSessionUser();\n const id = ensureID<ID>(user.id, repoConfig.prefix);\n const result = await uncached_getByID(id);\n\n if (!result) {\n throw new Error(`Could not \\`getFromSession\\`. No record with ID '${id}' found.`);\n }\n\n return result;\n }\n\n async function create(data: Data): Promise<Model> {\n if (!repoConfig.makeCreateMutation) {\n throw new Error('Could not `create`. `makeCreateMutation` is not defined.');\n }\n\n const values: Data & { id: ID } = {\n id: generateID<ID>(repoConfig.prefix),\n ...pick(data, repoConfig.fillable || []),\n };\n\n return repoConfig.makeCreateMutation(values);\n }\n\n async function update(data: Partial<Data> & { id: ID }): Promise<Model> {\n if (!repoConfig.makeUpdateMutation) {\n throw new Error('Could not `update`. `makeUpdateMutation` is not defined.');\n }\n\n return repoConfig.makeUpdateMutation(data);\n }\n\n return {\n create,\n getAll: (\n ...args: Parameters<typeof uncached_getAll>\n ): ReturnType<typeof uncached_getAll> => {\n return cache(uncached_getAll)(...args);\n },\n getByID: (\n ...args: Parameters<typeof uncached_getByID>\n ): ReturnType<typeof uncached_getByID> => {\n return cache(uncached_getByID)(...args);\n },\n getFromParams: (\n ...args: Parameters<typeof uncached_getFromParams>\n ): ReturnType<typeof uncached_getFromParams> => {\n return cache(uncached_getFromParams)(...args);\n },\n getFromSession: (\n ...args: Parameters<typeof uncached_getFromSession>\n ): ReturnType<typeof uncached_getFromSession> => {\n return cache(uncached_getFromSession)(...args);\n },\n getPaginated: (\n ...args: Parameters<typeof uncached_getPaginated>\n ): ReturnType<typeof uncached_getPaginated> => {\n return cache(uncached_getPaginated)(...args);\n },\n update,\n };\n}\n\nexport default createRepository;\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/utility/ensure-id-from-params.ts","../../src/database/create-repository.ts"],"names":["ensureIDFromParams","key","prefix","params","id","get_id_from_params_default","ensure_id_default","ensure_id_from_params_default","ensureConfig","config","keys","createRepository","guardID","guard_id_default","ensureID","getIDFromParams","paramKey","notFound","uncached_getAll","fnConfig","makeQuery","conditions","filters","guards","uncached_getPaginated","makeCountQuery","total","uncached_getByIndex","value","eq","result","uncached_ensureByIndex","args","uncached_getByID","uncached_ensureByID","uncached_getFromParams","uncached_ensureFromParams","create","data","makeInsertMutation","update","makeUpdateMutation","$delete","makeDeleteMutation","undelete","makeUndeleteMutation","cache","create_repository_default"],"mappings":"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","file":"index.js","sourcesContent":["import ensureID from './ensure-id';\nimport getIDFromParams from './get-id-from-params';\n\nasync function ensureIDFromParams<T extends string>(\n key: string,\n prefix: string,\n params?: Promise<Record<string, string>> | Record<string, string> | null\n): Promise<T> {\n const id = await getIDFromParams<T>(key, prefix, params);\n return ensureID<T>(id, prefix);\n}\n\nexport default ensureIDFromParams;\n","import { eq } from 'drizzle-orm';\nimport { PgColumn } from 'drizzle-orm/pg-core';\nimport { notFound } from 'next/navigation';\nimport { cache } from 'react';\n\nimport ensureIDFn from '../utility/ensure-id';\nimport ensureIDFromParamsFn from '../utility/ensure-id-from-params';\nimport getIDFromParamsFn from '../utility/get-id-from-params';\nimport guardIDFn from '../utility/guard-id';\nimport { Paginated } from '../utility/interfaces';\n\nimport {\n QueryConditions,\n PaginatedFunctionConfig,\n RepositoryConfig,\n SelectFunctionConfig,\n UnwrapColumnType,\n UnwrapFilters,\n UnwrapGuards,\n UnwrapID,\n UnwrapInsert,\n UnwrapModel,\n UnwrapUpdate,\n} from './interfaces';\n\nfunction ensureConfig<TConfig extends RepositoryConfig, TKeys extends keyof TConfig>(\n config: TConfig,\n keys: TKeys[]\n): { [K in TKeys]-?: NonNullable<TConfig[K]> } {\n for (const key of keys) {\n if (config[key] === undefined || config[key] === null) {\n throw new Error(`Repository config is missing required field: \"${String(key)}\"`);\n }\n }\n return config as unknown as { [K in TKeys]-?: NonNullable<TConfig[K]> };\n}\n\nfunction createRepository<\n TConfig extends RepositoryConfig<TIndexes, any, any>,\n TIndexes extends Record<string, PgColumn<any>> = Record<string, PgColumn<any>>,\n>(config: TConfig) {\n function guardID(\n id: (string | null | undefined)[] | string | null | undefined\n ): UnwrapID<TConfig> | UnwrapID<TConfig>[] | null {\n const { prefix } = ensureConfig(config, ['prefix']);\n\n if (Array.isArray(id)) {\n return guardIDFn<UnwrapID<TConfig>>(id, prefix);\n }\n\n return guardIDFn<UnwrapID<TConfig>>(id, prefix);\n }\n\n function ensureID(id: string | null | undefined): UnwrapID<TConfig> {\n const { prefix } = ensureConfig(config, ['prefix']);\n return ensureIDFn<UnwrapID<TConfig>>(id, prefix);\n }\n\n async function getIDFromParams(\n params?: Promise<Record<string, string>> | Record<string, string> | null\n ): Promise<UnwrapID<TConfig> | null> {\n const { paramKey, prefix } = ensureConfig(config, ['paramKey', 'prefix']);\n return getIDFromParamsFn<UnwrapID<TConfig>>(paramKey, prefix, params);\n }\n\n async function ensureIDFromParams(\n params?: Promise<Record<string, string>> | Record<string, string> | null\n ): Promise<UnwrapID<TConfig>> {\n const { paramKey, prefix } = ensureConfig(config, ['paramKey', 'prefix']);\n\n try {\n const id = await ensureIDFromParamsFn<UnwrapID<TConfig>>(paramKey, prefix, params);\n return id;\n } catch (err) {\n notFound();\n }\n }\n\n async function uncached_getAll(\n fnConfig?: SelectFunctionConfig<UnwrapFilters<TConfig>, UnwrapGuards<TConfig>>\n ): Promise<UnwrapModel<TConfig>[]> {\n const { makeQuery } = ensureConfig(config, ['makeQuery']);\n\n const conditions: QueryConditions = [];\n\n const filters = await config.applyFilters?.(fnConfig?.filters ?? null);\n conditions.push(...(filters || []));\n\n const guards = await config.applyGuards?.(fnConfig?.guards ?? null);\n conditions.push(...(guards || []));\n\n return makeQuery(conditions, {\n limit: fnConfig?.limit ?? -1,\n offset: fnConfig?.offset ?? 0,\n });\n }\n\n async function uncached_getPaginated(\n fnConfig?: PaginatedFunctionConfig<UnwrapFilters<TConfig>, UnwrapGuards<TConfig>>\n ): Promise<Paginated<UnwrapModel<TConfig>>> {\n const { makeCountQuery, makeQuery } = ensureConfig(config, ['makeCountQuery', 'makeQuery']);\n\n const conditions: QueryConditions = [];\n\n const filters = await config.applyFilters?.(fnConfig?.filters ?? null);\n conditions.push(...(filters || []));\n\n const guards = await config.applyGuards?.(fnConfig?.guards ?? null);\n conditions.push(...(guards || []));\n\n const total = await makeCountQuery(conditions);\n\n const data = await makeQuery(conditions, {\n limit: fnConfig?.limit ?? 10,\n offset: ((fnConfig?.page ?? 1) - 1) * (fnConfig?.limit ?? 10),\n });\n\n return {\n data,\n meta: { limit: fnConfig?.limit ?? 10, page: fnConfig?.page ?? 1, total },\n };\n }\n\n async function uncached_getByIndex<K extends keyof TIndexes>(\n key: K,\n value: UnwrapColumnType<TIndexes[K]>,\n fnConfig?: SelectFunctionConfig<UnwrapFilters<TConfig>, UnwrapGuards<TConfig>>\n ): Promise<UnwrapModel<TConfig> | null> {\n const { makeQuery } = ensureConfig(config, ['makeQuery']);\n\n if (!config.indexes?.[key]) {\n throw new Error(\n `'Could not \\`getByIndex\\`. Index ${String(key)} is not defined in the repository configuration.`\n );\n }\n\n const conditions: QueryConditions = [];\n\n const filters = await config.applyFilters?.(fnConfig?.filters ?? null);\n conditions.push(...(filters || []));\n\n const guards = await config.applyGuards?.(fnConfig?.guards ?? null);\n conditions.push(...(guards || []));\n\n conditions.push(eq(config.indexes[key], value));\n\n const [result] = await makeQuery(conditions, { limit: 1, offset: 0 });\n\n return result ?? null;\n }\n\n async function uncached_ensureByIndex<K extends keyof TIndexes>(\n ...args: Parameters<typeof uncached_getByIndex<K>>\n ): Promise<UnwrapModel<TConfig>> {\n const result = await uncached_getByIndex(...args);\n\n if (!result) {\n return notFound();\n }\n\n return result;\n }\n\n async function uncached_getByID(id: UnwrapID<TConfig>): Promise<UnwrapModel<TConfig> | null> {\n return uncached_getByIndex('id', id);\n }\n\n async function uncached_ensureByID(id: UnwrapID<TConfig>): Promise<UnwrapModel<TConfig>> {\n return uncached_ensureByIndex('id', id);\n }\n\n async function uncached_getFromParams(\n params?: Promise<Record<string, string>> | Record<string, string> | null\n ): Promise<UnwrapModel<TConfig> | null> {\n const id = await getIDFromParams(params);\n return id ? uncached_getByID(id) : null;\n }\n\n async function uncached_ensureFromParams(\n params?: Promise<Record<string, string>> | Record<string, string> | null\n ): Promise<UnwrapModel<TConfig>> {\n const id = await ensureIDFromParams(params);\n return uncached_ensureByID(id);\n }\n\n async function create(\n data: UnwrapInsert<TConfig>['data']\n ): Promise<UnwrapInsert<TConfig>['model']> {\n const { makeInsertMutation } = ensureConfig(config, ['makeInsertMutation']);\n return makeInsertMutation(data);\n }\n\n async function update(\n data: UnwrapUpdate<TConfig>['data']\n ): Promise<UnwrapUpdate<TConfig>['model']> {\n const { makeUpdateMutation } = ensureConfig(config, ['makeUpdateMutation']);\n return makeUpdateMutation(data);\n }\n\n async function $delete(id: UnwrapID<TConfig>): Promise<void> {\n const { makeDeleteMutation } = ensureConfig(config, ['makeDeleteMutation']);\n return makeDeleteMutation(id);\n }\n\n async function undelete(id: UnwrapID<TConfig>): Promise<void> {\n const { makeUndeleteMutation } = ensureConfig(config, ['makeUndeleteMutation']);\n return makeUndeleteMutation(id);\n }\n\n return {\n create,\n delete: $delete,\n ensureByID: cache(uncached_ensureByID),\n ensureByIndex: cache(uncached_ensureByIndex),\n ensureFromParams: cache(uncached_ensureFromParams),\n ensureID,\n ensureIDFromParams,\n getAll: cache(uncached_getAll),\n getByID: cache(uncached_getByID),\n getByIndex: cache(uncached_getByIndex),\n getFromParams: cache(uncached_getFromParams),\n getIDFromParams,\n getPaginated: cache(uncached_getPaginated),\n guardID,\n undelete,\n update,\n };\n}\n\nexport default createRepository;\n"]}
|
package/dist/forms/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { z } from 'zod';
|
|
1
|
+
import z$1, { z } from 'zod';
|
|
2
2
|
|
|
3
3
|
interface AwaitedFormResponse<M> {
|
|
4
4
|
data: M | null;
|
|
@@ -6,6 +6,19 @@ interface AwaitedFormResponse<M> {
|
|
|
6
6
|
validation: Record<string, string> | null;
|
|
7
7
|
}
|
|
8
8
|
type FormResponse<M> = Promise<AwaitedFormResponse<M>>;
|
|
9
|
+
type ValidationRule<V, T = undefined> = T extends undefined ? {
|
|
10
|
+
validator: V;
|
|
11
|
+
} : {
|
|
12
|
+
validator: V;
|
|
13
|
+
transformer: T;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
declare function createRule<V, T = undefined>(config: {
|
|
17
|
+
validator: V;
|
|
18
|
+
} | {
|
|
19
|
+
validator: V;
|
|
20
|
+
transformer: T;
|
|
21
|
+
}): ValidationRule<V, T>;
|
|
9
22
|
|
|
10
23
|
/**
|
|
11
24
|
* Custom error class to represent validation errors in form processing.
|
|
@@ -18,7 +31,7 @@ declare class ValidationError extends Error {
|
|
|
18
31
|
constructor(messages: Record<string, string>);
|
|
19
32
|
}
|
|
20
33
|
|
|
21
|
-
interface SubmitFormArgs<Schema extends z.
|
|
34
|
+
interface SubmitFormArgs<Schema extends z.ZodTypeAny, Response> {
|
|
22
35
|
fn: (data: z.infer<Schema>) => Promise<Response>;
|
|
23
36
|
formData: object;
|
|
24
37
|
onSuccess?: (model: Response) => Promise<void> | void;
|
|
@@ -31,6 +44,22 @@ interface SubmitFormArgs<Schema extends z.ZodType, Response> {
|
|
|
31
44
|
* @param args The arguments for submitting the form.
|
|
32
45
|
* @returns A promise that resolves to either the submitted model or an error.
|
|
33
46
|
*/
|
|
34
|
-
declare function submitForm<Schema extends z.
|
|
47
|
+
declare function submitForm<Schema extends z.ZodTypeAny, Response>(args: SubmitFormArgs<Schema, Response>): Promise<FormResponse<Response>>;
|
|
48
|
+
|
|
49
|
+
declare function validateSchema<T extends z.ZodTypeAny>(data: object, schema: T): Promise<z.infer<T>>;
|
|
50
|
+
|
|
51
|
+
declare function getCSVRule(): {
|
|
52
|
+
validator: z$1.ZodPipe<z$1.ZodString, z$1.ZodTransform<string[][], string>>;
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
declare function getExistsTransformer<T, ID>(key: string, value: ID, fn: (value: ID) => Promise<T>): Promise<NonNullable<T>>;
|
|
56
|
+
|
|
57
|
+
declare function getExistsValidator<T, ID>(fn: (value: ID) => Promise<T>): [(value: ID) => Promise<boolean>, {
|
|
58
|
+
message: string;
|
|
59
|
+
}];
|
|
60
|
+
|
|
61
|
+
declare function getNotExistsValidator<T, ID>(fn: (value: ID) => Promise<T>): [(value: ID) => Promise<boolean>, {
|
|
62
|
+
message: string;
|
|
63
|
+
}];
|
|
35
64
|
|
|
36
|
-
export { type FormResponse, submitForm };
|
|
65
|
+
export { type FormResponse, ValidationError, type ValidationRule, createRule, getCSVRule, getExistsTransformer, getExistsValidator, getNotExistsValidator, submitForm, validateSchema };
|
package/dist/forms/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {a as a$1}from'../chunk-
|
|
1
|
+
import {a as a$1}from'../chunk-UCMLSO7F.js';import {redirect}from'next/navigation';import v,{z as z$1}from'zod';function p(e){return e}var a=p;function R(e){let[,,t]=e.split(";");redirect(`${t.startsWith("/")?"":"/"}${t}`);}var u=R;var n=class extends Error{messages;constructor(t){super(JSON.stringify(t)),this.messages=t,this.name="ValidationError";}},s=n;function l(e){let t={};for(let r in e)typeof e[r]=="string"?t[r]=e[r].trim():typeof e[r]=="object"&&e[r]!==null?t[r]=l(e[r]):t[r]=e[r];return t}var f=l;function x(e){return e.issues.reduce((t,r)=>({...t,[r.path.join(".")]:r.message.replace(/"/gu,"")}),{})}var d=x;function T(e){return typeof e.input>"u"&&(e.code==="invalid_type"||e.code==="invalid_value")||!e.input&&(e.code==="invalid_format"||e.code==="too_small")}function y(e){return T(e)?{message:"REQUIRED"}:e.message?{message:e.message}:null}var c=y;async function I(e,t){try{return await t.parseAsync(f(e),{error:o=>c(o)})}catch(r){throw r instanceof z$1.ZodError?new s(d(r)):r}}var i=I;async function h(e){let t={data:null,error:null,validation:null};try{let r=await i(e.formData,e.schema),o=await e.fn(r);return await e.onSuccess?.(o),{...t,data:o}}catch(r){if(r instanceof s)return e.onValidationError?.(r),{...t,validation:r.messages};if(r instanceof Error)throw r.message==="NEXT_REDIRECT"&&"digest"in r&&u(String(r.digest)),r;return {...t,error:"submitForm encountered an unknown error"}}}var V=h;var D=v.string().transform(a$1);function w(){return a({validator:D})}var S=w;async function b(e,t,r){let o=await r(t);if(!o)throw new s({[e]:"NOT_FOUND"});return o}var Z=b;function F(e){return [async t=>!!await e(t),{message:"NOT_FOUND"}]}var z=F;function $(e){return [async t=>!await e(t),{message:"ALREADY_EXISTS"}]}var A=$;export{s as ValidationError,a as createRule,S as getCSVRule,Z as getExistsTransformer,z as getExistsValidator,A as getNotExistsValidator,V as submitForm,i as validateSchema};//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/forms/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/forms/utility/handle-redirect.ts","../../src/forms/utility/transform-errors.ts","../../src/forms/utility/validate-schema.ts","../../src/forms/submit-form.ts"],"names":["handleRedirect","digest","path","redirect","handle_redirect_default","transformErrors","error","acc","cur","transform_errors_default","validateSchema","data","schema","z","ValidationError_default","validate_schema_default","submitForm","args","response","model","submit_form_default"],"mappings":"uGAEA,SAASA,EAAeC,CAAAA,CAAsB,CAC1C,GAAM,GAAKC,CAAI,CAAA,CAAID,EAAO,KAAA,CAAM,GAAG,EACnCE,QAAAA,CAAS,CAAA,EAAGD,EAAK,UAAA,CAAW,GAAG,EAAI,EAAA,CAAK,GAAG,GAAGA,CAAI,CAAA,CAAE,EACxD,CAEA,IAAOE,EAAQJ,CAAAA,CCLf,SAASK,CAAAA,CAAgBC,CAAAA,CAA2C,CAChE,OAAOA,CAAAA,CAAM,OAAO,MAAA,CAChB,CAACC,EAAKC,CAAAA,IAAS,CACX,GAAGD,CAAAA,CACH,CAACC,EAAI,IAAA,CAAK,IAAA,CAAK,GAAG,CAAC,EAAGA,EAAI,OAAA,CAAQ,OAAA,CAAQ,MAAO,EAAE,CACvD,GACA,EACJ,CACJ,CAEA,IAAOC,EAAQJ,CAAAA,CCPf,eAAeK,EAAoCC,CAAAA,CAAcC,CAAAA,CAAgC,CAC7F,GAAI,CAEA,OADe,MAAMA,CAAAA,CAAO,WAAWD,CAAI,CAE/C,OAASL,CAAAA,CAAO,CACZ,MAAIA,CAAAA,YAAiBO,CAAAA,CAAE,QAAA,CACb,IAAIC,GAAAA,CAAgBL,CAAAA,CAAgBH,CAAK,CAAC,CAAA,CAE9CA,CACV,CACJ,CAEA,IAAOS,CAAAA,CAAQL,CAAAA,CCIf,eAAeM,CAAAA,CACXC,CAAAA,CAC+B,CAC/B,IAAIC,CAAAA,CAA0C,CAAE,IAAA,CAAM,IAAA,CAAM,MAAO,IAAA,CAAM,UAAA,CAAY,IAAK,CAAA,CAE1F,GAAI,CACA,IAAMP,CAAAA,CAAO,MAAMI,CAAAA,CAAeE,CAAAA,CAAK,SAAUA,CAAAA,CAAK,MAAM,EACtDE,CAAAA,CAAQ,MAAMF,EAAK,EAAA,CAAGN,CAAI,EAEhC,OAAA,MAAMM,CAAAA,CAAK,YAAYE,CAAK,CAAA,CAErB,CAAE,GAAGD,CAAAA,CAAU,KAAMC,CAAM,CACtC,OAASb,CAAAA,CAAO,CACZ,GAAIA,CAAAA,YAAiBQ,GAAAA,CACjB,OAAAG,CAAAA,CAAK,iBAAA,GAAoBX,CAAK,CAAA,CACvB,CAAE,GAAGY,CAAAA,CAAU,UAAA,CAAYZ,EAAM,QAAS,CAAA,CAErD,GAAIA,CAAAA,YAAiB,KAAA,CACjB,MAAIA,CAAAA,CAAM,OAAA,GAAY,iBAAmB,QAAA,GAAYA,CAAAA,EACjDF,EAAe,MAAA,CAAOE,CAAAA,CAAM,MAAM,CAAC,CAAA,CAEjCA,EAGV,OAAO,CAAE,GAAGY,CAAAA,CAAU,KAAA,CAAO,yCAA0C,CAC3E,CACJ,CAEA,IAAOE,CAAAA,CAAQJ","file":"index.js","sourcesContent":["import { redirect } from 'next/navigation';\n\nfunction handleRedirect(digest: string): void {\n const [, , path] = digest.split(';');\n redirect(`${path.startsWith('/') ? '' : '/'}${path}`);\n}\n\nexport default handleRedirect;\n","import { z } from 'zod';\n\nfunction transformErrors(error: z.ZodError): Record<string, string> {\n return error.issues.reduce(\n (acc, cur) => ({\n ...acc,\n [cur.path.join('.')]: cur.message.replace(/\"/gu, ''),\n }),\n {}\n );\n}\n\nexport default transformErrors;\n","import { z } from 'zod';\n\nimport ValidationError from './ValidationError';\nimport transformErrors from './transform-errors';\n\nasync function validateSchema<T extends z.ZodType>(data: object, schema: T): Promise<z.infer<T>> {\n try {\n const result = await schema.parseAsync(data);\n return result;\n } catch (error) {\n if (error instanceof z.ZodError) {\n throw new ValidationError(transformErrors(error));\n }\n throw error;\n }\n}\n\nexport default validateSchema;\n","import { z } from 'zod';\n\nimport handleRedirect from './utility/handle-redirect';\nimport type { AwaitedFormResponse, FormResponse } from './utility/interfaces';\nimport ValidationError from './utility/ValidationError';\nimport validateSchema from './utility/validate-schema';\n\ninterface SubmitFormArgs<Schema extends z.ZodType, Response> {\n fn: (data: z.infer<Schema>) => Promise<Response>;\n formData: object;\n onSuccess?: (model: Response) => Promise<void> | void;\n onValidationError?: (error: ValidationError) => void;\n schema: Schema;\n}\n\n/**\n * Submit a form and handle validation and submission errors.\n *\n * @param args The arguments for submitting the form.\n * @returns A promise that resolves to either the submitted model or an error.\n */\nasync function submitForm<Schema extends z.ZodType, Response>(\n args: SubmitFormArgs<Schema, Response>\n): Promise<FormResponse<Response>> {\n let response: AwaitedFormResponse<Response> = { data: null, error: null, validation: null };\n\n try {\n const data = await validateSchema(args.formData, args.schema);\n const model = await args.fn(data);\n\n await args.onSuccess?.(model);\n\n return { ...response, data: model };\n } catch (error) {\n if (error instanceof ValidationError) {\n args.onValidationError?.(error);\n return { ...response, validation: error.messages };\n }\n if (error instanceof Error) {\n if (error.message === 'NEXT_REDIRECT' && 'digest' in error) {\n handleRedirect(String(error.digest));\n }\n throw error;\n // return { ...response, error: error.message };\n }\n return { ...response, error: 'submitForm encountered an unknown error' };\n }\n}\n\nexport default submitForm;\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/forms/create-rule.ts","../../src/forms/utility/handle-redirect.ts","../../src/forms/ValidationError.ts","../../src/forms/utility/clean-data.ts","../../src/forms/utility/transform-errors.ts","../../src/forms/utility/transform-issue.ts","../../src/forms/validate-schema.ts","../../src/forms/submit-form.ts","../../src/forms/rules/get-csv-rule.ts","../../src/forms/transformers/get-exists-transformer.ts","../../src/forms/validators/get-exists-validator.ts","../../src/forms/validators/get-not-exists-validator.ts"],"names":["createRule","config","create_rule_default","handleRedirect","digest","path","redirect","handle_redirect_default","ValidationError","messages","ValidationError_default","cleanData","data","cleanedData","key","clean_data_default","transformErrors","error","acc","cur","transform_errors_default","isRequired","issue","transformIssue","transform_issue_default","validateSchema","schema","z","validate_schema_default","submitForm","args","response","model","submit_form_default","validator","parse_csv_default","getCSVRule","get_csv_rule_default","getExistsTransformer","value","fn","result","get_exists_transformer_default","getExistsValidator","get_exists_validator_default","getNotExistsValidator","get_not_exists_validator_default"],"mappings":"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","file":"index.js","sourcesContent":["import type { ValidationRule } from './utility/interfaces';\n\nfunction createRule<V, T = undefined>(\n config: { validator: V } | { validator: V; transformer: T }\n): ValidationRule<V, T> {\n return config as ValidationRule<V, T>;\n}\n\nexport default createRule;\n","import { redirect } from 'next/navigation';\n\nfunction handleRedirect(digest: string): void {\n const [, , path] = digest.split(';');\n redirect(`${path.startsWith('/') ? '' : '/'}${path}`);\n}\n\nexport default handleRedirect;\n","/**\n * Custom error class to represent validation errors in form processing.\n * \n * It extends the built-in Error class and includes a messages property\n * that holds a record of validation error messages.\n */\nclass ValidationError extends Error {\n public messages: Record<string, string>;\n\n public constructor(messages: Record<string, string>) {\n super(JSON.stringify(messages));\n\n this.messages = messages;\n this.name = 'ValidationError';\n }\n}\n\nexport default ValidationError;\n","function cleanData(data: object): object {\n const cleanedData: Record<string, unknown> = {};\n\n for (const key in data) {\n if (typeof data[key] === 'string') {\n cleanedData[key] = data[key].trim();\n } else if (typeof data[key] === 'object' && data[key] !== null) {\n cleanedData[key] = cleanData(data[key] as object);\n } else {\n cleanedData[key] = data[key];\n }\n }\n\n return cleanedData;\n}\n\nexport default cleanData;\n","import { z } from 'zod';\n\nfunction transformErrors(error: z.ZodError): Record<string, string> {\n return error.issues.reduce(\n (acc, cur) => ({\n ...acc,\n [cur.path.join('.')]: cur.message.replace(/\"/gu, ''),\n }),\n {}\n );\n}\n\nexport default transformErrors;\n","import type { $ZodIssue, $ZodIssueBase, $ZodRawIssue } from 'zod/v4/core';\n\nfunction isRequired<T extends $ZodIssueBase = $ZodIssue>(issue: $ZodRawIssue<T>): boolean {\n if (\n typeof issue.input === 'undefined' &&\n (issue.code === 'invalid_type' || issue.code === 'invalid_value')\n ) {\n return true;\n }\n\n if (!issue.input && (issue.code === 'invalid_format' || issue.code === 'too_small')) {\n return true;\n }\n\n return false;\n}\n\nfunction transformIssue<T extends $ZodIssueBase = $ZodIssue>(\n issue: $ZodRawIssue<T>\n): { message: string } | null {\n if (isRequired(issue)) {\n return { message: 'REQUIRED' };\n }\n\n return issue.message ? { message: issue.message } : null;\n}\n\nexport default transformIssue;\n","import { z } from 'zod';\n\nimport cleanData from './utility/clean-data';\nimport transformErrors from './utility/transform-errors';\nimport transformIssue from './utility/transform-issue';\n\nimport ValidationError from './ValidationError';\n\nasync function validateSchema<T extends z.ZodTypeAny>(\n data: object,\n schema: T\n): Promise<z.infer<T>> {\n try {\n const result = await schema.parseAsync(cleanData(data), {\n error: (issue) => transformIssue(issue),\n });\n return result;\n } catch (error) {\n if (error instanceof z.ZodError) {\n throw new ValidationError(transformErrors(error));\n }\n throw error;\n }\n}\n\nexport default validateSchema;\n","import { z } from 'zod';\n\nimport handleRedirect from './utility/handle-redirect';\nimport type { AwaitedFormResponse, FormResponse } from './utility/interfaces';\n\nimport ValidationError from './ValidationError';\nimport validateSchema from './validate-schema';\n\ninterface SubmitFormArgs<Schema extends z.ZodTypeAny, Response> {\n fn: (data: z.infer<Schema>) => Promise<Response>;\n formData: object;\n onSuccess?: (model: Response) => Promise<void> | void;\n onValidationError?: (error: ValidationError) => void;\n schema: Schema;\n}\n\n/**\n * Submit a form and handle validation and submission errors.\n *\n * @param args The arguments for submitting the form.\n * @returns A promise that resolves to either the submitted model or an error.\n */\nasync function submitForm<Schema extends z.ZodTypeAny, Response>(\n args: SubmitFormArgs<Schema, Response>\n): Promise<FormResponse<Response>> {\n let response: AwaitedFormResponse<Response> = { data: null, error: null, validation: null };\n\n try {\n const data = await validateSchema(args.formData, args.schema);\n const model = await args.fn(data);\n\n await args.onSuccess?.(model);\n\n return { ...response, data: model };\n } catch (error) {\n if (error instanceof ValidationError) {\n args.onValidationError?.(error);\n return { ...response, validation: error.messages };\n }\n if (error instanceof Error) {\n if (error.message === 'NEXT_REDIRECT' && 'digest' in error) {\n handleRedirect(String(error.digest));\n }\n throw error;\n // return { ...response, error: error.message };\n }\n return { ...response, error: 'submitForm encountered an unknown error' };\n }\n}\n\nexport default submitForm;\n","import z from 'zod';\n\nimport parseCSV from '../../csv/parse-csv';\n\nimport createRule from '../create-rule';\n\nconst validator = z.string().transform(parseCSV);\n\nfunction getCSVRule() {\n return createRule({ validator });\n}\n\nexport default getCSVRule;\n","import ValidationError from '../ValidationError';\n\nasync function getExistsTransformer<T, ID>(\n key: string,\n value: ID,\n fn: (value: ID) => Promise<T>\n): Promise<NonNullable<T>> {\n const result = await fn(value);\n\n if (!result) {\n throw new ValidationError({ [key]: 'NOT_FOUND' });\n }\n\n return result;\n}\n\nexport default getExistsTransformer;\n","function getExistsValidator<T, ID>(\n fn: (value: ID) => Promise<T>\n): [(value: ID) => Promise<boolean>, { message: string }] {\n return [\n async (value: ID) => {\n const result = await fn(value);\n return Boolean(result);\n },\n { message: 'NOT_FOUND' },\n ];\n}\n\nexport default getExistsValidator;\n","function getNotExistsValidator<T, ID>(\n fn: (value: ID) => Promise<T>\n): [(value: ID) => Promise<boolean>, { message: string }] {\n return [\n async (value: ID) => {\n const result = await fn(value);\n return !result;\n },\n { message: 'ALREADY_EXISTS' },\n ];\n}\n\nexport default getNotExistsValidator;\n"]}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
filters?: Partial<Filters> | null;
|
|
1
|
+
type ListFunctionConfig<Filters = undefined> = {
|
|
3
2
|
params?: Record<string, string> | null;
|
|
4
3
|
page?: number | null;
|
|
5
|
-
}
|
|
4
|
+
} & (Filters extends undefined ? {} : {
|
|
5
|
+
filters?: Partial<Filters> | null;
|
|
6
|
+
});
|
|
6
7
|
type MakeNullOptional<T> = {
|
|
7
8
|
[K in keyof T as null extends T[K] ? K : never]?: T[K];
|
|
8
9
|
} & {
|
package/dist/json/index.d.ts
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { z } from 'zod';
|
|
2
2
|
|
|
3
|
+
declare function validateJsonResponse<T extends z.ZodType>(query: Promise<Response>, schema: T): Promise<z.infer<T>>;
|
|
4
|
+
|
|
3
5
|
declare function validateJson<T extends z.ZodType>(data: unknown, schema: T): z.infer<T>;
|
|
4
6
|
|
|
5
|
-
export { validateJson };
|
|
7
|
+
export { validateJson, validateJsonResponse };
|
package/dist/json/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
function
|
|
1
|
+
function s(e,o){return o.parse(e)}var t=s;async function a(e,o){let n=await(await e).json();return t(n,o)}var r=a;export{t as validateJson,r as validateJsonResponse};//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/json/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/json/validate-json.ts"],"names":["validateJson","data","schema","validate_json_default"],"mappings":"AAEA,SAASA,CAAAA,CAAkCC,CAAAA,CAAeC,CAAAA,CAAuB,CAC7E,OAAOA,CAAAA,CAAO,KAAA,CAAMD,CAAI,CAC5B,CAEA,IAAOE,CAAAA,CAAQH","file":"index.js","sourcesContent":["import type { z } from 'zod';\n\nfunction validateJson<T extends z.ZodType>(data: unknown, schema: T): z.infer<T> {\n return schema.parse(data);\n}\n\nexport default validateJson;\n"]}
|
|
1
|
+
{"version":3,"sources":["../../src/json/validate-json.ts","../../src/json/validate-json-response.ts"],"names":["validateJson","data","schema","validate_json_default","validateJsonResponse","query","validate_json_response_default"],"mappings":"AAEA,SAASA,CAAAA,CAAkCC,CAAAA,CAAeC,CAAAA,CAAuB,CAC7E,OAAOA,CAAAA,CAAO,KAAA,CAAMD,CAAI,CAC5B,CAEA,IAAOE,CAAAA,CAAQH,ECFf,eAAeI,CAAAA,CACXC,CAAAA,CACAH,CAAAA,CACmB,CAEnB,IAAMD,CAAAA,CAAO,KAAA,CADI,MAAMI,GACK,IAAA,EAAK,CAEjC,OAAOF,CAAAA,CAAaF,CAAAA,CAAMC,CAAM,CACpC,KAEOI,CAAAA,CAAQF","file":"index.js","sourcesContent":["import type { z } from 'zod';\n\nfunction validateJson<T extends z.ZodType>(data: unknown, schema: T): z.infer<T> {\n return schema.parse(data);\n}\n\nexport default validateJson;\n","import type { z } from 'zod';\n\nimport validateJson from './validate-json';\n\nasync function validateJsonResponse<T extends z.ZodType>(\n query: Promise<Response>,\n schema: T\n): Promise<z.infer<T>> {\n const response = await query;\n const data = await response.json();\n\n return validateJson(data, schema);\n}\n\nexport default validateJsonResponse;\n"]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
interface MailObject<T extends object> {
|
|
2
|
+
subject: string | ((data: T) => Promise<string> | string);
|
|
3
|
+
template: (data: T) => Promise<React.ReactElement> | React.ReactElement;
|
|
4
|
+
}
|
|
5
|
+
interface MailOptions {
|
|
6
|
+
attachments?: {
|
|
7
|
+
content: string;
|
|
8
|
+
filename: string;
|
|
9
|
+
type: string;
|
|
10
|
+
}[];
|
|
11
|
+
bcc?: string[] | string;
|
|
12
|
+
cc?: string[] | string;
|
|
13
|
+
from?: string | null;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
declare function createMail<T extends object>(subject: string | ((data: T) => Promise<string> | string), template: (data: T) => Promise<React.ReactElement> | React.ReactElement): MailObject<T>;
|
|
17
|
+
|
|
18
|
+
declare function getMail<T extends object>(mail: MailObject<T>, data: T): Promise<{
|
|
19
|
+
subject: string;
|
|
20
|
+
html: string;
|
|
21
|
+
}>;
|
|
22
|
+
|
|
23
|
+
declare function sendMail<T extends object>(to: string[] | string, mail: MailObject<T>, data?: T, options?: MailOptions): Promise<boolean>;
|
|
24
|
+
|
|
25
|
+
export { type MailObject, createMail, getMail, sendMail };
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import P from'stream';import b from'@sendgrid/mail';function v(t,e){return {subject:t,template:e}}var w=v;async function S(t){let e=(await import('react-dom/server')).default;return new Promise(r=>{let n=new P.Writable,i="";function o(m,u,p){i+=m.toString(),p();}n._write=o;let{pipe:s}=e.renderToPipeableStream(t,{onShellReady:()=>{s(n),r(i);}});})}var g=S;async function _(t,e){let{subject:r,template:n}=t,i=typeof r=="function"?await r(e):r,o=await n(e);return {html:await g(o),subject:i}}var f=_;function T(t){return t?Array.isArray(t)?t.map(e=>({email:e})):[{email:t}]:[]}var c=T;async function D(t){if(!process.env.MAIL_API_KEY)throw new Error("Could not send mail via Mailtrap. Mail API key has not been set.");let[e,r]=process.env.MAIL_API_KEY.split("."),i=await(await fetch(`https://sandbox.api.mailtrap.io/api/send/${e}`,{method:"POST",headers:{"Api-Token":r,"Content-Type":"application/json"},body:JSON.stringify({attachments:t.attachments,bcc:c(t.bcc),cc:c(t.cc),from:t.from,html:t.html,subject:t.subject,to:c(t.to)})})).json();if(i.errors)throw new Error(`Could not send mail via Mailtrap. ${i.errors[0]}.`);return true}var A=D;function d(t,e){return Array.isArray(t)?t.map(r=>({email:r,type:e})):[{email:t,type:e}]}function L(t,e,r){return [...d(t,"to"),...d(e||[],"cc"),...d(r||[],"bcc")]}var y=L;async function x(t){if(!process.env.MAIL_API_KEY)throw new Error("Could not send mail via Mandrill. Mail API key has not been set.");let r={attachments:t.attachments?.map(o=>({content:o.content,name:o.filename,type:o.type})),from_email:t.from.email,from_name:t.from.name,html:t.html,subject:t.subject,preserve_recipients:true,to:y(t.to,t.cc,t.bcc)},i=await(await fetch("https://mandrillapp.com/api/1.0/messages/send",{method:"POST",body:JSON.stringify({key:process.env.MAIL_API_KEY,message:r})})).json();return Array.isArray(i)?i.every(o=>o.status==="sent"):i.status==="sent"}var R=x;function N(t){return t?Array.isArray(t)?t.map(e=>({email:e})):[{email:t}]:[]}var l=N;async function O(t){if(!process.env.MAIL_API_KEY)throw new Error("Could not send mail via Sendgrid. Mail API key has not been set.");b.setApiKey(process.env.MAIL_API_KEY);let e=await b.send({attachments:t.attachments,bcc:l(t.bcc),cc:l(t.cc),from:t.from,html:t.html,to:l(t.to),subject:t.subject});if(!e[0].statusCode.toString().startsWith("2"))throw new Error(`Could not send mail via Sendgrid. ${JSON.stringify(e)}`);return true}var h=O;function j(t){if(!t&&!process.env.MAIL_FROM)throw new Error("Mail from address has not been set as an environment variable, or provided in options.");let e=/^(?<name>[^<]+)<(?<email>[^>]+)>$/u.exec(t||process.env.MAIL_FROM||"");if(!e?.groups?.name||!e?.groups?.email)throw new Error('Mail from address is not the correct format. It should be "Name <email>".');return {email:e.groups.email.trim(),name:e.groups.name.trim()}}var I=j;var C=["MAILTRAP"],U=["MAILTRAP","MANDRILL","SENDGRID"],V="MAILTRAP",K="SENDGRID",E={MAILTRAP:A,MANDRILL:R,SENDGRID:h};async function k(t,e,r,n){let i=I(n?.from),{subject:o,html:s}=await f(e,r||{}),m={attachments:n?.attachments,bcc:n?.bcc,cc:n?.cc,from:i,html:s,subject:o,to:t},u=process.env.MAIL_ENABLE_PRODUCTION==="true"?U:C,p=process.env.MAIL_ENABLE_PRODUCTION==="true"?K:V,a=process.env.MAIL_DRIVER?process.env.MAIL_DRIVER.toUpperCase():p;if(!u.includes(a)||!E[a])throw new Error(`Mail driver ${a} is not supported. If you're in a production environment, you might need to set the MAIL_ENABLE_PRODUCTION environment variable to access this driver.`);let M=E[a];if(!M)throw new Error(`Mail driver ${a} is not supported.`);return M(m)}var Y=k;
|
|
2
|
+
export{w as createMail,f as getMail,Y as sendMail};//# sourceMappingURL=index.js.map
|
|
3
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/mail/create-mail.ts","../../src/mail/utility/render-mail.ts","../../src/mail/get-mail.ts","../../src/mail/drivers/mailtrap/transform-mailtrap-recipients.ts","../../src/mail/drivers/mailtrap/index.ts","../../src/mail/drivers/mandrill/transform-mandrill-recipients.ts","../../src/mail/drivers/mandrill/index.ts","../../src/mail/drivers/sendgrid/transform-sendgrid-recipients.ts","../../src/mail/drivers/sendgrid/index.ts","../../src/mail/utility/get-sender-details.ts","../../src/mail/send-mail.ts"],"names":["createMail","subject","template","create_mail_default","renderMail","element","ReactDOMServer","resolve","ws","stream","content","write","chunk","enc","next","pipe","render_mail_default","getMail","mail","data","subjectText","get_mail_default","transformMailtrapRecipients","emails","email","transform_mailtrap_recipients_default","sendMailtrapMail","sendObject","id","key","json","mailtrap_default","transformMandrillRecipientGroup","group","type","transformMandrillRecipients","to","cc","bcc","transform_mandrill_recipients_default","sendMandrillMail","message","attachment","item","mandrill_default","transformSendgridRecipients","transform_sendgrid_recipients_default","sendSendgridMail","sgMail","response","sendgrid_default","getSenderDetails","from","matches","get_sender_details_default","DEVELOPMENT_DRIVERS","PRODUCTION_DRIVERS","DEFAULT_DEVELOPMENT_DRIVER","DEFAULT_PRODUCTION_DRIVER","driverMap","sendMail","options","html","allowedDriverAliases","defaultDriverAlias","driverAlias","driver","send_mail_default"],"mappings":"oDAEA,SAASA,EACLC,CAAAA,CACAC,CAAAA,CACa,CACb,OAAO,CAAE,QAAAD,CAAAA,CAAS,QAAA,CAAAC,CAAS,CAC/B,CAEA,IAAOC,CAAAA,CAAQH,ECPf,eAAeI,CAAAA,CAAWC,CAAAA,CAA8C,CACpE,IAAMC,CAAAA,CAAAA,CAAkB,aAAa,kBAAkB,CAAA,EAAG,QAE1D,OAAO,IAAI,QAASC,CAAAA,EAAY,CAC5B,IAAMC,CAAAA,CAAK,IAAIC,EAAO,QAAA,CAClBC,CAAAA,CAAU,GAEd,SAASC,CAAAA,CACLC,CAAAA,CACAC,CAAAA,CACAC,EACI,CACJJ,CAAAA,EAAWE,EAAM,QAAA,EAAS,CAC1BE,IACJ,CAEAN,CAAAA,CAAG,MAAA,CAASG,EAEZ,GAAM,CAAE,KAAAI,CAAK,CAAA,CAAIT,EAAe,sBAAA,CAAuBD,CAAAA,CAAS,CAC5D,YAAA,CAAc,IAAM,CAChBU,CAAAA,CAAKP,CAAE,CAAA,CACPD,CAAAA,CAAQG,CAAO,EACnB,CACJ,CAAC,EACL,CAAC,CACL,CAEA,IAAOM,EAAQZ,CAAAA,CC1Bf,eAAea,EACXC,CAAAA,CACAC,CAAAA,CAC0C,CAC1C,GAAM,CAAE,OAAA,CAAAlB,CAAAA,CAAS,SAAAC,CAAS,CAAA,CAAIgB,EAExBE,CAAAA,CAAc,OAAOnB,CAAAA,EAAY,UAAA,CAAa,MAAMA,CAAAA,CAAQkB,CAAI,EAAIlB,CAAAA,CAEpEI,CAAAA,CAAU,MAAMH,CAAAA,CAASiB,CAAI,CAAA,CAGnC,OAAO,CACH,IAAA,CAHS,MAAMH,EAAWX,CAAO,CAAA,CAIjC,QAASe,CACb,CACJ,CAEA,IAAOC,CAAAA,CAAQJ,ECpBf,SAASK,CAAAA,CAA4BC,EAAiD,CAClF,OAAKA,EAGE,KAAA,CAAM,OAAA,CAAQA,CAAM,CAAA,CAAIA,EAAO,GAAA,CAAKC,CAAAA,GAAW,CAAE,KAAA,CAAAA,CAAM,EAAE,CAAA,CAAI,CAAC,CAAE,KAAA,CAAOD,CAAO,CAAC,CAAA,CAF3E,EAGf,CAEA,IAAOE,EAAQH,CAAAA,CCHf,eAAeI,CAAAA,CAAiBC,CAAAA,CAAkD,CAC9E,GAAI,CAAC,QAAQ,GAAA,CAAI,YAAA,CACb,MAAM,IAAI,KAAA,CAAM,kEAAkE,CAAA,CAQtF,GAAM,CAACC,CAAAA,CAAIC,CAAG,EAAI,OAAA,CAAQ,GAAA,CAAI,aAAa,KAAA,CAAM,GAAG,CAAA,CAgB9CC,CAAAA,CAAQ,MAdG,MAAM,KAAA,CAAM,4CAA4CF,CAAE,CAAA,CAAA,CAAI,CAC3E,MAAA,CAAQ,MAAA,CACR,OAAA,CAAS,CAAE,YAAaC,CAAAA,CAAK,cAAA,CAAgB,kBAAmB,CAAA,CAChE,IAAA,CAAM,KAAK,SAAA,CAAU,CACjB,WAAA,CAAaF,CAAAA,CAAW,YACxB,GAAA,CAAKF,CAAAA,CAA4BE,EAAW,GAAG,CAAA,CAC/C,GAAIF,CAAAA,CAA4BE,CAAAA,CAAW,EAAE,CAAA,CAC7C,IAAA,CAAMA,EAAW,IAAA,CACjB,IAAA,CAAMA,EAAW,IAAA,CACjB,OAAA,CAASA,EAAW,OAAA,CACpB,EAAA,CAAIF,CAAAA,CAA4BE,CAAAA,CAAW,EAAE,CACjD,CAAC,CACL,CAAC,CAAA,EAE4B,MAAK,CAElC,GAAIG,EAAK,MAAA,CACL,MAAM,IAAI,KAAA,CAAM,CAAA,kCAAA,EAAqCA,EAAK,MAAA,CAAO,CAAC,CAAC,CAAA,CAAA,CAAG,CAAA,CAG1E,OAAO,KACX,CAEA,IAAOC,CAAAA,CAAQL,ECvCf,SAASM,CAAAA,CACLC,EACAC,CAAAA,CAC8C,CAC9C,OAAI,KAAA,CAAM,OAAA,CAAQD,CAAK,CAAA,CACZA,CAAAA,CAAM,IAAKT,CAAAA,GAAW,CAAE,MAAAA,CAAAA,CAAO,IAAA,CAAAU,CAAK,CAAA,CAAE,EAE1C,CAAC,CAAE,MAAOD,CAAAA,CAAO,IAAA,CAAAC,CAAK,CAAC,CAClC,CAEA,SAASC,EACLC,CAAAA,CACAC,CAAAA,CACAC,EAC8C,CAC9C,OAAO,CACH,GAAGN,CAAAA,CAAgCI,CAAAA,CAAI,IAAI,EAC3C,GAAGJ,CAAAA,CAAgCK,GAAM,EAAC,CAAG,IAAI,CAAA,CACjD,GAAGL,EAAgCM,CAAAA,EAAO,GAAI,KAAK,CACvD,CACJ,CAEA,IAAOC,EAAQJ,CAAAA,CCdf,eAAeK,CAAAA,CAAiBb,CAAAA,CAAkD,CAC9E,GAAI,CAAC,QAAQ,GAAA,CAAI,YAAA,CACb,MAAM,IAAI,KAAA,CAAM,kEAAkE,CAAA,CAUtF,IAAMc,EAAU,CACZ,WAAA,CARgBd,EAAW,WAAA,EAAa,GAAA,CAAKe,IAAgB,CAC7D,OAAA,CAASA,CAAAA,CAAW,OAAA,CACpB,KAAMA,CAAAA,CAAW,QAAA,CACjB,KAAMA,CAAAA,CAAW,IACrB,EAAE,CAAA,CAKE,UAAA,CAAYf,EAAW,IAAA,CAAK,KAAA,CAC5B,UAAWA,CAAAA,CAAW,IAAA,CAAK,KAC3B,IAAA,CAAMA,CAAAA,CAAW,KACjB,OAAA,CAASA,CAAAA,CAAW,OAAA,CACpB,mBAAA,CAAqB,KACrB,EAAA,CAAIY,CAAAA,CAA4BZ,EAAW,EAAA,CAAIA,CAAAA,CAAW,GAAIA,CAAAA,CAAW,GAAG,CAChF,CAAA,CAWMG,EAAQ,KAAA,CARG,MAAM,MAAM,+CAAA,CAAiD,CAC1E,OAAQ,MAAA,CACR,IAAA,CAAM,IAAA,CAAK,SAAA,CAAU,CACjB,GAAA,CAAK,OAAA,CAAQ,IAAI,YAAA,CACjB,OAAA,CAAAW,CACJ,CAAC,CACL,CAAC,CAAA,EAE4B,IAAA,GAE7B,OAAO,KAAA,CAAM,QAAQX,CAAI,CAAA,CACnBA,EAAK,KAAA,CAAOa,CAAAA,EAASA,CAAAA,CAAK,MAAA,GAAW,MAAM,CAAA,CAC3Cb,CAAAA,CAAK,SAAW,MAC1B,CAEA,IAAOc,CAAAA,CAAQJ,CAAAA,CC9Cf,SAASK,CAAAA,CAA4BtB,CAAAA,CAAiD,CAClF,OAAKA,CAAAA,CAGE,MAAM,OAAA,CAAQA,CAAM,CAAA,CAAIA,CAAAA,CAAO,IAAKC,CAAAA,GAAW,CAAE,MAAAA,CAAM,CAAA,CAAE,EAAI,CAAC,CAAE,MAAOD,CAAO,CAAC,EAF3E,EAGf,CAEA,IAAOuB,CAAAA,CAAQD,ECDf,eAAeE,CAAAA,CAAiBpB,CAAAA,CAAkD,CAC9E,GAAI,CAAC,OAAA,CAAQ,IAAI,YAAA,CACb,MAAM,IAAI,KAAA,CAAM,kEAAkE,CAAA,CAGtFqB,CAAAA,CAAO,UAAU,OAAA,CAAQ,GAAA,CAAI,YAAY,CAAA,CAEzC,IAAMC,EAAW,MAAMD,CAAAA,CAAO,IAAA,CAAK,CAC/B,YAAarB,CAAAA,CAAW,WAAA,CACxB,IAAKmB,CAAAA,CAA4BnB,CAAAA,CAAW,GAAG,CAAA,CAC/C,EAAA,CAAImB,EAA4BnB,CAAAA,CAAW,EAAE,EAC7C,IAAA,CAAMA,CAAAA,CAAW,KACjB,IAAA,CAAMA,CAAAA,CAAW,KACjB,EAAA,CAAImB,CAAAA,CAA4BnB,CAAAA,CAAW,EAAE,EAC7C,OAAA,CAASA,CAAAA,CAAW,OACxB,CAAC,CAAA,CAED,GAAI,CAACsB,CAAAA,CAAS,CAAC,CAAA,CAAE,UAAA,CAAW,UAAS,CAAE,UAAA,CAAW,GAAG,CAAA,CACjD,MAAM,IAAI,KAAA,CAAM,CAAA,kCAAA,EAAqC,IAAA,CAAK,SAAA,CAAUA,CAAQ,CAAC,CAAA,CAAE,EAGnF,OAAO,KACX,CAEA,IAAOC,CAAAA,CAAQH,EC9Bf,SAASI,CAAAA,CAAiBC,EAAuD,CAC7E,GAAI,CAACA,CAAAA,EAAQ,CAAC,QAAQ,GAAA,CAAI,SAAA,CACtB,MAAM,IAAI,MACN,wFACJ,CAAA,CAGJ,IAAMC,CAAAA,CAAU,oCAAA,CAAqC,KAAKD,CAAAA,EAAQ,OAAA,CAAQ,GAAA,CAAI,SAAA,EAAa,EAAE,CAAA,CAE7F,GAAI,CAACC,CAAAA,EAAS,MAAA,EAAQ,MAAQ,CAACA,CAAAA,EAAS,MAAA,EAAQ,KAAA,CAC5C,MAAM,IAAI,KAAA,CACN,2EACJ,CAAA,CAGJ,OAAO,CACH,KAAA,CAAOA,CAAAA,CAAQ,OAAO,KAAA,CAAM,IAAA,GAC5B,IAAA,CAAMA,CAAAA,CAAQ,OAAO,IAAA,CAAK,IAAA,EAC9B,CACJ,CAEA,IAAOC,CAAAA,CAAQH,ECZf,IAAMI,CAAAA,CAAsB,CAAC,UAAU,CAAA,CACjCC,EAAqB,CAAC,UAAA,CAAY,WAAY,UAAU,CAAA,CAExDC,EAA6B,UAAA,CAC7BC,CAAAA,CAA4B,WAE5BC,CAAAA,CAAwC,CAC1C,SAAU5B,CAAAA,CACV,QAAA,CAAUa,CAAAA,CACV,QAAA,CAAUM,CACd,CAAA,CAEA,eAAeU,EACXxB,CAAAA,CACAlB,CAAAA,CACAC,EACA0C,CAAAA,CACgB,CAChB,IAAMT,CAAAA,CAAOE,CAAAA,CAAiBO,GAAS,IAAI,CAAA,CACrC,CAAE,OAAA,CAAA5D,CAAAA,CAAS,KAAA6D,CAAK,CAAA,CAAI,MAAMzC,CAAAA,CAAQH,EAAMC,CAAAA,EAAQ,EAAE,CAAA,CAElDQ,CAAAA,CAAiC,CACnC,WAAA,CAAakC,CAAAA,EAAS,WAAA,CACtB,GAAA,CAAKA,GAAS,GAAA,CACd,EAAA,CAAIA,GAAS,EAAA,CACb,IAAA,CAAAT,EACA,IAAA,CAAAU,CAAAA,CACA,OAAA,CAAA7D,CAAAA,CACA,GAAAmC,CACJ,CAAA,CAEM2B,EACF,OAAA,CAAQ,GAAA,CAAI,yBAA2B,MAAA,CAASP,CAAAA,CAAqBD,EAEnES,CAAAA,CACF,OAAA,CAAQ,IAAI,sBAAA,GAA2B,MAAA,CACjCN,EACAD,CAAAA,CAEJQ,CAAAA,CAAc,QAAQ,GAAA,CAAI,WAAA,CAC1B,OAAA,CAAQ,GAAA,CAAI,YAAY,WAAA,EAAY,CACpCD,EAEN,GAAI,CAACD,EAAqB,QAAA,CAASE,CAAW,GAAK,CAACN,CAAAA,CAAUM,CAAW,CAAA,CACrE,MAAM,IAAI,KAAA,CACN,CAAA,YAAA,EAAeA,CAAW,CAAA,sJAAA,CAC9B,CAAA,CAGJ,IAAMC,CAAAA,CAASP,EAAUM,CAAW,CAAA,CAEpC,GAAI,CAACC,CAAAA,CACD,MAAM,IAAI,KAAA,CAAM,eAAeD,CAAW,CAAA,kBAAA,CAAoB,EAGlE,OAAOC,CAAAA,CAAOvC,CAAU,CAC5B,KAEOwC,CAAAA,CAAQP","file":"index.js","sourcesContent":["import type { MailObject } from './utility/interfaces';\n\nfunction createMail<T extends object>(\n subject: string | ((data: T) => Promise<string> | string),\n template: (data: T) => Promise<React.ReactElement> | React.ReactElement\n): MailObject<T> {\n return { subject, template };\n}\n\nexport default createMail;\n","import stream from 'node:stream';\n\nasync function renderMail(element: React.ReactElement): Promise<string> {\n const ReactDOMServer = (await import('react-dom/server')).default;\n\n return new Promise((resolve) => {\n const ws = new stream.Writable();\n let content = '';\n\n function write<T extends { toString: () => string }>(\n chunk: T,\n enc: BufferEncoding,\n next: (error?: Error | null) => void\n ): void {\n content += chunk.toString();\n next();\n }\n\n ws._write = write; // eslint-disable-line no-underscore-dangle\n\n const { pipe } = ReactDOMServer.renderToPipeableStream(element, {\n onShellReady: () => {\n pipe(ws);\n resolve(content);\n },\n });\n });\n}\n\nexport default renderMail;\n","import renderMail from './utility/render-mail';\nimport type { MailObject } from './utility/interfaces';\n\nasync function getMail<T extends object>(\n mail: MailObject<T>,\n data: T\n): Promise<{ subject: string; html: string }> {\n const { subject, template } = mail;\n\n const subjectText = typeof subject === 'function' ? await subject(data) : subject;\n\n const element = await template(data);\n const html = await renderMail(element);\n\n return {\n html,\n subject: subjectText,\n };\n}\n\nexport default getMail;\n","function transformMailtrapRecipients(emails?: string[] | string): { email: string }[] {\n if (!emails) {\n return [];\n }\n return Array.isArray(emails) ? emails.map((email) => ({ email })) : [{ email: emails }];\n}\n\nexport default transformMailtrapRecipients;\n","import type { SendableMailObject } from '../../utility/interfaces';\n\nimport transformMailtrapRecipients from './transform-mailtrap-recipients';\n\nasync function sendMailtrapMail(sendObject: SendableMailObject): Promise<boolean> {\n if (!process.env.MAIL_API_KEY) {\n throw new Error('Could not send mail via Mailtrap. Mail API key has not been set.');\n }\n\n /*\n * The account id and api key are both in the MAIL_API_KEY variable, separated by a `.`. We need\n * to split them.\n */\n\n const [id, key] = process.env.MAIL_API_KEY.split('.');\n\n const response = await fetch(`https://sandbox.api.mailtrap.io/api/send/${id}`, {\n method: 'POST',\n headers: { 'Api-Token': key, 'Content-Type': 'application/json' },\n body: JSON.stringify({\n attachments: sendObject.attachments,\n bcc: transformMailtrapRecipients(sendObject.bcc),\n cc: transformMailtrapRecipients(sendObject.cc),\n from: sendObject.from,\n html: sendObject.html,\n subject: sendObject.subject,\n to: transformMailtrapRecipients(sendObject.to),\n }),\n });\n\n const json = (await response.json()) as { errors?: string[] };\n\n if (json.errors) {\n throw new Error(`Could not send mail via Mailtrap. ${json.errors[0]}.`);\n }\n\n return true;\n}\n\nexport default sendMailtrapMail;\n","function transformMandrillRecipientGroup(\n group: string[] | string,\n type: 'bcc' | 'cc' | 'to'\n): { email: string; type: 'bcc' | 'cc' | 'to' }[] {\n if (Array.isArray(group)) {\n return group.map((email) => ({ email, type }));\n }\n return [{ email: group, type }];\n}\n\nfunction transformMandrillRecipients(\n to: string[] | string,\n cc?: string[] | string,\n bcc?: string[] | string\n): { email: string; type: 'bcc' | 'cc' | 'to' }[] {\n return [\n ...transformMandrillRecipientGroup(to, 'to'),\n ...transformMandrillRecipientGroup(cc || [], 'cc'),\n ...transformMandrillRecipientGroup(bcc || [], 'bcc'),\n ];\n}\n\nexport default transformMandrillRecipients;\n","import type { SendableMailObject } from '../../utility/interfaces';\n\nimport transformMandrillRecipients from './transform-mandrill-recipients';\n\ninterface MandrillResponse {\n status: string;\n}\n\nasync function sendMandrillMail(sendObject: SendableMailObject): Promise<boolean> {\n if (!process.env.MAIL_API_KEY) {\n throw new Error('Could not send mail via Mandrill. Mail API key has not been set.');\n }\n\n const attachments = sendObject.attachments?.map((attachment) => ({\n content: attachment.content,\n name: attachment.filename,\n type: attachment.type,\n }));\n\n /* eslint-disable camelcase */\n const message = {\n attachments,\n from_email: sendObject.from.email,\n from_name: sendObject.from.name,\n html: sendObject.html,\n subject: sendObject.subject,\n preserve_recipients: true,\n to: transformMandrillRecipients(sendObject.to, sendObject.cc, sendObject.bcc),\n };\n /* eslint-enable camelcase */\n\n const response = await fetch('https://mandrillapp.com/api/1.0/messages/send', {\n method: 'POST',\n body: JSON.stringify({\n key: process.env.MAIL_API_KEY,\n message,\n }),\n });\n\n const json = (await response.json()) as MandrillResponse | [MandrillResponse];\n\n return Array.isArray(json)\n ? json.every((item) => item.status === 'sent')\n : json.status === 'sent';\n}\n\nexport default sendMandrillMail;\n","function transformSendgridRecipients(emails?: string[] | string): { email: string }[] {\n if (!emails) {\n return [];\n }\n return Array.isArray(emails) ? emails.map((email) => ({ email })) : [{ email: emails }];\n}\n\nexport default transformSendgridRecipients;\n","import sgMail from '@sendgrid/mail';\n\nimport type { SendableMailObject } from '../../utility/interfaces';\n\nimport transformSendgridRecipients from './transform-sendgrid-recipients';\n\nasync function sendSendgridMail(sendObject: SendableMailObject): Promise<boolean> {\n if (!process.env.MAIL_API_KEY) {\n throw new Error('Could not send mail via Sendgrid. Mail API key has not been set.');\n }\n\n sgMail.setApiKey(process.env.MAIL_API_KEY);\n\n const response = await sgMail.send({\n attachments: sendObject.attachments,\n bcc: transformSendgridRecipients(sendObject.bcc),\n cc: transformSendgridRecipients(sendObject.cc),\n from: sendObject.from,\n html: sendObject.html,\n to: transformSendgridRecipients(sendObject.to),\n subject: sendObject.subject,\n });\n\n if (!response[0].statusCode.toString().startsWith('2')) {\n throw new Error(`Could not send mail via Sendgrid. ${JSON.stringify(response)}`);\n }\n\n return true;\n}\n\nexport default sendSendgridMail;\n","function getSenderDetails(from?: string | null): { email: string; name: string } {\n if (!from && !process.env.MAIL_FROM) {\n throw new Error(\n 'Mail from address has not been set as an environment variable, or provided in options.'\n );\n }\n\n const matches = /^(?<name>[^<]+)<(?<email>[^>]+)>$/u.exec(from || process.env.MAIL_FROM || '');\n\n if (!matches?.groups?.name || !matches?.groups?.email) {\n throw new Error(\n 'Mail from address is not the correct format. It should be \"Name <email>\".'\n );\n }\n\n return {\n email: matches.groups.email.trim(),\n name: matches.groups.name.trim(),\n };\n}\n\nexport default getSenderDetails;\n","import sendMailtrapMail from './drivers/mailtrap';\nimport sendMandrillMail from './drivers/mandrill';\nimport sendSendgridMail from './drivers/sendgrid';\n\nimport getMail from './get-mail';\n\nimport getSenderDetails from './utility/get-sender-details';\nimport type { MailDriver, MailObject, MailOptions, SendableMailObject } from './utility/interfaces';\n\nconst DEVELOPMENT_DRIVERS = ['MAILTRAP'];\nconst PRODUCTION_DRIVERS = ['MAILTRAP', 'MANDRILL', 'SENDGRID'];\n\nconst DEFAULT_DEVELOPMENT_DRIVER = 'MAILTRAP';\nconst DEFAULT_PRODUCTION_DRIVER = 'SENDGRID';\n\nconst driverMap: Record<string, MailDriver> = {\n MAILTRAP: sendMailtrapMail,\n MANDRILL: sendMandrillMail,\n SENDGRID: sendSendgridMail,\n};\n\nasync function sendMail<T extends object>(\n to: string[] | string,\n mail: MailObject<T>,\n data?: T,\n options?: MailOptions\n): Promise<boolean> {\n const from = getSenderDetails(options?.from);\n const { subject, html } = await getMail(mail, data || {});\n\n const sendObject: SendableMailObject = {\n attachments: options?.attachments,\n bcc: options?.bcc,\n cc: options?.cc,\n from,\n html,\n subject,\n to,\n };\n\n const allowedDriverAliases =\n process.env.MAIL_ENABLE_PRODUCTION === 'true' ? PRODUCTION_DRIVERS : DEVELOPMENT_DRIVERS;\n\n const defaultDriverAlias =\n process.env.MAIL_ENABLE_PRODUCTION === 'true'\n ? DEFAULT_PRODUCTION_DRIVER\n : DEFAULT_DEVELOPMENT_DRIVER;\n\n const driverAlias = process.env.MAIL_DRIVER\n ? process.env.MAIL_DRIVER.toUpperCase()\n : defaultDriverAlias;\n\n if (!allowedDriverAliases.includes(driverAlias) || !driverMap[driverAlias]) {\n throw new Error(\n `Mail driver ${driverAlias} is not supported. If you're in a production environment, you might need to set the MAIL_ENABLE_PRODUCTION environment variable to access this driver.`\n );\n }\n\n const driver = driverMap[driverAlias];\n\n if (!driver) {\n throw new Error(`Mail driver ${driverAlias} is not supported.`);\n }\n\n return driver(sendObject);\n}\n\nexport default sendMail;\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { NextRequest, NextResponse } from 'next/server';
|
|
2
|
+
|
|
3
|
+
interface ProxyRedirect {
|
|
4
|
+
redirect: string;
|
|
5
|
+
}
|
|
6
|
+
type ProxyFunction = (request: NextRequest) => Promise<ProxyRedirect | null>;
|
|
7
|
+
|
|
8
|
+
declare function handleProxy(request: NextRequest, functions: ProxyFunction[]): Promise<NextResponse>;
|
|
9
|
+
|
|
10
|
+
export { type ProxyFunction, type ProxyRedirect, handleProxy };
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {NextResponse}from'next/server';async function i(e,o){for(let n of o){let t=await n(e);if(t)return NextResponse.redirect(new URL(t.redirect,e.url))}return NextResponse.next()}var f=i;export{f as handleProxy};//# sourceMappingURL=index.js.map
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/proxy/handle-proxy.ts"],"names":["handleProxy","request","functions","func","result","NextResponse","handle_proxy_default"],"mappings":"uCAKA,eAAeA,CAAAA,CACXC,EACAC,CAAAA,CACqB,CACrB,IAAA,IAAWC,CAAAA,IAAQD,EAAW,CAC1B,IAAME,EAAS,MAAMD,CAAAA,CAAKF,CAAO,CAAA,CAEjC,GAAIG,CAAAA,CACA,OAAOC,aAAa,QAAA,CAAS,IAAI,GAAA,CAAID,CAAAA,CAAO,SAAUH,CAAAA,CAAQ,GAAG,CAAC,CAE1E,CAEA,OAAOI,YAAAA,CAAa,MACxB,KAEOC,CAAAA,CAAQN","file":"index.js","sourcesContent":["import { NextResponse } from 'next/server';\nimport type { NextRequest } from 'next/server';\n\nimport type { ProxyFunction } from './utility/interfaces';\n\nasync function handleProxy(\n request: NextRequest,\n functions: ProxyFunction[]\n): Promise<NextResponse> {\n for (const func of functions) {\n const result = await func(request);\n\n if (result) {\n return NextResponse.redirect(new URL(result.redirect, request.url));\n }\n }\n\n return NextResponse.next();\n}\n\nexport default handleProxy;\n"]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Server-side storage utility for caching data using Redis. It is designed to match the interface of localStorage, but operates on the server side.
|
|
3
|
+
*/
|
|
4
|
+
declare const serverStorage: {
|
|
5
|
+
/**
|
|
6
|
+
* Get an item from the cache.
|
|
7
|
+
* @param prefix The prefix to use for the cache key.
|
|
8
|
+
* @param key The key of the item to retrieve.
|
|
9
|
+
* @returns The cached item, or null if not found.
|
|
10
|
+
*/
|
|
11
|
+
getItem(prefix: string, key: string): Promise<Record<string, unknown> | null>;
|
|
12
|
+
getArray(prefix: string, key: string): Promise<string[]>;
|
|
13
|
+
setArray(prefix: string, key: string, value: string[]): Promise<void>;
|
|
14
|
+
addToArray(prefix: string, key: string, value: string): Promise<void>;
|
|
15
|
+
removeFromArray(prefix: string, key: string, value: string): Promise<void>;
|
|
16
|
+
/**
|
|
17
|
+
* Set an item in the cache.
|
|
18
|
+
* @param prefix The prefix to use for the cache key.
|
|
19
|
+
* @param key The key of the item to set.
|
|
20
|
+
* @param value The value of the item to set.
|
|
21
|
+
*/
|
|
22
|
+
setItem(prefix: string, key: string, value: Record<string, unknown>, ttl?: number): Promise<void>;
|
|
23
|
+
setExpiry(prefix: string, key: string, ttl: number): Promise<void>;
|
|
24
|
+
/**
|
|
25
|
+
* Remove an item from the cache.
|
|
26
|
+
* @param prefix The prefix to use for the cache key.
|
|
27
|
+
* @param key The key of the item to remove.
|
|
28
|
+
*/
|
|
29
|
+
removeItem(prefix: string, key: string): Promise<void>;
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
export { serverStorage as default };
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {createClient}from'redis';var n=null;async function g(){if(!process.env.REDIS_URL)throw new Error("REDIS_URL is not defined. Access to the cache is not possible.");return n||(n=createClient({url:process.env.REDIS_URL}),await n.connect(),n)}var i=g;async function u(t,r,e){if(typeof e=="number")return e;let a=await(await i()).ttl(`[${t}]:${r}`);return a<0?0:a}var s=u;var c={async getItem(t,r){let e=await(await i()).get(`[${t}]:${r}`);if(!e)return null;try{return JSON.parse(e)}catch{return null}},async getArray(t,r){return await(await i()).sMembers(`[${t}]:${r}`)},async setArray(t,r,e){await(await i()).del(`[${t}]:${r}`),await(await i()).sAdd(`[${t}]:${r}`,e);},async addToArray(t,r,e){await(await i()).sAdd(`[${t}]:${r}`,e);},async removeFromArray(t,r,e){await(await i()).sRem(`[${t}]:${r}`,e);},async setItem(t,r,e,a){await(await i()).set(`[${t}]:${r}`,JSON.stringify(e),{expiration:{type:"EX",value:await s(t,r,a)}});},async setExpiry(t,r,e){await(await i()).expire(`[${t}]:${r}`,e);},async removeItem(t,r){await(await i()).del(`[${t}]:${r}`);}},p=c;export{p as default};//# sourceMappingURL=index.js.map
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/storage/utility/get-client.ts","../../src/storage/utility/get-ttl.ts","../../src/storage/index.ts"],"names":["client","getClient","createClient","get_client_default","getTTL","prefix","key","ttl","result","get_ttl_default","serverStorage","value","storage_default"],"mappings":"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","file":"index.js","sourcesContent":["import { createClient } from 'redis';\n\nimport isLocalhost from './is-localhost.js';\n\nlet client: ReturnType<typeof createClient> | null = null;\n\n/**\n * Get a Redis client instance. If the client does not exist, it creates a new one and connects to the Redis server.\n * If the client already exists, it returns the existing instance.\n *\n * @returns A promise that resolves to a Redis client instance.\n */\nasync function getClient(): Promise<ReturnType<typeof createClient>> {\n if (!process.env.REDIS_URL) {\n throw new Error('REDIS_URL is not defined. Access to the cache is not possible.');\n }\n\n if (client) {\n return client;\n }\n\n client = createClient({\n url: process.env.REDIS_URL,\n });\n\n await client.connect();\n return client;\n}\n\nexport default getClient;\n","import getClient from './get-client';\n\nasync function getTTL(prefix: string, key: string, ttl?: number): Promise<number> {\n // If a TTL is provided, return it directly\n\n if (typeof ttl === 'number') {\n return ttl;\n }\n\n // Otherwise, get the TTL from the storage\n\n const result = await (await getClient()).ttl(`[${prefix}]:${key}`);\n\n // If the result is -2, the key does not exist. If it's -1, the key exists but has no associated expire. In both cases, we return 0.\n\n if (result < 0) {\n return 0;\n }\n\n return result;\n}\n\nexport default getTTL;\n","import getClient from './utility/get-client';\nimport getTTL from './utility/get-ttl';\n\n/**\n * Server-side storage utility for caching data using Redis. It is designed to match the interface of localStorage, but operates on the server side.\n */\nconst serverStorage = {\n /**\n * Get an item from the cache.\n * @param prefix The prefix to use for the cache key.\n * @param key The key of the item to retrieve.\n * @returns The cached item, or null if not found.\n */\n async getItem(prefix: string, key: string): Promise<Record<string, unknown> | null> {\n const value = await (await getClient()).get(`[${prefix}]:${key}`);\n\n if (!value) {\n return null;\n }\n\n try {\n return JSON.parse(value);\n } catch {\n return null;\n }\n },\n\n async getArray(prefix: string, key: string): Promise<string[]> {\n const values = await (await getClient()).sMembers(`[${prefix}]:${key}`);\n return values;\n },\n\n async setArray(prefix: string, key: string, value: string[]): Promise<void> {\n await (await getClient()).del(`[${prefix}]:${key}`);\n await (await getClient()).sAdd(`[${prefix}]:${key}`, value);\n },\n\n async addToArray(prefix: string, key: string, value: string): Promise<void> {\n await (await getClient()).sAdd(`[${prefix}]:${key}`, value);\n },\n\n async removeFromArray(prefix: string, key: string, value: string): Promise<void> {\n await (await getClient()).sRem(`[${prefix}]:${key}`, value);\n },\n\n /**\n * Set an item in the cache.\n * @param prefix The prefix to use for the cache key.\n * @param key The key of the item to set.\n * @param value The value of the item to set.\n */\n async setItem(\n prefix: string,\n key: string,\n value: Record<string, unknown>,\n ttl?: number\n ): Promise<void> {\n await (\n await getClient()\n ).set(`[${prefix}]:${key}`, JSON.stringify(value), {\n expiration: { type: 'EX', value: await getTTL(prefix, key, ttl) },\n });\n },\n\n async setExpiry(prefix: string, key: string, ttl: number): Promise<void> {\n await (await getClient()).expire(`[${prefix}]:${key}`, ttl);\n },\n\n /**\n * Remove an item from the cache.\n * @param prefix The prefix to use for the cache key.\n * @param key The key of the item to remove.\n */\n async removeItem(prefix: string, key: string): Promise<void> {\n await (await getClient()).del(`[${prefix}]:${key}`);\n },\n};\n\nexport default serverStorage;\n"]}
|
package/dist/utility/index.d.ts
CHANGED
|
@@ -1,11 +1,14 @@
|
|
|
1
|
-
export { L as ListFunctionConfig, M as MakeNullOptional, P as Paginated } from '../interfaces-
|
|
1
|
+
export { L as ListFunctionConfig, M as MakeNullOptional, P as Paginated } from '../interfaces-DTUqy5Oj.js';
|
|
2
2
|
|
|
3
|
-
declare function ensureID<T extends string>(id: string
|
|
3
|
+
declare function ensureID<T extends string>(id: string | null | undefined, prefix: string): T;
|
|
4
4
|
|
|
5
5
|
declare function generateID<T extends string = string>(prefix?: string | null, length?: number): T;
|
|
6
6
|
|
|
7
|
-
declare function getIDFromParams<T extends string>(key: string, prefix: string, params?: Promise<Record<string, string>> | null): Promise<T>;
|
|
7
|
+
declare function getIDFromParams<T extends string>(key: string, prefix: string, params?: Promise<Record<string, string[] | string>> | Record<string, string[] | string> | null): Promise<T | null>;
|
|
8
8
|
|
|
9
|
-
declare function guardID<T extends string>(id: string
|
|
9
|
+
declare function guardID<T extends string>(id: (string | null | undefined)[], prefix: string): T[];
|
|
10
|
+
declare function guardID<T extends string>(id: string | null | undefined, prefix: string): T | null;
|
|
10
11
|
|
|
11
|
-
|
|
12
|
+
declare function log(alias: string, fnName: string, message: string): void;
|
|
13
|
+
|
|
14
|
+
export { ensureID, generateID, getIDFromParams, guardID, log };
|
package/dist/utility/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
export{b as ensureID,c as getIDFromParams,a as guardID}from'../chunk-BA3BC4CD.js';import {randomBytes}from'crypto';var i=16;function g(e,t=i){let r="abcdefghijklmnopqrstuvwxyz0123456789",n=randomBytes(t),s="";for(let o=0;o<t;o++)s+=r[n[o]%r.length];return `${e?e+"_":""}${s}`}var c=g;function d(e){return process.env.SZ_LOG==="true"?true:typeof process.env.SZ_LOG=="string"?process.env.SZ_LOG.split(",").includes(e):false}function p(e,t,r){d(e)&&console.log(`[${e}] ${t}: ${r}`);}var m=p;export{c as generateID,m as log};//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|