@farcaster/snap 1.2.1 → 1.3.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/dist/schemas.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { z } from "zod";
1
+ import { z } from "zod/v4";
2
2
  declare const buttonSchema: z.ZodObject<{
3
3
  label: z.ZodString;
4
4
  action: z.ZodEnum<{
package/dist/schemas.js CHANGED
@@ -1,4 +1,4 @@
1
- import { z } from "zod";
1
+ import { z } from "zod/v4";
2
2
  import { BAR_CHART_COLOR_VALUES, BUTTON_ACTION, BUTTON_ACTION_VALUES, BUTTON_GROUP_STYLE, BUTTON_GROUP_STYLE_VALUES, BUTTON_LAYOUT_VALUES, BUTTON_STYLE_VALUES, DEFAULT_BUTTON_LAYOUT, DEFAULT_LIST_STYLE, DEFAULT_SLIDER_STEP, DEFAULT_THEME_ACCENT, EFFECT_VALUES, ELEMENT_TYPE, GRID_CELL_SIZE_VALUES, GRID_GAP_VALUES, GROUP_LAYOUT_VALUES, HEX_COLOR_6_RE, HTTP_PREFIX, HTTPS_PREFIX, IMAGE_ASPECT_VALUES, INTERACTIVE_ELEMENT_TYPES, LIMITS, LIST_STYLE_VALUES, MEDIA_ELEMENT_TYPES, PAGE_ROOT_TYPE, PALETTE_COLOR_VALUES, PROGRESS_COLOR_VALUES, SLIDER_STEP_ALIGN_EPS, SPACER_SIZE, SPACER_SIZE_VALUES, SPEC_VERSION, TEXT_ALIGN_VALUES, TEXT_CONTENT_MAX, TEXT_STYLE, TEXT_STYLE_VALUES, VIDEO_ASPECT_VALUES, } from "./constants.js";
3
3
  /**
4
4
  * post/link/mini_app targets must be HTTPS in production; allow HTTP only for
@@ -1,5 +1,5 @@
1
1
  import { type SnapAction } from "../schemas.js";
2
- import { z } from "zod";
2
+ import { z } from "zod/v4";
3
3
  export type ParseRequestError = {
4
4
  type: "method_not_allowed";
5
5
  message: string;
@@ -1,6 +1,6 @@
1
1
  import { payloadSchema } from "../schemas.js";
2
2
  import { decodePayload, verifyJFSRequestBody } from "./verify.js";
3
- import { z } from "zod";
3
+ import { z } from "zod/v4";
4
4
  /** Default replay window per SPEC.md § Replay Protection (5 minutes). */
5
5
  const DEFAULT_SNAP_POST_MAX_SKEW_SECONDS = 300;
6
6
  const requestBodySchema = z.object({
@@ -1,10 +1,10 @@
1
- import * as jfs from "@farcaster/jfs"; // must be imported like this to avoid ERR_REQUIRE_ESM error
1
+ import { compact, decode, decodePayload as jfsDecodePayload, encodePayload as jfsEncodePayload, verify, } from "@farcaster/jfs";
2
2
  import { hexToBytes } from "viem";
3
3
  import { DEFAULT_SNAP_HUB_HTTP_BASE_URL, getActiveEd25519SignerKeysFromHubHttp, } from "./hubs.js";
4
4
  export async function verifyJFSRequestBody(requestBody, options = {}) {
5
5
  let compactJfs;
6
6
  try {
7
- compactJfs = jfs.compact({
7
+ compactJfs = compact({
8
8
  header: requestBody.header,
9
9
  payload: requestBody.payload,
10
10
  signature: requestBody.signature,
@@ -18,7 +18,7 @@ export async function verifyJFSRequestBody(requestBody, options = {}) {
18
18
  }
19
19
  let decoded;
20
20
  try {
21
- decoded = jfs.decode(compactJfs);
21
+ decoded = decode(compactJfs);
22
22
  }
23
23
  catch (error) {
24
24
  return {
@@ -27,7 +27,7 @@ export async function verifyJFSRequestBody(requestBody, options = {}) {
27
27
  };
28
28
  }
29
29
  try {
30
- await jfs.verify({ data: compactJfs, strict: true, keyTypes: ["app_key"] });
30
+ await verify({ data: compactJfs, strict: true, keyTypes: ["app_key"] });
31
31
  }
32
32
  catch (error) {
33
33
  return {
@@ -72,10 +72,10 @@ export async function verifyJFSRequestBody(requestBody, options = {}) {
72
72
  };
73
73
  }
74
74
  export function decodePayload(payload) {
75
- return jfs.decodePayload(payload);
75
+ return jfsDecodePayload(payload);
76
76
  }
77
77
  export function encodePayload(payload) {
78
- return jfs.encodePayload(payload);
78
+ return jfsEncodePayload(payload);
79
79
  }
80
80
  function bytesEqual(a, b) {
81
81
  if (a.length !== b.length)
@@ -1,4 +1,4 @@
1
- import { z } from "zod";
1
+ import { z } from "zod/v4";
2
2
  export type ValidationResult = {
3
3
  valid: boolean;
4
4
  issues: z.core.$ZodIssue[];
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@farcaster/snap",
3
- "version": "1.2.1",
3
+ "version": "1.3.0",
4
4
  "description": "Farcaster Snaps 🫰",
5
5
  "repository": {
6
6
  "type": "git",
@@ -31,16 +31,19 @@
31
31
  },
32
32
  "license": "MIT",
33
33
  "dependencies": {
34
- "@farcaster/jfs": "^0.2.2",
35
- "viem": "^2.21.0",
36
- "zod": "^4.3.6"
34
+ "@farcaster/jfs": "^0.3.0",
35
+ "viem": "^2.21.0"
36
+ },
37
+ "peerDependencies": {
38
+ "zod": "^3.25.0 || ^4.0.0"
37
39
  },
38
40
  "devDependencies": {
39
41
  "@types/node": "^25.5.0",
40
42
  "tsc-alias": "^1.8.16",
41
43
  "tsx": "^4.0.0",
42
44
  "typescript": "^5.4.0",
43
- "vitest": "^1.6.0"
45
+ "vitest": "^1.6.0",
46
+ "zod": "^4.0.0"
44
47
  },
45
48
  "scripts": {
46
49
  "build": "tsc && tsc-alias --resolve-full-paths --resolve-full-extension .js",
package/src/schemas.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { z } from "zod";
1
+ import { z } from "zod/v4";
2
2
  import {
3
3
  BAR_CHART_COLOR_VALUES,
4
4
  BUTTON_ACTION,
@@ -1,6 +1,6 @@
1
1
  import { payloadSchema, type SnapAction } from "../schemas";
2
2
  import { decodePayload, verifyJFSRequestBody } from "./verify";
3
- import { z } from "zod";
3
+ import { z } from "zod/v4";
4
4
 
5
5
  /** Default replay window per SPEC.md § Replay Protection (5 minutes). */
6
6
  const DEFAULT_SNAP_POST_MAX_SKEW_SECONDS = 300 as const;
@@ -1,4 +1,10 @@
1
- import * as jfs from "@farcaster/jfs"; // must be imported like this to avoid ERR_REQUIRE_ESM error
1
+ import {
2
+ compact,
3
+ decode,
4
+ decodePayload as jfsDecodePayload,
5
+ encodePayload as jfsEncodePayload,
6
+ verify,
7
+ } from "@farcaster/jfs";
2
8
  import { hexToBytes, type Hex } from "viem";
3
9
  import {
4
10
  DEFAULT_SNAP_HUB_HTTP_BASE_URL,
@@ -26,7 +32,7 @@ export async function verifyJFSRequestBody<TPayload>(
26
32
  > {
27
33
  let compactJfs: string;
28
34
  try {
29
- compactJfs = jfs.compact({
35
+ compactJfs = compact({
30
36
  header: requestBody.header,
31
37
  payload: requestBody.payload,
32
38
  signature: requestBody.signature,
@@ -38,9 +44,9 @@ export async function verifyJFSRequestBody<TPayload>(
38
44
  };
39
45
  }
40
46
 
41
- let decoded: ReturnType<typeof jfs.decode<TPayload>>;
47
+ let decoded: ReturnType<typeof decode<TPayload>>;
42
48
  try {
43
- decoded = jfs.decode<TPayload>(compactJfs);
49
+ decoded = decode<TPayload>(compactJfs);
44
50
  } catch (error) {
45
51
  return {
46
52
  valid: false,
@@ -49,7 +55,7 @@ export async function verifyJFSRequestBody<TPayload>(
49
55
  }
50
56
 
51
57
  try {
52
- await jfs.verify({ data: compactJfs, strict: true, keyTypes: ["app_key"] });
58
+ await verify({ data: compactJfs, strict: true, keyTypes: ["app_key"] });
53
59
  } catch (error) {
54
60
  return {
55
61
  valid: false,
@@ -106,11 +112,11 @@ export async function verifyJFSRequestBody<TPayload>(
106
112
  }
107
113
 
108
114
  export function decodePayload<TPayload>(payload: string): TPayload {
109
- return jfs.decodePayload<TPayload>(payload);
115
+ return jfsDecodePayload<TPayload>(payload);
110
116
  }
111
117
 
112
118
  export function encodePayload<TPayload>(payload: TPayload): string {
113
- return jfs.encodePayload(payload);
119
+ return jfsEncodePayload(payload);
114
120
  }
115
121
 
116
122
  function bytesEqual(a: Uint8Array, b: Uint8Array): boolean {
package/src/validator.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { z } from "zod";
1
+ import { z } from "zod/v4";
2
2
  import {
3
3
  BUTTON_GROUP_STYLE,
4
4
  DEFAULT_BUTTON_LAYOUT,