
Security News
Django Joins curl in Pushing Back on AI Slop Security Reports
Django has updated its security policies to reject AI-generated vulnerability reports that include fabricated or unverifiable content.
safe-module-template
Advanced tools
Safe-Module-Template is a tool for configuring smart contract templates. Here are the steps to configure a template:
At the beginning of the file, we need to import some necessary libraries and tools. For example, we need the ChainId, Comparison and Template types, and the generateUniqueId function.
import { Template, ChainId, Comparison } from '@/typings'
import { generateUniqueId } from '@/utils'
Next, we need to create a template object. This object needs to include the following properties:
Parameter | Type | Required | Description |
---|---|---|---|
id | String | Yes | The unique identifier of the template, which can be generated using the generateUniqueId function. |
chainId | ChainId | Yes | The ID of the chain, such as ChainId.ARBITRUM. |
templateName | String | Yes | The name of the template. |
contractAddress | String | Yes | The address of the smart contract. |
functionsConfig | Array | Yes | An array of function configurations. |
export const uniExactInputSingleTemplate: Template = {
id: generateUniqueId(),
chainId: ChainId.POLYGON,
templateName: 'Uniswap V3 Router2 ExactInputSingle',
contractAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45',
functionsConfig: [],
}
In the functionsConfig array, we need to configure an object for each function. This object needs to include the following properties:
Parameter | Type | Required | Description | Nested Parameters | |||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
sighash | String | Yes | The signature hash of the function. | - | |||||||||||||||||||||||||||||||||||
ethValue | Object | No | The signature hash of the function. |
| |||||||||||||||||||||||||||||||||||
params | Array | No | The parameter array of the current function. |
|
const functionsConfig = [
{
sighash: '0x04e45aaf', // This function only has one parameter and it is of tuple type.
params:[
{
index: 0,
params:[
{
index: 3,
require: true,
autoFillingSafeAddress: true,
}
]
}
]
}
]
export const uniExactInputSingleTemplate: Template = {
id: generateUniqueId(),
chainId: ChainId.POLYGON,
templateName: 'Uniswap V3 Router2 ExactInputSingle',
contractAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45',
functionsConfig: functionsConfig,
}
import { Template, ChainId, Comparison } from '@/typings'
import { generateUniqueId } from '@/utils'
export const uniExactInputSingleTemplate: Template = {
/**
* Please use the “generateUniqueId” method to generate a unique ID.
*/
id: generateUniqueId(),
/**
* Currently, only the following five networks are supported: ChainId.ARBITRUM, ChainId.ETHEREUM, ChainId.GOERLI, ChainId.POLYGON, ChainId.OPTIMISM.
* Please avoid adding any networks other than these five.
*/
chainId: ChainId.POLYGON,
/**
* The current template name should be as simple and concise as possible.
*/
templateName: 'Uniswap V3 Router2 ExactInputSingle',
/**
* Please make sure the contract address matches the current network, as the contract address may differ between networks.
*/
contractAddress: '0x68b3465833fb72A70ecDF485E0e4C7bD8665Fc45',
/**
* Configure the relevant methods and parameters for the current contract.
*/
functionsConfig: [
{
/**
* "The method's sighash."
* e.g. supply => 0x563dd613
*/
sighash: '0x04e45aaf',
/**
* What are the parameters for the method with sighash.
*/
params: [
{
index: 0,
params: [
// tokenIn
{
/**
* The current parameter index, starting from zero.
*/
index: 0,
/**
* Is a value for this parameter required?
*/
require: true,
/**
* The operator parameter is used to determine whether the permission should be greater than or equal to,
* less than or equal to, or equal to the current value when checking permissions.
*
* Greater than or equal to => Comparison.Gte
* Less than or equal to => Comparison.Lte
* Equal to => Comparison.Eq
*/
comparison: Comparison.Eq,
},
// tokenOut
{
/**
* The current parameter index, starting from zero.
*/
index: 1,
/**
* Is a value for this parameter required?
*/
require: true,
/**
* The operator parameter is used to determine whether the permission should be greater than or equal to,
* less than or equal to, or equal to the current value when checking permissions.
*
* Greater than or equal to => Comparison.Gte
* Less than or equal to => Comparison.Lte
* Equal to => Comparison.Eq
*/
comparison: Comparison.Eq,
},
// fee
{
/**
* The current parameter index, starting from zero.
*/
index: 2,
/**
* Is a value for this parameter required?
*/
require: true,
/**
* The operator parameter is used to determine whether the permission should be greater than or equal to,
* less than or equal to, or equal to the current value when checking permissions.
*
* Greater than or equal to => Comparison.Gte
* Less than or equal to => Comparison.Lte
* Equal to => Comparison.Eq
*/
comparison: Comparison.Eq,
},
// recipient
{
/**
* The current parameter index, starting from zero.
*/
index: 3,
/**
* Is a value for this parameter required?
*/
require: true,
/**
* The operator parameter is used to determine whether the permission should be greater than or equal to,
* less than or equal to, or equal to the current value when checking permissions.
*
* Greater than or equal to => Comparison.Gte
* Less than or equal to => Comparison.Lte
* Equal to => Comparison.Eq
*/
comparison: Comparison.Eq,
/**
* Should the current parameter value be automatically filled with the safe address.
* If not needed, please delete this field or change it to `false`
*/
autoFillingSafeAddress: true,
},
],
},
],
},
],
}
FAQs
safe-module-template
The npm package safe-module-template receives a total of 9 weekly downloads. As such, safe-module-template popularity was classified as not popular.
We found that safe-module-template demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Django has updated its security policies to reject AI-generated vulnerability reports that include fabricated or unverifiable content.
Security News
ECMAScript 2025 introduces Iterator Helpers, Set methods, JSON modules, and more in its latest spec update approved by Ecma in June 2025.
Security News
A new Node.js homepage button linking to paid support for EOL versions has sparked a heated discussion among contributors and the wider community.