@sqrzro/server 2.0.0-bz.5 → 2.0.0-bz.51

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.
Files changed (86) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +25 -1
  3. package/auth.d.ts +1 -0
  4. package/auth.js +1 -0
  5. package/cache.d.ts +1 -0
  6. package/cache.js +1 -0
  7. package/dist/auth/index.cjs +63 -0
  8. package/dist/auth/index.cjs.map +1 -0
  9. package/dist/auth/index.d.cts +106 -0
  10. package/dist/auth/index.d.ts +106 -0
  11. package/dist/auth/index.js +21 -0
  12. package/dist/auth/index.js.map +1 -0
  13. package/dist/cache/index.cjs +10 -0
  14. package/dist/cache/index.cjs.map +1 -0
  15. package/dist/cache/index.d.cts +4 -0
  16. package/dist/cache/index.d.ts +4 -0
  17. package/dist/cache/index.js +7 -0
  18. package/dist/cache/index.js.map +1 -0
  19. package/dist/database/schema.cjs +16 -0
  20. package/dist/database/schema.cjs.map +1 -0
  21. package/dist/database/schema.d.cts +288 -0
  22. package/dist/database/schema.d.ts +288 -0
  23. package/dist/database/schema.js +7 -0
  24. package/dist/database/schema.js.map +1 -0
  25. package/dist/forms/index.cjs +22 -0
  26. package/dist/forms/index.cjs.map +1 -0
  27. package/dist/forms/index.d.cts +50 -0
  28. package/dist/forms/index.d.ts +50 -0
  29. package/dist/forms/index.js +8 -0
  30. package/dist/forms/index.js.map +1 -0
  31. package/dist/lists/index.cjs +9 -0
  32. package/dist/lists/index.cjs.map +1 -0
  33. package/dist/lists/index.d.cts +18 -0
  34. package/dist/lists/index.d.ts +18 -0
  35. package/dist/lists/index.js +7 -0
  36. package/dist/lists/index.js.map +1 -0
  37. package/dist/mail/index.cjs +9 -0
  38. package/dist/mail/index.cjs.map +1 -0
  39. package/dist/mail/index.d.cts +20 -0
  40. package/dist/mail/index.d.ts +20 -0
  41. package/dist/mail/index.js +5 -0
  42. package/dist/mail/index.js.map +1 -0
  43. package/dist/middleware.cjs +9 -0
  44. package/dist/middleware.cjs.map +1 -0
  45. package/dist/middleware.d.cts +5 -0
  46. package/dist/middleware.d.ts +5 -4
  47. package/dist/middleware.js +7 -36
  48. package/dist/middleware.js.map +1 -0
  49. package/dist/url/index.cjs +12 -0
  50. package/dist/url/index.cjs.map +1 -0
  51. package/dist/url/index.d.cts +33 -0
  52. package/dist/url/index.d.ts +33 -0
  53. package/dist/url/index.js +7 -0
  54. package/dist/url/index.js.map +1 -0
  55. package/forms.d.ts +1 -0
  56. package/forms.js +1 -0
  57. package/jest.config.js +7 -0
  58. package/lists.d.ts +1 -0
  59. package/lists.js +1 -0
  60. package/mail.d.ts +1 -0
  61. package/mail.js +1 -0
  62. package/middleware.js +1 -1
  63. package/next-env.d.ts +5 -0
  64. package/package.json +77 -20
  65. package/schema.d.ts +1 -0
  66. package/schema.js +1 -0
  67. package/url.d.ts +1 -0
  68. package/url.js +1 -0
  69. package/dist/AuthService.d.ts +0 -10
  70. package/dist/AuthService.js +0 -36
  71. package/dist/DataService.d.ts +0 -29
  72. package/dist/DataService.js +0 -64
  73. package/dist/ImageService.d.ts +0 -7
  74. package/dist/ImageService.js +0 -23
  75. package/dist/LoginRequest.d.ts +0 -4
  76. package/dist/LoginRequest.js +0 -11
  77. package/dist/PasswordService.d.ts +0 -6
  78. package/dist/PasswordService.js +0 -63
  79. package/dist/RequestService.d.ts +0 -21
  80. package/dist/RequestService.js +0 -71
  81. package/dist/SessionService.d.ts +0 -5
  82. package/dist/SessionService.js +0 -56
  83. package/dist/index.d.ts +0 -8
  84. package/dist/index.js +0 -11
  85. package/dist/interfaces.d.ts +0 -11
  86. package/dist/interfaces.js +0 -2
