Skip to content
This repository has been archived by the owner on Jan 1, 2025. It is now read-only.
/ permit2-helper Public archive

Signature creation helper for Uniswap Permit2

License

Notifications You must be signed in to change notification settings

KumaCrypto/permit2-helper

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Permit2-helper

https://nodei.co/npm/permit2-helper.png?downloads=true

Overview

This library is designed to simplify interaction with the Uniswap Permit2 smart contract, which adds "permit" functionality to tokens that don't support it.

To learn more about why Permit2 was created and what its logic is:


Let's get started

  1. First, you need to install the library:
npm install permit2-helper
  1. Import the library at the beginning of your script:
import { Permit2 } from "permit2-helper";
  1. Create an instance of the class:
/*
Constructor takes object of parameters, it's interface:
    interface Permit2ConstructorParams {
    	signer?: SignerLike;
    	domainOpt?: DomainOptions;
    }

    interface DomainOptions {
    	chainId?: ethers.BigNumberish;
    	verifyingContract?: string;
    }
*/
const permit2Helper = new Permit2({
	signer: YourSigner,
	domainOpt: { chaindId: YourChainId, verifyingContract: YourVerifier },
});
  1. Call the function to sign the message (see below)

signPermitTransferFrom & signPermitWitnessTransferFrom


You probably only need two functions:

signPermitTransferFrom

signPermitTransferFrom args:

  • params: PermitTransferFromArgs, see code snippet
  • domainOptions?: DomainOptions | null, --> if you want to override default domain in class
  • signer?: SignerLike | null, --> if you want to override default signer in class
/*
    interface PermitTransferFromArgs {
	    permitted: TokenPermissions; --> desired token and amount which you will approve to spender
	    spender: string; --> approve receiver
	    nonce: ethers.BigNumberish; --> your nonce for this approve
	    deadline: ethers.BigNumberish; --> block.timestamp when approve will expired
    }

    interface TokenPermissions {
	    token: string;
	    amount: string | BigInt;
    }
*/

const params: {
        permitted: {
            token: token.address,
            amount: 123456789
        },
	    spender: spender.address,
	    nonce: 123,
	    deadline: 123456789,
}

const signature = await permit2Helper.signPermitTransferFrom(params);

signPermitWitnessTransferFrom

signPermitWitnessTransferFrom args:

  • params: PermitTransferFromArgs, --> same with signPermitTransferFrom
  • witnessValue: WitnessValue, --> your witness value (structure values)
  • witnessTypes: PermitWitnessTransferFromTypes, --> types for witness structure
  • domainOptions?: DomainOptions, --> same with signPermitTransferFrom
  • signer?: SignerLike --> same with signPermitTransferFrom
/*
    === Interfaces:
    type WitnessValue = Record<string, unknown>;

    interface PermitWitnessTransferFromTypes {
	    witnessType: ethers.TypedDataField;
	    witnessSubTypes: TypeElement;
    }
    ===

    Solidity struct for example:
        struct Witness {
		    address user;
	    }
*/

const witnessValue = {
	witness: { user: spender.address },
};

const witnessTyping = {
	witnessType: { type: "Witness", name: "witness" },
	witnessSubTypes: { Witness: [{ type: "address", name: "user" }] },
};

const signature = await permit2Helper.signPermitWitnessTransferFrom(
	paramsToSign,
	witnessValue,
	{
		witnessType: witnessTyping.witnessType,
		witnessSubTypes: witnessTyping.witnessSubTypes,
	},
);

For more examples see tests


Testing

cd ./test
npx hardhat test

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.



License MIT