
Product
Introducing Tier 1 Reachability: Precision CVE Triage for Enterprise Teams
Socket’s new Tier 1 Reachability filters out up to 80% of irrelevant CVEs, so security teams can focus on the vulnerabilities that matter.
ethereum-qr-code
Advanced tools
This plugin provides a convenient way to generate an ethereum address link out of the provided parameters based on EIP67.
The plugin generates the string based on the provided parameters and translates it into a QR code using the following qrcode plugin.
Demo: https://jibrelnetwork.github.io/ethereum-qr-code/
Install from NPM: npm install ethereum-qr-code --save
Use in your code
import EthereumQRPlugin from 'ethereum-qr-code';
// later in code
const qr = new EthereumQRPlugin(codeContainer);
const qrCode = qr.toCanvas({
selector: '#my-qr-code',
to,
gas
});
.toAddressString(config)
An encoder to translate your data into a string. Use if you want to generate a string.
Example:
qr.toAddressString({
“to”: 0x7cB57B5A97eAbe94205C07890BE4c1aD31E486A8,
“value”: 100,
})
//ethereum:0x7cB57B5A97eAbe94205C07890BE4c1aD31E486A8[?gas=21000][?value=100]
qr.toAddressString({
“to”: 0x7cB57B5A97eAbe94205C07890BE4c1aD31E486A8,
“value”: 10,
“gas”: 42000,
})
//ethereum:0x7cB57B5A97eAbe94205C07890BE4c1aD31E486A8[?gas=42000][?value=10]
.toCanvas(config, options)
Generates the canvas tag with the QR code. In this case the selector
field becomes available.
Returns a Promise object that is resolved when the code is successfully generated.
Example:
const qrCode = qr.toCanvas({
to,
gas
}, {
selector: '#my-qr-code',
});
qrCode.then(function(code){
console.log('Your QR is generated!');
console.log(code.value);
})
.toDataUrl(config, options)
A more flexible method that returns a QR in a dataUrl. This method returns a Promise that is resolved when the code is successfully generated.
Example:
const qrCode = qr.toDataUrl({
adres,
gas,
amount
});
qrCode.then(function(qrCodeDataUri){
console.log('Your QR id generated:', code.value); //'....'
})
.readStringToJSON(string)
A method to convert the EIP67 string back to the JSON object.
Example:
const paymentParams = qr.readStringToJSON(ethereum:0x7cB57B5A97eAbe94205C07890BE4c1aD31E486A8[?gas=4200][?value=150]');
console.log(paymentParams);
/*
{
to: '0x7cB57B5A97eAbe94205C07890BE4c1aD31E486A8',
gas: '4200',
value: '150'
}
*/
This QR code generator supports URI across three different use-cases:
ERC20
tokensWe cover these 3 different cases using a parameter called 'mode'. The details are outlined below.
URI scheme used to send ETH between accounts conforms early EIP67
proposals and Bitcoin scheme.
This is built to be backward compatible.
ethereum:<address>[?from=<sender_address>][?value=<ethamount>][?gas=<suggestedGas>]
Parameters:
to
| String | required - The address of the recipient account
from
| String | optional - Address of the tx sender. Defaults to current active account of the sender app
value
| Number | optional - Amount of ETH to send. Measured in wei
. Defaults to 0.
gas
| Number | optional - Recommended amount of gas. Defaults to 21000.
chainId
| Number | optional - Contains id of a selected blockchain to which transaction should be limited see EIP155 for details.
These are the only parameters needed for this use-case.
For the other use-cases, the mode
field allows for defining the structure of the resulting JSON. The URI scheme to invoke the contract's function uses JSON to encode the parameters specified.
Possible inputs for the mode
field:
contract_function
erc20__transfer
erc20__approve
erc20__transferFrom
These are explored in more detail below.
That mode is utilized by specifying "mode: "contract_function"
.
Example of the transfer
method using an ERC20
token:
{
"to": "0xcontractaddress",
"from": "0xsenderaddress",
"value": 0,
"gas": 100000,
"mode": "contract_function",
"functionSignature": {
"name": "transfer",
"payable": false,
"args": [
{
"name": "to",
"type": "address"
},
{
"name": "value",
"type": "uint"
}
]
},
"argsDefaults": [
{
"name": "to",
"value": "0xtokensrecipient"
},
{
"name": "value",
"value": 1000000000000000000
}
]
}
Parameters:
to
| String | required - Recipient address
from
| String | optional - Sender address. Defaults to current active user account
value
| Number | optional - Amount of ETH to send. Measured in wei
. Defaults to 0.
gas
| Number | optional - Recommended amount of gas. Defaults to 21000.
chainId
| Number | optional - Contains id of a selected blockchain to which transaction should be limited see EIP155 for details.
mode
| String | required - Mode of invocation. Expected value: contract_function
functionSignature
| Object | required - Object that defines signature of invoked function. It is used only if "mode" == "function"
name
| String | required - Name of the invoked function
payable
| Boolean | required - Defines whether function is able to receive ETH or not. (value
should be zero if false
)
args
| Array | optional - Contains list of function`s arguments. If this parameter is present - it must contain at least one element. If this parameter is not present - we assume that function do not have arguments.
type
| String | required - Type of the argument: uint
, uint8
, int32
, address
, bool
and so on.
name
| String | required - Name of the argument. Used to generate GUI for the transaction.
In fact, argument of Solidity function can be unnamed - this is OK if you develop a smart contract.
But QR codes are used to pass tx details between different wallets and GUI must be nice.
Therefore unnamed input fields in GUI are not possible. Therefore this parameter is required.
argsDefaults
| Array | optional - Array with default values for function arguments. If this parameter is present - it must contain at least one element. We do not require to provide defaults of all args.
name
| String | required - Name of the argument. Should be equal to the name of one of arguments from functionSignature
value
| Any | required - Default value for the function argument
ERC20
tokensThe 3 extra subtypes were added since ERC20 tokens are very popular.
To make it easier to send tokens between accounts we predefine function signatures for the methods from ERC20 specification:
"mode": "erc20__transfer"
will result in function transfer(address to, uint value) returns (bool success)
"mode": "erc20__approve"
=> function approve(address spender, uint value) returns (bool success)
"mode": "erc20__transferFrom"
=> function transferFrom(address from, address to, uint value) returns (bool success)
Example for transfer
method:
{
"to": "0xcontractaddress",
"from": "0xsenderaddress",
"gas": 100000,
"mode": "erc20__transfer",
"argsDefaults": [
{
"name": "to",
"value": "0xtokensrecipient"
}
]
}
Functionally, this is similar to the previous example.
Parameters:
to
| String | required - Recipient address
from
| String | optional - Sender address. Defaults to current active account of the sender user
gas
| Number | optional - Recommended amount of gas. Defaults to 21000.
mode
| String | required - Mode of invocation. Expected value: erc20__transfer
, erc20__approve
, erc20__transferFrom
chainId
| Number | optional - Contains id of a selected blockchain to which transaction should be limited see EIP155 for details.
argsDefaults
| Array | optional - Array with default values for function arguments.
name
| String | required - Name of the argument. Should be equal to the name of one of arguments from functionSignature
value
| Any | required - Default value for the function argument
Optional parameters are passed via configuration object as a second parameter to toDataUrl
and toCanvas
methods. It has following fields:
selector
| String | optionalIf you want the plugin to generate the canvas tag and place the QR code into your page DOM, you need to provide the DOM element selector.
options
| Object | optionalAllows to override extra options of the used qrcore plugin. Such as color, margin and scale. Use option.scale
with caution. The plugin selects a default value based on the length of the data. Manually setting may result in an error.
size
| String | optionalContact us via slack.com/jibrelnetwork
Or follow us on Twitter: @JibrelNetwork.
If you have a proposal, feature request, or are having trouble running the plugin, please submit an issue.
Developed by Qubist Labs Inc. / Jibrel Network (2017)
FAQs
utitlity library to deal with ethereum adresses
We found that ethereum-qr-code demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers 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.
Product
Socket’s new Tier 1 Reachability filters out up to 80% of irrelevant CVEs, so security teams can focus on the vulnerabilities that matter.
Research
/Security News
Ongoing npm supply chain attack spreads to DuckDB: multiple packages compromised with the same wallet-drainer malware.
Security News
The MCP Steering Committee has launched the official MCP Registry in preview, a central hub for discovering and publishing MCP servers.