🥜
Peanut Docs
  • Learn
    • 🥜What is Peanut?
    • 🏦Cashout
      • Supported geographies
    • 📩How to use Peanut Links?
      • ⚙️How do Peanut Links Work?
      • 🔒Trust assumptions
    • 📌Use cases
    • 📚Case Studies
      • 🎁Welcome Packs
      • 📘Raffles to Boost UWAs and Transactions
      • 📗Sending Testnet Tokens at Hackathons
      • 📙IRL Events Marketing
    • ⛓️Supported Chains and Tokens
    • 💰Pricing
    • 🆘Support
  • Integrate
    • Using the SDK
      • Create ClaimLinks
        • Create Link
        • Batch Create Links
        • Create Raffle Links
        • Create Multi-Token Link
        • Create NFT Link
        • Create Gasless Links
        • Create Branded Links
      • Claim
        • Claim Link
        • Claim Gasless Link
        • Claim Cross-Chain Link
        • Claim Raffle Link
        • Claim Link as Sender (Reclaiming)
      • Create Request Link
      • Pay a Request Link
      • Pay a Request Link X-Chain
      • Utils
        • Get Link Details
        • Cross-chain
          • Get Supported Destination Chains
          • Get Supported Destination Tokens
          • Get Cross-Chain Options
          • Get Cross-Chain Route
        • Raffle (Legacy)
          • Get Raffle Info
          • Get User Raffle Status
          • Get Raffle Leaderboard
        • Get Default Provider
        • Get Supported Peanut Chains
        • Toggle Verbosity
        • EthersV5 <> Peanut Transaction Types
        • Estimate Fee Options
        • Get Random String
        • Get all deposits for an Address
        • Get Token Balance
      • API Keys
      • White-Labelling
      • Troubleshooting
      • SDK FAQ
    • Embedding an IFrame
    • Integrate Directly in Smart Contracts
    • Wallet Integrations
      • 🎬UI Examples
  • Other
    • 👾Bug bounties
    • 🔓Security Audit
    • 📜Peanut Protocol Contracts
  • BLOGS
    • Transfer Abstraction
    • Can We Sidestep Onchain Identity?
  • Additional Links
    • 🐦Twitter
    • 😊Telegram
    • 🤙Discord
    • 🥜Work with Us
    • 🎨Press Kit
    • 👨‍⚖️Contact and Legal
Powered by GitBook
On this page
  • Create a Link using EthersV5
  • Create a Link using Signer Agnostic Functions:
  1. Integrate
  2. Using the SDK
  3. Create ClaimLinks

Create Link

Creating a Link that holds funds is easy. Have a look here how you can create one yourself!

There are two ways of creating a Link. If you are using EthersV5, you can simply call one SDK function to create a Link. If you are not using EthersV5, or want to have more control over the Link creation process, you can call a set of SDK functions.

Create a Link using EthersV5

The 'one function' approach requires you to pass in an EthersV5 signer, together with some basic information of the Link.

import peanut, { getDefaultProvider } from '@squirrel-labs/peanut-sdk';
import { Wallet } from 'ethersv5';

const chainId = '11155111' // Sepolia
const mnemonic = 'announce room limb pattern dry unit scale effort smooth jazz weasel alcohol'

async function createLink(): Promise<string | null> {
  let wallet = Wallet.fromMnemonic(mnemonic)

  const provider = await getDefaultProvider(chainId)
  wallet = wallet.connect(provider)
  
  const { link, txHash } = await peanut.createLink({
    structSigner: {
      signer: wallet
    },
    linkDetails: {
      chainId: chainId,
      tokenAmount: 0.01,
      tokenType: 0,  // 0 for ether, 1 for erc20, 2 for erc721, 3 for erc1155
      tokenDecimals: 18,
    }
  })
  return link
}

createLink().then((link) => console.log(link))

Create a Link using Signer Agnostic Functions:

You're not using EthersV5, but some other signing library (viem, web3js, wagmi, inhouse etc)? No problem! You will have to prepare the transactions(s), submit the transaction with your wallet, and use the resulting transaction hash to generate the link. The following is an example that does not use a particular signer.

const chainId = '11155111' // Sepolia
const mnemonic = 'announce room limb pattern dry unit scale effort smooth jazz weasel alcohol'

async function createLink(): Promise<string | null> {
	let wallet = Wallet.fromMnemonic(mnemonic)

	const provider = await getDefaultProvider(chainId)
	wallet = wallet.connect(provider)

	const linkDetails = {
		chainId: chainId,
		tokenAmount: 0.001,
		tokenType: 0, // 0 for ether, 1 for erc20, 2 for erc721, 3 for erc1155
		tokenDecimals: 18,
	}

	const password = await peanut.getRandomString(16)

	const preparedTransactions = await peanut.prepareDepositTxs({
		address: wallet.address,
		linkDetails,
		passwords: [password],
	})

	const transactionHashes: string[] = []

	for (const unsignedTx of preparedTransactions.unsignedTxs) {
		const convertedTx = peanut.peanutToEthersV5Tx(unsignedTx)

		const signedTx = await wallet.sendTransaction(convertedTx)

		transactionHashes.push(signedTx.hash)
	}

	const { links } = await peanut.getLinksFromTx({
		linkDetails,
		passwords: [password],
		txHash: transactionHashes[transactionHashes.length - 1],
	})
	return links[0]
}

createLink().then((link) => console.log(link))
PreviousCreate ClaimLinksNextBatch Create Links

Last updated 1 year ago