@sqrzro/server 4.0.0-alpha.46 → 4.0.0-alpha.47

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.
@@ -0,0 +1,2 @@
1
+ import {randomBytes}from'crypto';var a=16;function f(e,t=a){let r="abcdefghijklmnopqrstuvwxyz0123456789",n=randomBytes(t),o="";for(let s=0;s<t;s++)o+=r[n[s]%r.length];return `${e?e+"_":""}${o}`}var u=f;function i(e){return process.env.SZ_LOG==="true"?true:typeof process.env.SZ_LOG=="string"?process.env.SZ_LOG.split(",").includes(e):false}function g(e,t,r){i(e)&&console.log(`[${e}] ${t}: ${r}`);}var c=g;export{u as a,c as b};//# sourceMappingURL=chunk-6GDOIHTS.js.map
2
+ //# sourceMappingURL=chunk-6GDOIHTS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utility/generate-id.ts","../src/utility/syslog.ts"],"names":["ID_LENGTH","generateID","prefix","length","chars","bytes","randomBytes","result","i","generate_id_default","shouldLog","alias","syslog","fnName","message","syslog_default"],"mappings":"iCAEA,IAAMA,EAAY,EAAA,CAElB,SAASC,EAAsCC,CAAAA,CAAwBC,CAAAA,CAASH,EAAc,CAC1F,IAAMI,EAAQ,sCAAA,CACRC,CAAAA,CAAQC,YAAYH,CAAM,CAAA,CAE5BI,EAAS,EAAA,CAEb,IAAA,IAASC,EAAI,CAAA,CAAGA,CAAAA,CAAIL,EAAQK,CAAAA,EAAAA,CACxBD,CAAAA,EAAUH,EAAMC,CAAAA,CAAMG,CAAC,EAAIJ,CAAAA,CAAM,MAAM,EAG3C,OAAO,CAAA,EAAGF,EAASA,CAAAA,CAAS,GAAA,CAAM,EAAE,CAAA,EAAGK,CAAM,CAAA,CACjD,CAEA,IAAOE,CAAAA,CAAQR,ECjBf,SAASS,CAAAA,CAAUC,EAAwB,CACvC,OAAI,QAAQ,GAAA,CAAI,MAAA,GAAW,OAChB,IAAA,CAGP,OAAO,QAAQ,GAAA,CAAI,MAAA,EAAW,SACX,OAAA,CAAQ,GAAA,CAAI,OAAO,KAAA,CAAM,GAAG,CAAA,CAC7B,QAAA,CAASA,CAAK,CAAA,CAG7B,KACX,CAEA,SAASC,EAAOD,CAAAA,CAAeE,CAAAA,CAAgBC,EAAuB,CAC9DJ,CAAAA,CAAUC,CAAK,CAAA,EACf,OAAA,CAAQ,IAAI,CAAA,CAAA,EAAIA,CAAK,KAAKE,CAAM,CAAA,EAAA,EAAKC,CAAO,CAAA,CAAE,EAEtD,CAEA,IAAOC,CAAAA,CAAQH","file":"chunk-6GDOIHTS.js","sourcesContent":["import { randomBytes } from 'crypto';\n\nconst ID_LENGTH = 16;\n\nfunction generateID<T extends string = string>(prefix?: string | null, length = ID_LENGTH): T {\n const chars = 'abcdefghijklmnopqrstuvwxyz0123456789';\n const bytes = randomBytes(length);\n\n let result = '';\n\n for (let i = 0; i < length; i++) {\n result += chars[bytes[i] % chars.length];\n }\n\n return `${prefix ? prefix + '_' : ''}${result}` as T;\n}\n\nexport default generateID;\n","function shouldLog(alias: string): boolean {\n if (process.env.SZ_LOG === 'true') {\n return true;\n }\n\n if (typeof process.env.SZ_LOG === 'string') {\n const logAliases = process.env.SZ_LOG.split(',');\n return logAliases.includes(alias);\n }\n\n return false;\n}\n\nfunction syslog(alias: string, fnName: string, message: string): void {\n if (shouldLog(alias)) {\n console.log(`[${alias}] ${fnName}: ${message}`); // eslint-disable-line no-console\n }\n}\n\nexport default syslog;\n"]}
@@ -31,10 +31,12 @@ interface SubmitFormArgs<Schema extends z.ZodTypeAny, Response> {
31
31
  * @param args The arguments for submitting the form.
32
32
  * @returns A promise that resolves to either the submitted model or an error.
33
33
  */
34
- declare function submitForm<Schema extends z.ZodTypeAny, Response>(args: SubmitFormArgs<Schema, Response>): Promise<FormResponse<Response>>;
34
+ declare function submitForm<Schema extends z.ZodTypeAny, Response>(args: SubmitFormArgs<Schema, Response>): FormResponse<Response>;
35
35
 
36
36
  declare function validateSchema<T extends z.ZodTypeAny>(data: object, schema: T): Promise<z.infer<T>>;
37
37
 
38
+ declare function uploadFile(file: File): FormResponse<string>;
39
+
38
40
  declare function getNotExistsRefiner(field: string, fn: (value: any) => Promise<any>): [
39
41
  (data: any) => Promise<boolean>,
40
42
  {
@@ -57,4 +59,4 @@ declare function getNotExistsValidator<ID>(fn: (value: ID) => Promise<any>): [(v
57
59
  message: string;
58
60
  }];
59
61
 
60
- export { FormResponse, ValidationError, ValidationRule, createRule, getCSVRule, getExistsTransformer, getExistsValidator, getNotExistsRefiner, getNotExistsValidator, getPhoneRule, submitForm, validateSchema };
62
+ export { FormResponse, ValidationError, ValidationRule, createRule, getCSVRule, getExistsTransformer, getExistsValidator, getNotExistsRefiner, getNotExistsValidator, getPhoneRule, submitForm, uploadFile, validateSchema };
@@ -1,2 +1,2 @@
1
- import {a as a$1}from'../chunk-UCMLSO7F.js';import {b as b$1,a as a$2}from'../chunk-2ZLU4AUD.js';export{b as ValidationError,a as createRule,c as getExistsTransformer}from'../chunk-2ZLU4AUD.js';import {redirect}from'next/navigation';import c,{z as z$1}from'zod';function R(e){let[,,t]=e.split(";");redirect(`${t.startsWith("/")?"":"/"}${t}`);}var m=R;function u(e){let t={};for(let r in e)typeof e[r]=="string"?t[r]=e[r].trim():typeof e[r]=="object"&&e[r]!==null&&!(e[r]instanceof Date)?t[r]=u(e[r]):t[r]=e[r];return t}var f=u;function x(e){return e.issues.reduce((t,r)=>({...t,[r.path.join(".")]:r.message.replace(/"/gu,"")}),{})}var l=x;function y(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 E(e){return y(e)?{message:"REQUIRED"}:e.message?{message:e.message}:null}var d=E;async function I(e,t){try{return await t.parseAsync(f(e),{error:o=>d(o)})}catch(r){throw r instanceof z$1.ZodError?new b$1(l(r)):r}}var a=I;async function w(e){let t={data:null,error:null,validation:null};try{let r=await a(e.formData,e.schema),o=await e.fn(r);return await e.onSuccess?.(o),{...t,data:o}}catch(r){if(r instanceof b$1)return e.onValidationError?.(r),{...t,validation:r.messages};if(r instanceof Error)throw r.message==="NEXT_REDIRECT"&&"digest"in r&&m(String(r.digest)),r;return {...t,error:"submitForm encountered an unknown error"}}}var S=w;function v(e,t){return [async function(r){let o=await t(r[e]);return o?o.id===r.id:true},{message:"ALREADY_EXISTS",path:[e]}]}var D=v;var b=c.string().transform(a$1);function V(){return a$2({validator:b})}var Z=V;function z(e){return typeof e=="string"?e.replace(/[\s-]/g,""):e}function A(){let e=c.preprocess(z,c.string().regex(/^\d+$/).nonoptional());return a$2({validator:e})}var P=A;function $(e){return [async t=>!!await e(t),{message:"NOT_FOUND"}]}var F=$;function _(e){return [async t=>!await e(t),{message:"ALREADY_EXISTS"}]}var j=_;export{Z as getCSVRule,F as getExistsValidator,D as getNotExistsRefiner,j as getNotExistsValidator,P as getPhoneRule,S as submitForm,a as validateSchema};//# sourceMappingURL=index.js.map
1
+ import {b as b$1,a as a$2}from'../chunk-2ZLU4AUD.js';export{b as ValidationError,a as createRule,c as getExistsTransformer}from'../chunk-2ZLU4AUD.js';import {a as a$1}from'../chunk-UCMLSO7F.js';import {a as a$3}from'../chunk-6GDOIHTS.js';import'../chunk-BA3BC4CD.js';import {redirect}from'next/navigation';import x,{z as z$1}from'zod';import {put}from'@vercel/blob';import {joinURL}from'@sqrzro/utility';function F(e){let[,,t]=e.split(";");redirect(`${t.startsWith("/")?"":"/"}${t}`);}var f=F;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&&!(e[r]instanceof Date)&&!(e[r]instanceof File)?t[r]=l(e[r]):t[r]=e[r];return t}var p=l;function w(e){return e.issues.reduce((t,r)=>({...t,[r.path.join(".")]:r.message.replace(/"/gu,"")}),{})}var c=w;function I(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 D(e){return I(e)?{message:"REQUIRED"}:e.message?{message:e.message}:null}var d=D;async function S(e,t){try{return await t.parseAsync(p(e),{error:o=>d(o)})}catch(r){throw r instanceof z$1.ZodError?new b$1(c(r)):r}}var a=S;async function b(e){let t={data:null,error:null,validation:null};try{let r=await a(e.formData,e.schema),o=await e.fn(r);return await e.onSuccess?.(o),{...t,data:o}}catch(r){return r instanceof b$1?(e.onValidationError?.(r),{...t,validation:r.messages}):r instanceof Error?(r.message==="NEXT_REDIRECT"&&"digest"in r&&f(String(r.digest)),{...t,error:r.message}):{...t,error:"submitForm encountered an unknown error"}}}var i=b;function P(e){let t=process.env.APP_URL??"_default_",r=new URL(t),o=e.name.split(".").pop()??"";return joinURL(`${r.hostname.replace("www.","").replace(/\./g,"-")}${r.port?`-${r.port}`:""}`,`${a$3(null,32)}.${o}`)}var g=P;async function z(e){return (await put(g(e),e,{access:"public"})).url}var R=z;var V=x.object({file:x.instanceof(File)});async function Z(e){return i({fn:async t=>R(t.file),formData:{file:e},schema:V})}var A=Z;function _(e,t){return [async function(r){let o=await t(r[e]);return o?o.id===r.id:true},{message:"ALREADY_EXISTS",path:[e]}]}var j=_;var k=x.string().transform(a$1);function L(){return a$2({validator:k})}var U=L;function B(e){return typeof e=="string"?e.replace(/[\s-]/g,""):e}function C(){let e=x.preprocess(B,x.string().regex(/^\d+$/).nonoptional());return a$2({validator:e})}var X=C;function O(e){return [async t=>!!await e(t),{message:"NOT_FOUND"}]}var Y=O;function q(e){return [async t=>!await e(t),{message:"ALREADY_EXISTS"}]}var Q=q;export{U as getCSVRule,Y as getExistsValidator,j as getNotExistsRefiner,Q as getNotExistsValidator,X as getPhoneRule,i as submitForm,A as uploadFile,a as validateSchema};//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/forms/utility/handle-redirect.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/refiner/get-not-exists-refiner.ts","../../src/forms/rules/get-csv-rule.ts","../../src/forms/rules/get-phone-rule.ts","../../src/forms/validators/get-exists-validator.ts","../../src/forms/validators/get-not-exists-validator.ts"],"names":["handleRedirect","digest","path","redirect","handle_redirect_default","cleanData","data","cleanedData","key","clean_data_default","transformErrors","error","acc","cur","transform_errors_default","isRequired","issue","transformIssue","transform_issue_default","validateSchema","schema","z","ValidationError_default","validate_schema_default","submitForm","args","response","model","submit_form_default","getNotExistsRefiner","field","fn","result","get_not_exists_refiner_default","validator","parse_csv_default","getCSVRule","create_rule_default","get_csv_rule_default","preprocess","value","getPhoneRule","get_phone_rule_default","getExistsValidator","get_exists_validator_default","getNotExistsValidator","get_not_exists_validator_default"],"mappings":"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","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","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 (\n typeof data[key] === 'object' &&\n data[key] !== null &&\n !(data[key] instanceof Date)\n ) {\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","function getNotExistsRefiner(\n field: string,\n fn: (value: any) => Promise<any>\n): [\n (data: any) => Promise<boolean>,\n {\n message: string;\n path: string[];\n },\n] {\n return [\n async function (data: any) {\n const result = await fn(data[field]);\n\n if (!result) {\n return true;\n }\n\n return result.id === data.id;\n },\n { message: 'ALREADY_EXISTS', path: [field] },\n ];\n}\n\nexport default getNotExistsRefiner;\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 z from 'zod';\n\nimport createRule from '../create-rule';\n\nfunction preprocess(value: unknown): unknown {\n if (typeof value === 'string') {\n return value.replace(/[\\s-]/g, '');\n }\n return value;\n}\n\nfunction getPhoneRule() {\n const validator = z.preprocess(preprocess, z.string().regex(/^\\d+$/).nonoptional());\n return createRule({ validator });\n}\n\nexport default getPhoneRule;\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<ID>(\n fn: (value: ID) => Promise<any>\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
+ {"version":3,"sources":["../../src/forms/utility/handle-redirect.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/utility/transform-file-path.ts","../../src/forms/files/put-file.ts","../../src/forms/files/upload-file.ts","../../src/forms/refiner/get-not-exists-refiner.ts","../../src/forms/rules/get-csv-rule.ts","../../src/forms/rules/get-phone-rule.ts","../../src/forms/validators/get-exists-validator.ts","../../src/forms/validators/get-not-exists-validator.ts"],"names":["handleRedirect","digest","path","redirect","handle_redirect_default","cleanData","data","cleanedData","key","clean_data_default","transformErrors","error","acc","cur","transform_errors_default","isRequired","issue","transformIssue","transform_issue_default","validateSchema","schema","z","ValidationError_default","validate_schema_default","submitForm","args","response","model","submit_form_default","transformFilePath","file","url","obj","extension","joinURL","generate_id_default","transform_file_path_default","putFile","put","put_file_default","uploadFile","upload_file_default","getNotExistsRefiner","field","fn","result","get_not_exists_refiner_default","validator","parse_csv_default","getCSVRule","create_rule_default","get_csv_rule_default","preprocess","value","getPhoneRule","get_phone_rule_default","getExistsValidator","get_exists_validator_default","getNotExistsValidator","get_not_exists_validator_default"],"mappings":"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","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","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 (\n typeof data[key] === 'object' &&\n data[key] !== null &&\n !(data[key] instanceof Date) &&\n !(data[key] instanceof File)\n ) {\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): 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 { joinURL } from '@sqrzro/utility';\n\nimport { generateID } from '../../utility';\n\nfunction transformFilePath(file: File): string {\n const url = process.env.APP_URL ?? '_default_';\n const obj = new URL(url);\n\n const extension = file.name.split('.').pop() ?? '';\n\n return joinURL(\n `${obj.hostname.replace('www.', '').replace(/\\./g, '-')}${obj.port ? `-${obj.port}` : ''}`,\n `${generateID(null, 32)}.${extension}`\n );\n}\n\nexport default transformFilePath;\n","import { put } from '@vercel/blob';\n\nimport transformFilePath from '../utility/transform-file-path';\n\nasync function putFile(file: File): Promise<string> {\n const result = await put(transformFilePath(file), file, {\n access: 'public',\n });\n\n return result.url;\n}\n\nexport default putFile;\n","import z from 'zod';\n\nimport submitForm from '../submit-form';\nimport type { FormResponse } from '../utility/interfaces';\n\nimport putFile from './put-file';\n\nconst schema = z.object({\n file: z.instanceof(File),\n});\n\nasync function uploadFile(file: File): FormResponse<string> {\n return submitForm({\n fn: async (data: z.infer<typeof schema>): Promise<string> => putFile(data.file),\n formData: { file },\n schema,\n });\n}\n\nexport default uploadFile;\n","function getNotExistsRefiner(\n field: string,\n fn: (value: any) => Promise<any>\n): [\n (data: any) => Promise<boolean>,\n {\n message: string;\n path: string[];\n },\n] {\n return [\n async function (data: any) {\n const result = await fn(data[field]);\n\n if (!result) {\n return true;\n }\n\n return result.id === data.id;\n },\n { message: 'ALREADY_EXISTS', path: [field] },\n ];\n}\n\nexport default getNotExistsRefiner;\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 z from 'zod';\n\nimport createRule from '../create-rule';\n\nfunction preprocess(value: unknown): unknown {\n if (typeof value === 'string') {\n return value.replace(/[\\s-]/g, '');\n }\n return value;\n}\n\nfunction getPhoneRule() {\n const validator = z.preprocess(preprocess, z.string().regex(/^\\d+$/).nonoptional());\n return createRule({ validator });\n}\n\nexport default getPhoneRule;\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<ID>(\n fn: (value: ID) => Promise<any>\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,2 +1,2 @@
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),o="";for(let s=0;s<t;s++)o+=r[n[s]%r.length];return `${e?e+"_":""}${o}`}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 syslog};//# sourceMappingURL=index.js.map
1
+ export{a as generateID,b as syslog}from'../chunk-6GDOIHTS.js';export{b as ensureID,c as getIDFromParams,a as guardID}from'../chunk-BA3BC4CD.js';//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/utility/generate-id.ts","../../src/utility/syslog.ts"],"names":["ID_LENGTH","generateID","prefix","length","chars","bytes","randomBytes","result","i","generate_id_default","shouldLog","alias","syslog","fnName","message","syslog_default"],"mappings":"mHAEA,IAAMA,EAAY,EAAA,CAElB,SAASC,EAAsCC,CAAAA,CAAwBC,CAAAA,CAASH,EAAc,CAC1F,IAAMI,EAAQ,sCAAA,CACRC,CAAAA,CAAQC,YAAYH,CAAM,CAAA,CAE5BI,EAAS,EAAA,CAEb,IAAA,IAASC,EAAI,CAAA,CAAGA,CAAAA,CAAIL,EAAQK,CAAAA,EAAAA,CACxBD,CAAAA,EAAUH,EAAMC,CAAAA,CAAMG,CAAC,EAAIJ,CAAAA,CAAM,MAAM,EAG3C,OAAO,CAAA,EAAGF,EAASA,CAAAA,CAAS,GAAA,CAAM,EAAE,CAAA,EAAGK,CAAM,CAAA,CACjD,CAEA,IAAOE,CAAAA,CAAQR,ECjBf,SAASS,CAAAA,CAAUC,EAAwB,CACvC,OAAI,QAAQ,GAAA,CAAI,MAAA,GAAW,OAChB,IAAA,CAGP,OAAO,QAAQ,GAAA,CAAI,MAAA,EAAW,SACX,OAAA,CAAQ,GAAA,CAAI,OAAO,KAAA,CAAM,GAAG,CAAA,CAC7B,QAAA,CAASA,CAAK,CAAA,CAG7B,KACX,CAEA,SAASC,EAAOD,CAAAA,CAAeE,CAAAA,CAAgBC,EAAuB,CAC9DJ,CAAAA,CAAUC,CAAK,CAAA,EACf,OAAA,CAAQ,IAAI,CAAA,CAAA,EAAIA,CAAK,KAAKE,CAAM,CAAA,EAAA,EAAKC,CAAO,CAAA,CAAE,EAEtD,CAEA,IAAOC,CAAAA,CAAQH","file":"index.js","sourcesContent":["import { randomBytes } from 'crypto';\n\nconst ID_LENGTH = 16;\n\nfunction generateID<T extends string = string>(prefix?: string | null, length = ID_LENGTH): T {\n const chars = 'abcdefghijklmnopqrstuvwxyz0123456789';\n const bytes = randomBytes(length);\n\n let result = '';\n\n for (let i = 0; i < length; i++) {\n result += chars[bytes[i] % chars.length];\n }\n\n return `${prefix ? prefix + '_' : ''}${result}` as T;\n}\n\nexport default generateID;\n","function shouldLog(alias: string): boolean {\n if (process.env.SZ_LOG === 'true') {\n return true;\n }\n\n if (typeof process.env.SZ_LOG === 'string') {\n const logAliases = process.env.SZ_LOG.split(',');\n return logAliases.includes(alias);\n }\n\n return false;\n}\n\nfunction syslog(alias: string, fnName: string, message: string): void {\n if (shouldLog(alias)) {\n console.log(`[${alias}] ${fnName}: ${message}`); // eslint-disable-line no-console\n }\n}\n\nexport default syslog;\n"]}
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"index.js"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sqrzro/server",
3
- "version": "4.0.0-alpha.46",
3
+ "version": "4.0.0-alpha.47",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -44,6 +44,7 @@
44
44
  ],
45
45
  "dependencies": {
46
46
  "@sendgrid/mail": "^8.1.6",
47
+ "@vercel/blob": "^2.4.0",
47
48
  "csv": "^6.5.0",
48
49
  "drizzle-orm": "^0.45.1",
49
50
  "pg": "^8.20.0",