diff --git a/README.md b/README.md index 0a82352..291ec12 100644 --- a/README.md +++ b/README.md @@ -12,6 +12,7 @@ A lightweight, type-safe TypeScript library for generating prefixed IDs with cus - ๐ฆ **Lightweight** - Minimal dependencies (only `nanoid`) - ๐ **Zod Integration** - Built-in Zod validation schemas (optional) - โ **Valibot Integration** - Built-in Valibot validation schemas (optional) +- ๐๏ธ **ArkType Integration** - Built-in ArkType validation schemas (optional) - ๐งช **Well Tested** - Comprehensive test coverage - ๐ **Modern ESM** - ES modules with CommonJS support @@ -27,20 +28,6 @@ pnpm add typed-id bun add typed-id ``` -### Optional Dependencies - -For Zod validation support: - -```bash -npm install zod -``` - -For Valibot validation support: - -```bash -npm install valibot -``` - ## ๐ Usage ### Basic Usage @@ -117,7 +104,17 @@ const orderId = orderIdHelper.generate(); // processUser(orderId); // โ Type error: Argument of type 'OrderId' is not assignable to parameter of type 'UserId' ``` -## ๐ Zod Integration +## ๐ง Integrations + +Typed-id provides seamless integration with popular TypeScript validation libraries. Choose the one that fits your project's needs. + +### ๐ Zod Integration + +First, install Zod if you haven't already: + +```bash +npm install zod +``` If you're using Zod for validation, typed-id provides built-in schema creators: @@ -143,7 +140,13 @@ const userSchema = z.object({ }); ``` -## โ Valibot Integration +### โ Valibot Integration + +First, install Valibot if you haven't already: + +```bash +npm install valibot +``` If you're using Valibot for validation, typed-id provides built-in schema creators: @@ -170,6 +173,87 @@ const userSchema = object({ }); ``` +### ๐๏ธ ArkType Integration + +First, install ArkType if you haven't already: + +```bash +npm install arktype +``` + +If you're using ArkType for validation, typed-id provides built-in schema creators: + +```typescript +import { IdHelper } from "typed-id"; +import { createArkTypeIdSchema } from "typed-id/validators/arktype"; +import { ArkErrors } from "arktype"; + +const userIdHelper = new IdHelper("user"); +const userIdSchema = createArkTypeIdSchema(userIdHelper); + +// Validate IDs +const validId = userIdHelper.generate(); +const validResult = userIdSchema(validId); +console.log(validResult); // Returns the actual ID string if valid + +const invalidResult = userIdSchema("invalid_id"); +console.log(invalidResult instanceof ArkErrors); // true if invalid + +// Use in your ArkType schemas +import { type } from "arktype"; + +const userSchema = type({ + id: userIdSchema, + name: "string", + email: "string.email", +}); + +// Type-safe validation +const result = userSchema({ + id: userIdHelper.generate(), + name: "John Doe", + email: "john@example.com", +}); + +if (result instanceof ArkErrors) { + console.log("Validation failed:", result.summary); +} else { + console.log("Valid user:", result); // Fully typed user object +} +``` + +#### Custom Validation Examples + +```typescript +import { IdHelper } from "typed-id"; +import { createArkTypeIdSchema } from "typed-id/validators/arktype"; + +// Different ID helpers with custom configurations +const orderIdHelper = new IdHelper("order", { + separator: "::", + length: 12, + customAlphabets: "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789", +}); + +const sessionIdHelper = new IdHelper("session", { + separator: "_", + length: 16, + customAlphabets: "0123456789abcdef", // Hex only +}); + +// Create corresponding schemas +const orderIdSchema = createArkTypeIdSchema(orderIdHelper); +const sessionIdSchema = createArkTypeIdSchema(sessionIdHelper); + +// Validate different ID formats +const orderId = orderIdHelper.generate(); // "order::ABC123DEF456" +const sessionId = sessionIdHelper.generate(); // "session_a1b2c3d4e5f6789a" + +console.log(orderIdSchema(orderId)); // Valid: returns the ID +console.log(sessionIdSchema(sessionId)); // Valid: returns the ID +console.log(orderIdSchema(sessionId) instanceof ArkErrors); // true - wrong format +``` + ## โ๏ธ Configuration Options | Option | Type | Default | Description | @@ -300,6 +384,7 @@ This library has comprehensive test coverage including: - ID generation with custom options - Zod validation schemas - Valibot validation schemas +- ArkType validation schemas - Type safety verification Run tests: diff --git a/bun.lock b/bun.lock index ba4a5cc..84cd44d 100644 --- a/bun.lock +++ b/bun.lock @@ -10,23 +10,30 @@ "@types/bun": "latest", "@types/node": "^24.3.0", "@vitest/ui": "^3.2.4", + "arktype": "^2.1.20", "tsup": "^8.5.0", "valibot": "^1.1.0", "vitest": "^3.2.4", "zod": "^4.0.17", }, "peerDependencies": { + "arktype": "^2.1.20", "typescript": "^5", "valibot": "^1.1.0", "zod": "^4.0.17", }, "optionalPeers": [ + "arktype", "valibot", "zod", ], }, }, "packages": { + "@ark/schema": ["@ark/schema@0.46.0", "", { "dependencies": { "@ark/util": "0.46.0" } }, "sha512-c2UQdKgP2eqqDArfBqQIJppxJHvNNXuQPeuSPlDML4rjw+f1cu0qAlzOG4b8ujgm9ctIDWwhpyw6gjG5ledIVQ=="], + + "@ark/util": ["@ark/util@0.46.0", "", {}, "sha512-JPy/NGWn/lvf1WmGCPw2VGpBg5utZraE84I7wli18EDF3p3zc/e9WolT35tINeZO3l7C77SjqRJeAUoT0CvMRg=="], + "@esbuild/aix-ppc64": ["@esbuild/aix-ppc64@0.25.9", "", { "os": "aix", "cpu": "ppc64" }, "sha512-OaGtL73Jck6pBKjNIe24BnFE6agGl+6KxDtTfHhy1HmhthfKouEcOhqpSL64K4/0WCtbKFLOdzD/44cJ4k9opA=="], "@esbuild/android-arm": ["@esbuild/android-arm@0.25.9", "", { "os": "android", "cpu": "arm" }, "sha512-5WNI1DaMtxQ7t7B6xa572XMXpHAaI/9Hnhk8lcxF4zVN4xstUgTlvuGDorBguKEnZO70qwEcLpfifMLoxiPqHQ=="], @@ -169,6 +176,8 @@ "any-promise": ["any-promise@1.3.0", "", {}, "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A=="], + "arktype": ["arktype@2.1.20", "", { "dependencies": { "@ark/schema": "0.46.0", "@ark/util": "0.46.0" } }, "sha512-IZCEEXaJ8g+Ijd59WtSYwtjnqXiwM8sWQ5EjGamcto7+HVN9eK0C4p0zDlCuAwWhpqr6fIBkxPuYDl4/Mcj/+Q=="], + "assertion-error": ["assertion-error@2.0.1", "", {}, "sha512-Izi8RQcffqCeNVgFigKli1ssklIbpHnCYc6AknXGYoB6grJqyeby7jv12JUQgmTAnIDnbck1uxksT4dzN3PWBA=="], "balanced-match": ["balanced-match@1.0.2", "", {}, "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw=="], diff --git a/package.json b/package.json index 9c67f9a..d04f839 100644 --- a/package.json +++ b/package.json @@ -65,12 +65,14 @@ "@types/bun": "latest", "@types/node": "^24.3.0", "@vitest/ui": "^3.2.4", + "arktype": "^2.1.20", "tsup": "^8.5.0", "valibot": "^1.1.0", "vitest": "^3.2.4", "zod": "^4.0.17" }, "peerDependencies": { + "arktype": "^2.1.20", "typescript": "^5", "valibot": "^1.1.0", "zod": "^4.0.17" @@ -79,6 +81,9 @@ "nanoid": "^5.1.5" }, "peerDependenciesMeta": { + "arktype": { + "optional": true + }, "valibot": { "optional": true }, diff --git a/src/validators/arktype.ts b/src/validators/arktype.ts new file mode 100644 index 0000000..23931fa --- /dev/null +++ b/src/validators/arktype.ts @@ -0,0 +1,13 @@ +import { IdHelper } from "../id-helper"; +import { type } from "arktype"; +import type { GeneratedId, SeparatorOrDefault } from "../types"; +import type { Type } from "arktype"; + +export function createArkTypeIdSchema< + P extends string, + S extends string | undefined = undefined +>(idHelper: IdHelper
) {
+  const { regex } = idHelper;
+
+  return type