@visulima/api-platform 1.1.2 → 1.1.4

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 (46) hide show
  1. package/CHANGELOG.md +15 -0
  2. package/dist/chunk-AG2ROSSA.mjs +2 -0
  3. package/dist/{chunk-D5JLMBFH.mjs.map → chunk-AG2ROSSA.mjs.map} +1 -1
  4. package/dist/chunk-HONWWBY6.mjs +2 -0
  5. package/dist/{chunk-YR2QJYUL.mjs.map → chunk-HONWWBY6.mjs.map} +1 -1
  6. package/dist/chunk-JXD3457O.js +2 -0
  7. package/dist/chunk-JXD3457O.js.map +1 -0
  8. package/dist/chunk-M7LGAQP3.mjs +10 -0
  9. package/dist/{chunk-EGE7A4ZK.mjs.map → chunk-M7LGAQP3.mjs.map} +1 -1
  10. package/dist/chunk-OUWZ2PU5.js +2 -0
  11. package/dist/{chunk-JC4IRQUL.js.map → chunk-OUWZ2PU5.js.map} +0 -0
  12. package/dist/chunk-QIHOLJVA.js +2 -0
  13. package/dist/chunk-QIHOLJVA.js.map +1 -0
  14. package/dist/chunk-UI23SSBN.js +10 -0
  15. package/dist/chunk-UI23SSBN.js.map +1 -0
  16. package/dist/chunk-YOXCJZNX.mjs +2 -0
  17. package/dist/{chunk-5VRACIDE.mjs.map → chunk-YOXCJZNX.mjs.map} +0 -0
  18. package/dist/index-browser.js +1 -7
  19. package/dist/index-browser.mjs +1 -7
  20. package/dist/index-server.d.ts +1 -1
  21. package/dist/index-server.js +1 -452
  22. package/dist/index-server.js.map +1 -1
  23. package/dist/index-server.mjs +1 -452
  24. package/dist/index-server.mjs.map +1 -1
  25. package/dist/next/cli/index.js +3 -202
  26. package/dist/next/cli/index.js.map +1 -1
  27. package/dist/next/cli/index.mjs +3 -202
  28. package/dist/next/cli/index.mjs.map +1 -1
  29. package/dist/next/index-browser.js +1 -11
  30. package/dist/next/index-browser.mjs +1 -11
  31. package/dist/next/index-server.js +1 -75
  32. package/dist/next/index-server.js.map +1 -1
  33. package/dist/next/index-server.mjs +1 -75
  34. package/dist/next/index-server.mjs.map +1 -1
  35. package/package.json +4 -4
  36. package/dist/chunk-5VRACIDE.mjs +0 -10
  37. package/dist/chunk-CVURPKKG.js +0 -120
  38. package/dist/chunk-CVURPKKG.js.map +0 -1
  39. package/dist/chunk-D5JLMBFH.mjs +0 -284
  40. package/dist/chunk-EGE7A4ZK.mjs +0 -120
  41. package/dist/chunk-HOWWQBSN.js +0 -99
  42. package/dist/chunk-HOWWQBSN.js.map +0 -1
  43. package/dist/chunk-JC4IRQUL.js +0 -10
  44. package/dist/chunk-R6HXY2JR.js +0 -284
  45. package/dist/chunk-R6HXY2JR.js.map +0 -1
  46. package/dist/chunk-YR2QJYUL.mjs +0 -99
