@farcaster/frame-core 0.0.0-canary-20250430150627

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 (119) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +13 -0
  3. package/dist/actions/AddFrame.d.ts +36 -0
  4. package/dist/actions/AddFrame.js +57 -0
  5. package/dist/actions/ComposeCast.d.ts +32 -0
  6. package/dist/actions/ComposeCast.js +2 -0
  7. package/dist/actions/Ready.d.ts +13 -0
  8. package/dist/actions/Ready.js +6 -0
  9. package/dist/actions/SendToken.d.ts +48 -0
  10. package/dist/actions/SendToken.js +2 -0
  11. package/dist/actions/SignIn.d.ts +41 -0
  12. package/dist/actions/SignIn.js +47 -0
  13. package/dist/actions/SwapToken.d.ts +46 -0
  14. package/dist/actions/SwapToken.js +2 -0
  15. package/dist/actions/ViewProfile.d.ts +4 -0
  16. package/dist/actions/ViewProfile.js +2 -0
  17. package/dist/actions/ViewToken.d.ts +4 -0
  18. package/dist/actions/ViewToken.js +2 -0
  19. package/dist/actions/index.d.ts +8 -0
  20. package/dist/actions/index.js +44 -0
  21. package/dist/context.d.ts +72 -0
  22. package/dist/context.js +2 -0
  23. package/dist/errors.d.ts +13 -0
  24. package/dist/errors.js +12 -0
  25. package/dist/index.d.ts +7 -0
  26. package/dist/index.js +46 -0
  27. package/dist/internal/types.d.ts +8 -0
  28. package/dist/internal/types.js +2 -0
  29. package/dist/manifest.d.ts +101 -0
  30. package/dist/manifest.js +2 -0
  31. package/dist/schemas/embeds.d.ts +243 -0
  32. package/dist/schemas/embeds.js +32 -0
  33. package/dist/schemas/events.d.ts +131 -0
  34. package/dist/schemas/events.js +25 -0
  35. package/dist/schemas/index.d.ts +5 -0
  36. package/dist/schemas/index.js +21 -0
  37. package/dist/schemas/manifest.d.ts +208 -0
  38. package/dist/schemas/manifest.js +61 -0
  39. package/dist/schemas/notifications.d.ts +60 -0
  40. package/dist/schemas/notifications.js +23 -0
  41. package/dist/schemas/shared.d.ts +39 -0
  42. package/dist/schemas/shared.js +58 -0
  43. package/dist/types.d.ts +60 -0
  44. package/dist/types.js +21 -0
  45. package/dist/wallet/ethereum.d.ts +47 -0
  46. package/dist/wallet/ethereum.js +2 -0
  47. package/dist/wallet/index.d.ts +1 -0
  48. package/dist/wallet/index.js +37 -0
  49. package/esm/actions/AddFrame.d.ts +36 -0
  50. package/esm/actions/AddFrame.js +19 -0
  51. package/esm/actions/ComposeCast.d.ts +32 -0
  52. package/esm/actions/ComposeCast.js +1 -0
  53. package/esm/actions/Ready.d.ts +13 -0
  54. package/esm/actions/Ready.js +3 -0
  55. package/esm/actions/SendToken.d.ts +48 -0
  56. package/esm/actions/SendToken.js +1 -0
  57. package/esm/actions/SignIn.d.ts +41 -0
  58. package/esm/actions/SignIn.js +10 -0
  59. package/esm/actions/SwapToken.d.ts +46 -0
  60. package/esm/actions/SwapToken.js +1 -0
  61. package/esm/actions/ViewProfile.d.ts +4 -0
  62. package/esm/actions/ViewProfile.js +1 -0
  63. package/esm/actions/ViewToken.d.ts +4 -0
  64. package/esm/actions/ViewToken.js +1 -0
  65. package/esm/actions/index.d.ts +8 -0
  66. package/esm/actions/index.js +8 -0
  67. package/esm/context.d.ts +72 -0
  68. package/esm/context.js +1 -0
  69. package/esm/errors.d.ts +13 -0
  70. package/esm/errors.js +8 -0
  71. package/esm/index.d.ts +7 -0
  72. package/esm/index.js +7 -0
  73. package/esm/internal/types.d.ts +8 -0
  74. package/esm/internal/types.js +1 -0
  75. package/esm/manifest.d.ts +101 -0
  76. package/esm/manifest.js +1 -0
  77. package/esm/schemas/embeds.d.ts +243 -0
  78. package/esm/schemas/embeds.js +28 -0
  79. package/esm/schemas/events.d.ts +131 -0
  80. package/esm/schemas/events.js +22 -0
  81. package/esm/schemas/index.d.ts +5 -0
  82. package/esm/schemas/index.js +5 -0
  83. package/esm/schemas/manifest.d.ts +208 -0
  84. package/esm/schemas/manifest.js +58 -0
  85. package/esm/schemas/notifications.d.ts +60 -0
  86. package/esm/schemas/notifications.js +20 -0
  87. package/esm/schemas/shared.d.ts +39 -0
  88. package/esm/schemas/shared.js +54 -0
  89. package/esm/tsconfig.tsbuildinfo +1 -0
  90. package/esm/types.d.ts +60 -0
  91. package/esm/types.js +3 -0
  92. package/esm/wallet/ethereum.d.ts +47 -0
  93. package/esm/wallet/ethereum.js +1 -0
  94. package/esm/wallet/index.d.ts +1 -0
  95. package/esm/wallet/index.js +1 -0
  96. package/package.json +41 -0
  97. package/src/actions/AddFrame.ts +51 -0
  98. package/src/actions/ComposeCast.ts +36 -0
  99. package/src/actions/Ready.ts +15 -0
  100. package/src/actions/SendToken.ts +57 -0
  101. package/src/actions/SignIn.ts +51 -0
  102. package/src/actions/SwapToken.ts +54 -0
  103. package/src/actions/ViewProfile.ts +5 -0
  104. package/src/actions/ViewToken.ts +5 -0
  105. package/src/actions/index.ts +8 -0
  106. package/src/context.ts +90 -0
  107. package/src/errors.ts +21 -0
  108. package/src/index.ts +7 -0
  109. package/src/internal/types.ts +20 -0
  110. package/src/manifest.ts +113 -0
  111. package/src/schemas/embeds.ts +44 -0
  112. package/src/schemas/events.ts +41 -0
  113. package/src/schemas/index.ts +5 -0
  114. package/src/schemas/manifest.ts +68 -0
  115. package/src/schemas/notifications.ts +33 -0
  116. package/src/schemas/shared.ts +81 -0
  117. package/src/types.ts +95 -0
  118. package/src/wallet/ethereum.ts +65 -0
  119. package/src/wallet/index.ts +1 -0
