Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@0xsequence/core

Package Overview
Dependencies
Maintainers
6
Versions
301
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@0xsequence/core - npm Package Compare versions

Comparing version 0.0.0-20241114193556 to 0.0.0-20241216114019

5

dist/declarations/src/commons/signature.d.ts

@@ -6,2 +6,3 @@ import { ethers } from 'ethers';

isDynamic: boolean;
validationSignature?: string;
};

@@ -27,3 +28,3 @@ export type Signature<T extends config.Config> = {

trim: (data: string) => Promise<string>;
recover: (data: Z, payload: SignedPayload, provider: ethers.Provider) => Promise<T>;
recover: (data: Z, payload: SignedPayload, provider?: ethers.Provider, validateBehavior?: 'ignore' | 'throw') => Promise<T>;
supportsNoChainId: boolean;

@@ -37,3 +38,3 @@ encodeSigners: (config: Y, signatures: Map<string, SignaturePart>, subdigests: string[], chainId: ethers.BigNumberish) => {

hashSetImageHash: (imageHash: string) => string;
signaturesOf: (config: Y) => {
signaturesOf: (config: Y, referenceChainId?: ethers.BigNumberish) => {
address: string;

@@ -40,0 +41,0 @@ signature: string;

2

dist/declarations/src/v1/signature.d.ts

@@ -27,3 +27,3 @@ import { ethers } from 'ethers';

export declare function encodeSignature(signature: Signature | UnrecoveredSignature | ethers.BytesLike): string;
export declare function recoverSignature(data: UnrecoveredSignature, payload: base.SignedPayload, provider: ethers.Provider): Promise<Signature>;
export declare function recoverSignature(data: UnrecoveredSignature, payload: base.SignedPayload, provider?: ethers.Provider, validateBehavior?: 'ignore' | 'throw'): Promise<Signature>;
export declare function encodeSigners(config: WalletConfig, signatures: Map<string, base.SignaturePart>, subdigests: string[], _: ethers.BigNumberish): {

@@ -30,0 +30,0 @@ encoded: string;

@@ -46,3 +46,3 @@ import { ethers } from 'ethers';

}
export declare function recoverTopology(unrecovered: UnrecoveredTopology, subdigest: string, provider: ethers.Provider): Promise<Topology>;
export declare function recoverTopology(unrecovered: UnrecoveredTopology, subdigest: string, provider?: ethers.Provider, validateBehavior?: 'ignore' | 'throw'): Promise<Topology>;
export declare const partEncoder: {

@@ -99,3 +99,3 @@ concat: (a: ethers.BytesLike, b: ethers.BytesLike) => string;

subdigest: string;
}, provider: ethers.Provider): Promise<Signature | ChainedSignature>;
}, provider?: ethers.Provider, validateBehavior?: 'ignore' | 'throw'): Promise<Signature | ChainedSignature>;
export declare function encodeChain(main: ethers.BytesLike, suffix: ethers.BytesLike[]): string;

@@ -102,0 +102,0 @@ export declare function encodeSignature(decoded: UnrecoveredChainedSignature | ChainedSignature | UnrecoveredSignature | Signature | ethers.BytesLike): string;

@@ -1,1 +0,1 @@

export declare const VERSION = "2.0.25";
export declare const VERSION = "2.2.1";
{
"name": "@0xsequence/core",
"version": "0.0.0-20241114193556",
"version": "0.0.0-20241216114019",
"description": "core primitives for interacting with the sequence wallet contracts",

@@ -24,4 +24,4 @@ "repository": "https://github.com/0xsequence/sequence.js/tree/master/packages/core",

"dependencies": {
"@0xsequence/utils": "0.0.0-20241114193556",
"@0xsequence/abi": "0.0.0-20241114193556"
"@0xsequence/utils": "0.0.0-20241216114019",
"@0xsequence/abi": "0.0.0-20241216114019"
},

@@ -28,0 +28,0 @@ "scripts": {

@@ -7,2 +7,3 @@ import { ethers } from 'ethers'

isDynamic: boolean
validationSignature?: string
}

@@ -38,3 +39,3 @@

recover: (data: Z, payload: SignedPayload, provider: ethers.Provider) => Promise<T>
recover: (data: Z, payload: SignedPayload, provider?: ethers.Provider, validateBehavior?: 'ignore' | 'throw') => Promise<T>

@@ -59,3 +60,3 @@ supportsNoChainId: boolean

signaturesOf: (config: Y) => { address: string; signature: string }[]
signaturesOf: (config: Y, referenceChainId?: ethers.BigNumberish) => { address: string; signature: string }[]

@@ -62,0 +63,0 @@ signaturesOfDecoded: (decoded: Z) => string[]

@@ -128,3 +128,4 @@ import { ethers } from 'ethers'

payload: base.SignedPayload,
provider: ethers.Provider
provider?: ethers.Provider,
validateBehavior: 'ignore' | 'throw' = 'throw'
): Promise<Signature> {

@@ -140,4 +141,11 @@ const subdigest = base.subdigestOf(payload)

if (!s.address) throw new Error('Dynamic signature part must have address')
if (!isValidSignature(s.address, subdigest, s.signature, provider)) {
throw new Error(`Invalid dynamic signature part ${s.address}`)
if (validateBehavior !== 'ignore') {
if (!provider) {
throw new Error('Provider is required to validate EIP1271 signatures')
}
if (!isValidSignature(s.address, subdigest, s.signature, provider)) {
throw new Error(`Invalid dynamic signature part ${s.address}`)
}
}

@@ -221,4 +229,9 @@

recover: (data: UnrecoveredSignature, payload: base.SignedPayload, provider: ethers.Provider): Promise<Signature> => {
return recoverSignature(data, payload, provider)
recover: (
data: UnrecoveredSignature,
payload: base.SignedPayload,
provider?: ethers.Provider,
validateBehavior: 'ignore' | 'throw' = 'throw'
): Promise<Signature> => {
return recoverSignature(data, payload, provider, validateBehavior)
},

@@ -254,3 +267,3 @@

signaturesOf(config: WalletConfig): { address: string; signature: string }[] {
signaturesOf(config: WalletConfig, referenceChainId?: ethers.BigNumberish): { address: string; signature: string }[] {
return config.signers.filter(s => s.signature !== undefined).map(s => ({ address: s.address, signature: s.signature! }))

@@ -257,0 +270,0 @@ },

@@ -229,8 +229,9 @@ import { ethers } from 'ethers'

subdigest: string,
provider: ethers.Provider
provider?: ethers.Provider,
validateBehavior: 'ignore' | 'throw' = 'throw'
): Promise<Topology> {
if (isUnrecoveredNode(unrecovered)) {
const [left, right] = await Promise.all([
recoverTopology(unrecovered.left, subdigest, provider),
recoverTopology(unrecovered.right, subdigest, provider)
recoverTopology(unrecovered.left, subdigest, provider, validateBehavior),
recoverTopology(unrecovered.right, subdigest, provider, validateBehavior)
])

@@ -245,3 +246,3 @@

threshold: unrecovered.threshold,
tree: await recoverTopology(unrecovered.tree, subdigest, provider)
tree: await recoverTopology(unrecovered.tree, subdigest, provider, validateBehavior)
}

@@ -256,5 +257,11 @@ }

const isValid = await isValidSignature(unrecovered.address, subdigest, unrecovered.signature, provider)
if (!isValid) {
throw new InvalidSignatureLeafError(unrecovered)
if (validateBehavior !== 'ignore') {
if (!provider) {
throw new Error('Provider is required to validate EIP1271 signatures')
}
const isValid = await isValidSignature(unrecovered.address, subdigest, unrecovered.signature, provider)
if (!isValid) {
throw new InvalidSignatureLeafError(unrecovered)
}
}

@@ -604,3 +611,4 @@

payload: base.SignedPayload | { subdigest: string },
provider: ethers.Provider
provider?: ethers.Provider,
validateBehavior: 'ignore' | 'throw' = 'throw'
): Promise<Signature | ChainedSignature> {

@@ -617,3 +625,3 @@ const signedPayload = (payload as { subdigest: string }).subdigest === undefined ? (payload as base.SignedPayload) : undefined

if (!isUnrecoveredChainedSignature(signature)) {
const tree = await recoverTopology(signature.decoded.tree, subdigest, provider)
const tree = await recoverTopology(signature.decoded.tree, subdigest, provider, validateBehavior)
return { version: 2, type: signature.type, subdigest, config: { version: 2, ...signature.decoded, tree } }

@@ -633,3 +641,3 @@ }

for (const sig of [{ ...signature, suffix: undefined }, ...signature.suffix]) {
const recovered = await recoverSignature(sig, mutatedPayload, provider)
const recovered = await recoverSignature(sig, mutatedPayload, provider, validateBehavior)
result.unshift(recovered)

@@ -936,5 +944,6 @@

payload: base.SignedPayload,
provider: ethers.Provider
provider?: ethers.Provider,
validateBehavior: 'ignore' | 'throw' = 'throw'
): Promise<Signature> => {
return recoverSignature(data, payload, provider)
return recoverSignature(data, payload, provider, validateBehavior)
},

@@ -941,0 +950,0 @@

@@ -1,1 +0,1 @@

export const VERSION = '2.0.25'
export const VERSION = '2.2.1'

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc