From b1657749ae726e5855c427776f0e82618125904e Mon Sep 17 00:00:00 2001 From: Christopher Nascone Date: Sun, 28 Jan 2024 11:42:23 -0500 Subject: [PATCH 1/2] feat: factor out parseFrameMessage --- src/core/getFrameAccountAddress.ts | 28 +++---------------------- src/core/parseFrameMessage.ts | 33 ++++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+), 25 deletions(-) create mode 100644 src/core/parseFrameMessage.ts diff --git a/src/core/getFrameAccountAddress.ts b/src/core/getFrameAccountAddress.ts index c1ebd55ef1..8ab369c97f 100644 --- a/src/core/getFrameAccountAddress.ts +++ b/src/core/getFrameAccountAddress.ts @@ -1,18 +1,9 @@ -import { HubRpcClient, Message, getSSLHubRpcClient } from '@farcaster/hub-nodejs'; - -/** - * Farcaster Hub for signature verification, consider using a private hub if needed: - * https://docs.farcaster.xyz/hubble/hubble - */ -const HUB_URL = 'nemes.farcaster.xyz:2283'; +import { parseFrameMessage } from './parseFrameMessage'; type FidResponse = { verifications: string[]; }; -function getHubClient(): HubRpcClient { - return getSSLHubRpcClient(HUB_URL); -} /** * Get the Account Address from the Farcaster ID using the Frame. This uses a Neynar api * to get verified addresses belonging to the user wht that FID. This is using a demo api @@ -25,22 +16,9 @@ async function getFrameAccountAddress( body: { trustedData?: { messageBytes?: string } }, { NEYNAR_API_KEY = 'NEYNAR_API_DOCS' }, ): Promise { - let farcasterID = 0; - let validatedMessage: Message | undefined = undefined; - // Get the message from the request body - const frameMessage: Message = Message.decode( - Buffer.from(body?.trustedData?.messageBytes ?? '', 'hex'), - ); - // Validate the message - const client = getHubClient(); - const result = await client.validateMessage(frameMessage); - if (result.isOk() && result.value.valid && result.value.message) { - validatedMessage = result.value.message; - } else { - return; - } + const validatedMessage = await parseFrameMessage(body); // Get the Farcaster ID from the message - farcasterID = validatedMessage?.data?.fid ?? 0; + const farcasterID = validatedMessage?.data?.fid ?? 0; // Get the user verifications from the Farcaster Indexer const options = { method: 'GET', diff --git a/src/core/parseFrameMessage.ts b/src/core/parseFrameMessage.ts new file mode 100644 index 0000000000..e8d585128d --- /dev/null +++ b/src/core/parseFrameMessage.ts @@ -0,0 +1,33 @@ +import { HubRpcClient, Message, getSSLHubRpcClient } from '@farcaster/hub-nodejs'; + +/** + * Farcaster Hub for signature verification, consider using a private hub if needed: + * https://docs.farcaster.xyz/hubble/hubble + */ +const HUB_URL = 'nemes.farcaster.xyz:2283'; + +function getHubClient(): HubRpcClient { + return getSSLHubRpcClient(HUB_URL); +} + +/** + * Given a frame message, decode and validate it. If message is valid, + * return the message. Otherwise undefined. + * @param body The JSON received by server on frame callback + */ +async function parseFrameMessage(body: { trustedData?: { messageBytes?: string } }) { + let validatedMessage: Message | undefined = undefined; + // Get the message from the request body + const frameMessage: Message = Message.decode( + Buffer.from(body?.trustedData?.messageBytes ?? '', 'hex'), + ); + // Validate the message + const client = getHubClient(); + const result = await client.validateMessage(frameMessage); + if (result.isOk() && result.value.valid && result.value.message) { + validatedMessage = result.value.message; + } + return validatedMessage; +} + +export { parseFrameMessage }; From 66509774827f4cb629f0ef14293606a145548a6d Mon Sep 17 00:00:00 2001 From: Christopher Nascone Date: Sun, 28 Jan 2024 11:51:15 -0500 Subject: [PATCH 2/2] chore: remember to export --- src/index.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/src/index.ts b/src/index.ts index c8181c0bfb..38d44a7696 100644 --- a/src/index.ts +++ b/src/index.ts @@ -4,3 +4,4 @@ const version = '0.1.5'; export { version }; export { getFrameAccountAddress } from './core/getFrameAccountAddress'; export { getFrameMetadata } from './core/getFrameMetadata'; +export { parseFrameMessage } from './core/parseFrameMessage';