@@ -0,0 +1,19 @@
1
+ import * as Errors from '../errors';
2
+ /**
3
+ * Thrown when the frame does not have a valid domain manifest.
4
+ */
5
+ export class InvalidDomainManifest extends Errors.BaseError {
6
+ name = 'AddFrame.InvalidDomainManifest';
7
+ constructor() {
8
+ super('Invalid domain manifest');
9
+ }
10
+ }
11
+ /**
12
+ * Thrown when add frame action was rejected by the user.
13
+ */
14
+ export class RejectedByUser extends Errors.BaseError {
15
+ name = 'AddFrame.RejectedByUser';
16
+ constructor() {
17
+ super('Add frame rejected by user');
18
+ }
19
+ }
@@ -0,0 +1,32 @@
1
+ export type Options<close extends boolean | undefined = undefined> = {
2
+ /**
3
+ * Suggested text for the body of the cast.
4
+ *
5
+ * Mentions can be included using the human-writeable form (e.g. @farcaster).
6
+ **/
7
+ text?: string;
8
+ /** Suggested embeds. Max two. */
9
+ embeds?: [] | [string] | [string, string];
10
+ /** Suggested parent. */
11
+ parent?: {
12
+ type: 'cast';
13
+ hash: string;
14
+ };
15
+ /** Whether the app should be closed when this action is called. */
16
+ close?: close;
17
+ };
18
+ export type Result<close extends boolean | undefined = undefined> = close extends true ? undefined : {
19
+ cast: {
20
+ /** Cast of the created cast */
21
+ hash: string;
22
+ /** Text of the created cast */
23
+ text?: string;
24
+ /** Embeds of the created cast */
25
+ embeds?: [] | [string] | [string, string];
26
+ /** Parent of the created cast */
27
+ parent?: {
28
+ type: 'cast';
29
+ hash: string;
30
+ };
31
+ };
32
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,13 @@
1
+ export type ReadyOptions = {
2
+ /**
3
+ * Disable native gestures. Use this option if your frame uses gestures
4
+ * that conflict with native gestures.
5
+ *
6
+ * @defaultValue false
7
+ */
8
+ disableNativeGestures: boolean;
9
+ };
10
+ export declare const DEFAULT_READY_OPTIONS: {
11
+ disableNativeGestures: false;
12
+ };
13
+ export type Ready = (options?: Partial<ReadyOptions>) => void;
@@ -0,0 +1,3 @@
1
+ export const DEFAULT_READY_OPTIONS = {
2
+ disableNativeGestures: false,
3
+ };
@@ -0,0 +1,48 @@
1
+ export type SendTokenOptions = {
2
+ /**
3
+ * CAIP-19 asset ID
4
+ * For example, Base USDC:
5
+ * eip155:8453/erc20:0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913
6
+ */
7
+ token?: string;
8
+ /**
9
+ * Token amount, as numeric string.
10
+ * For example, 10 USDC: 1000000
11
+ */
12
+ amount?: string;
13
+ /**
14
+ * Recipient address.
15
+ */
16
+ recipientAddress?: string;
17
+ /**
18
+ * Recipient fid.
19
+ */
20
+ recipientFid?: number;
21
+ };
22
+ type SendTokenDetails = {
23
+ /**
24
+ * Tx identifier.
25
+ */
26
+ transaction: `0x${string}`;
27
+ };
28
+ type SendTokenErrorDetails = {
29
+ /**
30
+ * Error code.
31
+ */
32
+ error: string;
33
+ /**
34
+ * Error message.
35
+ */
36
+ message?: string;
37
+ };
38
+ export type SendTokenErrorReason = 'rejected_by_user' | 'send_failed';
39
+ export type SendTokenResult = {
40
+ success: true;
41
+ send: SendTokenDetails;
42
+ } | {
43
+ success: false;
44
+ reason: SendTokenErrorReason;
45
+ error?: SendTokenErrorDetails;
46
+ };
47
+ export type SendToken = (options: SendTokenOptions) => Promise<SendTokenResult>;
48
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,41 @@
1
+ import * as Errors from '../errors';
2
+ import type { OneOf } from '../internal/types';
3
+ export type SignInOptions = {
4
+ /**
5
+ * A random string used to prevent replay attacks.
6
+ */
7
+ nonce: string;
8
+ /**
9
+ * Start time at which the signature becomes valid.
10
+ * ISO 8601 datetime.
11
+ */
12
+ notBefore?: string;
13
+ /**
14
+ * Expiration time at which the signature is no longer valid.
15
+ * ISO 8601 datetime.
16
+ */
17
+ expirationTime?: string;
18
+ };
19
+ export type SignInResult = {
20
+ signature: string;
21
+ message: string;
22
+ };
23
+ export type SignIn = (options: SignInOptions) => Promise<SignInResult>;
24
+ type RejectedByUserJsonError = {
25
+ type: 'rejected_by_user';
26
+ };
27
+ export type SignInJsonError = RejectedByUserJsonError;
28
+ export type SignInJsonResult = OneOf<{
29
+ result: SignInResult;
30
+ } | {
31
+ error: SignInJsonError;
32
+ }>;
33
+ export type WireSignIn = (options: SignInOptions) => Promise<SignInJsonResult>;
34
+ /**
35
+ * Thrown when a sign in action was rejected.
36
+ */
37
+ export declare class RejectedByUser extends Errors.BaseError {
38
+ readonly name = "SignIn.RejectedByUser";
39
+ constructor();
40
+ }
41
+ export {};
@@ -0,0 +1,10 @@
1
+ import * as Errors from '../errors';
2
+ /**
3
+ * Thrown when a sign in action was rejected.
4
+ */
5
+ export class RejectedByUser extends Errors.BaseError {
6
+ name = 'SignIn.RejectedByUser';
7
+ constructor() {
8
+ super('Sign in rejected by user');
9
+ }
10
+ }
@@ -0,0 +1,46 @@
1
+ export type SwapTokenOptions = {
2
+ /**
3
+ * CAIP-19 asset ID
4
+ * For example, Base USDC:
5
+ * eip155:8453/erc20:0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913
6
+ */
7
+ sellToken?: string;
8
+ /**
9
+ * CAIP-19 token ID. For example, OP ETH:
10
+ * eip155:10/native
11
+ */
12
+ buyToken?: string;
13
+ /**
14
+ * Sell token amount, as numeric string.
15
+ * For example, 10 USDC: 1000000
16
+ */
17
+ sellAmount?: string;
18
+ };
19
+ type SwapTokenDetails = {
20
+ /**
21
+ * Array of tx identifiers in order of execution.
22
+ * Some swaps will have both an approval and swap tx.
23
+ */
24
+ transactions: `0x${string}`[];
25
+ };
26
+ type SwapTokenErrorDetails = {
27
+ /**
28
+ * Error code.
29
+ */
30
+ error: string;
31
+ /**
32
+ * Error message.
33
+ */
34
+ message?: string;
35
+ };
36
+ export type SwapErrorReason = 'rejected_by_user' | 'swap_failed';
37
+ export type SwapTokenResult = {
38
+ success: true;
39
+ swap: SwapTokenDetails;
40
+ } | {
41
+ success: false;
42
+ reason: SwapErrorReason;
43
+ error?: SwapTokenErrorDetails;
44
+ };
45
+ export type SwapToken = (options: SwapTokenOptions) => Promise<SwapTokenResult>;
46
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,4 @@
1
+ export type ViewProfileOptions = {
2
+ fid: number;
3
+ };
4
+ export type ViewProfile = (options: ViewProfileOptions) => Promise<void>;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,4 @@
1
+ export type ViewTokenOptions = {
2
+ token: string;
3
+ };
4
+ export type ViewToken = (options: ViewTokenOptions) => Promise<void>;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,8 @@
1
+ export * as AddFrame from './AddFrame';
2
+ export * as ComposeCast from './ComposeCast';
3
+ export * as Ready from './Ready';
4
+ export * as SignIn from './SignIn';
5
+ export * as SendToken from './SendToken';
6
+ export * as SwapToken from './SwapToken';
7
+ export * as ViewProfile from './ViewProfile';
8
+ export * as ViewToken from './ViewToken';
@@ -0,0 +1,8 @@
1
+ export * as AddFrame from './AddFrame';
2
+ export * as ComposeCast from './ComposeCast';
3
+ export * as Ready from './Ready';
4
+ export * as SignIn from './SignIn';
5
+ export * as SendToken from './SendToken';
6
+ export * as SwapToken from './SwapToken';
7
+ export * as ViewProfile from './ViewProfile';
8
+ export * as ViewToken from './ViewToken';
@@ -0,0 +1,72 @@
1
+ import type { FrameNotificationDetails } from './schemas';
2
+ export type CastEmbedLocationContext = {
3
+ type: 'cast_embed';
4
+ embed: string;
5
+ cast: {
6
+ fid: number;
7
+ hash: string;
8
+ };
9
+ };
10
+ export type NotificationLocationContext = {
11
+ type: 'notification';
12
+ notification: {
13
+ notificationId: string;
14
+ title: string;
15
+ body: string;
16
+ };
17
+ };
18
+ export type LauncherLocationContext = {
19
+ type: 'launcher';
20
+ };
21
+ export type ChannelLocationContext = {
22
+ type: 'channel';
23
+ channel: {
24
+ /**
25
+ * Channel key identifier
26
+ */
27
+ key: string;
28
+ /**
29
+ * Channel name
30
+ */
31
+ name: string;
32
+ /**
33
+ * Channel profile image URL
34
+ */
35
+ imageUrl?: string;
36
+ };
37
+ };
38
+ export type LocationContext = CastEmbedLocationContext | NotificationLocationContext | LauncherLocationContext | ChannelLocationContext;
39
+ export type AccountLocation = {
40
+ placeId: string;
41
+ /**
42
+ * Human-readable string describing the location
43
+ */
44
+ description: string;
45
+ };
46
+ export type UserContext = {
47
+ fid: number;
48
+ username?: string;
49
+ displayName?: string;
50
+ /**
51
+ * Profile image URL
52
+ */
53
+ pfpUrl?: string;
54
+ location?: AccountLocation;
55
+ };
56
+ export type SafeAreaInsets = {
57
+ top: number;
58
+ bottom: number;
59
+ left: number;
60
+ right: number;
61
+ };
62
+ export type ClientContext = {
63
+ clientFid: number;
64
+ added: boolean;
65
+ notificationDetails?: FrameNotificationDetails;
66
+ safeAreaInsets?: SafeAreaInsets;
67
+ };
68
+ export type FrameContext = {
69
+ client: ClientContext;
70
+ user: UserContext;
71
+ location?: LocationContext;
72
+ };
package/esm/context.js ADDED
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,13 @@
1
+ export type GlobalErrorType<name extends string = 'Error'> = Error & {
2
+ name: name;
3
+ };
4
+ export declare class BaseError<cause extends Error | undefined = undefined> extends Error {
5
+ name: string;
6
+ cause: cause;
7
+ constructor(message: string, options?: BaseError.Options<cause>);
8
+ }
9
+ export declare namespace BaseError {
10
+ type Options<cause extends Error | undefined = Error | undefined> = {
11
+ cause?: cause | undefined;
12
+ };
13
+ }
package/esm/errors.js ADDED
@@ -0,0 +1,8 @@
1
+ export class BaseError extends Error {
2
+ name = 'BaseError';
3
+ cause;
4
+ constructor(message, options = {}) {
5
+ super(message, options.cause ? { cause: options.cause } : undefined);
6
+ this.cause = options.cause;
7
+ }
8
+ }
package/esm/index.d.ts ADDED
@@ -0,0 +1,7 @@
1
+ export * from './actions';
2
+ export * from './wallet';
3
+ export * as Errors from './errors';
4
+ export * as Context from './context';
5
+ export * as Manifest from './manifest';
6
+ export * from './types';
7
+ export * from './schemas';
package/esm/index.js ADDED
@@ -0,0 +1,7 @@
1
+ export * from './actions';
2
+ export * from './wallet';
3
+ export * as Errors from './errors';
4
+ export * as Context from './context';
5
+ export * as Manifest from './manifest';
6
+ export * from './types';
7
+ export * from './schemas';
@@ -0,0 +1,8 @@
1
+ type Compute<type> = {
2
+ [key in keyof type]: type[key];
3
+ } & unknown;
4
+ type KeyofUnion<type> = type extends type ? keyof type : never;
5
+ export type OneOf<union extends object, fallback extends object | undefined = undefined, keys extends KeyofUnion<union> = KeyofUnion<union>> = union extends infer item ? Compute<item & {
6
+ [key in Exclude<keys, keyof item>]?: fallback extends object ? key extends keyof fallback ? fallback[key] : undefined : undefined;
7
+ }> : never;
8
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,101 @@
1
+ /**
2
+ * Farcaster manifest for a domain hosted at `/.well-known/farcaster.json`
3
+ */
4
+ export type Manifest = {
5
+ accountAssociation: AccountAssociation;
6
+ frame: FrameConfig;
7
+ };
8
+ /**
9
+ * Signed domain association linking this frame to a Farcaster account
10
+ *
11
+ * A DomainAssociation can be generated using the {@link https://warpcast.com/~/developers/domains | Warpcast
12
+ * Domains Developer} tool.
13
+ */
14
+ export type AccountAssociation = {
15
+ /**
16
+ * Base64URL encoded JFS signature
17
+ */
18
+ header: string;
19
+ /**
20
+ * Base64URL encoded payload signature
21
+ */
22
+ payload: string;
23
+ /**
24
+ * Base64URL encoded signature
25
+ */
26
+ signature: string;
27
+ };
28
+ /**
29
+ * Frame configuration
30
+ *
31
+ * @example
32
+ * ``ts
33
+ * const frame: FrameConfig = {
34
+ * version: '1',
35
+ * name: 'Yoink!',
36
+ * homeUrl: 'https://yoink.party',
37
+ * iconUrl: 'https://yoink.party/img/icon.png',
38
+ * imageUrl: 'https://yoink.party/framesV2/opengraph-image',
39
+ * buttonTitle: '🚩 Start',
40
+ * splashImageUrl: 'https://yoink.party/img/splash.png',
41
+ * splashImageBackgroundColor: '#eeeee4',
42
+ * webhookUrl: 'https://yoink.party/webhook'
43
+ * };
44
+ * ``
45
+ */
46
+ export type FrameConfig = {
47
+ /**
48
+ * Manifest version
49
+ *
50
+ * Must be the literal '1'.
51
+ */
52
+ version: '1';
53
+ /**
54
+ * App name that will be displayed to users
55
+ *
56
+ * Max length of 32 characters.
57
+ */
58
+ name: string;
59
+ /**
60
+ * Default launch URL
61
+ *
62
+ * Max length of 1024 characters.
63
+ */
64
+ homeUrl: string;
65
+ /**
66
+ * Icon URL
67
+ *
68
+ * Max length of 1024 characters. Image must be 200x200px and less than 1MB.
69
+ */
70
+ iconUrl: string;
71
+ /**
72
+ * Image URL
73
+ *
74
+ * Max length of 1024 characters. Image must have a 3:2 ratio.
75
+ */
76
+ imageUrl: string;
77
+ /**
78
+ * Default button title to use when frame is rendered.
79
+ *
80
+ * Max length of 32 characters.
81
+ */
82
+ buttonTitle: string;
83
+ /**
84
+ * Splash image URL
85
+ *
86
+ * Max length of 1024 characters. Image must be 200x200px and less than 1MB.
87
+ */
88
+ splashImageUrl?: string;
89
+ /**
90
+ * Splash background color
91
+ *
92
+ * Must be a hex color code.
93
+ */
94
+ splashBackgroundColor?: string;
95
+ /**
96
+ * URL to which clients will POST server events.
97
+ * Max length of 1024 characters.
98
+ * Required if the frame application uses notifications.
99
+ */
100
+ webhookUrl?: string;
101
+ };
@@ -0,0 +1 @@
1
+ export {};