@@ -0,0 +1,288 @@
1
+ import * as drizzle_orm_pg_core from 'drizzle-orm/pg-core';
2
+
3
+ declare const mfaType: drizzle_orm_pg_core.PgEnum<["TOTP", "HARDWARE"]>;
4
+ declare const scope: drizzle_orm_pg_core.PgEnum<["ANON", "MFA", "AUTHED"]>;
5
+ type Scope = (typeof scope.enumValues)[number];
6
+ declare const authSchema: drizzle_orm_pg_core.PgSchema<"auth">;
7
+ declare const authUserTable: drizzle_orm_pg_core.PgTableWithColumns<{
8
+ name: "user_credentials";
9
+ schema: "auth";
10
+ columns: {
11
+ id: drizzle_orm_pg_core.PgColumn<{
12
+ name: "id";
13
+ tableName: "user_credentials";
14
+ dataType: "string";
15
+ columnType: "PgText";
16
+ data: string;
17
+ driverParam: string;
18
+ notNull: true;
19
+ hasDefault: false;
20
+ enumValues: [string, ...string[]];
21
+ baseColumn: never;
22
+ }, {}, {}>;
23
+ email: drizzle_orm_pg_core.PgColumn<{
24
+ name: "email";
25
+ tableName: "user_credentials";
26
+ dataType: "string";
27
+ columnType: "PgText";
28
+ data: string;
29
+ driverParam: string;
30
+ notNull: true;
31
+ hasDefault: false;
32
+ enumValues: [string, ...string[]];
33
+ baseColumn: never;
34
+ }, {}, {}>;
35
+ password: drizzle_orm_pg_core.PgColumn<{
36
+ name: "password";
37
+ tableName: "user_credentials";
38
+ dataType: "string";
39
+ columnType: "PgText";
40
+ data: string;
41
+ driverParam: string;
42
+ notNull: false;
43
+ hasDefault: false;
44
+ enumValues: [string, ...string[]];
45
+ baseColumn: never;
46
+ }, {}, {}>;
47
+ role: drizzle_orm_pg_core.PgColumn<{
48
+ name: "role";
49
+ tableName: "user_credentials";
50
+ dataType: "number";
51
+ columnType: "PgInteger";
52
+ data: number;
53
+ driverParam: string | number;
54
+ notNull: true;
55
+ hasDefault: true;
56
+ enumValues: undefined;
57
+ baseColumn: never;
58
+ }, {}, {}>;
59
+ };
60
+ dialect: "pg";
61
+ }>;
62
+ type AuthUser = typeof authUserTable.$inferSelect;
63
+ declare const authSessionTable: drizzle_orm_pg_core.PgTableWithColumns<{
64
+ name: "sessions";
65
+ schema: "auth";
66
+ columns: {
67
+ id: drizzle_orm_pg_core.PgColumn<{
68
+ name: "id";
69
+ tableName: "sessions";
70
+ dataType: "string";
71
+ columnType: "PgText";
72
+ data: string;
73
+ driverParam: string;
74
+ notNull: true;
75
+ hasDefault: false;
76
+ enumValues: [string, ...string[]];
77
+ baseColumn: never;
78
+ }, {}, {}>;
79
+ userId: drizzle_orm_pg_core.PgColumn<{
80
+ name: "userId";
81
+ tableName: "sessions";
82
+ dataType: "string";
83
+ columnType: "PgText";
84
+ data: string;
85
+ driverParam: string;
86
+ notNull: true;
87
+ hasDefault: false;
88
+ enumValues: [string, ...string[]];
89
+ baseColumn: never;
90
+ }, {}, {}>;
91
+ scope: drizzle_orm_pg_core.PgColumn<{
92
+ name: "scope";
93
+ tableName: "sessions";
94
+ dataType: "string";
95
+ columnType: "PgEnumColumn";
96
+ data: "ANON" | "MFA" | "AUTHED";
97
+ driverParam: string;
98
+ notNull: true;
99
+ hasDefault: true;
100
+ enumValues: ["ANON", "MFA", "AUTHED"];
101
+ baseColumn: never;
102
+ }, {}, {}>;
103
+ expiresAt: drizzle_orm_pg_core.PgColumn<{
104
+ name: "expiresAt";
105
+ tableName: "sessions";
106
+ dataType: "date";
107
+ columnType: "PgTimestamp";
108
+ data: Date;
109
+ driverParam: string;
110
+ notNull: true;
111
+ hasDefault: false;
112
+ enumValues: undefined;
113
+ baseColumn: never;
114
+ }, {}, {}>;
115
+ };
116
+ dialect: "pg";
117
+ }>;
118
+ type AuthSession = typeof authSessionTable.$inferSelect;
119
+ declare const authResetTable: drizzle_orm_pg_core.PgTableWithColumns<{
120
+ name: "resets";
121
+ schema: "auth";
122
+ columns: {
123
+ id: drizzle_orm_pg_core.PgColumn<{
124
+ name: "id";
125
+ tableName: "resets";
126
+ dataType: "string";
127
+ columnType: "PgText";
128
+ data: string;
129
+ driverParam: string;
130
+ notNull: true;
131
+ hasDefault: false;
132
+ enumValues: [string, ...string[]];
133
+ baseColumn: never;
134
+ }, {}, {}>;
135
+ userId: drizzle_orm_pg_core.PgColumn<{
136
+ name: "userId";
137
+ tableName: "resets";
138
+ dataType: "string";
139
+ columnType: "PgText";
140
+ data: string;
141
+ driverParam: string;
142
+ notNull: true;
143
+ hasDefault: false;
144
+ enumValues: [string, ...string[]];
145
+ baseColumn: never;
146
+ }, {}, {}>;
147
+ expiresAt: drizzle_orm_pg_core.PgColumn<{
148
+ name: "expiresAt";
149
+ tableName: "resets";
150
+ dataType: "date";
151
+ columnType: "PgTimestamp";
152
+ data: Date;
153
+ driverParam: string;
154
+ notNull: true;
155
+ hasDefault: false;
156
+ enumValues: undefined;
157
+ baseColumn: never;
158
+ }, {}, {}>;
159
+ };
160
+ dialect: "pg";
161
+ }>;
162
+ type AuthReset = typeof authResetTable.$inferSelect;
163
+ declare const authMFATable: drizzle_orm_pg_core.PgTableWithColumns<{
164
+ name: "mfas";
165
+ schema: "auth";
166
+ columns: {
167
+ id: drizzle_orm_pg_core.PgColumn<{
168
+ name: "id";
169
+ tableName: "mfas";
170
+ dataType: "string";
171
+ columnType: "PgText";
172
+ data: string;
173
+ driverParam: string;
174
+ notNull: true;
175
+ hasDefault: false;
176
+ enumValues: [string, ...string[]];
177
+ baseColumn: never;
178
+ }, {}, {}>;
179
+ name: drizzle_orm_pg_core.PgColumn<{
180
+ name: "name";
181
+ tableName: "mfas";
182
+ dataType: "string";
183
+ columnType: "PgText";
184
+ data: string;
185
+ driverParam: string;
186
+ notNull: true;
187
+ hasDefault: false;
188
+ enumValues: [string, ...string[]];
189
+ baseColumn: never;
190
+ }, {}, {}>;
191
+ userId: drizzle_orm_pg_core.PgColumn<{
192
+ name: "userId";
193
+ tableName: "mfas";
194
+ dataType: "string";
195
+ columnType: "PgText";
196
+ data: string;
197
+ driverParam: string;
198
+ notNull: true;
199
+ hasDefault: false;
200
+ enumValues: [string, ...string[]];
201
+ baseColumn: never;
202
+ }, {}, {}>;
203
+ type: drizzle_orm_pg_core.PgColumn<{
204
+ name: "type";
205
+ tableName: "mfas";
206
+ dataType: "string";
207
+ columnType: "PgEnumColumn";
208
+ data: "TOTP" | "HARDWARE";
209
+ driverParam: string;
210
+ notNull: true;
211
+ hasDefault: true;
212
+ enumValues: ["TOTP", "HARDWARE"];
213
+ baseColumn: never;
214
+ }, {}, {}>;
215
+ secret: drizzle_orm_pg_core.PgColumn<{
216
+ name: "secret";
217
+ tableName: "mfas";
218
+ dataType: "string";
219
+ columnType: "PgText";
220
+ data: string;
221
+ driverParam: string;
222
+ notNull: true;
223
+ hasDefault: false;
224
+ enumValues: [string, ...string[]];
225
+ baseColumn: never;
226
+ }, {}, {}>;
227
+ verifiedAt: drizzle_orm_pg_core.PgColumn<{
228
+ name: "verifiedAt";
229
+ tableName: "mfas";
230
+ dataType: "date";
231
+ columnType: "PgTimestamp";
232
+ data: Date;
233
+ driverParam: string;
234
+ notNull: false;
235
+ hasDefault: false;
236
+ enumValues: undefined;
237
+ baseColumn: never;
238
+ }, {}, {}>;
239
+ };
240
+ dialect: "pg";
241
+ }>;
242
+ type AuthMFA = typeof authMFATable.$inferSelect;
243
+ declare const authClientTable: drizzle_orm_pg_core.PgTableWithColumns<{
244
+ name: "client_credentials";
245
+ schema: "auth";
246
+ columns: {
247
+ id: drizzle_orm_pg_core.PgColumn<{
248
+ name: "id";
249
+ tableName: "client_credentials";
250
+ dataType: "string";
251
+ columnType: "PgText";
252
+ data: string;
253
+ driverParam: string;
254
+ notNull: true;
255
+ hasDefault: false;
256
+ enumValues: [string, ...string[]];
257
+ baseColumn: never;
258
+ }, {}, {}>;
259
+ alias: drizzle_orm_pg_core.PgColumn<{
260
+ name: "alias";
261
+ tableName: "client_credentials";
262
+ dataType: "string";
263
+ columnType: "PgText";
264
+ data: string;
265
+ driverParam: string;
266
+ notNull: true;
267
+ hasDefault: false;
268
+ enumValues: [string, ...string[]];
269
+ baseColumn: never;
270
+ }, {}, {}>;
271
+ secret: drizzle_orm_pg_core.PgColumn<{
272
+ name: "secret";
273
+ tableName: "client_credentials";
274
+ dataType: "string";
275
+ columnType: "PgText";
276
+ data: string;
277
+ driverParam: string;
278
+ notNull: true;
279
+ hasDefault: false;
280
+ enumValues: [string, ...string[]];
281
+ baseColumn: never;
282
+ }, {}, {}>;
283
+ };
284
+ dialect: "pg";
285
+ }>;
286
+ type AuthClient = typeof authClientTable.$inferSelect;
287
+
288
+ export { type AuthClient, type AuthMFA, type AuthReset, type AuthSession, type AuthUser, type Scope, authClientTable, authMFATable, authResetTable, authSchema, authSessionTable, authUserTable, mfaType, scope };
@@ -0,0 +1,7 @@
1
+ import { pgEnum, pgSchema, text, integer, uniqueIndex, timestamp } from 'drizzle-orm/pg-core';
2
+
3
+ var u=10,p=pgEnum("mfaType",["TOTP","HARDWARE"]),c=pgEnum("scope",["ANON","MFA","AUTHED"]),t=pgSchema("auth"),l=t.table("user_credentials",{id:text("id").primaryKey(),email:text("email").notNull(),password:text("password"),role:integer("role").notNull().default(u)},s=>({unique:uniqueIndex().on(s.email,s.role)})),y=t.table("sessions",{id:text("id").primaryKey(),userId:text("userId").notNull().references(()=>l.id,{onDelete:"cascade"}),scope:c("scope").notNull().default("ANON"),expiresAt:timestamp("expiresAt").notNull()}),f=t.table("resets",{id:text("id").primaryKey(),userId:text("userId").notNull().references(()=>l.id,{onDelete:"cascade"}),expiresAt:timestamp("expiresAt").notNull()}),m=t.table("mfas",{id:text("id").primaryKey(),name:text("name").notNull(),userId:text("userId").notNull().references(()=>l.id,{onDelete:"cascade"}),type:p("type").notNull().default("TOTP"),secret:text("secret").notNull(),verifiedAt:timestamp("verifiedAt")}),A=t.table("client_credentials",{id:text("id").primaryKey(),alias:text("alias").notNull().unique(),secret:text("secret").notNull().unique()});
4
+
5
+ export { A as authClientTable, m as authMFATable, f as authResetTable, t as authSchema, y as authSessionTable, l as authUserTable, p as mfaType, c as scope };
6
+ //# sourceMappingURL=out.js.map
7
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/database/schema.ts"],"names":["integer","pgEnum","pgSchema","text","timestamp","uniqueIndex","DEFAULT_ROLE","mfaType","scope","authSchema","authUserTable","table","authSessionTable","authResetTable","authMFATable","authClientTable"],"mappings":"AAEA,OAAS,WAAAA,EAAS,UAAAC,EAAQ,YAAAC,EAAU,QAAAC,EAAM,aAAAC,EAAW,eAAAC,MAAmB,sBAExE,IAAMC,EAAe,GAERC,EAAUN,EAAO,UAAW,CAAC,OAAQ,UAAU,CAAC,EAChDO,EAAQP,EAAO,QAAS,CAAC,OAAQ,MAAO,QAAQ,CAAC,EAIjDQ,EAAaP,EAAS,MAAM,EAE5BQ,EAAgBD,EAAW,MACpC,mBACA,CACI,GAAIN,EAAK,IAAI,EAAE,WAAW,EAC1B,MAAOA,EAAK,OAAO,EAAE,QAAQ,EAC7B,SAAUA,EAAK,UAAU,EACzB,KAAMH,EAAQ,MAAM,EAAE,QAAQ,EAAE,QAAQM,CAAY,CACxD,EACCK,IAAW,CACR,OAAQN,EAAY,EAAE,GAAGM,EAAM,MAAOA,EAAM,IAAI,CACpD,EACJ,EAIaC,EAAmBH,EAAW,MAAM,WAAY,CACzD,GAAIN,EAAK,IAAI,EAAE,WAAW,EAC1B,OAAQA,EAAK,QAAQ,EAChB,QAAQ,EACR,WAAW,IAAMO,EAAc,GAAI,CAAE,SAAU,SAAU,CAAC,EAC/D,MAAOF,EAAM,OAAO,EAAE,QAAQ,EAAE,QAAQ,MAAM,EAC9C,UAAWJ,EAAU,WAAW,EAAE,QAAQ,CAC9C,CAAC,EAIYS,EAAiBJ,EAAW,MAAM,SAAU,CACrD,GAAIN,EAAK,IAAI,EAAE,WAAW,EAC1B,OAAQA,EAAK,QAAQ,EAChB,QAAQ,EACR,WAAW,IAAMO,EAAc,GAAI,CAAE,SAAU,SAAU,CAAC,EAC/D,UAAWN,EAAU,WAAW,EAAE,QAAQ,CAC9C,CAAC,EAIYU,EAAeL,EAAW,MAAM,OAAQ,CACjD,GAAIN,EAAK,IAAI,EAAE,WAAW,EAC1B,KAAMA,EAAK,MAAM,EAAE,QAAQ,EAC3B,OAAQA,EAAK,QAAQ,EAChB,QAAQ,EACR,WAAW,IAAMO,EAAc,GAAI,CAAE,SAAU,SAAU,CAAC,EAC/D,KAAMH,EAAQ,MAAM,EAAE,QAAQ,EAAE,QAAQ,MAAM,EAC9C,OAAQJ,EAAK,QAAQ,EAAE,QAAQ,EAC/B,WAAYC,EAAU,YAAY,CACtC,CAAC,EAIYW,EAAkBN,EAAW,MAAM,qBAAsB,CAClE,GAAIN,EAAK,IAAI,EAAE,WAAW,EAC1B,MAAOA,EAAK,OAAO,EAAE,QAAQ,EAAE,OAAO,EACtC,OAAQA,EAAK,QAAQ,EAAE,QAAQ,EAAE,OAAO,CAC5C,CAAC","sourcesContent":["/* istanbul ignore file */\n\nimport { integer, pgEnum, pgSchema, text, timestamp, uniqueIndex } from 'drizzle-orm/pg-core';\n\nconst DEFAULT_ROLE = 10;\n\nexport const mfaType = pgEnum('mfaType', ['TOTP', 'HARDWARE']);\nexport const scope = pgEnum('scope', ['ANON', 'MFA', 'AUTHED']);\n\nexport type Scope = (typeof scope.enumValues)[number];\n\nexport const authSchema = pgSchema('auth');\n\nexport const authUserTable = authSchema.table(\n 'user_credentials',\n {\n id: text('id').primaryKey(),\n email: text('email').notNull(),\n password: text('password'),\n role: integer('role').notNull().default(DEFAULT_ROLE),\n },\n (table) => ({\n unique: uniqueIndex().on(table.email, table.role),\n })\n);\n\nexport type AuthUser = typeof authUserTable.$inferSelect;\n\nexport const authSessionTable = authSchema.table('sessions', {\n id: text('id').primaryKey(),\n userId: text('userId')\n .notNull()\n .references(() => authUserTable.id, { onDelete: 'cascade' }),\n scope: scope('scope').notNull().default('ANON'),\n expiresAt: timestamp('expiresAt').notNull(),\n});\n\nexport type AuthSession = typeof authSessionTable.$inferSelect;\n\nexport const authResetTable = authSchema.table('resets', {\n id: text('id').primaryKey(),\n userId: text('userId')\n .notNull()\n .references(() => authUserTable.id, { onDelete: 'cascade' }),\n expiresAt: timestamp('expiresAt').notNull(),\n});\n\nexport type AuthReset = typeof authResetTable.$inferSelect;\n\nexport const authMFATable = authSchema.table('mfas', {\n id: text('id').primaryKey(),\n name: text('name').notNull(),\n userId: text('userId')\n .notNull()\n .references(() => authUserTable.id, { onDelete: 'cascade' }),\n type: mfaType('type').notNull().default('TOTP'),\n secret: text('secret').notNull(),\n verifiedAt: timestamp('verifiedAt'),\n});\n\nexport type AuthMFA = typeof authMFATable.$inferSelect;\n\nexport const authClientTable = authSchema.table('client_credentials', {\n id: text('id').primaryKey(),\n alias: text('alias').notNull().unique(),\n secret: text('secret').notNull().unique(),\n});\n\nexport type AuthClient = typeof authClientTable.$inferSelect;\n"]}
@@ -0,0 +1,22 @@
1
+ 'use strict';
2
+
3
+ var server = require('next/server');
4
+ var l = require('joi');
5
+
6
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
7
+
8
+ var l__default = /*#__PURE__*/_interopDefault(l);
9
+
10
+ var a=class extends Error{messages;constructor(e){super(JSON.stringify(e)),this.messages=e,this.name="ValidationError";}},i=a;var d={"alternatives.all":"","alternatives.any":"","alternatives.match":"","alternatives.one":"","alternatives.types":"","any.custom":"","any.default":"","any.failover":"","any.invalid":"","any.only":"","any.ref":"","any.required":"{{#label}} is required","any.unknown":"","array.base":"","array.excludes":"","array.includesRequiredBoth":"","array.includesRequiredKnowns":"","array.includesRequiredUnknowns":"","array.includes":"","array.length":"","array.max":"","array.min":"","array.orderedLength":"","array.sort":"","array.sort.mismatching":"","array.sort.unsupported":"","array.sparse":"","array.unique":"","array.hasKnown":"","array.hasUnknown":"","binary.base":"","binary.length":"","binary.max":"","binary.min":"","boolean.base":"","date.base":"","date.format":"","date.greater":"","date.less":"","date.max":"","date.min":"","date.strict":"","function.arity":"","function.class":"","function.maxArity":"","function.minArity":"","number.base":"{{#label}} should be a number","number.greater":"","number.infinity":"","number.integer":"","number.less":"","number.max":"","number.min":"{{#label}} should be greater than or equal to {{#limit}}","number.multiple":"","number.negative":"","number.port":"","number.positive":"","number.precision":"","number.unsafe":"","object.unknown":"","object.and":"","object.assert":"","object.base":"","object.length":"","object.max":"","object.min":"","object.missing":"","object.nand":"","object.pattern.match":"","object.refType":"","object.regex":"","object.rename.multiple":"","object.rename.override":"","object.schema":"","object.instance":"","object.with":"","object.without":"","object.xor":"","object.oxor":"","string.alphanum":"","string.base64":"","string.base":"","string.creditCard":"","string.dataUri":"","string.domain":"","string.email":"","string.empty":"{{#label}} is required","string.guid":"","string.hexAlign":"","string.hex":"","string.hostname":"","string.ipVersion":"","string.ip":"","string.isoDate":"","string.isoDuration":"","string.length":"","string.lowercase":"","string.max":"","string.min":"","string.normalize":"","string.pattern.base":"{{#label}} is not in the correct format","string.pattern.name":"","string.pattern.invert.base":"","string.pattern.invert.name":"","string.token":"","string.trim":"","string.uppercase":"","string.uri":"","string.uriCustomScheme":"","string.uriRelativeOnly":"","symbol.base":"","symbol.map":""},s=d;function S(){return l__default.default}function v(){return s}function b(){return Object.entries(s).reduce((r,[e,n])=>n?{...r,[e]:n}:r,{})}function g(r){let e=r.details.reduce((n,t)=>({...n,[t.path.join(".")]:t.message.replace(/"/gu,"")}),{});return new i(e)}async function m(r,e,n){try{return [await e.validateAsync(r,{abortEarly:!1,messages:n||b(),stripUnknown:!0}),null]}catch(t){return t instanceof l__default.default.ValidationError?[null,g(t)]:t instanceof Error?[null,t]:[null,new Error("Unknown validation error occured")]}}function w(r){return l__default.default.object(r)}function A(r,e){return r.append(e)}function c(r){return {cause:r.cause,message:r.message,name:r.name,stack:r.stack}}function p(r){return !!Object.prototype.hasOwnProperty.call(r,"fn")}async function f(r){let e={...r.formData};if(r.request){let[t,o]=await m(r.formData,r.request);if(o!==null)return o instanceof i&&r.onValidationError?.(o),[null,c(o)];e=t;}if(!p(r))return await r.onSuccess?.(e),[e,null];let n=null;try{n=await r.fn(e);}catch(t){if(t instanceof i)return r.onValidationError?.(t),[null,c(t)];throw t instanceof Error?t:new Error("The function supplied to submitForm encountered an unknown error")}if(!n)throw new Error("NO_MODEL");return await r.onSuccess?.(n),[n,null]}async function O(r){let[e,n]=await f(r);if(n!==null){if(n.name==="ValidationError")try{let t=JSON.parse(n.message);return [null,server.NextResponse.json(t,{status:422})]}catch{return [null,server.NextResponse.json({message:"An unknown error occured"},{status:500})]}return [null,server.NextResponse.json({message:n.message},{status:500})]}return [e,null]}var y=["image/png","image/jpeg","image/jpg"];async function R(r,e){return r?r instanceof File?(e?.types||y).includes(r.type)?r.size>(e?.maxSize||5242880)?Promise.resolve([null,new Error("IMAGE_TOO_HEAVY")]):Promise.resolve([r,null]):Promise.resolve([null,new Error("IMAGE_TYPE_NOT_VALID")]):Promise.resolve([null,new Error("IMAGE_NOT_VALID")]):Promise.resolve([null,new Error("IMAGE_UNDEFINED")])}
11
+
12
+ exports.ValidationError = i;
13
+ exports.createSchema = w;
14
+ exports.extendSchema = A;
15
+ exports.getDefaultErrorMessages = v;
16
+ exports.submitAPIRequest = O;
17
+ exports.submitForm = f;
18
+ exports.validate = S;
19
+ exports.validateImage = R;
20
+ exports.validateSchema = m;
21
+ //# sourceMappingURL=out.js.map
22
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/forms/FormService.ts","../../src/forms/ValidationError.ts","../../src/forms/ValidationService.ts","../../src/forms/lang.ts","../../src/forms/ImageService.ts"],"names":["NextResponse","ValidationError","messages","ValidationError_default","Joi","lang_default","validate","getDefaultErrorMessages","getErrorMessages","acc","key","value","transformErrors","error","cur","validateSchema","formData","validation","err","createSchema","schema","extendSchema","appends","serializeError","hasFn","args","submitForm","data","validated","validationError","model","submitAPIRequest","response","errors","DEFAULT_TYPES","validateImage","image","config"],"mappings":"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","sourcesContent":["/* eslint-disable max-statements */\n\nimport type { SerializedError, SerializedErrorable } from '@sqrzro/interfaces';\nimport type Joi from 'joi';\nimport { NextResponse } from 'next/server';\n\nimport ValidationError from './ValidationError';\nimport { validateSchema } from './ValidationService';\n\nfunction serializeError(err: Error): SerializedError {\n return {\n cause: err.cause,\n message: err.message,\n name: err.name,\n stack: err.stack,\n };\n}\n\ninterface SubmitFormArgs<F extends object> {\n formData: F;\n onSuccess?: (model: F) => Promise<void> | void;\n onValidationError?: (error: ValidationError) => void;\n request?: Joi.ObjectSchema<F>;\n}\n\ninterface SubmitFormArgsWithFn<F extends object, M> extends Omit<SubmitFormArgs<F>, 'onSuccess'> {\n fn: (data: F) => Promise<M | null>;\n onSuccess?: (model: M) => Promise<void> | void;\n}\n\nfunction hasFn<F extends object, M>(\n args: SubmitFormArgs<F> | SubmitFormArgsWithFn<F, M>\n): args is SubmitFormArgsWithFn<F, M> {\n return Boolean(Object.prototype.hasOwnProperty.call(args, 'fn'));\n}\n\nexport async function submitForm<F extends object>(\n args: SubmitFormArgs<F>\n): Promise<SerializedErrorable<F>>;\nexport async function submitForm<F extends object, M>(\n args: SubmitFormArgsWithFn<F, M>\n): Promise<SerializedErrorable<M>>;\n\nexport async function submitForm<F extends object, M>(\n args: SubmitFormArgs<F> | SubmitFormArgsWithFn<F, M>\n): Promise<[F, null] | [M, null] | [null, SerializedError]> {\n let data = { ...args.formData };\n\n if (args.request) {\n const [validated, validationError] = await validateSchema<F>(args.formData, args.request);\n\n if (validationError !== null) {\n if (validationError instanceof ValidationError) {\n args.onValidationError?.(validationError);\n }\n\n return [null, serializeError(validationError)];\n }\n\n data = validated;\n }\n\n if (!hasFn(args)) {\n await args.onSuccess?.(data);\n return [data, null];\n }\n\n let model: Awaited<M> | null = null;\n\n try {\n model = await args.fn(data);\n } catch (err: unknown) {\n if (err instanceof ValidationError) {\n args.onValidationError?.(err);\n return [null, serializeError(err)];\n }\n if (err instanceof Error) {\n throw err;\n }\n throw new Error('The function supplied to submitForm encountered an unknown error');\n }\n\n if (!model) {\n throw new Error('NO_MODEL');\n }\n\n await args.onSuccess?.(model);\n return [model, null];\n}\n\nexport async function submitAPIRequest<F extends object, M>(\n args: SubmitFormArgsWithFn<F, M>\n): Promise<[M, null] | [null, NextResponse]> {\n const [response, error] = await submitForm<F, M>(args);\n\n if (error !== null) {\n if (error.name === 'ValidationError') {\n try {\n const errors = JSON.parse(error.message) as Record<string, string>;\n return [null, NextResponse.json(errors, { status: 422 })];\n } catch (err) {\n return [\n null,\n NextResponse.json({ message: 'An unknown error occured' }, { status: 500 }),\n ];\n }\n }\n return [null, NextResponse.json({ message: error.message }, { status: 500 })];\n }\n\n return [response, null];\n}\n","class 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","import type { Errorable } from '@sqrzro/interfaces';\nimport Joi from 'joi';\n\nimport lang from './lang';\nimport ValidationError from './ValidationError';\n\nexport function validate(): typeof Joi {\n return Joi;\n}\n\nexport type ValidationCustomHelpers<V = any> = Joi.CustomHelpers<V>; // eslint-disable-line @typescript-eslint/no-explicit-any\nexport type ValidationExternalHelpers<V = any> = Joi.ExternalHelpers<V>; // eslint-disable-line @typescript-eslint/no-explicit-any\nexport type ValidationErrorReport = Joi.ErrorReport;\n\nexport function getDefaultErrorMessages(): Record<string, string> {\n return lang;\n}\n\nfunction getErrorMessages(): Record<string, string> {\n return Object.entries(lang).reduce((acc, [key, value]) => {\n if (!value) {\n return acc;\n }\n return {\n ...acc,\n [key]: value,\n };\n }, {});\n}\n\nfunction transformErrors(error: Joi.ValidationError): ValidationError {\n const messages = error.details.reduce(\n (acc, cur) => ({\n ...acc,\n [cur.path.join('.')]: cur.message.replace(/\"/gu, ''),\n }),\n {}\n );\n return new ValidationError(messages);\n}\n\n/**\n * This function takes FormData and a schema. It then attempts to transform the FormData into an\n * object that matches `T`. This is because the FormData object is not typed and we want to be able\n * to validate it properly typed.\n *\n * Once transformed, the object is validated against the schema. This will result in either a\n * properly typed `T` object or an array of validation errors.\n * @param formData\n * @param validation\n * @returns\n */\nexport async function validateSchema<T>(\n formData: Partial<T>,\n validation: Joi.ObjectSchema<T>,\n messages?: Record<string, string>\n): Promise<Errorable<T>> {\n try {\n const validated = await validation.validateAsync(formData, {\n abortEarly: false,\n messages: messages || getErrorMessages(),\n stripUnknown: true,\n });\n\n return [validated, null];\n } catch (err) {\n if (err instanceof Joi.ValidationError) {\n return [null, transformErrors(err)];\n }\n\n if (err instanceof Error) {\n return [null, err];\n }\n\n return [null, new Error('Unknown validation error occured')];\n }\n}\n\nexport function createSchema<T>(schema: Joi.SchemaMap<T, true>): Joi.ObjectSchema<T> {\n return Joi.object<T>(schema);\n}\n\nexport function extendSchema<T, U extends T>(\n schema: Joi.ObjectSchema<T>,\n appends: Joi.PartialSchemaMap<U>\n): Joi.ObjectSchema<U> {\n return schema.append<U>(appends);\n}\n","const messages: Record<string, string> = {\n 'alternatives.all': '',\n 'alternatives.any': '',\n 'alternatives.match': '',\n 'alternatives.one': '',\n 'alternatives.types': '',\n 'any.custom': '',\n 'any.default': '',\n 'any.failover': '',\n 'any.invalid': '',\n 'any.only': '',\n 'any.ref': '',\n 'any.required': '{{#label}} is required',\n 'any.unknown': '',\n 'array.base': '',\n 'array.excludes': '',\n 'array.includesRequiredBoth': '',\n 'array.includesRequiredKnowns': '',\n 'array.includesRequiredUnknowns': '',\n 'array.includes': '',\n 'array.length': '',\n 'array.max': '',\n 'array.min': '',\n 'array.orderedLength': '',\n 'array.sort': '',\n 'array.sort.mismatching': '',\n 'array.sort.unsupported': '',\n 'array.sparse': '',\n 'array.unique': '',\n 'array.hasKnown': '',\n 'array.hasUnknown': '',\n 'binary.base': '',\n 'binary.length': '',\n 'binary.max': '',\n 'binary.min': '',\n 'boolean.base': '',\n 'date.base': '',\n 'date.format': '',\n 'date.greater': '',\n 'date.less': '',\n 'date.max': '',\n 'date.min': '',\n 'date.strict': '',\n 'function.arity': '',\n 'function.class': '',\n 'function.maxArity': '',\n 'function.minArity': '',\n 'number.base': '{{#label}} should be a number',\n 'number.greater': '',\n 'number.infinity': '',\n 'number.integer': '',\n 'number.less': '',\n 'number.max': '',\n 'number.min': '{{#label}} should be greater than or equal to {{#limit}}',\n 'number.multiple': '',\n 'number.negative': '',\n 'number.port': '',\n 'number.positive': '',\n 'number.precision': '',\n 'number.unsafe': '',\n 'object.unknown': '',\n 'object.and': '',\n 'object.assert': '',\n 'object.base': '',\n 'object.length': '',\n 'object.max': '',\n 'object.min': '',\n 'object.missing': '',\n 'object.nand': '',\n 'object.pattern.match': '',\n 'object.refType': '',\n 'object.regex': '',\n 'object.rename.multiple': '',\n 'object.rename.override': '',\n 'object.schema': '',\n 'object.instance': '',\n 'object.with': '',\n 'object.without': '',\n 'object.xor': '',\n 'object.oxor': '',\n 'string.alphanum': '',\n 'string.base64': '',\n 'string.base': '',\n 'string.creditCard': '',\n 'string.dataUri': '',\n 'string.domain': '',\n 'string.email': '',\n 'string.empty': '{{#label}} is required',\n 'string.guid': '',\n 'string.hexAlign': '',\n 'string.hex': '',\n 'string.hostname': '',\n 'string.ipVersion': '',\n 'string.ip': '',\n 'string.isoDate': '',\n 'string.isoDuration': '',\n 'string.length': '',\n 'string.lowercase': '',\n 'string.max': '',\n 'string.min': '',\n 'string.normalize': '',\n 'string.pattern.base': '{{#label}} is not in the correct format',\n 'string.pattern.name': '',\n 'string.pattern.invert.base': '',\n 'string.pattern.invert.name': '',\n 'string.token': '',\n 'string.trim': '',\n 'string.uppercase': '',\n 'string.uri': '',\n 'string.uriCustomScheme': '',\n 'string.uriRelativeOnly': '',\n 'symbol.base': '',\n 'symbol.map': '',\n};\n\nexport default messages;\n","'use server';\n\nimport type { Errorable } from '@sqrzro/interfaces';\n\nconst DEFAULT_TYPES = ['image/png', 'image/jpeg', 'image/jpg'];\n// 5MB\nconst DEFAULT_MAX_SIZE = 5242880;\n\ninterface ImageValidationConfig {\n maxSize?: number;\n types?: string[];\n}\n\nexport async function validateImage(\n image: File | null,\n config?: ImageValidationConfig\n): Promise<Errorable<File>> {\n if (!image) {\n return Promise.resolve([null, new Error('IMAGE_UNDEFINED')]);\n }\n\n if (!(image instanceof File)) {\n return Promise.resolve([null, new Error('IMAGE_NOT_VALID')]);\n }\n\n if (!(config?.types || DEFAULT_TYPES).includes(image.type)) {\n return Promise.resolve([null, new Error('IMAGE_TYPE_NOT_VALID')]);\n }\n\n if (image.size > (config?.maxSize || DEFAULT_MAX_SIZE)) {\n return Promise.resolve([null, new Error('IMAGE_TOO_HEAVY')]);\n }\n\n return Promise.resolve([image, null]);\n}\n"]}
@@ -0,0 +1,50 @@
1
+ import { SerializedErrorable, Errorable } from '@sqrzro/interfaces';
2
+ import Joi from 'joi';
3
+ import { NextResponse } from 'next/server';
4
+
5
+ declare class ValidationError extends Error {
6
+ messages: Record<string, string>;
7
+ constructor(messages: Record<string, string>);
8
+ }
9
+
10
+ interface SubmitFormArgs<F extends object> {
11
+ formData: F;
12
+ onSuccess?: (model: F) => Promise<void> | void;
13
+ onValidationError?: (error: ValidationError) => void;
14
+ request?: Joi.ObjectSchema<F>;
15
+ }
16
+ interface SubmitFormArgsWithFn<F extends object, M> extends Omit<SubmitFormArgs<F>, 'onSuccess'> {
17
+ fn: (data: F) => Promise<M | null>;
18
+ onSuccess?: (model: M) => Promise<void> | void;
19
+ }
20
+ declare function submitForm<F extends object>(args: SubmitFormArgs<F>): Promise<SerializedErrorable<F>>;
21
+ declare function submitForm<F extends object, M>(args: SubmitFormArgsWithFn<F, M>): Promise<SerializedErrorable<M>>;
22
+ declare function submitAPIRequest<F extends object, M>(args: SubmitFormArgsWithFn<F, M>): Promise<[M, null] | [null, NextResponse]>;
23
+
24
+ interface ImageValidationConfig {
25
+ maxSize?: number;
26
+ types?: string[];
27
+ }
28
+ declare function validateImage(image: File | null, config?: ImageValidationConfig): Promise<Errorable<File>>;
29
+
30
+ declare function validate(): typeof Joi;
31
+ type ValidationCustomHelpers<V = any> = Joi.CustomHelpers<V>;
32
+ type ValidationExternalHelpers<V = any> = Joi.ExternalHelpers<V>;
33
+ type ValidationErrorReport = Joi.ErrorReport;
34
+ declare function getDefaultErrorMessages(): Record<string, string>;
35
+ /**
36
+ * This function takes FormData and a schema. It then attempts to transform the FormData into an
37
+ * object that matches `T`. This is because the FormData object is not typed and we want to be able
38
+ * to validate it properly typed.
39
+ *
40
+ * Once transformed, the object is validated against the schema. This will result in either a
41
+ * properly typed `T` object or an array of validation errors.
42
+ * @param formData
43
+ * @param validation
44
+ * @returns
45
+ */
46
+ declare function validateSchema<T>(formData: Partial<T>, validation: Joi.ObjectSchema<T>, messages?: Record<string, string>): Promise<Errorable<T>>;
47
+ declare function createSchema<T>(schema: Joi.SchemaMap<T, true>): Joi.ObjectSchema<T>;
48
+ declare function extendSchema<T, U extends T>(schema: Joi.ObjectSchema<T>, appends: Joi.PartialSchemaMap<U>): Joi.ObjectSchema<U>;
49
+
50
+ export { type ValidationCustomHelpers, ValidationError, type ValidationErrorReport, type ValidationExternalHelpers, createSchema, extendSchema, getDefaultErrorMessages, submitAPIRequest, submitForm, validate, validateImage, validateSchema };
@@ -0,0 +1,50 @@
1
+ import { SerializedErrorable, Errorable } from '@sqrzro/interfaces';
2
+ import Joi from 'joi';
3
+ import { NextResponse } from 'next/server';
4
+
5
+ declare class ValidationError extends Error {
6
+ messages: Record<string, string>;
7
+ constructor(messages: Record<string, string>);
8
+ }
9
+
10
+ interface SubmitFormArgs<F extends object> {
11
+ formData: F;
12
+ onSuccess?: (model: F) => Promise<void> | void;
13
+ onValidationError?: (error: ValidationError) => void;
14
+ request?: Joi.ObjectSchema<F>;
15
+ }
16
+ interface SubmitFormArgsWithFn<F extends object, M> extends Omit<SubmitFormArgs<F>, 'onSuccess'> {
17
+ fn: (data: F) => Promise<M | null>;
18
+ onSuccess?: (model: M) => Promise<void> | void;
19
+ }
20
+ declare function submitForm<F extends object>(args: SubmitFormArgs<F>): Promise<SerializedErrorable<F>>;
21
+ declare function submitForm<F extends object, M>(args: SubmitFormArgsWithFn<F, M>): Promise<SerializedErrorable<M>>;
22
+ declare function submitAPIRequest<F extends object, M>(args: SubmitFormArgsWithFn<F, M>): Promise<[M, null] | [null, NextResponse]>;
23
+
24
+ interface ImageValidationConfig {
25
+ maxSize?: number;
26
+ types?: string[];
27
+ }
28
+ declare function validateImage(image: File | null, config?: ImageValidationConfig): Promise<Errorable<File>>;
29
+
30
+ declare function validate(): typeof Joi;
31
+ type ValidationCustomHelpers<V = any> = Joi.CustomHelpers<V>;
32
+ type ValidationExternalHelpers<V = any> = Joi.ExternalHelpers<V>;
33
+ type ValidationErrorReport = Joi.ErrorReport;
34
+ declare function getDefaultErrorMessages(): Record<string, string>;
35
+ /**
36
+ * This function takes FormData and a schema. It then attempts to transform the FormData into an
37
+ * object that matches `T`. This is because the FormData object is not typed and we want to be able
38
+ * to validate it properly typed.
39
+ *
40
+ * Once transformed, the object is validated against the schema. This will result in either a
41
+ * properly typed `T` object or an array of validation errors.
42
+ * @param formData
43
+ * @param validation
44
+ * @returns
45
+ */
46
+ declare function validateSchema<T>(formData: Partial<T>, validation: Joi.ObjectSchema<T>, messages?: Record<string, string>): Promise<Errorable<T>>;
47
+ declare function createSchema<T>(schema: Joi.SchemaMap<T, true>): Joi.ObjectSchema<T>;
48
+ declare function extendSchema<T, U extends T>(schema: Joi.ObjectSchema<T>, appends: Joi.PartialSchemaMap<U>): Joi.ObjectSchema<U>;
49
+
50
+ export { type ValidationCustomHelpers, ValidationError, type ValidationErrorReport, type ValidationExternalHelpers, createSchema, extendSchema, getDefaultErrorMessages, submitAPIRequest, submitForm, validate, validateImage, validateSchema };
@@ -0,0 +1,8 @@
1
+ import { NextResponse } from 'next/server';
2
+ import l from 'joi';
3
+
4
+ var a=class extends Error{messages;constructor(e){super(JSON.stringify(e)),this.messages=e,this.name="ValidationError";}},i=a;var d={"alternatives.all":"","alternatives.any":"","alternatives.match":"","alternatives.one":"","alternatives.types":"","any.custom":"","any.default":"","any.failover":"","any.invalid":"","any.only":"","any.ref":"","any.required":"{{#label}} is required","any.unknown":"","array.base":"","array.excludes":"","array.includesRequiredBoth":"","array.includesRequiredKnowns":"","array.includesRequiredUnknowns":"","array.includes":"","array.length":"","array.max":"","array.min":"","array.orderedLength":"","array.sort":"","array.sort.mismatching":"","array.sort.unsupported":"","array.sparse":"","array.unique":"","array.hasKnown":"","array.hasUnknown":"","binary.base":"","binary.length":"","binary.max":"","binary.min":"","boolean.base":"","date.base":"","date.format":"","date.greater":"","date.less":"","date.max":"","date.min":"","date.strict":"","function.arity":"","function.class":"","function.maxArity":"","function.minArity":"","number.base":"{{#label}} should be a number","number.greater":"","number.infinity":"","number.integer":"","number.less":"","number.max":"","number.min":"{{#label}} should be greater than or equal to {{#limit}}","number.multiple":"","number.negative":"","number.port":"","number.positive":"","number.precision":"","number.unsafe":"","object.unknown":"","object.and":"","object.assert":"","object.base":"","object.length":"","object.max":"","object.min":"","object.missing":"","object.nand":"","object.pattern.match":"","object.refType":"","object.regex":"","object.rename.multiple":"","object.rename.override":"","object.schema":"","object.instance":"","object.with":"","object.without":"","object.xor":"","object.oxor":"","string.alphanum":"","string.base64":"","string.base":"","string.creditCard":"","string.dataUri":"","string.domain":"","string.email":"","string.empty":"{{#label}} is required","string.guid":"","string.hexAlign":"","string.hex":"","string.hostname":"","string.ipVersion":"","string.ip":"","string.isoDate":"","string.isoDuration":"","string.length":"","string.lowercase":"","string.max":"","string.min":"","string.normalize":"","string.pattern.base":"{{#label}} is not in the correct format","string.pattern.name":"","string.pattern.invert.base":"","string.pattern.invert.name":"","string.token":"","string.trim":"","string.uppercase":"","string.uri":"","string.uriCustomScheme":"","string.uriRelativeOnly":"","symbol.base":"","symbol.map":""},s=d;function S(){return l}function v(){return s}function b(){return Object.entries(s).reduce((r,[e,n])=>n?{...r,[e]:n}:r,{})}function g(r){let e=r.details.reduce((n,t)=>({...n,[t.path.join(".")]:t.message.replace(/"/gu,"")}),{});return new i(e)}async function m(r,e,n){try{return [await e.validateAsync(r,{abortEarly:!1,messages:n||b(),stripUnknown:!0}),null]}catch(t){return t instanceof l.ValidationError?[null,g(t)]:t instanceof Error?[null,t]:[null,new Error("Unknown validation error occured")]}}function w(r){return l.object(r)}function A(r,e){return r.append(e)}function c(r){return {cause:r.cause,message:r.message,name:r.name,stack:r.stack}}function p(r){return !!Object.prototype.hasOwnProperty.call(r,"fn")}async function f(r){let e={...r.formData};if(r.request){let[t,o]=await m(r.formData,r.request);if(o!==null)return o instanceof i&&r.onValidationError?.(o),[null,c(o)];e=t;}if(!p(r))return await r.onSuccess?.(e),[e,null];let n=null;try{n=await r.fn(e);}catch(t){if(t instanceof i)return r.onValidationError?.(t),[null,c(t)];throw t instanceof Error?t:new Error("The function supplied to submitForm encountered an unknown error")}if(!n)throw new Error("NO_MODEL");return await r.onSuccess?.(n),[n,null]}async function O(r){let[e,n]=await f(r);if(n!==null){if(n.name==="ValidationError")try{let t=JSON.parse(n.message);return [null,NextResponse.json(t,{status:422})]}catch{return [null,NextResponse.json({message:"An unknown error occured"},{status:500})]}return [null,NextResponse.json({message:n.message},{status:500})]}return [e,null]}var y=["image/png","image/jpeg","image/jpg"];async function R(r,e){return r?r instanceof File?(e?.types||y).includes(r.type)?r.size>(e?.maxSize||5242880)?Promise.resolve([null,new Error("IMAGE_TOO_HEAVY")]):Promise.resolve([r,null]):Promise.resolve([null,new Error("IMAGE_TYPE_NOT_VALID")]):Promise.resolve([null,new Error("IMAGE_NOT_VALID")]):Promise.resolve([null,new Error("IMAGE_UNDEFINED")])}
5
+
6
+ export { i as ValidationError, w as createSchema, A as extendSchema, v as getDefaultErrorMessages, O as submitAPIRequest, f as submitForm, S as validate, R as validateImage, m as validateSchema };
7
+ //# sourceMappingURL=out.js.map
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/forms/FormService.ts","../../src/forms/ValidationError.ts","../../src/forms/ValidationService.ts","../../src/forms/lang.ts","../../src/forms/ImageService.ts"],"names":["NextResponse","ValidationError","messages","ValidationError_default","Joi","lang_default","validate","getDefaultErrorMessages","getErrorMessages","acc","key","value","transformErrors","error","cur","validateSchema","formData","validation","err","createSchema","schema","extendSchema","appends","serializeError","hasFn","args","submitForm","data","validated","validationError","model","submitAPIRequest","response","errors","DEFAULT_TYPES","validateImage","image","config"],"mappings":"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","sourcesContent":["/* eslint-disable max-statements */\n\nimport type { SerializedError, SerializedErrorable } from '@sqrzro/interfaces';\nimport type Joi from 'joi';\nimport { NextResponse } from 'next/server';\n\nimport ValidationError from './ValidationError';\nimport { validateSchema } from './ValidationService';\n\nfunction serializeError(err: Error): SerializedError {\n return {\n cause: err.cause,\n message: err.message,\n name: err.name,\n stack: err.stack,\n };\n}\n\ninterface SubmitFormArgs<F extends object> {\n formData: F;\n onSuccess?: (model: F) => Promise<void> | void;\n onValidationError?: (error: ValidationError) => void;\n request?: Joi.ObjectSchema<F>;\n}\n\ninterface SubmitFormArgsWithFn<F extends object, M> extends Omit<SubmitFormArgs<F>, 'onSuccess'> {\n fn: (data: F) => Promise<M | null>;\n onSuccess?: (model: M) => Promise<void> | void;\n}\n\nfunction hasFn<F extends object, M>(\n args: SubmitFormArgs<F> | SubmitFormArgsWithFn<F, M>\n): args is SubmitFormArgsWithFn<F, M> {\n return Boolean(Object.prototype.hasOwnProperty.call(args, 'fn'));\n}\n\nexport async function submitForm<F extends object>(\n args: SubmitFormArgs<F>\n): Promise<SerializedErrorable<F>>;\nexport async function submitForm<F extends object, M>(\n args: SubmitFormArgsWithFn<F, M>\n): Promise<SerializedErrorable<M>>;\n\nexport async function submitForm<F extends object, M>(\n args: SubmitFormArgs<F> | SubmitFormArgsWithFn<F, M>\n): Promise<[F, null] | [M, null] | [null, SerializedError]> {\n let data = { ...args.formData };\n\n if (args.request) {\n const [validated, validationError] = await validateSchema<F>(args.formData, args.request);\n\n if (validationError !== null) {\n if (validationError instanceof ValidationError) {\n args.onValidationError?.(validationError);\n }\n\n return [null, serializeError(validationError)];\n }\n\n data = validated;\n }\n\n if (!hasFn(args)) {\n await args.onSuccess?.(data);\n return [data, null];\n }\n\n let model: Awaited<M> | null = null;\n\n try {\n model = await args.fn(data);\n } catch (err: unknown) {\n if (err instanceof ValidationError) {\n args.onValidationError?.(err);\n return [null, serializeError(err)];\n }\n if (err instanceof Error) {\n throw err;\n }\n throw new Error('The function supplied to submitForm encountered an unknown error');\n }\n\n if (!model) {\n throw new Error('NO_MODEL');\n }\n\n await args.onSuccess?.(model);\n return [model, null];\n}\n\nexport async function submitAPIRequest<F extends object, M>(\n args: SubmitFormArgsWithFn<F, M>\n): Promise<[M, null] | [null, NextResponse]> {\n const [response, error] = await submitForm<F, M>(args);\n\n if (error !== null) {\n if (error.name === 'ValidationError') {\n try {\n const errors = JSON.parse(error.message) as Record<string, string>;\n return [null, NextResponse.json(errors, { status: 422 })];\n } catch (err) {\n return [\n null,\n NextResponse.json({ message: 'An unknown error occured' }, { status: 500 }),\n ];\n }\n }\n return [null, NextResponse.json({ message: error.message }, { status: 500 })];\n }\n\n return [response, null];\n}\n","class 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","import type { Errorable } from '@sqrzro/interfaces';\nimport Joi from 'joi';\n\nimport lang from './lang';\nimport ValidationError from './ValidationError';\n\nexport function validate(): typeof Joi {\n return Joi;\n}\n\nexport type ValidationCustomHelpers<V = any> = Joi.CustomHelpers<V>; // eslint-disable-line @typescript-eslint/no-explicit-any\nexport type ValidationExternalHelpers<V = any> = Joi.ExternalHelpers<V>; // eslint-disable-line @typescript-eslint/no-explicit-any\nexport type ValidationErrorReport = Joi.ErrorReport;\n\nexport function getDefaultErrorMessages(): Record<string, string> {\n return lang;\n}\n\nfunction getErrorMessages(): Record<string, string> {\n return Object.entries(lang).reduce((acc, [key, value]) => {\n if (!value) {\n return acc;\n }\n return {\n ...acc,\n [key]: value,\n };\n }, {});\n}\n\nfunction transformErrors(error: Joi.ValidationError): ValidationError {\n const messages = error.details.reduce(\n (acc, cur) => ({\n ...acc,\n [cur.path.join('.')]: cur.message.replace(/\"/gu, ''),\n }),\n {}\n );\n return new ValidationError(messages);\n}\n\n/**\n * This function takes FormData and a schema. It then attempts to transform the FormData into an\n * object that matches `T`. This is because the FormData object is not typed and we want to be able\n * to validate it properly typed.\n *\n * Once transformed, the object is validated against the schema. This will result in either a\n * properly typed `T` object or an array of validation errors.\n * @param formData\n * @param validation\n * @returns\n */\nexport async function validateSchema<T>(\n formData: Partial<T>,\n validation: Joi.ObjectSchema<T>,\n messages?: Record<string, string>\n): Promise<Errorable<T>> {\n try {\n const validated = await validation.validateAsync(formData, {\n abortEarly: false,\n messages: messages || getErrorMessages(),\n stripUnknown: true,\n });\n\n return [validated, null];\n } catch (err) {\n if (err instanceof Joi.ValidationError) {\n return [null, transformErrors(err)];\n }\n\n if (err instanceof Error) {\n return [null, err];\n }\n\n return [null, new Error('Unknown validation error occured')];\n }\n}\n\nexport function createSchema<T>(schema: Joi.SchemaMap<T, true>): Joi.ObjectSchema<T> {\n return Joi.object<T>(schema);\n}\n\nexport function extendSchema<T, U extends T>(\n schema: Joi.ObjectSchema<T>,\n appends: Joi.PartialSchemaMap<U>\n): Joi.ObjectSchema<U> {\n return schema.append<U>(appends);\n}\n","const messages: Record<string, string> = {\n 'alternatives.all': '',\n 'alternatives.any': '',\n 'alternatives.match': '',\n 'alternatives.one': '',\n 'alternatives.types': '',\n 'any.custom': '',\n 'any.default': '',\n 'any.failover': '',\n 'any.invalid': '',\n 'any.only': '',\n 'any.ref': '',\n 'any.required': '{{#label}} is required',\n 'any.unknown': '',\n 'array.base': '',\n 'array.excludes': '',\n 'array.includesRequiredBoth': '',\n 'array.includesRequiredKnowns': '',\n 'array.includesRequiredUnknowns': '',\n 'array.includes': '',\n 'array.length': '',\n 'array.max': '',\n 'array.min': '',\n 'array.orderedLength': '',\n 'array.sort': '',\n 'array.sort.mismatching': '',\n 'array.sort.unsupported': '',\n 'array.sparse': '',\n 'array.unique': '',\n 'array.hasKnown': '',\n 'array.hasUnknown': '',\n 'binary.base': '',\n 'binary.length': '',\n 'binary.max': '',\n 'binary.min': '',\n 'boolean.base': '',\n 'date.base': '',\n 'date.format': '',\n 'date.greater': '',\n 'date.less': '',\n 'date.max': '',\n 'date.min': '',\n 'date.strict': '',\n 'function.arity': '',\n 'function.class': '',\n 'function.maxArity': '',\n 'function.minArity': '',\n 'number.base': '{{#label}} should be a number',\n 'number.greater': '',\n 'number.infinity': '',\n 'number.integer': '',\n 'number.less': '',\n 'number.max': '',\n 'number.min': '{{#label}} should be greater than or equal to {{#limit}}',\n 'number.multiple': '',\n 'number.negative': '',\n 'number.port': '',\n 'number.positive': '',\n 'number.precision': '',\n 'number.unsafe': '',\n 'object.unknown': '',\n 'object.and': '',\n 'object.assert': '',\n 'object.base': '',\n 'object.length': '',\n 'object.max': '',\n 'object.min': '',\n 'object.missing': '',\n 'object.nand': '',\n 'object.pattern.match': '',\n 'object.refType': '',\n 'object.regex': '',\n 'object.rename.multiple': '',\n 'object.rename.override': '',\n 'object.schema': '',\n 'object.instance': '',\n 'object.with': '',\n 'object.without': '',\n 'object.xor': '',\n 'object.oxor': '',\n 'string.alphanum': '',\n 'string.base64': '',\n 'string.base': '',\n 'string.creditCard': '',\n 'string.dataUri': '',\n 'string.domain': '',\n 'string.email': '',\n 'string.empty': '{{#label}} is required',\n 'string.guid': '',\n 'string.hexAlign': '',\n 'string.hex': '',\n 'string.hostname': '',\n 'string.ipVersion': '',\n 'string.ip': '',\n 'string.isoDate': '',\n 'string.isoDuration': '',\n 'string.length': '',\n 'string.lowercase': '',\n 'string.max': '',\n 'string.min': '',\n 'string.normalize': '',\n 'string.pattern.base': '{{#label}} is not in the correct format',\n 'string.pattern.name': '',\n 'string.pattern.invert.base': '',\n 'string.pattern.invert.name': '',\n 'string.token': '',\n 'string.trim': '',\n 'string.uppercase': '',\n 'string.uri': '',\n 'string.uriCustomScheme': '',\n 'string.uriRelativeOnly': '',\n 'symbol.base': '',\n 'symbol.map': '',\n};\n\nexport default messages;\n","'use server';\n\nimport type { Errorable } from '@sqrzro/interfaces';\n\nconst DEFAULT_TYPES = ['image/png', 'image/jpeg', 'image/jpg'];\n// 5MB\nconst DEFAULT_MAX_SIZE = 5242880;\n\ninterface ImageValidationConfig {\n maxSize?: number;\n types?: string[];\n}\n\nexport async function validateImage(\n image: File | null,\n config?: ImageValidationConfig\n): Promise<Errorable<File>> {\n if (!image) {\n return Promise.resolve([null, new Error('IMAGE_UNDEFINED')]);\n }\n\n if (!(image instanceof File)) {\n return Promise.resolve([null, new Error('IMAGE_NOT_VALID')]);\n }\n\n if (!(config?.types || DEFAULT_TYPES).includes(image.type)) {\n return Promise.resolve([null, new Error('IMAGE_TYPE_NOT_VALID')]);\n }\n\n if (image.size > (config?.maxSize || DEFAULT_MAX_SIZE)) {\n return Promise.resolve([null, new Error('IMAGE_TOO_HEAVY')]);\n }\n\n return Promise.resolve([image, null]);\n}\n"]}
@@ -0,0 +1,9 @@
1
+ 'use strict';
2
+
3
+ var utility = require('@sqrzro/utility');
4
+
5
+ var g="id",c="asc",A=1,s=10;function d(n){return {skip:(n-1)*s,take:s}}function u(n,t=[]){let{dir:e,page:r,sort:i,...o}=n||{};return {...d(r?parseInt(r,10):A),orderBy:{[i||g]:e||c},where:utility.getFromObject(o,t)}}async function l({allowedFilters:n,fn:t,searchParams:e}){try{let r=u(e,n);return [await t(r),null]}catch(r){return r instanceof Error?[null,r]:[null,new Error("[getList] An unknown error occurred")]}}
6
+
7
+ exports.getList = l;
8
+ //# sourceMappingURL=out.js.map
9
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lists/ListService.ts"],"names":["getFromObject","DEFAULT_SORT","DEFAULT_DIR","DEFAULT_PAGE","DEFAULT_LIMIT","createPaginationArgs","page","createFindManyArgs","searchParams","allowedFilters","dir","sort","filters","getList","fn","args","err"],"mappings":"AACA,OAAS,iBAAAA,MAAqB,kBAY9B,IAAMC,EAAe,KACfC,EAAc,MACdC,EAAe,EACfC,EAAgB,GAQtB,SAASC,EAAqBC,EAAsB,CAChD,MAAO,CAAE,MAAOA,EAAO,GAAKF,EAAe,KAAMA,CAAc,CACnE,CAEA,SAASG,EACLC,EACAC,EAA2B,CAAC,EAChB,CACZ,GAAM,CAAE,IAAAC,EAAK,KAAAJ,EAAM,KAAAK,EAAM,GAAGC,CAAQ,EAAIJ,GAAgB,CAAC,EAEzD,MAAO,CACH,GAAGH,EAAqBC,EAAO,SAASA,EAAM,EAAE,EAAIH,CAAY,EAChE,QAAS,CAAE,CAACQ,GAAQV,CAAY,EAAGS,GAAOR,CAAY,EACtD,MAAOF,EAAcY,EAASH,CAAc,CAChD,CACJ,CAEA,eAAsBI,EAAW,CAC7B,eAAAJ,EACA,GAAAK,EACA,aAAAN,CACJ,EAA4C,CACxC,GAAI,CACA,IAAMO,EAAOR,EAAmBC,EAAcC,CAAc,EAC5D,MAAO,CAAC,MAAMK,EAAGC,CAAI,EAAG,IAAI,CAChC,OAASC,EAAK,CACV,OAAIA,aAAe,MACR,CAAC,KAAMA,CAAG,EAEd,CAAC,KAAM,IAAI,MAAM,qCAAqC,CAAC,CAClE,CACJ","sourcesContent":["import type { Errorable } from '@sqrzro/interfaces';\nimport { getFromObject } from '@sqrzro/utility';\n\ninterface PaginationArgs {\n skip: number;\n take: number;\n}\n\ninterface FindManyArgs extends PaginationArgs {\n orderBy: Record<string, string>;\n where: Record<string, string>;\n}\n\nconst DEFAULT_SORT = 'id';\nconst DEFAULT_DIR = 'asc';\nconst DEFAULT_PAGE = 1;\nconst DEFAULT_LIMIT = 10;\n\ninterface GetListArgs<T> {\n allowedFilters?: string[];\n fn: (args: FindManyArgs) => Promise<T[]>;\n searchParams?: Record<string, string>;\n}\n\nfunction createPaginationArgs(page): PaginationArgs {\n return { skip: (page - 1) * DEFAULT_LIMIT, take: DEFAULT_LIMIT };\n}\n\nfunction createFindManyArgs(\n searchParams?: Record<string, string>,\n allowedFilters: string[] = []\n): FindManyArgs {\n const { dir, page, sort, ...filters } = searchParams || {};\n\n return {\n ...createPaginationArgs(page ? parseInt(page, 10) : DEFAULT_PAGE),\n orderBy: { [sort || DEFAULT_SORT]: dir || DEFAULT_DIR },\n where: getFromObject(filters, allowedFilters),\n };\n}\n\nexport async function getList<T>({\n allowedFilters,\n fn,\n searchParams,\n}: GetListArgs<T>): Promise<Errorable<T[]>> {\n try {\n const args = createFindManyArgs(searchParams, allowedFilters);\n return [await fn(args), null];\n } catch (err) {\n if (err instanceof Error) {\n return [null, err];\n }\n return [null, new Error('[getList] An unknown error occurred')];\n }\n}\n"]}
@@ -0,0 +1,18 @@
1
+ import { Errorable } from '@sqrzro/interfaces';
2
+
3
+ interface PaginationArgs {
4
+ skip: number;
5
+ take: number;
6
+ }
7
+ interface FindManyArgs extends PaginationArgs {
8
+ orderBy: Record<string, string>;
9
+ where: Record<string, string>;
10
+ }
11
+ interface GetListArgs<T> {
12
+ allowedFilters?: string[];
13
+ fn: (args: FindManyArgs) => Promise<T[]>;
14
+ searchParams?: Record<string, string>;
15
+ }
16
+ declare function getList<T>({ allowedFilters, fn, searchParams, }: GetListArgs<T>): Promise<Errorable<T[]>>;
17
+
18
+ export { getList };
@@ -0,0 +1,18 @@
1
+ import { Errorable } from '@sqrzro/interfaces';
2
+
3
+ interface PaginationArgs {
4
+ skip: number;
5
+ take: number;
6
+ }
7
+ interface FindManyArgs extends PaginationArgs {
8
+ orderBy: Record<string, string>;
9
+ where: Record<string, string>;
10
+ }
11
+ interface GetListArgs<T> {
12
+ allowedFilters?: string[];
13
+ fn: (args: FindManyArgs) => Promise<T[]>;
14
+ searchParams?: Record<string, string>;
15
+ }
16
+ declare function getList<T>({ allowedFilters, fn, searchParams, }: GetListArgs<T>): Promise<Errorable<T[]>>;
17
+
18
+ export { getList };
@@ -0,0 +1,7 @@
1
+ import { getFromObject } from '@sqrzro/utility';
2
+
3
+ var g="id",c="asc",A=1,s=10;function d(n){return {skip:(n-1)*s,take:s}}function u(n,t=[]){let{dir:e,page:r,sort:i,...o}=n||{};return {...d(r?parseInt(r,10):A),orderBy:{[i||g]:e||c},where:getFromObject(o,t)}}async function l({allowedFilters:n,fn:t,searchParams:e}){try{let r=u(e,n);return [await t(r),null]}catch(r){return r instanceof Error?[null,r]:[null,new Error("[getList] An unknown error occurred")]}}
4
+
5
+ export { l as getList };
6
+ //# sourceMappingURL=out.js.map
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lists/ListService.ts"],"names":["getFromObject","DEFAULT_SORT","DEFAULT_DIR","DEFAULT_PAGE","DEFAULT_LIMIT","createPaginationArgs","page","createFindManyArgs","searchParams","allowedFilters","dir","sort","filters","getList","fn","args","err"],"mappings":"AACA,OAAS,iBAAAA,MAAqB,kBAY9B,IAAMC,EAAe,KACfC,EAAc,MACdC,EAAe,EACfC,EAAgB,GAQtB,SAASC,EAAqBC,EAAsB,CAChD,MAAO,CAAE,MAAOA,EAAO,GAAKF,EAAe,KAAMA,CAAc,CACnE,CAEA,SAASG,EACLC,EACAC,EAA2B,CAAC,EAChB,CACZ,GAAM,CAAE,IAAAC,EAAK,KAAAJ,EAAM,KAAAK,EAAM,GAAGC,CAAQ,EAAIJ,GAAgB,CAAC,EAEzD,MAAO,CACH,GAAGH,EAAqBC,EAAO,SAASA,EAAM,EAAE,EAAIH,CAAY,EAChE,QAAS,CAAE,CAACQ,GAAQV,CAAY,EAAGS,GAAOR,CAAY,EACtD,MAAOF,EAAcY,EAASH,CAAc,CAChD,CACJ,CAEA,eAAsBI,EAAW,CAC7B,eAAAJ,EACA,GAAAK,EACA,aAAAN,CACJ,EAA4C,CACxC,GAAI,CACA,IAAMO,EAAOR,EAAmBC,EAAcC,CAAc,EAC5D,MAAO,CAAC,MAAMK,EAAGC,CAAI,EAAG,IAAI,CAChC,OAASC,EAAK,CACV,OAAIA,aAAe,MACR,CAAC,KAAMA,CAAG,EAEd,CAAC,KAAM,IAAI,MAAM,qCAAqC,CAAC,CAClE,CACJ","sourcesContent":["import type { Errorable } from '@sqrzro/interfaces';\nimport { getFromObject } from '@sqrzro/utility';\n\ninterface PaginationArgs {\n skip: number;\n take: number;\n}\n\ninterface FindManyArgs extends PaginationArgs {\n orderBy: Record<string, string>;\n where: Record<string, string>;\n}\n\nconst DEFAULT_SORT = 'id';\nconst DEFAULT_DIR = 'asc';\nconst DEFAULT_PAGE = 1;\nconst DEFAULT_LIMIT = 10;\n\ninterface GetListArgs<T> {\n allowedFilters?: string[];\n fn: (args: FindManyArgs) => Promise<T[]>;\n searchParams?: Record<string, string>;\n}\n\nfunction createPaginationArgs(page): PaginationArgs {\n return { skip: (page - 1) * DEFAULT_LIMIT, take: DEFAULT_LIMIT };\n}\n\nfunction createFindManyArgs(\n searchParams?: Record<string, string>,\n allowedFilters: string[] = []\n): FindManyArgs {\n const { dir, page, sort, ...filters } = searchParams || {};\n\n return {\n ...createPaginationArgs(page ? parseInt(page, 10) : DEFAULT_PAGE),\n orderBy: { [sort || DEFAULT_SORT]: dir || DEFAULT_DIR },\n where: getFromObject(filters, allowedFilters),\n };\n}\n\nexport async function getList<T>({\n allowedFilters,\n fn,\n searchParams,\n}: GetListArgs<T>): Promise<Errorable<T[]>> {\n try {\n const args = createFindManyArgs(searchParams, allowedFilters);\n return [await fn(args), null];\n } catch (err) {\n if (err instanceof Error) {\n return [null, err];\n }\n return [null, new Error('[getList] An unknown error occurred')];\n }\n}\n"]}