From 8f0db97f6a369f16ddb17039b44328116b77d966 Mon Sep 17 00:00:00 2001 From: Leonardo Zizzamia Date: Sat, 27 Jan 2024 18:56:08 -0800 Subject: [PATCH] readme --- README.md | 106 ++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 104 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index a5a2ac8e39..1c07460f39 100644 --- a/README.md +++ b/README.md @@ -17,21 +17,82 @@ npm install @coinbase/onchainkit pnpm add @coinbase/onchainkit ``` +

## FrameKit 🖼️ +A Frame transforms any cast into an interactive app. + +Creating a frame is easy: select an image and add clickable buttons. When a button is clicked, you receive a callback and can send another image with more buttons. To learn more, check out "[Farcaster Frames Official Documentation](https://warpcast.notion.site/Farcaster-Frames-4bd47fe97dc74a42a48d3a234636d8c5)". + +### getFrameAccountAddress() + +When a user interacts with your Frame, you will receive a JSON message called `Frame Signature Packet`. From this message, you can extract the Account Address using the `getFrameAccountAddress()` function. + +This Account Address can then be utilized for subsequent operations, enhancing the personalized experience of using the Frame for each individual. + +Note: To utilize this function, we rely on [Neynar APIs](https://docs.neynar.com/reference/user-bulk). In order to avoid rate limiting, please ensure that you have your own API KEY. + +```ts +// Steps 1. import getFrameAccountAddress from @coinbase/onchainkit +import { getFrameAccountAddress } from '@coinbase/onchainkit'; +import { NextRequest, NextResponse } from 'next/server'; + +async function getResponse(req: NextRequest): Promise { + let accountAddress = ''; + try { + // Step 2. Read the body from the Next Request + const body = await req.json(); + // Step 3. Get from the body the Account Address of the user using the Frame + accountAddress = await getFrameAccountAddress(body, { NEYNAR_API_KEY: 'NEYNAR_API_DOCS' }); + } catch (err) { + console.error(err); + } + + // Step 4. Use the account address for your next step + return new NextResponse(` + + + + BOAT + + + + + + +

BOAT Text

+ + + `); +} + +export async function POST(req: NextRequest): Promise { + return getResponse(req); +} + +export const dynamic = 'force-dynamic'; +``` + +`getFrameAccountAddress` params + +- `body`: The Frame Signature Packet body +- `options`: + - `NEYNAR_API_KEY`: The NEYNAR_API_KEY used to access [Neynar Farcaster Indexer](https://docs.neynar.com/reference/user-bulk) + +
### getFrameMetadata() With Next.js App routing, use the `getFrameMetadata` inside your `page.ts` to get the metadata need it for your Frame. ```ts -// Steps 1. import generateFrameNextMetadata from @coinbase/onchainkit +// Steps 1. import getFrameMetadata from @coinbase/onchainkit import { getFrameMetadata } from '@coinbase/onchainkit'; import type { Metadata } from 'next'; import HomePage from './home'; -// Step 2. Use generateFrameNextMetadata to shape your Frame metadata +// Step 2. Use getFrameMetadata to shape your Frame metadata const frameMetadata = getFrameMetadata({ buttons: ['boat'], image: 'https://build-onchain-apps.vercel.app/release/v-0-17.png', @@ -56,3 +117,44 @@ export default function Page() { - `buttons`: A list of strings which are the label for the buttons in the frame (max 4 buttons). - `image`: An image which must be smaller than 10MB and should have an aspect ratio of 1.91:1 - `post_url`: A valid POST URL to send the Signature Packet to. + +
+ +## The Team and Our Community ☁️ 🌁 ☁️ + +OnchainKit is all about community; for any questions, feel free to: + +1. Reach out to the core maintainers on Twitter or Farcaster + + + + + + + + +
+ + + +
+ Leonardo Zizzamia +
+ + + +
+ Alvaro Raminelli +
+ + + +
+ Rob Polak +
+ +
+ +## License + +This project is licensed under the MIT License - see the [LICENSE.md](LICENSE.md) file for details \ No newline at end of file