Research
Security News
Kill Switch Hidden in npm Packages Typosquatting Chalk and Chokidar
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
request-address
Advanced tools
request-address
Defines a JSON-based protocol for requesting bitcoin addresses and more
A service or wallet requests a bitcoin address request requestAddress
:
{
"version": "0",
"type": "requestAddress",
"withMessageSignature": "SX0KOveC",
"withExtendedPublicKey": true,
"withScriptType": "p2wpkh"
}
The other service or wallet replies with the requested address
:
{
"version": "0",
"type": "address",
"bitcoinAddress": "bc1qfd8phxz2vcazlfjtxqef94xjwulf5xyjghrxge",
"signature": "Hzqs3cyg1YYF7M/m+U3BbDFykpZELv4xQhk4uWGCGAoOOq3kYKcR3uUzhXludmyEjQct7rAx3NxrWDBUmWcs/B8=",
"extendedPublicKey": "zpub6rjWsJX5PFBXVAivrvSX7QUwtHKPuudSYokPBiA35H6g6ue4YaLPNQYhSkiL1G8zGAhQNuiMi15k4xMKBy4jHPj99uWDnKihRuvGDycEGiD"
}
A user can be prompted to verify received address with verifyAddress
:
{
"version": "0",
"type": "verifyAddress",
"bitcoinAddress": "bc1qfd8phxz2vcazlfjtxqef94xjwulf5xyjghrxge"
}
A service or wallet can also request an extended public key requestExtendedPublicKey
:
{
"version": "0",
"type": "requestExtendedPublicKey",
"withScriptType": "p2wpkh"
}
The other service or wallet replies with the requested extendedPublicKey
:
{
"version": "0",
"type": "extendedPublicKey",
"extendedPublicKey": "zpub6rjWsJX5PFBXVAivrvSX7QUwtHKPuudSYokPBiA35H6g6ue4YaLPNQYhSkiL1G8zGAhQNuiMi15k4xMKBy4jHPj99uWDnKihRuvGDycEGiD"
}
A service or wallet sends a paymentRequest
:
{
"version": "0",
"type": "paymentRequest",
"bitcoinAddress": "bc1qfd8phxz2vcazlfjtxqef94xjwulf5xyjghrxge",
"amount": 0.01,
"label": "Dragon's Tale",
"message": "Elderberries",
"slip24": {
"recipientName": "Dragon's Tale",
"nonce": null,
"memos": [{
"type": "text",
"text": "Elderberries"
}],
"outputs": [{
"address": "bc1qfd8phxz2vcazlfjtxqef94xjwulf5xyjghrxge",
"amount": 1000000
}],
"signature": "MEQCIH+0V4j4DTzT4y9EE9XHjQlyRfwHnnVQL9NFFYVCta1PAiAW0mlS4YtDzNzwJ0gR8ApKzdIKmSBKzClnxyFFp84oig=="
}
}
serializeMessage(message: Message): string
Serialize a message to string for transmission
parseMessage(value: any): Message
Parse a string into a message
Message
type Message =
| RequestAddressV0Message
| RequestExtendedPublicKeyV0Message
| VerifyAddressV0Message
| AddressV0Message
| ExtendedPublicKeyV0Message
| PaymentRequestV0Message
| CloseV0Message;
RequestAddressV0Message
type RequestAddressV0Message = {
version: MessageVersion.V0,
type: V0MessageType.RequestAddress,
withMessageSignature?: string | false | null,
withExtendedPublicKey?: boolean | null,
withScriptType?: V0MessageScriptType | null,
};
RequestExtendedPublicKeyV0Message
type RequestExtendedPublicKeyV0Message = {
version: MessageVersion.V0,
type: V0MessageType.RequestExtendedPublicKey,
withScriptType?: V0MessageScriptType | null,
};
VerifyAddressV0Message
type VerifyAddressV0Message = {
version: MessageVersion.V0,
type: V0MessageType.VerifyAddress,
bitcoinAddress: string,
};
AddressV0Message
type AddressV0Message = {
version: MessageVersion.V0,
type: V0MessageType.Address,
bitcoinAddress: string,
signature?: string | null,
extendedPublicKey?: string | null,
};
ExtendedPublicKeyV0Message
type ExtendedPublicKeyV0Message = {
version: MessageVersion.V0,
type: V0MessageType.ExtendedPublicKey,
extendedPublicKey: string,
};
PaymentRequestV0Message
type PaymentRequestV0Message = {
version: MessageVersion.V0,
type: V0MessageType.PaymentRequest,
bitcoinAddress: string,
amount: number,
label: string | null,
message: string | null,
slip24: Slip24 | null,
};
CloseV0Message
type CloseV0Message = {
version: MessageVersion.V0,
type: V0MessageType.Close,
};
V0MessageScriptType
enum V0MessageScriptType {
P2PKH = 'p2pkh',
P2WPKH = 'p2wpkh',
P2SH = 'p2sh',
P2TR = 'p2tr',
}
V0MessageType
enum V0MessageType {
RequestAddress = 'requestAddress',
RequestExtendedPublicKey = 'requestExtendedPublicKey',
VerifyAddress = 'verifyAddress',
Address = 'address',
ExtendedPublicKey = 'extendedPublicKey',
PaymentRequest = 'paymentRequest',
Close = 'close',
}
MessageVersion
enum MessageVersion {
V0 = '0',
}
Slip24
type Slip24 = {
recipientName: string,
nonce: string | null,
memos: Array<{
type: 'text',
text: string,
} | {
type: 'refund',
refund: string,
} | {
type: 'coinPurchase',
coinPurchase: {
coinType: number,
amount: string,
address: string,
},
}>,
outputs: Array<{
amount: number,
address: string,
}>,
signature: string,
};
MIT
FAQs
Request bitcoin address api messages
The npm package request-address receives a total of 266 weekly downloads. As such, request-address popularity was classified as not popular.
We found that request-address demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 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.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.