@@ -1,284 +0,0 @@
1
- // src/swagger/swagger-handler.ts
2
- import { modelsToOpenApi } from "@visulima/crud";
3
- import debug from "debug";
4
- import merge from "lodash.merge";
5
- import { existsSync, readFileSync } from "fs";
6
- import path from "path";
7
-
8
- // src/connect/serializers/yaml.ts
9
- import { stringify } from "yaml";
10
- var yamlTransformer = (data) => stringify(data, { indent: 2 });
11
- var yaml_default = yamlTransformer;
12
-
13
- // src/swagger/extend-swagger-spec.ts
14
- import { header as headerCase } from "case";
15
- import { toXML } from "jstoxml";
16
- import { stringify as stringify2 } from "yaml";
17
- var jsonMediaType = "application/json";
18
- var prepareStatusContent = (methodSpec, status, mediaType) => {
19
- var _a, _b, _c, _d, _e;
20
- if (((_b = (_a = methodSpec == null ? void 0 : methodSpec.responses) == null ? void 0 : _a[status]) == null ? void 0 : _b.content) === void 0) {
21
- methodSpec.responses[status].content = {};
22
- }
23
- if (((_e = (_d = (_c = methodSpec == null ? void 0 : methodSpec.responses) == null ? void 0 : _c[status]) == null ? void 0 : _d.content) == null ? void 0 : _e[mediaType]) === void 0) {
24
- methodSpec.responses[status].content[mediaType] = {};
25
- }
26
- };
27
- var extendComponentSchemas = (spec, schemaName, schema) => {
28
- if (typeof spec.components !== "object") {
29
- spec.components = {};
30
- }
31
- if (typeof spec.components.schemas !== "object") {
32
- spec.components.schemas = {};
33
- }
34
- if (spec.components.schemas[schemaName] === void 0) {
35
- spec.components.schemas[schemaName] = schema;
36
- }
37
- };
38
- var extendResponseSchema = (methodSpec, status, mediaType, schemaName, schemaIsArray) => {
39
- var _a, _b, _c, _d;
40
- prepareStatusContent(methodSpec, status, mediaType);
41
- if (((_d = (_c = (_b = (_a = methodSpec == null ? void 0 : methodSpec.responses) == null ? void 0 : _a[status]) == null ? void 0 : _b.content) == null ? void 0 : _c[mediaType]) == null ? void 0 : _d.schema) === void 0) {
42
- methodSpec.responses[status].content[mediaType].schema = {};
43
- }
44
- methodSpec.responses[status].content[mediaType].schema = schemaIsArray ? {
45
- type: "array",
46
- items: {
47
- $ref: `#/components/schemas/${schemaName}`
48
- }
49
- } : {
50
- $ref: `#/components/schemas/${schemaName}`
51
- };
52
- };
53
- var extendSwaggerWithMediaTypeSchema = (methodSpec, responseSpec, allowedMediaTypes, pathKey, spec, status) => {
54
- let example;
55
- let examples;
56
- Object.entries(responseSpec.content).forEach(([mediaName, contentSpec]) => {
57
- if (typeof contentSpec.schema === "object") {
58
- const { schema } = contentSpec;
59
- if (mediaName === jsonMediaType && contentSpec.examples !== void 0) {
60
- examples = contentSpec.examples;
61
- } else if (mediaName === jsonMediaType && contentSpec.example !== void 0) {
62
- example = contentSpec.example;
63
- }
64
- const schemaIsArray = schema.type === "array";
65
- Object.entries(allowedMediaTypes || {}).forEach(([mediaType, allowed]) => {
66
- if (!allowed) {
67
- return;
68
- }
69
- let schemaName;
70
- if (schema.$ref === void 0) {
71
- schemaName = `${headerCase(pathKey.trim().replace("/", ""))}${mediaType === "application/ld+json" ? ".jsonld" : ""}`;
72
- extendComponentSchemas(spec, schemaName, schema);
73
- } else {
74
- schemaName = schema.$ref.replace("#/components/schemas/", "");
75
- }
76
- extendResponseSchema(methodSpec, status, mediaType, schemaName, schemaIsArray);
77
- });
78
- }
79
- });
80
- return { examples, example };
81
- };
82
- var extendSwaggerWithMediaTypeExample = (methodSpec, responseSpec, status, allowedMediaTypes, transformers, example) => {
83
- Object.keys(responseSpec.content).forEach((mediaName) => {
84
- if (mediaName === jsonMediaType) {
85
- return;
86
- }
87
- Object.entries(allowedMediaTypes || {}).forEach(([mediaType, allowed]) => {
88
- var _a, _b, _c, _d;
89
- if (!allowed) {
90
- return;
91
- }
92
- prepareStatusContent(methodSpec, status, mediaType);
93
- if (((_d = (_c = (_b = (_a = methodSpec == null ? void 0 : methodSpec.responses) == null ? void 0 : _a[status]) == null ? void 0 : _b.content) == null ? void 0 : _c[mediaType]) == null ? void 0 : _d.example) === void 0) {
94
- methodSpec.responses[status].content[mediaType].example = {};
95
- }
96
- let transformed = false;
97
- transformers.forEach(({ regex, transformer }) => {
98
- if (!transformed && regex.test(mediaType)) {
99
- methodSpec.responses[status].content[mediaType].example = transformer(example);
100
- transformed = true;
101
- }
102
- });
103
- if (!transformed) {
104
- methodSpec.responses[status].content[mediaType].example = example;
105
- }
106
- });
107
- });
108
- };
109
- var extendComponentExamples = (spec, exampleName, examples) => {
110
- if (typeof spec.components !== "object") {
111
- spec.components = {};
112
- }
113
- if (typeof spec.components.examples !== "object") {
114
- spec.components.examples = {};
115
- }
116
- if (spec.components.examples[exampleName] === void 0 && examples[exampleName] !== void 0) {
117
- spec.components.examples[exampleName] = examples[exampleName];
118
- }
119
- };
120
- var prepareResponseExamples = (spec, methodSpec, status, mediaType, transformers, examples) => {
121
- var _a, _b, _c, _d;
122
- prepareStatusContent(methodSpec, status, mediaType);
123
- if (((_d = (_c = (_b = (_a = methodSpec == null ? void 0 : methodSpec.responses) == null ? void 0 : _a[status]) == null ? void 0 : _b.content) == null ? void 0 : _c[mediaType]) == null ? void 0 : _d.examples) === void 0) {
124
- methodSpec.responses[status].content[mediaType].examples = {};
125
- }
126
- const transformedExamples = {};
127
- Object.entries(examples).forEach(([exampleName, example]) => {
128
- var _a2, _b2;
129
- let transformed = false;
130
- transformers.forEach(({ regex, transformer }) => {
131
- var _a3, _b3, _c2, _d2, _e, _f;
132
- if (!transformed && regex.test(mediaType)) {
133
- let data = "";
134
- if (((_b3 = (_a3 = spec.components) == null ? void 0 : _a3.examples) == null ? void 0 : _b3[exampleName]) !== void 0) {
135
- data = ((_d2 = (_c2 = spec.components) == null ? void 0 : _c2.examples) == null ? void 0 : _d2[exampleName]).value;
136
- } else if (example) {
137
- data = ((_f = (_e = spec.components) == null ? void 0 : _e.examples) == null ? void 0 : _f[example.$ref.replace("#/components/examples/", "")]).value;
138
- } else if (typeof (example == null ? void 0 : example.value) === "string") {
139
- data = example.value;
140
- }
141
- transformedExamples[exampleName] = {
142
- value: transformer(data)
143
- };
144
- transformed = true;
145
- }
146
- });
147
- if (!transformed) {
148
- transformedExamples[exampleName] = ((_b2 = (_a2 = spec.components) == null ? void 0 : _a2.examples) == null ? void 0 : _b2[exampleName]) === void 0 ? example : {
149
- $ref: `#/components/examples/${exampleName}`
150
- };
151
- }
152
- });
153
- methodSpec.responses[status].content[mediaType].examples = transformedExamples;
154
- };
155
- var extendSwaggerWithMediaTypeExamples = (spec, methodSpec, status, responseSpec, allowedMediaTypes, pathKey, transformers, examples) => {
156
- const examplesName = `${headerCase(pathKey.trim().replace("/", ""))}`;
157
- Object.keys(responseSpec.content).forEach((mediaName) => {
158
- if (mediaName === jsonMediaType) {
159
- return;
160
- }
161
- Object.entries(allowedMediaTypes || {}).forEach(([mediaType, allowed]) => {
162
- if (!allowed) {
163
- return;
164
- }
165
- extendComponentExamples(spec, examplesName, examples);
166
- prepareResponseExamples(spec, methodSpec, status, mediaType, transformers, examples);
167
- });
168
- });
169
- };
170
- function extendSwaggerSpec(spec, allowedMediaTypes, transformers = [
171
- {
172
- regex: /xml/,
173
- transformer: (value) => toXML(value, {
174
- header: true,
175
- indent: " "
176
- })
177
- },
178
- {
179
- regex: /yaml|yml/,
180
- transformer: (value) => stringify2(value, { indent: 2 })
181
- }
182
- ]) {
183
- if (typeof spec === "object" && typeof spec.paths === "object") {
184
- Object.entries(spec.paths).forEach(([pathKey, pathSpec]) => {
185
- Object.values(pathSpec).forEach((methodSpec) => {
186
- if (typeof methodSpec.responses === "object") {
187
- Object.entries(methodSpec.responses).forEach(([status, responseSpec]) => {
188
- if (typeof responseSpec.content === "object") {
189
- const { examples, example } = extendSwaggerWithMediaTypeSchema(
190
- methodSpec,
191
- responseSpec,
192
- allowedMediaTypes,
193
- pathKey,
194
- spec,
195
- status
196
- );
197
- if (example !== void 0) {
198
- extendSwaggerWithMediaTypeExample(
199
- methodSpec,
200
- responseSpec,
201
- status,
202
- allowedMediaTypes,
203
- transformers,
204
- example
205
- );
206
- } else if (examples !== void 0) {
207
- extendSwaggerWithMediaTypeExamples(
208
- spec,
209
- methodSpec,
210
- status,
211
- responseSpec,
212
- allowedMediaTypes,
213
- pathKey,
214
- transformers,
215
- examples
216
- );
217
- }
218
- }
219
- });
220
- }
221
- });
222
- });
223
- }
224
- return spec;
225
- }
226
-
227
- // src/swagger/swagger-handler.ts
228
- var swaggerCrudDebug = debug("visulima:api-platform:swagger:crud:get-static-properties-swagger");
229
- var swaggerHandler = (options = {}) => {
230
- const {
231
- allowedMediaTypes = {
232
- "application/json": true
233
- },
234
- swaggerFilePath,
235
- crud,
236
- specs
237
- } = options;
238
- return async (request, response) => {
239
- const swaggerPath = path.join(process.cwd(), swaggerFilePath || "swagger/swagger.json");
240
- if (!existsSync(swaggerPath)) {
241
- throw new Error(`Swagger file not found at ${swaggerPath}. Did you change the output path in "withOpenApi" inside the next.config.js file?`);
242
- }
243
- const fileContents = readFileSync(swaggerPath, "utf8");
244
- let spec = extendSwaggerSpec(JSON.parse(fileContents), allowedMediaTypes);
245
- let crudSwagger = {};
246
- if (crud !== void 0) {
247
- try {
248
- const modelsOpenApi = await modelsToOpenApi(crud);
249
- crudSwagger = {
250
- components: { schemas: modelsOpenApi.schemas, examples: modelsOpenApi.examples },
251
- tags: modelsOpenApi.tags,
252
- paths: modelsOpenApi.paths
253
- };
254
- crudSwagger = extendSwaggerSpec(crudSwagger, allowedMediaTypes);
255
- swaggerCrudDebug(JSON.stringify(crudSwagger, null, 2));
256
- spec = merge(spec, crudSwagger);
257
- } catch (error) {
258
- console.log(error);
259
- throw new Error("Please install @visulima/crud to use the crud swagger generator.");
260
- }
261
- }
262
- if (Array.isArray(specs)) {
263
- specs.forEach((value) => {
264
- spec = merge(spec, extendSwaggerSpec(value, allowedMediaTypes));
265
- });
266
- }
267
- if (typeof request.headers.accept === "string" && /yaml|yml/.test(request.headers.accept)) {
268
- response.statusCode = 200;
269
- response.setHeader("Content-Type", request.headers.accept);
270
- response.end(yaml_default(spec));
271
- } else {
272
- response.statusCode = 200;
273
- response.setHeader("Content-Type", "application/json");
274
- response.end(JSON.stringify(spec, null, 2));
275
- }
276
- };
277
- };
278
- var swagger_handler_default = swaggerHandler;
279
-
280
- export {
281
- yaml_default,
282
- swagger_handler_default
283
- };
284
- //# sourceMappingURL=chunk-D5JLMBFH.mjs.map
@@ -1,120 +0,0 @@
1
- // src/next/routes/pages/swagger/redoc.tsx
2
- import Head from "next/head";
3
- import { RedocStandalone } from "redoc";
4
- import { Fragment, jsxDEV } from "react/jsx-dev-runtime";
5
- var RedocApiDocument = (name, swagger = {}) => ({ swaggerData }) => /* @__PURE__ */ jsxDEV(Fragment, {
6
- children: [
7
- /* @__PURE__ */ jsxDEV(Head, {
8
- children: [
9
- /* @__PURE__ */ jsxDEV("title", {
10
- children: name
11
- }, void 0, false, {
12
- fileName: "src/next/routes/pages/swagger/redoc.tsx",
13
- lineNumber: 20,
14
- columnNumber: 21
15
- }, this),
16
- /* @__PURE__ */ jsxDEV("style", {
17
- children: `
18
- body {
19
- background: #fafafa !important;
20
- }
21
- `
22
- }, void 0, false, {
23
- fileName: "src/next/routes/pages/swagger/redoc.tsx",
24
- lineNumber: 21,
25
- columnNumber: 21
26
- }, this)
27
- ]
28
- }, void 0, true, {
29
- fileName: "src/next/routes/pages/swagger/redoc.tsx",
30
- lineNumber: 19,
31
- columnNumber: 17
32
- }, this),
33
- /* @__PURE__ */ jsxDEV(RedocStandalone, {
34
- ...swagger,
35
- spec: swaggerData
36
- }, void 0, false, {
37
- fileName: "src/next/routes/pages/swagger/redoc.tsx",
38
- lineNumber: 30,
39
- columnNumber: 17
40
- }, this)
41
- ]
42
- }, void 0, true, {
43
- fileName: "src/next/routes/pages/swagger/redoc.tsx",
44
- lineNumber: 18,
45
- columnNumber: 13
46
- }, this);
47
- var redoc_default = RedocApiDocument;
48
-
49
- // src/next/routes/pages/swagger/swagger.tsx
50
- import dynamic from "next/dynamic";
51
- import Head2 from "next/head";
52
- import { Fragment as Fragment2, jsxDEV as jsxDEV2 } from "react/jsx-dev-runtime";
53
- var SwaggerUI = dynamic(() => import("swagger-ui-react"), { ssr: false });
54
- dynamic(import("swagger-ui-react/swagger-ui.css"), { ssr: false });
55
- var SwaggerApiDocument = (name, swagger = {}) => ({ swaggerData }) => /* @__PURE__ */ jsxDEV2(Fragment2, {
56
- children: [
57
- /* @__PURE__ */ jsxDEV2(Head2, {
58
- children: [
59
- /* @__PURE__ */ jsxDEV2("title", {
60
- children: name
61
- }, void 0, false, {
62
- fileName: "src/next/routes/pages/swagger/swagger.tsx",
63
- lineNumber: 23,
64
- columnNumber: 21
65
- }, this),
66
- /* @__PURE__ */ jsxDEV2("style", {
67
- children: `
68
- body {
69
- background: #fafafa !important;
70
- }
71
- `
72
- }, void 0, false, {
73
- fileName: "src/next/routes/pages/swagger/swagger.tsx",
74
- lineNumber: 24,
75
- columnNumber: 21
76
- }, this)
77
- ]
78
- }, void 0, true, {
79
- fileName: "src/next/routes/pages/swagger/swagger.tsx",
80
- lineNumber: 22,
81
- columnNumber: 17
82
- }, this),
83
- /* @__PURE__ */ jsxDEV2(SwaggerUI, {
84
- ...swagger,
85
- spec: swaggerData
86
- }, void 0, false, {
87
- fileName: "src/next/routes/pages/swagger/swagger.tsx",
88
- lineNumber: 33,
89
- columnNumber: 17
90
- }, this)
91
- ]
92
- }, void 0, true, {
93
- fileName: "src/next/routes/pages/swagger/swagger.tsx",
94
- lineNumber: 21,
95
- columnNumber: 13
96
- }, this);
97
- var swagger_default = SwaggerApiDocument;
98
-
99
- // src/next/routes/pages/swagger/get-static-properties-swagger.ts
100
- import debug from "debug";
101
- var swaggerDebug = debug("visulima:api-platform:swagger:get-static-properties-swagger");
102
- var getStaticProps = (swaggerUrl) => async () => {
103
- const response = await fetch(swaggerUrl);
104
- const swaggerData = await response.json();
105
- swaggerDebug(swaggerData);
106
- return {
107
- props: {
108
- swaggerUrl,
109
- swaggerData: JSON.parse(JSON.stringify(swaggerData))
110
- }
111
- };
112
- };
113
- var get_static_properties_swagger_default = getStaticProps;
114
-
115
- export {
116
- redoc_default,
117
- swagger_default,
118
- get_static_properties_swagger_default
119
- };
120
- //# sourceMappingURL=chunk-EGE7A4ZK.mjs.map
@@ -1,99 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkJC4IRQULjs = require('./chunk-JC4IRQUL.js');
4
-
5
- // src/zod/index.ts
6
- var zod_exports = {};
7
- _chunkJC4IRQULjs.__export.call(void 0, zod_exports, {
8
- dateIn: () => dateIn,
9
- dateOut: () => dateOut
10
- });
11
- var _zodtots = require('zod-to-ts');
12
-
13
- // src/zod/date-in-schema.ts
14
-
15
-
16
-
17
-
18
-
19
-
20
- var _zod = require('zod');
21
- var zodDateInKind = "ZodDateIn";
22
- var isoDateRegex = /^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2}(\.\d{3})?)?Z?$/;
23
- var _ZodDateIn = class extends _zod.ZodType {
24
- _parse(input) {
25
- const { status, ctx } = this._processInputParams(input);
26
- if (ctx.parsedType !== _zod.ZodParsedType.string) {
27
- _zod.addIssueToContext.call(void 0, ctx, {
28
- code: _zod.ZodIssueCode.invalid_type,
29
- expected: _zod.ZodParsedType.string,
30
- received: ctx.parsedType
31
- });
32
- return _zod.INVALID;
33
- }
34
- if (!isoDateRegex.test(ctx.data)) {
35
- _zod.addIssueToContext.call(void 0, ctx, {
36
- code: _zod.ZodIssueCode.invalid_string,
37
- validation: "regex"
38
- });
39
- status.dirty();
40
- }
41
- const date = new Date(ctx.data);
42
- if (Number.isNaN(date.getTime())) {
43
- _zod.addIssueToContext.call(void 0, ctx, {
44
- code: _zod.ZodIssueCode.invalid_date
45
- });
46
- return _zod.INVALID;
47
- }
48
- return { status: status.value, value: date };
49
- }
50
- };
51
- var ZodDateIn = _ZodDateIn;
52
- ZodDateIn.create = () => new _ZodDateIn({
53
- typeName: zodDateInKind
54
- });
55
-
56
- // src/zod/date-out-schema.ts
57
-
58
-
59
-
60
-
61
-
62
-
63
-
64
- var zodDateOutKind = "ZodDateOut";
65
- var _ZodDateOut = class extends _zod.ZodType {
66
- _parse(input) {
67
- const { status, ctx } = this._processInputParams(input);
68
- if (ctx.parsedType !== _zod.ZodParsedType.date) {
69
- _zod.addIssueToContext.call(void 0, ctx, {
70
- code: _zod.ZodIssueCode.invalid_type,
71
- expected: _zod.ZodParsedType.date,
72
- received: ctx.parsedType
73
- });
74
- return _zod.INVALID;
75
- }
76
- if (Number.isNaN(ctx.data.getTime())) {
77
- _zod.addIssueToContext.call(void 0, ctx, {
78
- code: _zod.ZodIssueCode.invalid_date
79
- });
80
- return _zod.INVALID;
81
- }
82
- return { status: status.value, value: ctx.data.toISOString() };
83
- }
84
- };
85
- var ZodDateOut = _ZodDateOut;
86
- ZodDateOut.create = () => new _ZodDateOut({
87
- typeName: zodDateOutKind
88
- });
89
-
90
- // src/zod/index.ts
91
- var dateIn = (...parameters) => _zodtots.withGetType.call(void 0, ZodDateIn.create(...parameters), (ts) => ts.factory.createKeywordTypeNode(ts.SyntaxKind.StringKeyword));
92
- var dateOut = (...parameters) => _zodtots.withGetType.call(void 0, ZodDateOut.create(...parameters), (ts) => ts.factory.createKeywordTypeNode(ts.SyntaxKind.StringKeyword));
93
-
94
-
95
-
96
-
97
-
98
- exports.dateIn = dateIn; exports.dateOut = dateOut; exports.zod_exports = zod_exports;
99
- //# sourceMappingURL=chunk-HOWWQBSN.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/zod/index.ts","../src/zod/date-in-schema.ts","../src/zod/date-out-schema.ts"],"names":["addIssueToContext","INVALID","ZodIssueCode","ZodParsedType","ZodType"],"mappings":";;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAAS,mBAAmB;;;ACC5B;AAAA,EACI;AAAA,EAAmB;AAAA,EAAS;AAAA,EAAc;AAAA,EAAe;AAAA,OACtD;AAEP,IAAM,gBAAgB;AAOf,IAAM,eAAe;AAOrB,IAAM,aAAN,cAAwB,QAAoC;AAAA,EAE/D,OAAO,OAA0C;AAE7C,UAAM,EAAE,QAAQ,IAAI,IAAI,KAAK,oBAAoB,KAAK;AACtD,QAAI,IAAI,eAAe,cAAc,QAAQ;AACzC,wBAAkB,KAAK;AAAA,QACnB,MAAM,aAAa;AAAA,QACnB,UAAU,cAAc;AAAA,QACxB,UAAU,IAAI;AAAA,MAClB,CAAC;AACD,aAAO;AAAA,IACX;AAEA,QAAI,CAAC,aAAa,KAAK,IAAI,IAAc,GAAG;AACxC,wBAAkB,KAAK;AAAA,QACnB,MAAM,aAAa;AAAA,QACnB,YAAY;AAAA,MAChB,CAAC;AACD,aAAO,MAAM;AAAA,IACjB;AAEA,UAAM,OAAO,IAAI,KAAK,IAAI,IAAI;AAE9B,QAAI,OAAO,MAAM,KAAK,QAAQ,CAAC,GAAG;AAC9B,wBAAkB,KAAK;AAAA,QACnB,MAAM,aAAa;AAAA,MACvB,CAAC;AACD,aAAO;AAAA,IACX;AAEA,WAAO,EAAE,QAAQ,OAAO,OAAO,OAAO,KAAK;AAAA,EAC/C;AAKJ;AArCO,IAAM,YAAN;AAAM,UAkCF,SAAS,MAAM,IAAI,WAAU;AAAA,EAChC,UAAU;AACd,CAAC;;;ACtDL;AAAA,EACI,qBAAAA;AAAA,EAAmB,WAAAC;AAAA,EAAS,gBAAAC;AAAA,EAAc,iBAAAC;AAAA,EAAe,WAAAC;AAAA,OACtD;AAEP,IAAM,iBAAiB;AAOhB,IAAM,cAAN,cAAyBA,SAAqC;AAAA,EAEjE,OAAO,OAA4C;AAE/C,UAAM,EAAE,QAAQ,IAAI,IAAI,KAAK,oBAAoB,KAAK;AAEtD,QAAI,IAAI,eAAeD,eAAc,MAAM;AACvC,MAAAH,mBAAkB,KAAK;AAAA,QACnB,MAAME,cAAa;AAAA,QACnB,UAAUC,eAAc;AAAA,QACxB,UAAU,IAAI;AAAA,MAClB,CAAC;AACD,aAAOF;AAAA,IACX;AAEA,QAAI,OAAO,MAAM,IAAI,KAAK,QAAQ,CAAC,GAAG;AAClC,MAAAD,mBAAkB,KAAK;AAAA,QACnB,MAAME,cAAa;AAAA,MACvB,CAAC;AACD,aAAOD;AAAA,IACX;AAEA,WAAO,EAAE,QAAQ,OAAO,OAAO,OAAQ,IAAI,KAAc,YAAY,EAAE;AAAA,EAC3E;AAKJ;AA5BO,IAAM,aAAN;AAAM,WAyBF,SAAS,MAAM,IAAI,YAAW;AAAA,EACjC,UAAU;AACd,CAAC;;;AFjCE,IAAM,SAAS,IAAI,eAAoD,YAAY,UAAU,OAAO,GAAG,UAAU,GAAG,CAAC,OAAO,GAAG,QAAQ,sBAAsB,GAAG,WAAW,aAAa,CAAC;AAEzL,IAAM,UAAU,IAAI,eAAqD,YAAY,WAAW,OAAO,GAAG,UAAU,GAAG,CAAC,OAAO,GAAG,QAAQ,sBAAsB,GAAG,WAAW,aAAa,CAAC","sourcesContent":["import { withGetType } from \"zod-to-ts\";\n\nimport { ZodDateIn } from \"./date-in-schema\";\nimport { ZodDateOut } from \"./date-out-schema\";\n\n// eslint-disable-next-line max-len\nexport const dateIn = (...parameters: Parameters<typeof ZodDateIn.create>) => withGetType(ZodDateIn.create(...parameters), (ts) => ts.factory.createKeywordTypeNode(ts.SyntaxKind.StringKeyword));\n// eslint-disable-next-line max-len\nexport const dateOut = (...parameters: Parameters<typeof ZodDateOut.create>) => withGetType(ZodDateOut.create(...parameters), (ts) => ts.factory.createKeywordTypeNode(ts.SyntaxKind.StringKeyword));\n","import type { ParseInput, ParseReturnType, ZodTypeDef } from \"zod\";\nimport {\n addIssueToContext, INVALID, ZodIssueCode, ZodParsedType, ZodType,\n} from \"zod\";\n\nconst zodDateInKind = \"ZodDateIn\";\n\n// simple regex for ISO date, supports the following formats:\n// 2021-01-01T00:00:00.000Z\n// 2021-01-01T00:00:00Z\n// 2021-01-01T00:00:00\n// 2021-01-01\nexport const isoDateRegex = /^\\d{4}-\\d{2}-\\d{2}(T\\d{2}:\\d{2}:\\d{2}(\\.\\d{3})?)?Z?$/;\n\n// eslint-disable-next-line unicorn/prevent-abbreviations\nexport interface ZodDateInDef extends ZodTypeDef {\n typeName: typeof zodDateInKind;\n}\n\nexport class ZodDateIn extends ZodType<Date, ZodDateInDef, string> {\n // eslint-disable-next-line no-underscore-dangle\n _parse(input: ParseInput): ParseReturnType<Date> {\n // eslint-disable-next-line no-underscore-dangle\n const { status, ctx } = this._processInputParams(input);\n if (ctx.parsedType !== ZodParsedType.string) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_type,\n expected: ZodParsedType.string,\n received: ctx.parsedType,\n });\n return INVALID;\n }\n\n if (!isoDateRegex.test(ctx.data as string)) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_string,\n validation: \"regex\",\n });\n status.dirty();\n }\n\n const date = new Date(ctx.data);\n\n if (Number.isNaN(date.getTime())) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_date,\n });\n return INVALID;\n }\n\n return { status: status.value, value: date };\n }\n\n static create = () => new ZodDateIn({\n typeName: zodDateInKind,\n });\n}\n","import type { ParseInput, ParseReturnType, ZodTypeDef } from \"zod\";\nimport {\n addIssueToContext, INVALID, ZodIssueCode, ZodParsedType, ZodType,\n} from \"zod\";\n\nconst zodDateOutKind = \"ZodDateOut\";\n\n// eslint-disable-next-line unicorn/prevent-abbreviations\nexport interface ZodDateOutDef extends ZodTypeDef {\n typeName: typeof zodDateOutKind;\n}\n\nexport class ZodDateOut extends ZodType<string, ZodDateOutDef, Date> {\n // eslint-disable-next-line no-underscore-dangle\n _parse(input: ParseInput): ParseReturnType<string> {\n // eslint-disable-next-line no-underscore-dangle\n const { status, ctx } = this._processInputParams(input);\n\n if (ctx.parsedType !== ZodParsedType.date) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_type,\n expected: ZodParsedType.date,\n received: ctx.parsedType,\n });\n return INVALID;\n }\n\n if (Number.isNaN(ctx.data.getTime())) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_date,\n });\n return INVALID;\n }\n\n return { status: status.value, value: (ctx.data as Date).toISOString() };\n }\n\n static create = () => new ZodDateOut({\n typeName: zodDateOutKind,\n });\n}\n"]}
@@ -1,10 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});var __defProp = Object.defineProperty;
2
- var __export = (target, all) => {
3
- for (var name in all)
4
- __defProp(target, name, { get: all[name], enumerable: true });
5
- };
6
-
7
-
8
-
9
- exports.__export = __export;
10
- //# sourceMappingURL=chunk-JC4IRQUL.js.map