@appstrate/validation 1.3.0 → 1.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@appstrate/validation",
3
- "version": "1.3.0",
3
+ "version": "1.4.0",
4
4
  "type": "module",
5
5
  "files": [
6
6
  "src"
@@ -10,7 +10,8 @@
10
10
  "./zip": "./src/zip.ts",
11
11
  "./integrity": "./src/integrity.ts",
12
12
  "./naming": "./src/naming.ts",
13
- "./dependencies": "./src/dependencies.ts"
13
+ "./dependencies": "./src/dependencies.ts",
14
+ "./semver": "./src/semver.ts"
14
15
  },
15
16
  "scripts": {
16
17
  "test": "bun test",
package/src/index.ts CHANGED
@@ -36,8 +36,11 @@ export const serviceRequirementSchema = z.looseObject({
36
36
  connectionMode: z.enum(["user", "admin"]).optional(),
37
37
  });
38
38
 
39
- const slugString = z.string().min(1).regex(SLUG_REGEX, {
40
- error: "Must be a valid slug (a-z, 0-9, hyphens, no leading/trailing hyphen)",
39
+ export const PACKAGE_REF_REGEX =
40
+ /^(?:@[a-z0-9]([a-z0-9-]*[a-z0-9])?\/)?[a-z0-9]([a-z0-9-]*[a-z0-9])?$/;
41
+
42
+ const packageRefString = z.string().min(1).regex(PACKAGE_REF_REGEX, {
43
+ error: "Must be a valid slug or scoped name (@scope/name)",
41
44
  });
42
45
 
43
46
  const semverRangeString = z.string().refine((val) => semver.validRange(val) !== null, {
@@ -89,8 +92,8 @@ export type FlowJsonSchemaObject = z.infer<typeof jsonSchemaObjectSchema>;
89
92
  const flowSharedFields = {
90
93
  requires: z.looseObject({
91
94
  services: z.array(serviceRequirementSchema),
92
- skills: z.array(slugString).optional(),
93
- extensions: z.array(slugString).optional(),
95
+ skills: z.array(packageRefString).optional(),
96
+ extensions: z.array(packageRefString).optional(),
94
97
  }),
95
98
  input: z
96
99
  .object({
package/src/semver.ts ADDED
@@ -0,0 +1,35 @@
1
+ import semver from "semver";
2
+
3
+ /** Check whether `v` is a valid semver version string. */
4
+ export function isValidVersion(v: string): boolean {
5
+ return semver.valid(v) !== null;
6
+ }
7
+
8
+ /** Check whether `v` is a valid semver range string. */
9
+ export function isValidRange(v: string): boolean {
10
+ return semver.validRange(v) !== null;
11
+ }
12
+
13
+ /** Return `true` if version `a` is strictly greater than version `b`. Returns `false` if either is invalid. */
14
+ export function versionGt(a: string, b: string): boolean {
15
+ try {
16
+ return semver.gt(a, b);
17
+ } catch {
18
+ return false;
19
+ }
20
+ }
21
+
22
+ /** Comparator for sorting versions in descending order (highest first). */
23
+ export function compareVersionsDesc(a: string, b: string): number {
24
+ return semver.rcompare(a, b);
25
+ }
26
+
27
+ /** Find the highest version in `versions` that satisfies `range`, or `null` if none match. */
28
+ export function matchVersion(versions: string[], range: string): string | null {
29
+ return semver.maxSatisfying(versions, range);
30
+ }
31
+
32
+ /** Return `true` if `v` is a prerelease version (e.g. `1.0.0-beta.1`). */
33
+ export function isPrerelease(v: string): boolean {
34
+ return semver.prerelease(v) !== null;
35
+ }