@farcaster/frame-core 0.2.0 → 0.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.
Files changed (142) hide show
  1. package/dist/index.d.ts +153 -10
  2. package/dist/index.js +18 -33
  3. package/esm/index.d.ts +153 -10
  4. package/esm/index.js +17 -10
  5. package/esm/tsconfig.tsbuildinfo +1 -1
  6. package/package.json +6 -8
  7. package/src/index.ts +50 -10
  8. package/dist/actions/AddMiniApp.d.ts +0 -36
  9. package/dist/actions/AddMiniApp.js +0 -57
  10. package/dist/actions/ComposeCast.d.ts +0 -37
  11. package/dist/actions/ComposeCast.js +0 -2
  12. package/dist/actions/Haptics.d.ts +0 -5
  13. package/dist/actions/Haptics.js +0 -2
  14. package/dist/actions/Ready.d.ts +0 -13
  15. package/dist/actions/Ready.js +0 -6
  16. package/dist/actions/SendToken.d.ts +0 -48
  17. package/dist/actions/SendToken.js +0 -2
  18. package/dist/actions/SignIn.d.ts +0 -55
  19. package/dist/actions/SignIn.js +0 -47
  20. package/dist/actions/SwapToken.d.ts +0 -46
  21. package/dist/actions/SwapToken.js +0 -2
  22. package/dist/actions/ViewCast.d.ts +0 -25
  23. package/dist/actions/ViewCast.js +0 -2
  24. package/dist/actions/ViewProfile.d.ts +0 -4
  25. package/dist/actions/ViewProfile.js +0 -2
  26. package/dist/actions/ViewToken.d.ts +0 -4
  27. package/dist/actions/ViewToken.js +0 -2
  28. package/dist/actions/index.d.ts +0 -10
  29. package/dist/actions/index.js +0 -46
  30. package/dist/back.d.ts +0 -13
  31. package/dist/back.js +0 -6
  32. package/dist/context.d.ts +0 -94
  33. package/dist/context.js +0 -2
  34. package/dist/errors.d.ts +0 -13
  35. package/dist/errors.js +0 -12
  36. package/dist/internal/types.d.ts +0 -8
  37. package/dist/internal/types.js +0 -2
  38. package/dist/manifest.d.ts +0 -107
  39. package/dist/manifest.js +0 -2
  40. package/dist/schemas/embeds.d.ts +0 -243
  41. package/dist/schemas/embeds.js +0 -32
  42. package/dist/schemas/events.d.ts +0 -131
  43. package/dist/schemas/events.js +0 -25
  44. package/dist/schemas/index.d.ts +0 -5
  45. package/dist/schemas/index.js +0 -21
  46. package/dist/schemas/manifest.d.ts +0 -348
  47. package/dist/schemas/manifest.js +0 -114
  48. package/dist/schemas/notifications.d.ts +0 -60
  49. package/dist/schemas/notifications.js +0 -23
  50. package/dist/schemas/shared.d.ts +0 -40
  51. package/dist/schemas/shared.js +0 -83
  52. package/dist/solana.d.ts +0 -72
  53. package/dist/solana.js +0 -15
  54. package/dist/solanaWire.d.ts +0 -3
  55. package/dist/solanaWire.js +0 -84
  56. package/dist/types.d.ts +0 -87
  57. package/dist/types.js +0 -41
  58. package/dist/wallet/ethereum.d.ts +0 -47
  59. package/dist/wallet/ethereum.js +0 -2
  60. package/dist/wallet/index.d.ts +0 -1
  61. package/dist/wallet/index.js +0 -37
  62. package/esm/actions/AddMiniApp.d.ts +0 -36
  63. package/esm/actions/AddMiniApp.js +0 -19
  64. package/esm/actions/ComposeCast.d.ts +0 -37
  65. package/esm/actions/ComposeCast.js +0 -1
  66. package/esm/actions/Haptics.d.ts +0 -5
  67. package/esm/actions/Haptics.js +0 -1
  68. package/esm/actions/Ready.d.ts +0 -13
  69. package/esm/actions/Ready.js +0 -3
  70. package/esm/actions/SendToken.d.ts +0 -48
  71. package/esm/actions/SendToken.js +0 -1
  72. package/esm/actions/SignIn.d.ts +0 -55
  73. package/esm/actions/SignIn.js +0 -10
  74. package/esm/actions/SwapToken.d.ts +0 -46
  75. package/esm/actions/SwapToken.js +0 -1
  76. package/esm/actions/ViewCast.d.ts +0 -25
  77. package/esm/actions/ViewCast.js +0 -1
  78. package/esm/actions/ViewProfile.d.ts +0 -4
  79. package/esm/actions/ViewProfile.js +0 -1
  80. package/esm/actions/ViewToken.d.ts +0 -4
  81. package/esm/actions/ViewToken.js +0 -1
  82. package/esm/actions/index.d.ts +0 -10
  83. package/esm/actions/index.js +0 -10
  84. package/esm/back.d.ts +0 -13
  85. package/esm/back.js +0 -3
  86. package/esm/context.d.ts +0 -94
  87. package/esm/context.js +0 -1
  88. package/esm/errors.d.ts +0 -13
  89. package/esm/errors.js +0 -8
  90. package/esm/internal/types.d.ts +0 -8
  91. package/esm/internal/types.js +0 -1
  92. package/esm/manifest.d.ts +0 -107
  93. package/esm/manifest.js +0 -1
  94. package/esm/schemas/embeds.d.ts +0 -243
  95. package/esm/schemas/embeds.js +0 -28
  96. package/esm/schemas/events.d.ts +0 -131
  97. package/esm/schemas/events.js +0 -22
  98. package/esm/schemas/index.d.ts +0 -5
  99. package/esm/schemas/index.js +0 -5
  100. package/esm/schemas/manifest.d.ts +0 -348
  101. package/esm/schemas/manifest.js +0 -111
  102. package/esm/schemas/notifications.d.ts +0 -60
  103. package/esm/schemas/notifications.js +0 -20
  104. package/esm/schemas/shared.d.ts +0 -40
  105. package/esm/schemas/shared.js +0 -79
  106. package/esm/solana.d.ts +0 -72
  107. package/esm/solana.js +0 -11
  108. package/esm/solanaWire.d.ts +0 -3
  109. package/esm/solanaWire.js +0 -80
  110. package/esm/types.d.ts +0 -87
  111. package/esm/types.js +0 -23
  112. package/esm/wallet/ethereum.d.ts +0 -47
  113. package/esm/wallet/ethereum.js +0 -1
  114. package/esm/wallet/index.d.ts +0 -1
  115. package/esm/wallet/index.js +0 -1
  116. package/src/actions/AddMiniApp.ts +0 -51
  117. package/src/actions/ComposeCast.ts +0 -44
  118. package/src/actions/Haptics.ts +0 -9
  119. package/src/actions/Ready.ts +0 -15
  120. package/src/actions/SendToken.ts +0 -57
  121. package/src/actions/SignIn.ts +0 -67
  122. package/src/actions/SwapToken.ts +0 -54
  123. package/src/actions/ViewCast.ts +0 -27
  124. package/src/actions/ViewProfile.ts +0 -5
  125. package/src/actions/ViewToken.ts +0 -5
  126. package/src/actions/index.ts +0 -10
  127. package/src/back.ts +0 -15
  128. package/src/context.ts +0 -117
  129. package/src/errors.ts +0 -21
  130. package/src/internal/types.ts +0 -20
  131. package/src/manifest.ts +0 -120
  132. package/src/schemas/embeds.ts +0 -44
  133. package/src/schemas/events.ts +0 -41
  134. package/src/schemas/index.ts +0 -5
  135. package/src/schemas/manifest.ts +0 -125
  136. package/src/schemas/notifications.ts +0 -33
  137. package/src/schemas/shared.ts +0 -109
  138. package/src/solana.ts +0 -108
  139. package/src/solanaWire.ts +0 -120
  140. package/src/types.ts +0 -155
  141. package/src/wallet/ethereum.ts +0 -65
  142. package/src/wallet/index.ts +0 -1
@@ -1,55 +0,0 @@
1
- import * as Errors from '../errors.ts';
2
- import type { OneOf } from '../internal/types.ts';
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
- * Whether an [Auth
20
- * Address](https://github.com/farcasterxyz/protocol/discussions/225) signed
21
- * message is acceptable. Defaults to `false` to maintain backwards
22
- * compatibility, though applications should set this to `true` for the best
23
- * user experience assuming their verification method supports it.
24
- *
25
- * @default false
26
- */
27
- acceptAuthAddress?: boolean;
28
- };
29
- export type SignInResult = {
30
- signature: string;
31
- message: string;
32
- /**
33
- * Indicates if the signature was produced by a custody or auth address.
34
- */
35
- authMethod: 'custody' | 'authAddress';
36
- };
37
- export type SignIn = (options: SignInOptions) => Promise<SignInResult>;
38
- type RejectedByUserJsonError = {
39
- type: 'rejected_by_user';
40
- };
41
- export type SignInJsonError = RejectedByUserJsonError;
42
- export type SignInJsonResult = OneOf<{
43
- result: SignInResult;
44
- } | {
45
- error: SignInJsonError;
46
- }>;
47
- export type WireSignIn = (options: SignInOptions) => Promise<SignInJsonResult>;
48
- /**
49
- * Thrown when a sign in action was rejected.
50
- */
51
- export declare class RejectedByUser extends Errors.BaseError {
52
- readonly name = "SignIn.RejectedByUser";
53
- constructor();
54
- }
55
- export {};
@@ -1,10 +0,0 @@
1
- import * as Errors from "../errors.js";
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
- }
@@ -1,46 +0,0 @@
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, 1 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 {};
@@ -1 +0,0 @@
1
- export {};
@@ -1,25 +0,0 @@
1
- export type ViewCastOptions = {
2
- /**
3
- * The hash of the cast to view.
4
- * @example "0x6a112e2d35e2d2008e25dd29811e8769d1edd9ca"
5
- */
6
- hash: string;
7
- /**
8
- * Whether the app should be closed when this action is called.
9
- * If true, the app will be closed after opening the cast view.
10
- */
11
- close?: boolean;
12
- };
13
- /**
14
- * Opens a cast view in the Farcaster client.
15
- *
16
- * @example
17
- * ```ts
18
- * await sdk.actions.viewCast({
19
- * hash: "0x6a112e2d35e2d2008e25dd29811e8769d1edd9ca"
20
- * })
21
- * ```
22
- *
23
- * @see {@link https://miniapps.farcaster.xyz/docs/sdk/actions/view-cast | View Cast Documentation}
24
- */
25
- export type ViewCast = (options: ViewCastOptions) => Promise<void>;
@@ -1 +0,0 @@
1
- export {};
@@ -1,4 +0,0 @@
1
- export type ViewProfileOptions = {
2
- fid: number;
3
- };
4
- export type ViewProfile = (options: ViewProfileOptions) => Promise<void>;
@@ -1 +0,0 @@
1
- export {};
@@ -1,4 +0,0 @@
1
- export type ViewTokenOptions = {
2
- token: string;
3
- };
4
- export type ViewToken = (options: ViewTokenOptions) => Promise<void>;
@@ -1 +0,0 @@
1
- export {};
@@ -1,10 +0,0 @@
1
- export * as AddMiniApp from './AddMiniApp.ts';
2
- export * as ComposeCast from './ComposeCast.ts';
3
- export * as Haptics from './Haptics.ts';
4
- export * as Ready from './Ready.ts';
5
- export * as SignIn from './SignIn.ts';
6
- export * as SendToken from './SendToken.ts';
7
- export * as SwapToken from './SwapToken.ts';
8
- export * as ViewCast from './ViewCast.ts';
9
- export * as ViewProfile from './ViewProfile.ts';
10
- export * as ViewToken from './ViewToken.ts';
@@ -1,10 +0,0 @@
1
- export * as AddMiniApp from "./AddMiniApp.js";
2
- export * as ComposeCast from "./ComposeCast.js";
3
- export * as Haptics from "./Haptics.js";
4
- export * as Ready from "./Ready.js";
5
- export * as SignIn from "./SignIn.js";
6
- export * as SendToken from "./SendToken.js";
7
- export * as SwapToken from "./SwapToken.js";
8
- export * as ViewCast from "./ViewCast.js";
9
- export * as ViewProfile from "./ViewProfile.js";
10
- export * as ViewToken from "./ViewToken.js";
package/esm/back.d.ts DELETED
@@ -1,13 +0,0 @@
1
- export type BackState = {
2
- /**
3
- * Is the back control visible. Note that on mobile devices Farcaster clients
4
- * may support a gesture based control rather than button control.
5
- *
6
- * @default false
7
- */
8
- visible: boolean;
9
- };
10
- export declare const DEFAULT_BACK_STATE: {
11
- visible: false;
12
- };
13
- export type UpdateBackState = (state: BackState) => Promise<void>;
package/esm/back.js DELETED
@@ -1,3 +0,0 @@
1
- export const DEFAULT_BACK_STATE = {
2
- visible: false,
3
- };
package/esm/context.d.ts DELETED
@@ -1,94 +0,0 @@
1
- import type { FrameNotificationDetails } from './schemas/index.ts';
2
- export type MiniappUser = {
3
- fid: number;
4
- username?: string;
5
- displayName?: string;
6
- pfpUrl?: string;
7
- };
8
- export interface MiniappCast {
9
- author: MiniappUser;
10
- hash: string;
11
- parentHash?: string;
12
- parentFid?: number;
13
- timestamp?: number;
14
- mentions?: MiniappUser[];
15
- text: string;
16
- embeds?: string[];
17
- channelKey?: string;
18
- }
19
- export type CastEmbedLocationContext = {
20
- type: 'cast_embed';
21
- embed: string;
22
- cast: MiniappCast;
23
- };
24
- export type CastShareLocationContext = {
25
- type: 'cast_share';
26
- cast: MiniappCast;
27
- };
28
- export type NotificationLocationContext = {
29
- type: 'notification';
30
- notification: {
31
- notificationId: string;
32
- title: string;
33
- body: string;
34
- };
35
- };
36
- export type LauncherLocationContext = {
37
- type: 'launcher';
38
- };
39
- export type ChannelLocationContext = {
40
- type: 'channel';
41
- channel: {
42
- /**
43
- * Channel key identifier
44
- */
45
- key: string;
46
- /**
47
- * Channel name
48
- */
49
- name: string;
50
- /**
51
- * Channel profile image URL
52
- */
53
- imageUrl?: string;
54
- };
55
- };
56
- export type LocationContext = CastEmbedLocationContext | CastShareLocationContext | NotificationLocationContext | LauncherLocationContext | ChannelLocationContext;
57
- export type AccountLocation = {
58
- placeId: string;
59
- /**
60
- * Human-readable string describing the location
61
- */
62
- description: string;
63
- };
64
- export type UserContext = {
65
- fid: number;
66
- username?: string;
67
- displayName?: string;
68
- /**
69
- * Profile image URL
70
- */
71
- pfpUrl?: string;
72
- location?: AccountLocation;
73
- };
74
- export type SafeAreaInsets = {
75
- top: number;
76
- bottom: number;
77
- left: number;
78
- right: number;
79
- };
80
- export type ClientContext = {
81
- clientFid: number;
82
- added: boolean;
83
- notificationDetails?: FrameNotificationDetails;
84
- safeAreaInsets?: SafeAreaInsets;
85
- };
86
- export type ClientFeatures = {
87
- haptics: boolean;
88
- };
89
- export type FrameContext = {
90
- client: ClientContext;
91
- user: UserContext;
92
- location?: LocationContext;
93
- features?: ClientFeatures;
94
- };
package/esm/context.js DELETED
@@ -1 +0,0 @@
1
- export {};
package/esm/errors.d.ts DELETED
@@ -1,13 +0,0 @@
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 DELETED
@@ -1,8 +0,0 @@
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
- }
@@ -1,8 +0,0 @@
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 {};
@@ -1 +0,0 @@
1
- export {};
package/esm/manifest.d.ts DELETED
@@ -1,107 +0,0 @@
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://farcaster.xyz/~/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
- /**
102
- * Canonical domain for the frame application.
103
- * If specified, this domain will be treated as the primary domain for the frame.
104
- * Max length of 1024 characters.
105
- */
106
- canonicalDomain?: string;
107
- };
package/esm/manifest.js DELETED
@@ -1 +0,0 @@
1
- export {};