From 922248c64c1b31fb4bf837190593c721cf05721a Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Wed, 4 Sep 2024 09:14:00 +0000
Subject: [PATCH 01/20] feat(api): OpenAPI spec update via Stainless API (#242)
---
.stats.yml | 2 +-
api.md | 4 -
src/index.ts | 4 -
src/resources/index.ts | 11 +-
src/resources/starknet/index.ts | 11 +-
src/resources/starknet/starknet.ts | 125 +----
src/resources/starknet/transaction.ts | 509 ++++++++++++++----
.../starknet/transaction.test.ts | 1 +
8 files changed, 407 insertions(+), 260 deletions(-)
diff --git a/.stats.yml b/.stats.yml
index e508d94..64d4b01 100755
--- a/.stats.yml
+++ b/.stats.yml
@@ -1,2 +1,2 @@
configured_endpoints: 19
-openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-589a4d2cf4a075a6f8798c67792c098d3aaa7d5b95164464d0e69a1be50414c2.yml
+openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-ee82f1cd6cc69f1cc2a54c096e0e5ffe1ae521a4c079a3e445bfe5de700a1d76.yml
diff --git a/api.md b/api.md
index 13ac820..88da31f 100755
--- a/api.md
+++ b/api.md
@@ -173,13 +173,9 @@ Methods:
Types:
-- StarknetErc1155Details
- StarknetErc1155Diff
-- StarknetErc20Details
- StarknetErc20Diff
-- StarknetErc721Details
- StarknetErc721Diff
-- StarknetNativeDiff
## Transaction
diff --git a/src/index.ts b/src/index.ts
index e4d4446..bd5e0e0 100755
--- a/src/index.ts
+++ b/src/index.ts
@@ -334,13 +334,9 @@ export namespace Blockaid {
export import Bitcoin = API.Bitcoin;
export import Starknet = API.Starknet;
- export import StarknetErc1155Details = API.StarknetErc1155Details;
export import StarknetErc1155Diff = API.StarknetErc1155Diff;
- export import StarknetErc20Details = API.StarknetErc20Details;
export import StarknetErc20Diff = API.StarknetErc20Diff;
- export import StarknetErc721Details = API.StarknetErc721Details;
export import StarknetErc721Diff = API.StarknetErc721Diff;
- export import StarknetNativeDiff = API.StarknetNativeDiff;
export import Site = API.Site;
export import SiteScanHitResponse = API.SiteScanHitResponse;
diff --git a/src/resources/index.ts b/src/resources/index.ts
index f84bc42..deac5e2 100755
--- a/src/resources/index.ts
+++ b/src/resources/index.ts
@@ -80,16 +80,7 @@ export {
SiteScanParams,
Site,
} from './site';
-export {
- StarknetErc1155Details,
- StarknetErc1155Diff,
- StarknetErc20Details,
- StarknetErc20Diff,
- StarknetErc721Details,
- StarknetErc721Diff,
- StarknetNativeDiff,
- Starknet,
-} from './starknet/starknet';
+export { StarknetErc1155Diff, StarknetErc20Diff, StarknetErc721Diff, Starknet } from './starknet/starknet';
export {
StellarAssetContractDetailsSchema,
StellarAssetTransferDetailsSchema,
diff --git a/src/resources/starknet/index.ts b/src/resources/starknet/index.ts
index 0aace7f..3a1a707 100755
--- a/src/resources/starknet/index.ts
+++ b/src/resources/starknet/index.ts
@@ -1,13 +1,4 @@
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
-export {
- StarknetErc1155Details,
- StarknetErc1155Diff,
- StarknetErc20Details,
- StarknetErc20Diff,
- StarknetErc721Details,
- StarknetErc721Diff,
- StarknetNativeDiff,
- Starknet,
-} from './starknet';
+export { StarknetErc1155Diff, StarknetErc20Diff, StarknetErc721Diff, Starknet } from './starknet';
export { TransactionScanResponse, TransactionScanParams, Transaction } from './transaction';
diff --git a/src/resources/starknet/starknet.ts b/src/resources/starknet/starknet.ts
index 086bf9c..3a5d01a 100755
--- a/src/resources/starknet/starknet.ts
+++ b/src/resources/starknet/starknet.ts
@@ -8,28 +8,6 @@ export class Starknet extends APIResource {
transaction: TransactionAPI.Transaction = new TransactionAPI.Transaction(this._client);
}
-export interface StarknetErc1155Details {
- /**
- * Address of the token's contract
- */
- address: string;
-
- /**
- * token's name
- */
- name: string;
-
- /**
- * token's symbol
- */
- symbol: string;
-
- /**
- * Type of the asset (`ERC1155`)
- */
- type?: 'ERC1155';
-}
-
export interface StarknetErc1155Diff {
/**
* Token ID of the transfer
@@ -39,51 +17,19 @@ export interface StarknetErc1155Diff {
/**
* USD price of the asset
*/
- usd_price: number;
+ usd_price: string;
/**
* Value of the transfer
*/
value: number;
- /**
- * URL of the asset's logo
- */
- logo_url?: string | null;
-
/**
* Summarized description of the transfer
*/
summary?: string | null;
}
-export interface StarknetErc20Details {
- /**
- * Address of the token's contract
- */
- address: string;
-
- /**
- * token's decimals
- */
- decimals: number;
-
- /**
- * token's name
- */
- name: string;
-
- /**
- * token's symbol
- */
- symbol: string;
-
- /**
- * Type of the asset (`ERC20`)
- */
- type?: 'ERC20';
-}
-
export interface StarknetErc20Diff {
/**
* Raw value of the transfer
@@ -93,17 +39,12 @@ export interface StarknetErc20Diff {
/**
* USD price of the asset
*/
- usd_price: number;
+ usd_price: string;
/**
* Value of the transfer
*/
- value: number;
-
- /**
- * URL of the asset's logo
- */
- logo_url?: string | null;
+ value: string;
/**
* Summarized description of the transfer
@@ -111,28 +52,6 @@ export interface StarknetErc20Diff {
summary?: string | null;
}
-export interface StarknetErc721Details {
- /**
- * Address of the token's contract
- */
- address: string;
-
- /**
- * token's name
- */
- name: string;
-
- /**
- * token's symbol
- */
- symbol: string;
-
- /**
- * Type of the asset (`ERC721`)
- */
- type?: 'ERC721';
-}
-
export interface StarknetErc721Diff {
/**
* Token ID of the transfer
@@ -142,39 +61,7 @@ export interface StarknetErc721Diff {
/**
* USD price of the asset
*/
- usd_price: number;
-
- /**
- * URL of the asset's logo
- */
- logo_url?: string | null;
-
- /**
- * Summarized description of the transfer
- */
- summary?: string | null;
-}
-
-export interface StarknetNativeDiff {
- /**
- * Raw value of the transfer
- */
- raw_value: number;
-
- /**
- * USD price of the asset
- */
- usd_price: number;
-
- /**
- * Value of the transfer
- */
- value: number;
-
- /**
- * URL of the asset's logo
- */
- logo_url?: string | null;
+ usd_price: string;
/**
* Summarized description of the transfer
@@ -183,13 +70,9 @@ export interface StarknetNativeDiff {
}
export namespace Starknet {
- export import StarknetErc1155Details = StarknetAPI.StarknetErc1155Details;
export import StarknetErc1155Diff = StarknetAPI.StarknetErc1155Diff;
- export import StarknetErc20Details = StarknetAPI.StarknetErc20Details;
export import StarknetErc20Diff = StarknetAPI.StarknetErc20Diff;
- export import StarknetErc721Details = StarknetAPI.StarknetErc721Details;
export import StarknetErc721Diff = StarknetAPI.StarknetErc721Diff;
- export import StarknetNativeDiff = StarknetAPI.StarknetNativeDiff;
export import Transaction = TransactionAPI.Transaction;
export import TransactionScanResponse = TransactionAPI.TransactionScanResponse;
export import TransactionScanParams = TransactionAPI.TransactionScanParams;
diff --git a/src/resources/starknet/transaction.ts b/src/resources/starknet/transaction.ts
index c78ca4d..036b194 100755
--- a/src/resources/starknet/transaction.ts
+++ b/src/resources/starknet/transaction.ts
@@ -19,7 +19,7 @@ export interface TransactionScanResponse {
* Simulation result; Only present if simulation option is included in the request
*/
simulation?:
- | TransactionScanResponse.StarknetSimulationResultSchema
+ | TransactionScanResponse.StarknetStarknetSimulationResultSchema
| TransactionScanResponse.StarknetSimulationErrorSchema
| null;
@@ -27,25 +27,25 @@ export interface TransactionScanResponse {
* Validation result; Only present if validation option is included in the request
*/
validation?:
- | TransactionScanResponse.StarknetValidationResultSchema
+ | TransactionScanResponse.StarknetValidationResultSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchema
| TransactionScanResponse.StarknetValidationErrorSchema
| null;
}
export namespace TransactionScanResponse {
- export interface StarknetSimulationResultSchema {
+ export interface StarknetStarknetSimulationResultSchema {
/**
* Summary of the actions and asset transfers that were made by the requested
* account address
*/
- account_summary: StarknetSimulationResultSchema.AccountSummary;
+ account_summary: StarknetStarknetSimulationResultSchema.AccountSummary;
status: 'Success';
/**
* Details of addresses involved in the transaction
*/
- address_details?: Array;
+ address_details?: Array;
/**
* Mapping between the address of an account to the assets diff during the
@@ -54,13 +54,17 @@ export namespace TransactionScanResponse {
assets_diffs?: Record<
string,
Array<
- | StarknetSimulationResultSchema.StarknetAccountSingleAssetDiffSchemaTypeNativeAssetDetailsSchemaNativeDiffSchema
- | StarknetSimulationResultSchema.StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaErc20DiffSchema
- | StarknetSimulationResultSchema.StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaErc721DiffSchema
- | StarknetSimulationResultSchema.StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaErc1155DiffSchema
+ | StarknetStarknetSimulationResultSchema.StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DiffSchema
+ | StarknetStarknetSimulationResultSchema.StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DiffSchema
+ | StarknetStarknetSimulationResultSchema.StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DiffSchema
>
>;
+ /**
+ * Optional block number or tag context for the simulation
+ */
+ block_number?: string | null;
+
/**
* Mapping between the address of an account to the exposure of the assets during
* the transaction
@@ -68,14 +72,14 @@ export namespace TransactionScanResponse {
exposures?: Record<
string,
Array<
- | StarknetSimulationResultSchema.StarknetAddressAssetExposureSchemaErc20DetailsSchemaErc20ExposureSchema
- | StarknetSimulationResultSchema.StarknetAddressAssetExposureSchemaErc721DetailsSchemaErc721ExposureSchema
- | StarknetSimulationResultSchema.StarknetAddressAssetExposureSchemaErc1155DetailsSchemaErc1155ExposureSchema
+ | StarknetStarknetSimulationResultSchema.StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema
+ | StarknetStarknetSimulationResultSchema.StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema
+ | StarknetStarknetSimulationResultSchema.StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema
>
>;
}
- export namespace StarknetSimulationResultSchema {
+ export namespace StarknetStarknetSimulationResultSchema {
/**
* Summary of the actions and asset transfers that were made by the requested
* account address
@@ -84,10 +88,10 @@ export namespace TransactionScanResponse {
/**
* Exposures made by the requested account address
*/
- exposures: Array<
- | AccountSummary.StarknetAddressAssetExposureSchemaErc20DetailsSchemaErc20ExposureSchema
- | AccountSummary.StarknetAddressAssetExposureSchemaErc721DetailsSchemaErc721ExposureSchema
- | AccountSummary.StarknetAddressAssetExposureSchemaErc1155DetailsSchemaErc1155ExposureSchema
+ account_exposures: Array<
+ | AccountSummary.StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema
+ | AccountSummary.StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema
+ | AccountSummary.StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema
>;
/**
@@ -99,10 +103,9 @@ export namespace TransactionScanResponse {
* Assets diffs of the requested account address
*/
assets_diffs?: Array<
- | AccountSummary.StarknetAccountSingleAssetDiffSchemaTypeNativeAssetDetailsSchemaNativeDiffSchema
- | AccountSummary.StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaErc20DiffSchema
- | AccountSummary.StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaErc721DiffSchema
- | AccountSummary.StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaErc1155DiffSchema
+ | AccountSummary.StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DiffSchema
+ | AccountSummary.StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DiffSchema
+ | AccountSummary.StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DiffSchema
>;
/**
@@ -112,24 +115,56 @@ export namespace TransactionScanResponse {
}
export namespace AccountSummary {
- export interface StarknetAddressAssetExposureSchemaErc20DetailsSchemaErc20ExposureSchema {
- asset: StarknetAPI.StarknetErc20Details;
+ export interface StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema {
+ asset: StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema.Asset;
/**
* Mapping between the spender address and the exposure of the asset
*/
spenders?: Record<
string,
- StarknetAddressAssetExposureSchemaErc20DetailsSchemaErc20ExposureSchema.Spenders
+ StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema.Spenders
>;
}
- export namespace StarknetAddressAssetExposureSchemaErc20DetailsSchemaErc20ExposureSchema {
+ export namespace StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's decimals
+ */
+ decimals: number;
+
+ /**
+ * token's name
+ */
+ name: string;
+
+ /**
+ * token's symbol
+ */
+ symbol: string;
+
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC20`)
+ */
+ type?: 'ERC20';
+ }
+
export interface Spenders {
/**
* Approval value of the ERC20 token
*/
- approval: number;
+ approval: string;
exposure: Array;
@@ -145,19 +180,46 @@ export namespace TransactionScanResponse {
}
}
- export interface StarknetAddressAssetExposureSchemaErc721DetailsSchemaErc721ExposureSchema {
- asset: StarknetAPI.StarknetErc721Details;
+ export interface StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema {
+ asset: StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema.Asset;
/**
* Mapping between the spender address and the exposure of the asset
*/
spenders?: Record<
string,
- StarknetAddressAssetExposureSchemaErc721DetailsSchemaErc721ExposureSchema.Spenders
+ StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema.Spenders
>;
}
- export namespace StarknetAddressAssetExposureSchemaErc721DetailsSchemaErc721ExposureSchema {
+ export namespace StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's name
+ */
+ name: string;
+
+ /**
+ * token's symbol
+ */
+ symbol: string;
+
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC721`)
+ */
+ type?: 'ERC721';
+ }
+
export interface Spenders {
exposure: Array;
@@ -173,19 +235,46 @@ export namespace TransactionScanResponse {
}
}
- export interface StarknetAddressAssetExposureSchemaErc1155DetailsSchemaErc1155ExposureSchema {
- asset: StarknetAPI.StarknetErc1155Details;
+ export interface StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema {
+ asset: StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema.Asset;
/**
* Mapping between the spender address and the exposure of the asset
*/
spenders?: Record<
string,
- StarknetAddressAssetExposureSchemaErc1155DetailsSchemaErc1155ExposureSchema.Spenders
+ StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema.Spenders
>;
}
- export namespace StarknetAddressAssetExposureSchemaErc1155DetailsSchemaErc1155ExposureSchema {
+ export namespace StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's name
+ */
+ name: string;
+
+ /**
+ * token's symbol
+ */
+ symbol: string;
+
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC1155`)
+ */
+ type?: 'ERC1155';
+ }
+
export interface Spenders {
exposure: Array;
@@ -221,74 +310,99 @@ export namespace TransactionScanResponse {
total?: number;
}
- export interface StarknetAccountSingleAssetDiffSchemaTypeNativeAssetDetailsSchemaNativeDiffSchema {
- asset: StarknetAccountSingleAssetDiffSchemaTypeNativeAssetDetailsSchemaNativeDiffSchema.Asset;
+ export interface StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DiffSchema {
+ asset: StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DiffSchema.Asset;
/**
* Details of the incoming transfer
*/
- in?: StarknetAPI.StarknetNativeDiff | null;
+ in?: StarknetAPI.StarknetErc20Diff | null;
/**
* Details of the outgoing transfer
*/
- out?: StarknetAPI.StarknetNativeDiff | null;
+ out?: StarknetAPI.StarknetErc20Diff | null;
}
- export namespace StarknetAccountSingleAssetDiffSchemaTypeNativeAssetDetailsSchemaNativeDiffSchema {
+ export namespace StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DiffSchema {
export interface Asset {
/**
- * Decimals of the asset
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's decimals
*/
- decimals?: 18;
+ decimals: number;
/**
- * Name of the asset
+ * token's name
*/
- name?: 'STRK';
+ name: string;
/**
- * Symbol of the asset
+ * token's symbol
*/
- symbol?: 'STRK';
+ symbol: string;
/**
- * Type of the asset (`NATIVE`)
+ * URL of the asset's logo
*/
- type?: 'NATIVE';
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC20`)
+ */
+ type?: 'ERC20';
}
}
- export interface StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaErc20DiffSchema {
- asset: StarknetAPI.StarknetErc20Details;
+ export interface StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DiffSchema {
+ asset: StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DiffSchema.Asset;
/**
* Details of the incoming transfer
*/
- in?: StarknetAPI.StarknetErc20Diff | null;
+ in?: StarknetAPI.StarknetErc721Diff | null;
/**
* Details of the outgoing transfer
*/
- out?: StarknetAPI.StarknetErc20Diff | null;
+ out?: StarknetAPI.StarknetErc721Diff | null;
}
- export interface StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaErc721DiffSchema {
- asset: StarknetAPI.StarknetErc721Details;
+ export namespace StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DiffSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
- /**
- * Details of the incoming transfer
- */
- in?: StarknetAPI.StarknetErc721Diff | null;
+ /**
+ * token's name
+ */
+ name: string;
- /**
- * Details of the outgoing transfer
- */
- out?: StarknetAPI.StarknetErc721Diff | null;
+ /**
+ * token's symbol
+ */
+ symbol: string;
+
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC721`)
+ */
+ type?: 'ERC721';
+ }
}
- export interface StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaErc1155DiffSchema {
- asset: StarknetAPI.StarknetErc1155Details;
+ export interface StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DiffSchema {
+ asset: StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DiffSchema.Asset;
/**
* Details of the incoming transfer
@@ -300,6 +414,35 @@ export namespace TransactionScanResponse {
*/
out?: StarknetAPI.StarknetErc1155Diff | null;
}
+
+ export namespace StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DiffSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's name
+ */
+ name: string;
+
+ /**
+ * token's symbol
+ */
+ symbol: string;
+
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC1155`)
+ */
+ type?: 'ERC1155';
+ }
+ }
}
export interface AddressDetail {
@@ -314,74 +457,99 @@ export namespace TransactionScanResponse {
description?: string | null;
}
- export interface StarknetAccountSingleAssetDiffSchemaTypeNativeAssetDetailsSchemaNativeDiffSchema {
- asset: StarknetAccountSingleAssetDiffSchemaTypeNativeAssetDetailsSchemaNativeDiffSchema.Asset;
+ export interface StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DiffSchema {
+ asset: StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DiffSchema.Asset;
/**
* Details of the incoming transfer
*/
- in?: StarknetAPI.StarknetNativeDiff | null;
+ in?: StarknetAPI.StarknetErc20Diff | null;
/**
* Details of the outgoing transfer
*/
- out?: StarknetAPI.StarknetNativeDiff | null;
+ out?: StarknetAPI.StarknetErc20Diff | null;
}
- export namespace StarknetAccountSingleAssetDiffSchemaTypeNativeAssetDetailsSchemaNativeDiffSchema {
+ export namespace StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DiffSchema {
export interface Asset {
/**
- * Decimals of the asset
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's decimals
+ */
+ decimals: number;
+
+ /**
+ * token's name
*/
- decimals?: 18;
+ name: string;
/**
- * Name of the asset
+ * token's symbol
*/
- name?: 'STRK';
+ symbol: string;
/**
- * Symbol of the asset
+ * URL of the asset's logo
*/
- symbol?: 'STRK';
+ logo_url?: string | null;
/**
- * Type of the asset (`NATIVE`)
+ * Type of the asset (`ERC20`)
*/
- type?: 'NATIVE';
+ type?: 'ERC20';
}
}
- export interface StarknetAccountSingleAssetDiffSchemaTypeErc20DetailsSchemaErc20DiffSchema {
- asset: StarknetAPI.StarknetErc20Details;
+ export interface StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DiffSchema {
+ asset: StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DiffSchema.Asset;
/**
* Details of the incoming transfer
*/
- in?: StarknetAPI.StarknetErc20Diff | null;
+ in?: StarknetAPI.StarknetErc721Diff | null;
/**
* Details of the outgoing transfer
*/
- out?: StarknetAPI.StarknetErc20Diff | null;
+ out?: StarknetAPI.StarknetErc721Diff | null;
}
- export interface StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaErc721DiffSchema {
- asset: StarknetAPI.StarknetErc721Details;
+ export namespace StarknetAccountSingleAssetDiffSchemaTypeErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DiffSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's name
+ */
+ name: string;
- /**
- * Details of the incoming transfer
- */
- in?: StarknetAPI.StarknetErc721Diff | null;
+ /**
+ * token's symbol
+ */
+ symbol: string;
- /**
- * Details of the outgoing transfer
- */
- out?: StarknetAPI.StarknetErc721Diff | null;
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC721`)
+ */
+ type?: 'ERC721';
+ }
}
- export interface StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaErc1155DiffSchema {
- asset: StarknetAPI.StarknetErc1155Details;
+ export interface StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DiffSchema {
+ asset: StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DiffSchema.Asset;
/**
* Details of the incoming transfer
@@ -394,24 +562,85 @@ export namespace TransactionScanResponse {
out?: StarknetAPI.StarknetErc1155Diff | null;
}
- export interface StarknetAddressAssetExposureSchemaErc20DetailsSchemaErc20ExposureSchema {
- asset: StarknetAPI.StarknetErc20Details;
+ export namespace StarknetAccountSingleAssetDiffSchemaTypeErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DiffSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's name
+ */
+ name: string;
+
+ /**
+ * token's symbol
+ */
+ symbol: string;
+
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC1155`)
+ */
+ type?: 'ERC1155';
+ }
+ }
+
+ export interface StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema {
+ asset: StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema.Asset;
/**
* Mapping between the spender address and the exposure of the asset
*/
spenders?: Record<
string,
- StarknetAddressAssetExposureSchemaErc20DetailsSchemaErc20ExposureSchema.Spenders
+ StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema.Spenders
>;
}
- export namespace StarknetAddressAssetExposureSchemaErc20DetailsSchemaErc20ExposureSchema {
+ export namespace StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc20ExposureSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's decimals
+ */
+ decimals: number;
+
+ /**
+ * token's name
+ */
+ name: string;
+
+ /**
+ * token's symbol
+ */
+ symbol: string;
+
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC20`)
+ */
+ type?: 'ERC20';
+ }
+
export interface Spenders {
/**
* Approval value of the ERC20 token
*/
- approval: number;
+ approval: string;
exposure: Array;
@@ -427,19 +656,46 @@ export namespace TransactionScanResponse {
}
}
- export interface StarknetAddressAssetExposureSchemaErc721DetailsSchemaErc721ExposureSchema {
- asset: StarknetAPI.StarknetErc721Details;
+ export interface StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema {
+ asset: StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema.Asset;
/**
* Mapping between the spender address and the exposure of the asset
*/
spenders?: Record<
string,
- StarknetAddressAssetExposureSchemaErc721DetailsSchemaErc721ExposureSchema.Spenders
+ StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema.Spenders
>;
}
- export namespace StarknetAddressAssetExposureSchemaErc721DetailsSchemaErc721ExposureSchema {
+ export namespace StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc721ExposureSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's name
+ */
+ name: string;
+
+ /**
+ * token's symbol
+ */
+ symbol: string;
+
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC721`)
+ */
+ type?: 'ERC721';
+ }
+
export interface Spenders {
exposure: Array;
@@ -455,19 +711,46 @@ export namespace TransactionScanResponse {
}
}
- export interface StarknetAddressAssetExposureSchemaErc1155DetailsSchemaErc1155ExposureSchema {
- asset: StarknetAPI.StarknetErc1155Details;
+ export interface StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema {
+ asset: StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema.Asset;
/**
* Mapping between the spender address and the exposure of the asset
*/
spenders?: Record<
string,
- StarknetAddressAssetExposureSchemaErc1155DetailsSchemaErc1155ExposureSchema.Spenders
+ StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema.Spenders
>;
}
- export namespace StarknetAddressAssetExposureSchemaErc1155DetailsSchemaErc1155ExposureSchema {
+ export namespace StarknetAddressAssetExposureSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155DetailsSchemaAnnotatedIntSkipValidationPlainSerializerGetPydanticSchemaErc1155ExposureSchema {
+ export interface Asset {
+ /**
+ * Address of the token's contract
+ */
+ address: string;
+
+ /**
+ * token's name
+ */
+ name: string;
+
+ /**
+ * token's symbol
+ */
+ symbol: string;
+
+ /**
+ * URL of the asset's logo
+ */
+ logo_url?: string | null;
+
+ /**
+ * Type of the asset (`ERC1155`)
+ */
+ type?: 'ERC1155';
+ }
+
export interface Spenders {
exposure: Array;
@@ -493,7 +776,7 @@ export namespace TransactionScanResponse {
status: 'Error';
}
- export interface StarknetValidationResultSchema {
+ export interface StarknetValidationResultSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchema {
/**
* A textual classification that can be presented to the user explaining the
* reason.
@@ -508,7 +791,7 @@ export namespace TransactionScanResponse {
/**
* A list of features about this transaction explaining the validation
*/
- features: Array;
+ features: Array;
/**
* A textual description about the reasons the transaction was flagged with
@@ -524,7 +807,7 @@ export namespace TransactionScanResponse {
status: 'Success';
}
- export namespace StarknetValidationResultSchema {
+ export namespace StarknetValidationResultSchemaTypeAnnotatedIntSkipValidationPlainSerializerGetPydanticSchema {
export interface Feature {
/**
* Address the feature refers to
@@ -576,11 +859,17 @@ export interface TransactionScanParams {
| TransactionScanParams.StarknetDeployAccountV1TransactionSchema
| TransactionScanParams.StarknetDeployAccountV3TransactionSchema;
+ /**
+ * Optional block number or tag context for the simulation
+ */
+ block_number?: string | null;
+
/**
* List of options to include in the response
*
- * - `simulation`: Include simulation output in the response
- * - `validation`: Include security validation of the transaction in the response
+ * - `Options.validation`: Include Options.validation output in the response
+ *
+ * - `Options.simulation`: Include Options.simulation output in the response
*/
options?: Array<'validation' | 'simulation'>;
}
diff --git a/tests/api-resources/starknet/transaction.test.ts b/tests/api-resources/starknet/transaction.test.ts
index 9317722..6742dea 100755
--- a/tests/api-resources/starknet/transaction.test.ts
+++ b/tests/api-resources/starknet/transaction.test.ts
@@ -37,6 +37,7 @@ describe('resource transaction', () => {
version: 1,
calldata: ['string', 'string', 'string'],
},
+ block_number: 'block_number',
options: ['validation'],
});
});
From 1785ebf0c192172db1f77ae61c7746c4d68376f5 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Wed, 4 Sep 2024 09:15:47 +0000
Subject: [PATCH 02/20] fix(client): correct File construction from node-fetch
Responses (#244)
---
src/uploads.ts | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/src/uploads.ts b/src/uploads.ts
index 081827c..a920351 100755
--- a/src/uploads.ts
+++ b/src/uploads.ts
@@ -114,7 +114,12 @@ export async function toFile(
const blob = await value.blob();
name ||= new URL(value.url).pathname.split(/[\\/]/).pop() ?? 'unknown_file';
- return new File([blob as any], name, options);
+ // we need to convert the `Blob` into an array buffer because the `Blob` class
+ // that `node-fetch` defines is incompatible with the web standard which results
+ // in `new File` interpreting it as a string instead of binary data.
+ const data = isBlobLike(blob) ? [(await blob.arrayBuffer()) as any] : [blob];
+
+ return new File(data, name, options);
}
const bits = await getBytes(value);
From 667c725588317244135db18eb9feceb9f9085655 Mon Sep 17 00:00:00 2001
From: stainless-bot
Date: Wed, 4 Sep 2024 11:46:25 +0000
Subject: [PATCH 03/20] codegen metadata
---
.stats.yml | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/.stats.yml b/.stats.yml
index 64d4b01..bb6a0f2 100755
--- a/.stats.yml
+++ b/.stats.yml
@@ -1,2 +1,2 @@
configured_endpoints: 19
-openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-ee82f1cd6cc69f1cc2a54c096e0e5ffe1ae521a4c079a3e445bfe5de700a1d76.yml
+openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-9fc564e9983fc5b76a1807b0f40fe7d17bf2280cc5cc8bf33725a566268663c7.yml
From e5bae2fae7305769e6cec349b915d6576bf84f1e Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Wed, 4 Sep 2024 11:55:11 +0000
Subject: [PATCH 04/20] feat(api): OpenAPI spec update via Stainless API (#245)
---
.stats.yml | 2 +-
.../starknet/transaction.test.ts | 61 +++++++++++++++----
2 files changed, 50 insertions(+), 13 deletions(-)
diff --git a/.stats.yml b/.stats.yml
index bb6a0f2..371120a 100755
--- a/.stats.yml
+++ b/.stats.yml
@@ -1,2 +1,2 @@
configured_endpoints: 19
-openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-9fc564e9983fc5b76a1807b0f40fe7d17bf2280cc5cc8bf33725a566268663c7.yml
+openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-afd7650fff0657b156f89de7dfc8bab51082063f79392c1241486fe77e1deb14.yml
diff --git a/tests/api-resources/starknet/transaction.test.ts b/tests/api-resources/starknet/transaction.test.ts
index 6742dea..a851cd6 100755
--- a/tests/api-resources/starknet/transaction.test.ts
+++ b/tests/api-resources/starknet/transaction.test.ts
@@ -11,10 +11,30 @@ const client = new Blockaid({
describe('resource transaction', () => {
test('scan: only required params', async () => {
const responsePromise = client.starknet.transaction.scan({
- account_address: 'account_address',
+ account_address: '0x62a2959fa6502b30cbfb51199fbbe72e72ee4f5a86ec754b4172c7d7beb6ff4',
chain: 'mainnet',
- metadata: { type: 'wallet', url: 'url' },
- transaction: { max_fee: 'max_fee', nonce: 'nonce', sender_address: 'sender_address', version: 1 },
+ metadata: { type: 'wallet', url: 'giftnostra.com' },
+ transaction: {
+ calldata: [
+ '0x1',
+ '0x4b33a775b537a39c8960120806e815764f173e4fa76546e6706c31aa1b0ac4a',
+ '0x994f23fef04108984d50a4f870723cd46f95d592ed3de9a13f97d5c55846fb',
+ '0x9',
+ '0x1',
+ '0x53c91253bc9682c04929ca02ed00b3e423f6710d2ee7e0d5ebb06f3ecf368a8',
+ '0x1',
+ '0x62a2959fa6502b30cbfb51199fbbe72e72ee4f5a86ec754b4172c7d7beb6ff4',
+ '0x1',
+ '0x5f612ce',
+ '0x0',
+ '0x0',
+ '0x0',
+ ],
+ chain_id: '0x534e5f4d41494e',
+ nonce: '0xc',
+ sender_address: '0x1840b3c89a446c74a3962647a2a7fb449d83905c4511027dfa9e099c6886691',
+ version: 3,
+ },
});
const rawResponse = await responsePromise.asResponse();
expect(rawResponse).toBeInstanceOf(Response);
@@ -27,18 +47,35 @@ describe('resource transaction', () => {
test('scan: required and optional params', async () => {
const response = await client.starknet.transaction.scan({
- account_address: 'account_address',
+ account_address: '0x62a2959fa6502b30cbfb51199fbbe72e72ee4f5a86ec754b4172c7d7beb6ff4',
chain: 'mainnet',
- metadata: { type: 'wallet', url: 'url' },
+ metadata: { type: 'wallet', url: 'giftnostra.com' },
transaction: {
- max_fee: 'max_fee',
- nonce: 'nonce',
- sender_address: 'sender_address',
- version: 1,
- calldata: ['string', 'string', 'string'],
+ calldata: [
+ '0x1',
+ '0x4b33a775b537a39c8960120806e815764f173e4fa76546e6706c31aa1b0ac4a',
+ '0x994f23fef04108984d50a4f870723cd46f95d592ed3de9a13f97d5c55846fb',
+ '0x9',
+ '0x1',
+ '0x53c91253bc9682c04929ca02ed00b3e423f6710d2ee7e0d5ebb06f3ecf368a8',
+ '0x1',
+ '0x62a2959fa6502b30cbfb51199fbbe72e72ee4f5a86ec754b4172c7d7beb6ff4',
+ '0x1',
+ '0x5f612ce',
+ '0x0',
+ '0x0',
+ '0x0',
+ ],
+ chain_id: '0x534e5f4d41494e',
+ nonce: '0xc',
+ sender_address: '0x1840b3c89a446c74a3962647a2a7fb449d83905c4511027dfa9e099c6886691',
+ version: 3,
+ account_deployment_data: ['string', 'string', 'string'],
+ nonce_data_availability_mode: 0,
+ paymaster_data: ['string', 'string', 'string'],
},
- block_number: 'block_number',
- options: ['validation'],
+ block_number: '0xa12e3',
+ options: ['validation', 'simulation'],
});
});
});
From 98816a042c0fb8ccc8ff0bbfc74a73a82b62818e Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Thu, 5 Sep 2024 10:30:25 +0000
Subject: [PATCH 05/20] feat(api): OpenAPI spec update via Stainless API (#246)
---
.stats.yml | 2 +-
src/resources/evm/evm.ts | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/.stats.yml b/.stats.yml
index 371120a..c7f63f4 100755
--- a/.stats.yml
+++ b/.stats.yml
@@ -1,2 +1,2 @@
configured_endpoints: 19
-openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-afd7650fff0657b156f89de7dfc8bab51082063f79392c1241486fe77e1deb14.yml
+openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-e5c860e614083c96ad126c68ee8c87a979a9ed6b648a1ec879e917138a2e38dd.yml
diff --git a/src/resources/evm/evm.ts b/src/resources/evm/evm.ts
index dfec450..72a0f0d 100755
--- a/src/resources/evm/evm.ts
+++ b/src/resources/evm/evm.ts
@@ -273,7 +273,7 @@ export interface Erc20Exposure {
* the amount that was asked in the approval request for this spender from the
* current address and asset
*/
- approval: number;
+ approval: string;
exposure: Array;
From 7778143ec32ad729237c022271b0b43993f8e94e Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Thu, 5 Sep 2024 10:30:51 +0000
Subject: [PATCH 06/20] chore(internal): dependency updates (#247)
---
yarn.lock | 26 +++++++++++++-------------
1 file changed, 13 insertions(+), 13 deletions(-)
diff --git a/yarn.lock b/yarn.lock
index 358dbf2..0f17a27 100755
--- a/yarn.lock
+++ b/yarn.lock
@@ -1200,12 +1200,12 @@ brace-expansion@^2.0.1:
dependencies:
balanced-match "^1.0.0"
-braces@^3.0.2:
- version "3.0.2"
- resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107"
- integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==
+braces@^3.0.3:
+ version "3.0.3"
+ resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.3.tgz#490332f40919452272d55a8480adc0c441358789"
+ integrity sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==
dependencies:
- fill-range "^7.0.1"
+ fill-range "^7.1.1"
browserslist@^4.22.2:
version "4.22.2"
@@ -1762,10 +1762,10 @@ file-entry-cache@^6.0.1:
dependencies:
flat-cache "^3.0.4"
-fill-range@^7.0.1:
- version "7.0.1"
- resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40"
- integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==
+fill-range@^7.1.1:
+ version "7.1.1"
+ resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.1.1.tgz#44265d3cac07e3ea7dc247516380643754a05292"
+ integrity sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==
dependencies:
to-regex-range "^5.0.1"
@@ -2638,11 +2638,11 @@ merge2@^1.3.0, merge2@^1.4.1:
integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==
micromatch@^4.0.4:
- version "4.0.5"
- resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6"
- integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==
+ version "4.0.8"
+ resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.8.tgz#d66fa18f3a47076789320b9b1af32bd86d9fa202"
+ integrity sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==
dependencies:
- braces "^3.0.2"
+ braces "^3.0.3"
picomatch "^2.3.1"
mime-db@1.51.0:
From ef4bc3156ccc0bbec6de4c5e106fe8ec82296df1 Mon Sep 17 00:00:00 2001
From: Stainless Bot
Date: Fri, 6 Sep 2024 12:31:55 -0400
Subject: [PATCH 07/20] fix file permissions
---
.devcontainer/Dockerfile | 0
.devcontainer/devcontainer.json | 0
.eslintrc.js | 0
.github/workflows/ci.yml | 0
.github/workflows/publish-npm.yml | 0
.github/workflows/release-doctor.yml | 0
.gitignore | 0
.prettierignore | 0
.prettierrc.json | 0
.release-please-manifest.json | 0
.stats.yml | 0
Brewfile | 0
CONTRIBUTING.md | 0
LICENSE | 0
README.md | 0
SECURITY.md | 0
api.md | 0
bin/check-release-environment | 0
bin/publish-npm | 0
examples/.keep | 0
jest.config.ts | 0
package.json | 0
release-please-config.json | 0
scripts/utils/check-version.cjs | 0
scripts/utils/fix-index-exports.cjs | 0
scripts/utils/make-dist-package-json.cjs | 0
scripts/utils/postprocess-files.cjs | 0
src/_shims/MultipartBody.ts | 0
src/_shims/README.md | 0
src/_shims/auto/runtime-bun.ts | 0
src/_shims/auto/runtime-deno.ts | 0
src/_shims/auto/runtime-node.ts | 0
src/_shims/auto/runtime.ts | 0
src/_shims/auto/types-deno.ts | 0
src/_shims/auto/types-node.ts | 0
src/_shims/auto/types.d.ts | 0
src/_shims/auto/types.js | 0
src/_shims/auto/types.mjs | 0
src/_shims/bun-runtime.ts | 0
src/_shims/index-deno.ts | 0
src/_shims/index.d.ts | 0
src/_shims/index.js | 0
src/_shims/index.mjs | 0
src/_shims/manual-types.d.ts | 0
src/_shims/manual-types.js | 0
src/_shims/manual-types.mjs | 0
src/_shims/node-runtime.ts | 0
src/_shims/node-types.d.ts | 0
src/_shims/node-types.js | 0
src/_shims/node-types.mjs | 0
src/_shims/registry.ts | 0
src/_shims/web-runtime.ts | 0
src/_shims/web-types.d.ts | 0
src/_shims/web-types.js | 0
src/_shims/web-types.mjs | 0
src/core.ts | 0
src/error.ts | 0
src/index.ts | 0
src/lib/.keep | 0
src/resource.ts | 0
src/resources/bitcoin/bitcoin.ts | 0
src/resources/bitcoin/index.ts | 0
src/resources/bitcoin/transaction.ts | 0
src/resources/evm/evm.ts | 0
src/resources/evm/index.ts | 0
src/resources/evm/json-rpc.ts | 0
src/resources/evm/post-transaction-bulk.ts | 0
src/resources/evm/post-transaction.ts | 0
src/resources/evm/transaction-bulk.ts | 0
src/resources/evm/transaction-raw.ts | 0
src/resources/evm/transaction.ts | 0
src/resources/evm/user-operation.ts | 0
src/resources/index.ts | 0
src/resources/site.ts | 0
src/resources/solana/address.ts | 0
src/resources/solana/index.ts | 0
src/resources/solana/message.ts | 0
src/resources/solana/solana.ts | 0
src/resources/starknet/index.ts | 0
src/resources/starknet/starknet.ts | 0
src/resources/starknet/transaction.ts | 0
src/resources/stellar/index.ts | 0
src/resources/stellar/stellar.ts | 0
src/resources/stellar/transaction.ts | 0
src/resources/token-bulk.ts | 0
src/resources/token.ts | 0
src/shims/node.ts | 0
src/shims/web.ts | 0
src/uploads.ts | 0
src/version.ts | 0
tests/api-resources/bitcoin/transaction.test.ts | 0
tests/api-resources/evm/json-rpc.test.ts | 0
tests/api-resources/evm/post-transaction-bulk.test.ts | 0
tests/api-resources/evm/post-transaction.test.ts | 0
tests/api-resources/evm/transaction-bulk.test.ts | 0
tests/api-resources/evm/transaction-raw.test.ts | 0
tests/api-resources/evm/transaction.test.ts | 0
tests/api-resources/evm/user-operation.test.ts | 0
tests/api-resources/site.test.ts | 0
tests/api-resources/solana/address.test.ts | 0
tests/api-resources/solana/message.test.ts | 0
tests/api-resources/starknet/transaction.test.ts | 0
tests/api-resources/stellar/transaction.test.ts | 0
tests/api-resources/token-bulk.test.ts | 0
tests/api-resources/token.test.ts | 0
tests/form.test.ts | 0
tests/index.test.ts | 0
tests/responses.test.ts | 0
tests/stringifyQuery.test.ts | 0
tests/uploads.test.ts | 0
tsc-multi.json | 0
tsconfig.build.json | 0
tsconfig.deno.json | 0
tsconfig.dist-src.json | 0
tsconfig.json | 0
yarn.lock | 0
116 files changed, 0 insertions(+), 0 deletions(-)
mode change 100755 => 100644 .devcontainer/Dockerfile
mode change 100755 => 100644 .devcontainer/devcontainer.json
mode change 100755 => 100644 .eslintrc.js
mode change 100755 => 100644 .github/workflows/ci.yml
mode change 100755 => 100644 .github/workflows/publish-npm.yml
mode change 100755 => 100644 .github/workflows/release-doctor.yml
mode change 100755 => 100644 .gitignore
mode change 100755 => 100644 .prettierignore
mode change 100755 => 100644 .prettierrc.json
mode change 100755 => 100644 .release-please-manifest.json
mode change 100755 => 100644 .stats.yml
mode change 100755 => 100644 Brewfile
mode change 100755 => 100644 CONTRIBUTING.md
mode change 100755 => 100644 LICENSE
mode change 100755 => 100644 README.md
mode change 100755 => 100644 SECURITY.md
mode change 100755 => 100644 api.md
mode change 100755 => 100644 bin/check-release-environment
mode change 100755 => 100644 bin/publish-npm
mode change 100755 => 100644 examples/.keep
mode change 100755 => 100644 jest.config.ts
mode change 100755 => 100644 package.json
mode change 100755 => 100644 release-please-config.json
mode change 100755 => 100644 scripts/utils/check-version.cjs
mode change 100755 => 100644 scripts/utils/fix-index-exports.cjs
mode change 100755 => 100644 scripts/utils/make-dist-package-json.cjs
mode change 100755 => 100644 scripts/utils/postprocess-files.cjs
mode change 100755 => 100644 src/_shims/MultipartBody.ts
mode change 100755 => 100644 src/_shims/README.md
mode change 100755 => 100644 src/_shims/auto/runtime-bun.ts
mode change 100755 => 100644 src/_shims/auto/runtime-deno.ts
mode change 100755 => 100644 src/_shims/auto/runtime-node.ts
mode change 100755 => 100644 src/_shims/auto/runtime.ts
mode change 100755 => 100644 src/_shims/auto/types-deno.ts
mode change 100755 => 100644 src/_shims/auto/types-node.ts
mode change 100755 => 100644 src/_shims/auto/types.d.ts
mode change 100755 => 100644 src/_shims/auto/types.js
mode change 100755 => 100644 src/_shims/auto/types.mjs
mode change 100755 => 100644 src/_shims/bun-runtime.ts
mode change 100755 => 100644 src/_shims/index-deno.ts
mode change 100755 => 100644 src/_shims/index.d.ts
mode change 100755 => 100644 src/_shims/index.js
mode change 100755 => 100644 src/_shims/index.mjs
mode change 100755 => 100644 src/_shims/manual-types.d.ts
mode change 100755 => 100644 src/_shims/manual-types.js
mode change 100755 => 100644 src/_shims/manual-types.mjs
mode change 100755 => 100644 src/_shims/node-runtime.ts
mode change 100755 => 100644 src/_shims/node-types.d.ts
mode change 100755 => 100644 src/_shims/node-types.js
mode change 100755 => 100644 src/_shims/node-types.mjs
mode change 100755 => 100644 src/_shims/registry.ts
mode change 100755 => 100644 src/_shims/web-runtime.ts
mode change 100755 => 100644 src/_shims/web-types.d.ts
mode change 100755 => 100644 src/_shims/web-types.js
mode change 100755 => 100644 src/_shims/web-types.mjs
mode change 100755 => 100644 src/core.ts
mode change 100755 => 100644 src/error.ts
mode change 100755 => 100644 src/index.ts
mode change 100755 => 100644 src/lib/.keep
mode change 100755 => 100644 src/resource.ts
mode change 100755 => 100644 src/resources/bitcoin/bitcoin.ts
mode change 100755 => 100644 src/resources/bitcoin/index.ts
mode change 100755 => 100644 src/resources/bitcoin/transaction.ts
mode change 100755 => 100644 src/resources/evm/evm.ts
mode change 100755 => 100644 src/resources/evm/index.ts
mode change 100755 => 100644 src/resources/evm/json-rpc.ts
mode change 100755 => 100644 src/resources/evm/post-transaction-bulk.ts
mode change 100755 => 100644 src/resources/evm/post-transaction.ts
mode change 100755 => 100644 src/resources/evm/transaction-bulk.ts
mode change 100755 => 100644 src/resources/evm/transaction-raw.ts
mode change 100755 => 100644 src/resources/evm/transaction.ts
mode change 100755 => 100644 src/resources/evm/user-operation.ts
mode change 100755 => 100644 src/resources/index.ts
mode change 100755 => 100644 src/resources/site.ts
mode change 100755 => 100644 src/resources/solana/address.ts
mode change 100755 => 100644 src/resources/solana/index.ts
mode change 100755 => 100644 src/resources/solana/message.ts
mode change 100755 => 100644 src/resources/solana/solana.ts
mode change 100755 => 100644 src/resources/starknet/index.ts
mode change 100755 => 100644 src/resources/starknet/starknet.ts
mode change 100755 => 100644 src/resources/starknet/transaction.ts
mode change 100755 => 100644 src/resources/stellar/index.ts
mode change 100755 => 100644 src/resources/stellar/stellar.ts
mode change 100755 => 100644 src/resources/stellar/transaction.ts
mode change 100755 => 100644 src/resources/token-bulk.ts
mode change 100755 => 100644 src/resources/token.ts
mode change 100755 => 100644 src/shims/node.ts
mode change 100755 => 100644 src/shims/web.ts
mode change 100755 => 100644 src/uploads.ts
mode change 100755 => 100644 src/version.ts
mode change 100755 => 100644 tests/api-resources/bitcoin/transaction.test.ts
mode change 100755 => 100644 tests/api-resources/evm/json-rpc.test.ts
mode change 100755 => 100644 tests/api-resources/evm/post-transaction-bulk.test.ts
mode change 100755 => 100644 tests/api-resources/evm/post-transaction.test.ts
mode change 100755 => 100644 tests/api-resources/evm/transaction-bulk.test.ts
mode change 100755 => 100644 tests/api-resources/evm/transaction-raw.test.ts
mode change 100755 => 100644 tests/api-resources/evm/transaction.test.ts
mode change 100755 => 100644 tests/api-resources/evm/user-operation.test.ts
mode change 100755 => 100644 tests/api-resources/site.test.ts
mode change 100755 => 100644 tests/api-resources/solana/address.test.ts
mode change 100755 => 100644 tests/api-resources/solana/message.test.ts
mode change 100755 => 100644 tests/api-resources/starknet/transaction.test.ts
mode change 100755 => 100644 tests/api-resources/stellar/transaction.test.ts
mode change 100755 => 100644 tests/api-resources/token-bulk.test.ts
mode change 100755 => 100644 tests/api-resources/token.test.ts
mode change 100755 => 100644 tests/form.test.ts
mode change 100755 => 100644 tests/index.test.ts
mode change 100755 => 100644 tests/responses.test.ts
mode change 100755 => 100644 tests/stringifyQuery.test.ts
mode change 100755 => 100644 tests/uploads.test.ts
mode change 100755 => 100644 tsc-multi.json
mode change 100755 => 100644 tsconfig.build.json
mode change 100755 => 100644 tsconfig.deno.json
mode change 100755 => 100644 tsconfig.dist-src.json
mode change 100755 => 100644 tsconfig.json
mode change 100755 => 100644 yarn.lock
diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile
old mode 100755
new mode 100644
diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json
old mode 100755
new mode 100644
diff --git a/.eslintrc.js b/.eslintrc.js
old mode 100755
new mode 100644
diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml
old mode 100755
new mode 100644
diff --git a/.github/workflows/publish-npm.yml b/.github/workflows/publish-npm.yml
old mode 100755
new mode 100644
diff --git a/.github/workflows/release-doctor.yml b/.github/workflows/release-doctor.yml
old mode 100755
new mode 100644
diff --git a/.gitignore b/.gitignore
old mode 100755
new mode 100644
diff --git a/.prettierignore b/.prettierignore
old mode 100755
new mode 100644
diff --git a/.prettierrc.json b/.prettierrc.json
old mode 100755
new mode 100644
diff --git a/.release-please-manifest.json b/.release-please-manifest.json
old mode 100755
new mode 100644
diff --git a/.stats.yml b/.stats.yml
old mode 100755
new mode 100644
diff --git a/Brewfile b/Brewfile
old mode 100755
new mode 100644
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
old mode 100755
new mode 100644
diff --git a/LICENSE b/LICENSE
old mode 100755
new mode 100644
diff --git a/README.md b/README.md
old mode 100755
new mode 100644
diff --git a/SECURITY.md b/SECURITY.md
old mode 100755
new mode 100644
diff --git a/api.md b/api.md
old mode 100755
new mode 100644
diff --git a/bin/check-release-environment b/bin/check-release-environment
old mode 100755
new mode 100644
diff --git a/bin/publish-npm b/bin/publish-npm
old mode 100755
new mode 100644
diff --git a/examples/.keep b/examples/.keep
old mode 100755
new mode 100644
diff --git a/jest.config.ts b/jest.config.ts
old mode 100755
new mode 100644
diff --git a/package.json b/package.json
old mode 100755
new mode 100644
diff --git a/release-please-config.json b/release-please-config.json
old mode 100755
new mode 100644
diff --git a/scripts/utils/check-version.cjs b/scripts/utils/check-version.cjs
old mode 100755
new mode 100644
diff --git a/scripts/utils/fix-index-exports.cjs b/scripts/utils/fix-index-exports.cjs
old mode 100755
new mode 100644
diff --git a/scripts/utils/make-dist-package-json.cjs b/scripts/utils/make-dist-package-json.cjs
old mode 100755
new mode 100644
diff --git a/scripts/utils/postprocess-files.cjs b/scripts/utils/postprocess-files.cjs
old mode 100755
new mode 100644
diff --git a/src/_shims/MultipartBody.ts b/src/_shims/MultipartBody.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/README.md b/src/_shims/README.md
old mode 100755
new mode 100644
diff --git a/src/_shims/auto/runtime-bun.ts b/src/_shims/auto/runtime-bun.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/auto/runtime-deno.ts b/src/_shims/auto/runtime-deno.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/auto/runtime-node.ts b/src/_shims/auto/runtime-node.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/auto/runtime.ts b/src/_shims/auto/runtime.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/auto/types-deno.ts b/src/_shims/auto/types-deno.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/auto/types-node.ts b/src/_shims/auto/types-node.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/auto/types.d.ts b/src/_shims/auto/types.d.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/auto/types.js b/src/_shims/auto/types.js
old mode 100755
new mode 100644
diff --git a/src/_shims/auto/types.mjs b/src/_shims/auto/types.mjs
old mode 100755
new mode 100644
diff --git a/src/_shims/bun-runtime.ts b/src/_shims/bun-runtime.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/index-deno.ts b/src/_shims/index-deno.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/index.d.ts b/src/_shims/index.d.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/index.js b/src/_shims/index.js
old mode 100755
new mode 100644
diff --git a/src/_shims/index.mjs b/src/_shims/index.mjs
old mode 100755
new mode 100644
diff --git a/src/_shims/manual-types.d.ts b/src/_shims/manual-types.d.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/manual-types.js b/src/_shims/manual-types.js
old mode 100755
new mode 100644
diff --git a/src/_shims/manual-types.mjs b/src/_shims/manual-types.mjs
old mode 100755
new mode 100644
diff --git a/src/_shims/node-runtime.ts b/src/_shims/node-runtime.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/node-types.d.ts b/src/_shims/node-types.d.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/node-types.js b/src/_shims/node-types.js
old mode 100755
new mode 100644
diff --git a/src/_shims/node-types.mjs b/src/_shims/node-types.mjs
old mode 100755
new mode 100644
diff --git a/src/_shims/registry.ts b/src/_shims/registry.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/web-runtime.ts b/src/_shims/web-runtime.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/web-types.d.ts b/src/_shims/web-types.d.ts
old mode 100755
new mode 100644
diff --git a/src/_shims/web-types.js b/src/_shims/web-types.js
old mode 100755
new mode 100644
diff --git a/src/_shims/web-types.mjs b/src/_shims/web-types.mjs
old mode 100755
new mode 100644
diff --git a/src/core.ts b/src/core.ts
old mode 100755
new mode 100644
diff --git a/src/error.ts b/src/error.ts
old mode 100755
new mode 100644
diff --git a/src/index.ts b/src/index.ts
old mode 100755
new mode 100644
diff --git a/src/lib/.keep b/src/lib/.keep
old mode 100755
new mode 100644
diff --git a/src/resource.ts b/src/resource.ts
old mode 100755
new mode 100644
diff --git a/src/resources/bitcoin/bitcoin.ts b/src/resources/bitcoin/bitcoin.ts
old mode 100755
new mode 100644
diff --git a/src/resources/bitcoin/index.ts b/src/resources/bitcoin/index.ts
old mode 100755
new mode 100644
diff --git a/src/resources/bitcoin/transaction.ts b/src/resources/bitcoin/transaction.ts
old mode 100755
new mode 100644
diff --git a/src/resources/evm/evm.ts b/src/resources/evm/evm.ts
old mode 100755
new mode 100644
diff --git a/src/resources/evm/index.ts b/src/resources/evm/index.ts
old mode 100755
new mode 100644
diff --git a/src/resources/evm/json-rpc.ts b/src/resources/evm/json-rpc.ts
old mode 100755
new mode 100644
diff --git a/src/resources/evm/post-transaction-bulk.ts b/src/resources/evm/post-transaction-bulk.ts
old mode 100755
new mode 100644
diff --git a/src/resources/evm/post-transaction.ts b/src/resources/evm/post-transaction.ts
old mode 100755
new mode 100644
diff --git a/src/resources/evm/transaction-bulk.ts b/src/resources/evm/transaction-bulk.ts
old mode 100755
new mode 100644
diff --git a/src/resources/evm/transaction-raw.ts b/src/resources/evm/transaction-raw.ts
old mode 100755
new mode 100644
diff --git a/src/resources/evm/transaction.ts b/src/resources/evm/transaction.ts
old mode 100755
new mode 100644
diff --git a/src/resources/evm/user-operation.ts b/src/resources/evm/user-operation.ts
old mode 100755
new mode 100644
diff --git a/src/resources/index.ts b/src/resources/index.ts
old mode 100755
new mode 100644
diff --git a/src/resources/site.ts b/src/resources/site.ts
old mode 100755
new mode 100644
diff --git a/src/resources/solana/address.ts b/src/resources/solana/address.ts
old mode 100755
new mode 100644
diff --git a/src/resources/solana/index.ts b/src/resources/solana/index.ts
old mode 100755
new mode 100644
diff --git a/src/resources/solana/message.ts b/src/resources/solana/message.ts
old mode 100755
new mode 100644
diff --git a/src/resources/solana/solana.ts b/src/resources/solana/solana.ts
old mode 100755
new mode 100644
diff --git a/src/resources/starknet/index.ts b/src/resources/starknet/index.ts
old mode 100755
new mode 100644
diff --git a/src/resources/starknet/starknet.ts b/src/resources/starknet/starknet.ts
old mode 100755
new mode 100644
diff --git a/src/resources/starknet/transaction.ts b/src/resources/starknet/transaction.ts
old mode 100755
new mode 100644
diff --git a/src/resources/stellar/index.ts b/src/resources/stellar/index.ts
old mode 100755
new mode 100644
diff --git a/src/resources/stellar/stellar.ts b/src/resources/stellar/stellar.ts
old mode 100755
new mode 100644
diff --git a/src/resources/stellar/transaction.ts b/src/resources/stellar/transaction.ts
old mode 100755
new mode 100644
diff --git a/src/resources/token-bulk.ts b/src/resources/token-bulk.ts
old mode 100755
new mode 100644
diff --git a/src/resources/token.ts b/src/resources/token.ts
old mode 100755
new mode 100644
diff --git a/src/shims/node.ts b/src/shims/node.ts
old mode 100755
new mode 100644
diff --git a/src/shims/web.ts b/src/shims/web.ts
old mode 100755
new mode 100644
diff --git a/src/uploads.ts b/src/uploads.ts
old mode 100755
new mode 100644
diff --git a/src/version.ts b/src/version.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/bitcoin/transaction.test.ts b/tests/api-resources/bitcoin/transaction.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/evm/json-rpc.test.ts b/tests/api-resources/evm/json-rpc.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/evm/post-transaction-bulk.test.ts b/tests/api-resources/evm/post-transaction-bulk.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/evm/post-transaction.test.ts b/tests/api-resources/evm/post-transaction.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/evm/transaction-bulk.test.ts b/tests/api-resources/evm/transaction-bulk.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/evm/transaction-raw.test.ts b/tests/api-resources/evm/transaction-raw.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/evm/transaction.test.ts b/tests/api-resources/evm/transaction.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/evm/user-operation.test.ts b/tests/api-resources/evm/user-operation.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/site.test.ts b/tests/api-resources/site.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/solana/address.test.ts b/tests/api-resources/solana/address.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/solana/message.test.ts b/tests/api-resources/solana/message.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/starknet/transaction.test.ts b/tests/api-resources/starknet/transaction.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/stellar/transaction.test.ts b/tests/api-resources/stellar/transaction.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/token-bulk.test.ts b/tests/api-resources/token-bulk.test.ts
old mode 100755
new mode 100644
diff --git a/tests/api-resources/token.test.ts b/tests/api-resources/token.test.ts
old mode 100755
new mode 100644
diff --git a/tests/form.test.ts b/tests/form.test.ts
old mode 100755
new mode 100644
diff --git a/tests/index.test.ts b/tests/index.test.ts
old mode 100755
new mode 100644
diff --git a/tests/responses.test.ts b/tests/responses.test.ts
old mode 100755
new mode 100644
diff --git a/tests/stringifyQuery.test.ts b/tests/stringifyQuery.test.ts
old mode 100755
new mode 100644
diff --git a/tests/uploads.test.ts b/tests/uploads.test.ts
old mode 100755
new mode 100644
diff --git a/tsc-multi.json b/tsc-multi.json
old mode 100755
new mode 100644
diff --git a/tsconfig.build.json b/tsconfig.build.json
old mode 100755
new mode 100644
diff --git a/tsconfig.deno.json b/tsconfig.deno.json
old mode 100755
new mode 100644
diff --git a/tsconfig.dist-src.json b/tsconfig.dist-src.json
old mode 100755
new mode 100644
diff --git a/tsconfig.json b/tsconfig.json
old mode 100755
new mode 100644
diff --git a/yarn.lock b/yarn.lock
old mode 100755
new mode 100644
From 2aab321c9275131140fd83846b8c1bf8c3dc660a Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Tue, 10 Sep 2024 12:48:21 +0000
Subject: [PATCH 08/20] feat(api): OpenAPI spec update via Stainless API (#248)
---
.stats.yml | 2 +-
api.md | 1 +
src/index.ts | 1 +
src/resources/index.ts | 1 +
src/resources/solana/index.ts | 1 +
src/resources/solana/solana.ts | 29 +++++++++++++++++++++++++++++
6 files changed, 34 insertions(+), 1 deletion(-)
diff --git a/.stats.yml b/.stats.yml
index c7f63f4..1807b01 100644
--- a/.stats.yml
+++ b/.stats.yml
@@ -1,2 +1,2 @@
configured_endpoints: 19
-openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-e5c860e614083c96ad126c68ee8c87a979a9ed6b648a1ec879e917138a2e38dd.yml
+openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-cbd51756ac7452c36818b539beb7290b102260a1bbd4adaab6a71d87c66d3270.yml
diff --git a/api.md b/api.md
index 88da31f..30382f9 100644
--- a/api.md
+++ b/api.md
@@ -129,6 +129,7 @@ Types:
- TotalUsdDiffSchema
- TransactionErrorDetails
- TxScanRequestSchema
+- ValidationFeature
## Message
diff --git a/src/index.ts b/src/index.ts
index bd5e0e0..44a82f9 100644
--- a/src/index.ts
+++ b/src/index.ts
@@ -324,6 +324,7 @@ export namespace Blockaid {
export import TotalUsdDiffSchema = API.TotalUsdDiffSchema;
export import TransactionErrorDetails = API.TransactionErrorDetails;
export import TxScanRequestSchema = API.TxScanRequestSchema;
+ export import ValidationFeature = API.ValidationFeature;
export import Stellar = API.Stellar;
export import StellarAssetContractDetailsSchema = API.StellarAssetContractDetailsSchema;
diff --git a/src/resources/index.ts b/src/resources/index.ts
index deac5e2..c8b9c23 100644
--- a/src/resources/index.ts
+++ b/src/resources/index.ts
@@ -33,6 +33,7 @@ export {
TotalUsdDiffSchema,
TransactionErrorDetails,
TxScanRequestSchema,
+ ValidationFeature,
Solana,
} from './solana/solana';
export {
diff --git a/src/resources/solana/index.ts b/src/resources/solana/index.ts
index 733ef11..21812c8 100644
--- a/src/resources/solana/index.ts
+++ b/src/resources/solana/index.ts
@@ -33,6 +33,7 @@ export {
TotalUsdDiffSchema,
TransactionErrorDetails,
TxScanRequestSchema,
+ ValidationFeature,
Solana,
} from './solana';
export { AddressScanParams, Address } from './address';
diff --git a/src/resources/solana/solana.ts b/src/resources/solana/solana.ts
index 45eb452..5be9f30 100644
--- a/src/resources/solana/solana.ts
+++ b/src/resources/solana/solana.ts
@@ -205,6 +205,12 @@ export namespace CombinedValidationResult {
* Transaction validation result
*/
export interface Validation {
+ /**
+ * A list of features explaining what is happening in the transaction in different
+ * levels of severity
+ */
+ extended_features: Array;
+
/**
* A list of features about this transaction explaining the validation
*/
@@ -742,6 +748,28 @@ export namespace TxScanRequestSchema {
}
}
+export interface ValidationFeature {
+ /**
+ * Textual description
+ */
+ description: string;
+
+ /**
+ * Feature name
+ */
+ feature_id: string;
+
+ /**
+ * An enumeration.
+ */
+ type: 'Info' | 'Benign' | 'Warning' | 'Malicious';
+
+ /**
+ * Address the feature refers to
+ */
+ address?: string | null;
+}
+
export namespace Solana {
export import AccountSummarySchema = SolanaAPI.AccountSummarySchema;
export import AddressScanRequestSchema = SolanaAPI.AddressScanRequestSchema;
@@ -775,6 +803,7 @@ export namespace Solana {
export import TotalUsdDiffSchema = SolanaAPI.TotalUsdDiffSchema;
export import TransactionErrorDetails = SolanaAPI.TransactionErrorDetails;
export import TxScanRequestSchema = SolanaAPI.TxScanRequestSchema;
+ export import ValidationFeature = SolanaAPI.ValidationFeature;
export import Message = MessageAPI.Message;
export import MessageScanParams = MessageAPI.MessageScanParams;
export import Address = AddressAPI.Address;
From 8d73c25281042ecc087f3f845ff29f9296ab2eec Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Tue, 10 Sep 2024 13:13:16 +0000
Subject: [PATCH 09/20] fix(uploads): avoid making redundant memory copies
(#251)
---
src/uploads.ts | 8 +++++---
tests/uploads.test.ts | 8 ++++++++
2 files changed, 13 insertions(+), 3 deletions(-)
diff --git a/src/uploads.ts b/src/uploads.ts
index a920351..8fd2154 100644
--- a/src/uploads.ts
+++ b/src/uploads.ts
@@ -107,8 +107,10 @@ export async function toFile(
// If it's a promise, resolve it.
value = await value;
- // Use the file's options if there isn't one provided
- options ??= isFileLike(value) ? { lastModified: value.lastModified, type: value.type } : {};
+ // If we've been given a `File` we don't need to do anything
+ if (isFileLike(value)) {
+ return value;
+ }
if (isResponseLike(value)) {
const blob = await value.blob();
@@ -126,7 +128,7 @@ export async function toFile(
name ||= getName(value) ?? 'unknown_file';
- if (!options.type) {
+ if (!options?.type) {
const type = (bits[0] as any)?.type;
if (typeof type === 'string') {
options = { ...options, type };
diff --git a/tests/uploads.test.ts b/tests/uploads.test.ts
index 96a5928..cd25677 100644
--- a/tests/uploads.test.ts
+++ b/tests/uploads.test.ts
@@ -54,4 +54,12 @@ describe('toFile', () => {
const file = await toFile(input);
expect(file.name).toEqual('uploads.test.ts');
});
+
+ it('does not copy File objects', async () => {
+ const input = new File(['foo'], 'input.jsonl', { type: 'jsonl' });
+ const file = await toFile(input);
+ expect(file).toBe(input);
+ expect(file.name).toEqual('input.jsonl');
+ expect(file.type).toBe('jsonl');
+ });
});
From bc00dced8522b301e37523812f7783de262ee931 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Tue, 10 Sep 2024 13:17:20 +0000
Subject: [PATCH 10/20] chore(internal): codegen related update (#252)
---
src/uploads.ts | 8 +++-----
tests/uploads.test.ts | 8 --------
2 files changed, 3 insertions(+), 13 deletions(-)
diff --git a/src/uploads.ts b/src/uploads.ts
index 8fd2154..a920351 100644
--- a/src/uploads.ts
+++ b/src/uploads.ts
@@ -107,10 +107,8 @@ export async function toFile(
// If it's a promise, resolve it.
value = await value;
- // If we've been given a `File` we don't need to do anything
- if (isFileLike(value)) {
- return value;
- }
+ // Use the file's options if there isn't one provided
+ options ??= isFileLike(value) ? { lastModified: value.lastModified, type: value.type } : {};
if (isResponseLike(value)) {
const blob = await value.blob();
@@ -128,7 +126,7 @@ export async function toFile(
name ||= getName(value) ?? 'unknown_file';
- if (!options?.type) {
+ if (!options.type) {
const type = (bits[0] as any)?.type;
if (typeof type === 'string') {
options = { ...options, type };
diff --git a/tests/uploads.test.ts b/tests/uploads.test.ts
index cd25677..96a5928 100644
--- a/tests/uploads.test.ts
+++ b/tests/uploads.test.ts
@@ -54,12 +54,4 @@ describe('toFile', () => {
const file = await toFile(input);
expect(file.name).toEqual('uploads.test.ts');
});
-
- it('does not copy File objects', async () => {
- const input = new File(['foo'], 'input.jsonl', { type: 'jsonl' });
- const file = await toFile(input);
- expect(file).toBe(input);
- expect(file.name).toEqual('input.jsonl');
- expect(file.type).toBe('jsonl');
- });
});
From b56587a1ab78278e37ea00070e81a734f53b97a6 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Tue, 10 Sep 2024 13:18:49 +0000
Subject: [PATCH 11/20] chore(internal): codegen related update (#253)
---
src/uploads.ts | 8 +++++---
tests/uploads.test.ts | 8 ++++++++
2 files changed, 13 insertions(+), 3 deletions(-)
diff --git a/src/uploads.ts b/src/uploads.ts
index a920351..8fd2154 100644
--- a/src/uploads.ts
+++ b/src/uploads.ts
@@ -107,8 +107,10 @@ export async function toFile(
// If it's a promise, resolve it.
value = await value;
- // Use the file's options if there isn't one provided
- options ??= isFileLike(value) ? { lastModified: value.lastModified, type: value.type } : {};
+ // If we've been given a `File` we don't need to do anything
+ if (isFileLike(value)) {
+ return value;
+ }
if (isResponseLike(value)) {
const blob = await value.blob();
@@ -126,7 +128,7 @@ export async function toFile(
name ||= getName(value) ?? 'unknown_file';
- if (!options.type) {
+ if (!options?.type) {
const type = (bits[0] as any)?.type;
if (typeof type === 'string') {
options = { ...options, type };
diff --git a/tests/uploads.test.ts b/tests/uploads.test.ts
index 96a5928..cd25677 100644
--- a/tests/uploads.test.ts
+++ b/tests/uploads.test.ts
@@ -54,4 +54,12 @@ describe('toFile', () => {
const file = await toFile(input);
expect(file.name).toEqual('uploads.test.ts');
});
+
+ it('does not copy File objects', async () => {
+ const input = new File(['foo'], 'input.jsonl', { type: 'jsonl' });
+ const file = await toFile(input);
+ expect(file).toBe(input);
+ expect(file.name).toEqual('input.jsonl');
+ expect(file.type).toBe('jsonl');
+ });
});
From f785f5394a5917db0822bbcd43454eb2eefe3ec2 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Tue, 10 Sep 2024 13:20:51 +0000
Subject: [PATCH 12/20] fix(errors): pass message through to APIConnectionError
(#254)
---
src/error.ts | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/error.ts b/src/error.ts
index 026e878..354059a 100644
--- a/src/error.ts
+++ b/src/error.ts
@@ -49,7 +49,7 @@ export class APIError extends BlockaidError {
headers: Headers | undefined,
) {
if (!status) {
- return new APIConnectionError({ cause: castToError(errorResponse) });
+ return new APIConnectionError({ message, cause: castToError(errorResponse) });
}
const error = errorResponse as Record;
@@ -101,7 +101,7 @@ export class APIUserAbortError extends APIError {
export class APIConnectionError extends APIError {
override readonly status: undefined = undefined;
- constructor({ message, cause }: { message?: string; cause?: Error | undefined }) {
+ constructor({ message, cause }: { message?: string | undefined; cause?: Error | undefined }) {
super(undefined, undefined, message || 'Connection error.', undefined);
// in some environments the 'cause' property is already declared
// @ts-ignore
From f1e5a10672acf16bd2f4580c1a945e07655895b2 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Tue, 10 Sep 2024 13:21:24 +0000
Subject: [PATCH 13/20] chore: better object fallback behaviour for casting
errors (#255)
---
src/core.ts | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/src/core.ts b/src/core.ts
index 6b59935..5d652d0 100644
--- a/src/core.ts
+++ b/src/core.ts
@@ -978,6 +978,11 @@ const validatePositiveInteger = (name: string, n: unknown): number => {
export const castToError = (err: any): Error => {
if (err instanceof Error) return err;
+ if (typeof err === 'object' && err !== null) {
+ try {
+ return new Error(JSON.stringify(err));
+ } catch {}
+ }
return new Error(err);
};
From 2fa0c63ab516fa73316c552d10424ee70db942aa Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Thu, 12 Sep 2024 08:05:00 +0000
Subject: [PATCH 14/20] feat(api): OpenAPI spec update via Stainless API (#256)
---
.stats.yml | 2 +-
src/core.ts | 5 --
src/error.ts | 4 +-
src/resources/evm/evm.ts | 3 +-
src/resources/token-bulk.ts | 158 ++++++++++++++++++++++++++++++++++-
src/resources/token.ts | 161 +++++++++++++++++++++++++++++++++++-
6 files changed, 320 insertions(+), 13 deletions(-)
diff --git a/.stats.yml b/.stats.yml
index 1807b01..8a1a197 100644
--- a/.stats.yml
+++ b/.stats.yml
@@ -1,2 +1,2 @@
configured_endpoints: 19
-openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-cbd51756ac7452c36818b539beb7290b102260a1bbd4adaab6a71d87c66d3270.yml
+openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-eae472593d02f56a6a609d7f7feb00ba233294ddae078cbfa69b906af1f41500.yml
diff --git a/src/core.ts b/src/core.ts
index 5d652d0..6b59935 100644
--- a/src/core.ts
+++ b/src/core.ts
@@ -978,11 +978,6 @@ const validatePositiveInteger = (name: string, n: unknown): number => {
export const castToError = (err: any): Error => {
if (err instanceof Error) return err;
- if (typeof err === 'object' && err !== null) {
- try {
- return new Error(JSON.stringify(err));
- } catch {}
- }
return new Error(err);
};
diff --git a/src/error.ts b/src/error.ts
index 354059a..026e878 100644
--- a/src/error.ts
+++ b/src/error.ts
@@ -49,7 +49,7 @@ export class APIError extends BlockaidError {
headers: Headers | undefined,
) {
if (!status) {
- return new APIConnectionError({ message, cause: castToError(errorResponse) });
+ return new APIConnectionError({ cause: castToError(errorResponse) });
}
const error = errorResponse as Record;
@@ -101,7 +101,7 @@ export class APIUserAbortError extends APIError {
export class APIConnectionError extends APIError {
override readonly status: undefined = undefined;
- constructor({ message, cause }: { message?: string | undefined; cause?: Error | undefined }) {
+ constructor({ message, cause }: { message?: string; cause?: Error | undefined }) {
super(undefined, undefined, message || 'Connection error.', undefined);
// in some environments the 'cause' property is already declared
// @ts-ignore
diff --git a/src/resources/evm/evm.ts b/src/resources/evm/evm.ts
index 72a0f0d..d6f1d8b 100644
--- a/src/resources/evm/evm.ts
+++ b/src/resources/evm/evm.ts
@@ -526,7 +526,8 @@ export type TokenScanSupportedChain =
| 'blast'
| 'zksync'
| 'scroll'
- | 'degen';
+ | 'degen'
+ | 'bitcoin';
export interface TransactionScanFeature {
/**
diff --git a/src/resources/token-bulk.ts b/src/resources/token-bulk.ts
index 5499328..90f01be 100644
--- a/src/resources/token-bulk.ts
+++ b/src/resources/token-bulk.ts
@@ -54,7 +54,7 @@ export namespace TokenBulkScanResponse {
/**
* Metadata of the token
*/
- metadata: Results.SolanaMetadata | Results.BasicMetadataToken;
+ metadata: Results.SolanaMetadata | Results.BitcoinMetadataToken | Results.EvmMetadataToken;
/**
* An enumeration.
@@ -134,6 +134,16 @@ export namespace TokenBulkScanResponse {
}
export interface SolanaMetadata {
+ /**
+ * Contract balance
+ */
+ contract_balance?: SolanaMetadata.ContractBalance;
+
+ /**
+ * Contract deploy date
+ */
+ creation_timestamp?: string;
+
/**
* Address of the deployer of the fungible token
*/
@@ -144,6 +154,14 @@ export namespace TokenBulkScanResponse {
*/
description?: string;
+ /**
+ * social links of the token
+ */
+ external_links?: SolanaMetadata.ExternalLinks;
+
+ /**
+ * Solana token freeze authority account
+ */
freeze_authority?: string;
/**
@@ -151,6 +169,9 @@ export namespace TokenBulkScanResponse {
*/
image_url?: string;
+ /**
+ * Solana token mint authority account
+ */
mint_authority?: string;
/**
@@ -158,6 +179,16 @@ export namespace TokenBulkScanResponse {
*/
name?: string;
+ /**
+ * Contract owner address
+ */
+ owner?: string;
+
+ /**
+ * Contract owner balance
+ */
+ owner_balance?: SolanaMetadata.OwnerBalance;
+
/**
* Symbol of the token
*/
@@ -168,10 +199,86 @@ export namespace TokenBulkScanResponse {
*/
type?: string;
+ /**
+ * Solana token update authority account
+ */
update_authority?: string;
}
- export interface BasicMetadataToken {
+ export namespace SolanaMetadata {
+ /**
+ * Contract balance
+ */
+ export interface ContractBalance {
+ amount?: number;
+
+ amount_wei?: string;
+ }
+
+ /**
+ * social links of the token
+ */
+ export interface ExternalLinks {
+ homepage?: string;
+
+ telegram_channel_id?: string;
+
+ twitter_page?: string;
+ }
+
+ /**
+ * Contract owner balance
+ */
+ export interface OwnerBalance {
+ amount?: number;
+
+ amount_wei?: string;
+ }
+ }
+
+ export interface BitcoinMetadataToken {
+ /**
+ * The unique ID for the Rune
+ */
+ id?: string;
+
+ /**
+ * The formatted name of the rune, with spacers
+ */
+ formatted_name?: string;
+
+ /**
+ * Name of the token
+ */
+ name?: string;
+
+ /**
+ * The rune's unique sequential number.
+ */
+ number?: number;
+
+ /**
+ * Symbol of the token
+ */
+ symbol?: string;
+
+ /**
+ * Type of the token
+ */
+ type?: string;
+ }
+
+ export interface EvmMetadataToken {
+ /**
+ * Contract balance
+ */
+ contract_balance?: EvmMetadataToken.ContractBalance;
+
+ /**
+ * Contract deploy date
+ */
+ creation_timestamp?: string;
+
/**
* Address of the deployer of the fungible token
*/
@@ -182,6 +289,11 @@ export namespace TokenBulkScanResponse {
*/
description?: string;
+ /**
+ * social links of the token
+ */
+ external_links?: EvmMetadataToken.ExternalLinks;
+
/**
* URL of the token image
*/
@@ -192,6 +304,16 @@ export namespace TokenBulkScanResponse {
*/
name?: string;
+ /**
+ * Contract owner address
+ */
+ owner?: string;
+
+ /**
+ * Contract owner balance
+ */
+ owner_balance?: EvmMetadataToken.OwnerBalance;
+
/**
* Symbol of the token
*/
@@ -203,6 +325,37 @@ export namespace TokenBulkScanResponse {
type?: string;
}
+ export namespace EvmMetadataToken {
+ /**
+ * Contract balance
+ */
+ export interface ContractBalance {
+ amount?: number;
+
+ amount_wei?: string;
+ }
+
+ /**
+ * social links of the token
+ */
+ export interface ExternalLinks {
+ homepage?: string;
+
+ telegram_channel_id?: string;
+
+ twitter_page?: string;
+ }
+
+ /**
+ * Contract owner balance
+ */
+ export interface OwnerBalance {
+ amount?: number;
+
+ amount_wei?: string;
+ }
+ }
+
/**
* Trading limits of the token
*/
@@ -256,6 +409,7 @@ export namespace TokenBulkScanResponse {
| 'HIGH_TRADE_VOLUME'
| 'MARKET_PLACE_SALES_HISTORY'
| 'HIGH_REPUTATION_TOKEN'
+ | 'ONCHAIN_ACTIVITY_VALIDATOR'
| 'STATIC_CODE_SIGNATURE'
| 'KNOWN_MALICIOUS'
| 'METADATA'
diff --git a/src/resources/token.ts b/src/resources/token.ts
index 6fb5fb9..c1711ad 100644
--- a/src/resources/token.ts
+++ b/src/resources/token.ts
@@ -58,7 +58,10 @@ export interface TokenScanResponse {
/**
* Metadata of the token
*/
- metadata: TokenScanResponse.SolanaMetadata | TokenScanResponse.BasicMetadataToken;
+ metadata:
+ | TokenScanResponse.SolanaMetadata
+ | TokenScanResponse.BitcoinMetadataToken
+ | TokenScanResponse.EvmMetadataToken;
/**
* An enumeration.
@@ -138,6 +141,16 @@ export namespace TokenScanResponse {
}
export interface SolanaMetadata {
+ /**
+ * Contract balance
+ */
+ contract_balance?: SolanaMetadata.ContractBalance;
+
+ /**
+ * Contract deploy date
+ */
+ creation_timestamp?: string;
+
/**
* Address of the deployer of the fungible token
*/
@@ -148,6 +161,14 @@ export namespace TokenScanResponse {
*/
description?: string;
+ /**
+ * social links of the token
+ */
+ external_links?: SolanaMetadata.ExternalLinks;
+
+ /**
+ * Solana token freeze authority account
+ */
freeze_authority?: string;
/**
@@ -155,6 +176,9 @@ export namespace TokenScanResponse {
*/
image_url?: string;
+ /**
+ * Solana token mint authority account
+ */
mint_authority?: string;
/**
@@ -162,6 +186,16 @@ export namespace TokenScanResponse {
*/
name?: string;
+ /**
+ * Contract owner address
+ */
+ owner?: string;
+
+ /**
+ * Contract owner balance
+ */
+ owner_balance?: SolanaMetadata.OwnerBalance;
+
/**
* Symbol of the token
*/
@@ -172,10 +206,86 @@ export namespace TokenScanResponse {
*/
type?: string;
+ /**
+ * Solana token update authority account
+ */
update_authority?: string;
}
- export interface BasicMetadataToken {
+ export namespace SolanaMetadata {
+ /**
+ * Contract balance
+ */
+ export interface ContractBalance {
+ amount?: number;
+
+ amount_wei?: string;
+ }
+
+ /**
+ * social links of the token
+ */
+ export interface ExternalLinks {
+ homepage?: string;
+
+ telegram_channel_id?: string;
+
+ twitter_page?: string;
+ }
+
+ /**
+ * Contract owner balance
+ */
+ export interface OwnerBalance {
+ amount?: number;
+
+ amount_wei?: string;
+ }
+ }
+
+ export interface BitcoinMetadataToken {
+ /**
+ * The unique ID for the Rune
+ */
+ id?: string;
+
+ /**
+ * The formatted name of the rune, with spacers
+ */
+ formatted_name?: string;
+
+ /**
+ * Name of the token
+ */
+ name?: string;
+
+ /**
+ * The rune's unique sequential number.
+ */
+ number?: number;
+
+ /**
+ * Symbol of the token
+ */
+ symbol?: string;
+
+ /**
+ * Type of the token
+ */
+ type?: string;
+ }
+
+ export interface EvmMetadataToken {
+ /**
+ * Contract balance
+ */
+ contract_balance?: EvmMetadataToken.ContractBalance;
+
+ /**
+ * Contract deploy date
+ */
+ creation_timestamp?: string;
+
/**
* Address of the deployer of the fungible token
*/
@@ -186,6 +296,11 @@ export namespace TokenScanResponse {
*/
description?: string;
+ /**
+ * social links of the token
+ */
+ external_links?: EvmMetadataToken.ExternalLinks;
+
/**
* URL of the token image
*/
@@ -196,6 +311,16 @@ export namespace TokenScanResponse {
*/
name?: string;
+ /**
+ * Contract owner address
+ */
+ owner?: string;
+
+ /**
+ * Contract owner balance
+ */
+ owner_balance?: EvmMetadataToken.OwnerBalance;
+
/**
* Symbol of the token
*/
@@ -207,6 +332,37 @@ export namespace TokenScanResponse {
type?: string;
}
+ export namespace EvmMetadataToken {
+ /**
+ * Contract balance
+ */
+ export interface ContractBalance {
+ amount?: number;
+
+ amount_wei?: string;
+ }
+
+ /**
+ * social links of the token
+ */
+ export interface ExternalLinks {
+ homepage?: string;
+
+ telegram_channel_id?: string;
+
+ twitter_page?: string;
+ }
+
+ /**
+ * Contract owner balance
+ */
+ export interface OwnerBalance {
+ amount?: number;
+
+ amount_wei?: string;
+ }
+ }
+
/**
* Trading limits of the token
*/
@@ -260,6 +416,7 @@ export namespace TokenScanResponse {
| 'HIGH_TRADE_VOLUME'
| 'MARKET_PLACE_SALES_HISTORY'
| 'HIGH_REPUTATION_TOKEN'
+ | 'ONCHAIN_ACTIVITY_VALIDATOR'
| 'STATIC_CODE_SIGNATURE'
| 'KNOWN_MALICIOUS'
| 'METADATA'
From 5f37e2307816bb164e5cea7f224ff26e011d4450 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Thu, 12 Sep 2024 08:08:15 +0000
Subject: [PATCH 15/20] chore(internal): codegen related update (#257)
---
src/uploads.ts | 8 +++-----
tests/uploads.test.ts | 8 --------
2 files changed, 3 insertions(+), 13 deletions(-)
diff --git a/src/uploads.ts b/src/uploads.ts
index 8fd2154..a920351 100644
--- a/src/uploads.ts
+++ b/src/uploads.ts
@@ -107,10 +107,8 @@ export async function toFile(
// If it's a promise, resolve it.
value = await value;
- // If we've been given a `File` we don't need to do anything
- if (isFileLike(value)) {
- return value;
- }
+ // Use the file's options if there isn't one provided
+ options ??= isFileLike(value) ? { lastModified: value.lastModified, type: value.type } : {};
if (isResponseLike(value)) {
const blob = await value.blob();
@@ -128,7 +126,7 @@ export async function toFile(
name ||= getName(value) ?? 'unknown_file';
- if (!options?.type) {
+ if (!options.type) {
const type = (bits[0] as any)?.type;
if (typeof type === 'string') {
options = { ...options, type };
diff --git a/tests/uploads.test.ts b/tests/uploads.test.ts
index cd25677..96a5928 100644
--- a/tests/uploads.test.ts
+++ b/tests/uploads.test.ts
@@ -54,12 +54,4 @@ describe('toFile', () => {
const file = await toFile(input);
expect(file.name).toEqual('uploads.test.ts');
});
-
- it('does not copy File objects', async () => {
- const input = new File(['foo'], 'input.jsonl', { type: 'jsonl' });
- const file = await toFile(input);
- expect(file).toBe(input);
- expect(file.name).toEqual('input.jsonl');
- expect(file.type).toBe('jsonl');
- });
});
From d7c64c33362d42a352fd4cc4b7b64be0ab8c7e11 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Thu, 12 Sep 2024 08:08:55 +0000
Subject: [PATCH 16/20] chore(internal): codegen related update (#258)
---
src/uploads.ts | 8 +++++---
tests/uploads.test.ts | 8 ++++++++
2 files changed, 13 insertions(+), 3 deletions(-)
diff --git a/src/uploads.ts b/src/uploads.ts
index a920351..8fd2154 100644
--- a/src/uploads.ts
+++ b/src/uploads.ts
@@ -107,8 +107,10 @@ export async function toFile(
// If it's a promise, resolve it.
value = await value;
- // Use the file's options if there isn't one provided
- options ??= isFileLike(value) ? { lastModified: value.lastModified, type: value.type } : {};
+ // If we've been given a `File` we don't need to do anything
+ if (isFileLike(value)) {
+ return value;
+ }
if (isResponseLike(value)) {
const blob = await value.blob();
@@ -126,7 +128,7 @@ export async function toFile(
name ||= getName(value) ?? 'unknown_file';
- if (!options.type) {
+ if (!options?.type) {
const type = (bits[0] as any)?.type;
if (typeof type === 'string') {
options = { ...options, type };
diff --git a/tests/uploads.test.ts b/tests/uploads.test.ts
index 96a5928..cd25677 100644
--- a/tests/uploads.test.ts
+++ b/tests/uploads.test.ts
@@ -54,4 +54,12 @@ describe('toFile', () => {
const file = await toFile(input);
expect(file.name).toEqual('uploads.test.ts');
});
+
+ it('does not copy File objects', async () => {
+ const input = new File(['foo'], 'input.jsonl', { type: 'jsonl' });
+ const file = await toFile(input);
+ expect(file).toBe(input);
+ expect(file.name).toEqual('input.jsonl');
+ expect(file.type).toBe('jsonl');
+ });
});
From e5904f098f9a5c82348d3db680e6136dac31e4c7 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Thu, 12 Sep 2024 08:10:30 +0000
Subject: [PATCH 17/20] fix(errors): pass message through to APIConnectionError
(#259)
---
src/error.ts | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/error.ts b/src/error.ts
index 026e878..354059a 100644
--- a/src/error.ts
+++ b/src/error.ts
@@ -49,7 +49,7 @@ export class APIError extends BlockaidError {
headers: Headers | undefined,
) {
if (!status) {
- return new APIConnectionError({ cause: castToError(errorResponse) });
+ return new APIConnectionError({ message, cause: castToError(errorResponse) });
}
const error = errorResponse as Record;
@@ -101,7 +101,7 @@ export class APIUserAbortError extends APIError {
export class APIConnectionError extends APIError {
override readonly status: undefined = undefined;
- constructor({ message, cause }: { message?: string; cause?: Error | undefined }) {
+ constructor({ message, cause }: { message?: string | undefined; cause?: Error | undefined }) {
super(undefined, undefined, message || 'Connection error.', undefined);
// in some environments the 'cause' property is already declared
// @ts-ignore
From 0b79ea32a1ff0fb6587131b817bc1ee137ecd34f Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Thu, 12 Sep 2024 08:10:56 +0000
Subject: [PATCH 18/20] chore: better object fallback behaviour for casting
errors (#260)
---
src/core.ts | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/src/core.ts b/src/core.ts
index 6b59935..5d652d0 100644
--- a/src/core.ts
+++ b/src/core.ts
@@ -978,6 +978,11 @@ const validatePositiveInteger = (name: string, n: unknown): number => {
export const castToError = (err: any): Error => {
if (err instanceof Error) return err;
+ if (typeof err === 'object' && err !== null) {
+ try {
+ return new Error(JSON.stringify(err));
+ } catch {}
+ }
return new Error(err);
};
From b5ed130827b2a08e37d233185a19529fa4375042 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Thu, 12 Sep 2024 18:19:11 +0000
Subject: [PATCH 19/20] feat(api): OpenAPI spec update via Stainless API (#261)
---
.stats.yml | 2 +-
src/resources/evm/evm.ts | 1 +
2 files changed, 2 insertions(+), 1 deletion(-)
diff --git a/.stats.yml b/.stats.yml
index 8a1a197..b8229b2 100644
--- a/.stats.yml
+++ b/.stats.yml
@@ -1,2 +1,2 @@
configured_endpoints: 19
-openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-eae472593d02f56a6a609d7f7feb00ba233294ddae078cbfa69b906af1f41500.yml
+openapi_spec_url: https://storage.googleapis.com/stainless-sdk-openapi-specs/new%2Fblockaid-71b132e4cfaa16a7800dcf1c024f0de69e48469d725dddda07a900b505c7e32a.yml
diff --git a/src/resources/evm/evm.ts b/src/resources/evm/evm.ts
index d6f1d8b..669154b 100644
--- a/src/resources/evm/evm.ts
+++ b/src/resources/evm/evm.ts
@@ -635,6 +635,7 @@ export type TransactionScanSupportedChain =
| 'degen'
| 'avalanche-fuji'
| 'immutable-zkevm'
+ | 'immutable-zkevm-testnet'
| 'gnosis'
| 'worldchain';
From b237a7a071b2591a1eb37baa741199283ee92730 Mon Sep 17 00:00:00 2001
From: "stainless-app[bot]"
<142633134+stainless-app[bot]@users.noreply.github.com>
Date: Thu, 12 Sep 2024 18:19:32 +0000
Subject: [PATCH 20/20] release: 0.26.0
---
.release-please-manifest.json | 2 +-
CHANGELOG.md | 32 ++++++++++++++++++++++++++++++++
package.json | 2 +-
src/version.ts | 2 +-
4 files changed, 35 insertions(+), 3 deletions(-)
diff --git a/.release-please-manifest.json b/.release-please-manifest.json
index 945fbaf..c84411f 100644
--- a/.release-please-manifest.json
+++ b/.release-please-manifest.json
@@ -1,3 +1,3 @@
{
- ".": "0.25.0"
+ ".": "0.26.0"
}
diff --git a/CHANGELOG.md b/CHANGELOG.md
index c5cfc4b..11f514e 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -1,5 +1,37 @@
# Changelog
+## 0.26.0 (2024-09-12)
+
+Full Changelog: [v0.25.0...v0.26.0](https://github.com/blockaid-official/blockaid-client-node/compare/v0.25.0...v0.26.0)
+
+### Features
+
+* **api:** OpenAPI spec update via Stainless API ([#242](https://github.com/blockaid-official/blockaid-client-node/issues/242)) ([922248c](https://github.com/blockaid-official/blockaid-client-node/commit/922248c64c1b31fb4bf837190593c721cf05721a))
+* **api:** OpenAPI spec update via Stainless API ([#245](https://github.com/blockaid-official/blockaid-client-node/issues/245)) ([e5bae2f](https://github.com/blockaid-official/blockaid-client-node/commit/e5bae2fae7305769e6cec349b915d6576bf84f1e))
+* **api:** OpenAPI spec update via Stainless API ([#246](https://github.com/blockaid-official/blockaid-client-node/issues/246)) ([98816a0](https://github.com/blockaid-official/blockaid-client-node/commit/98816a042c0fb8ccc8ff0bbfc74a73a82b62818e))
+* **api:** OpenAPI spec update via Stainless API ([#248](https://github.com/blockaid-official/blockaid-client-node/issues/248)) ([2aab321](https://github.com/blockaid-official/blockaid-client-node/commit/2aab321c9275131140fd83846b8c1bf8c3dc660a))
+* **api:** OpenAPI spec update via Stainless API ([#256](https://github.com/blockaid-official/blockaid-client-node/issues/256)) ([2fa0c63](https://github.com/blockaid-official/blockaid-client-node/commit/2fa0c63ab516fa73316c552d10424ee70db942aa))
+* **api:** OpenAPI spec update via Stainless API ([#261](https://github.com/blockaid-official/blockaid-client-node/issues/261)) ([b5ed130](https://github.com/blockaid-official/blockaid-client-node/commit/b5ed130827b2a08e37d233185a19529fa4375042))
+
+
+### Bug Fixes
+
+* **client:** correct File construction from node-fetch Responses ([#244](https://github.com/blockaid-official/blockaid-client-node/issues/244)) ([1785ebf](https://github.com/blockaid-official/blockaid-client-node/commit/1785ebf0c192172db1f77ae61c7746c4d68376f5))
+* **errors:** pass message through to APIConnectionError ([#254](https://github.com/blockaid-official/blockaid-client-node/issues/254)) ([f785f53](https://github.com/blockaid-official/blockaid-client-node/commit/f785f5394a5917db0822bbcd43454eb2eefe3ec2))
+* **errors:** pass message through to APIConnectionError ([#259](https://github.com/blockaid-official/blockaid-client-node/issues/259)) ([e5904f0](https://github.com/blockaid-official/blockaid-client-node/commit/e5904f098f9a5c82348d3db680e6136dac31e4c7))
+* **uploads:** avoid making redundant memory copies ([#251](https://github.com/blockaid-official/blockaid-client-node/issues/251)) ([8d73c25](https://github.com/blockaid-official/blockaid-client-node/commit/8d73c25281042ecc087f3f845ff29f9296ab2eec))
+
+
+### Chores
+
+* better object fallback behaviour for casting errors ([#255](https://github.com/blockaid-official/blockaid-client-node/issues/255)) ([f1e5a10](https://github.com/blockaid-official/blockaid-client-node/commit/f1e5a10672acf16bd2f4580c1a945e07655895b2))
+* better object fallback behaviour for casting errors ([#260](https://github.com/blockaid-official/blockaid-client-node/issues/260)) ([0b79ea3](https://github.com/blockaid-official/blockaid-client-node/commit/0b79ea32a1ff0fb6587131b817bc1ee137ecd34f))
+* **internal:** codegen related update ([#252](https://github.com/blockaid-official/blockaid-client-node/issues/252)) ([bc00dce](https://github.com/blockaid-official/blockaid-client-node/commit/bc00dced8522b301e37523812f7783de262ee931))
+* **internal:** codegen related update ([#253](https://github.com/blockaid-official/blockaid-client-node/issues/253)) ([b56587a](https://github.com/blockaid-official/blockaid-client-node/commit/b56587a1ab78278e37ea00070e81a734f53b97a6))
+* **internal:** codegen related update ([#257](https://github.com/blockaid-official/blockaid-client-node/issues/257)) ([5f37e23](https://github.com/blockaid-official/blockaid-client-node/commit/5f37e2307816bb164e5cea7f224ff26e011d4450))
+* **internal:** codegen related update ([#258](https://github.com/blockaid-official/blockaid-client-node/issues/258)) ([d7c64c3](https://github.com/blockaid-official/blockaid-client-node/commit/d7c64c33362d42a352fd4cc4b7b64be0ab8c7e11))
+* **internal:** dependency updates ([#247](https://github.com/blockaid-official/blockaid-client-node/issues/247)) ([7778143](https://github.com/blockaid-official/blockaid-client-node/commit/7778143ec32ad729237c022271b0b43993f8e94e))
+
## 0.25.0 (2024-09-01)
Full Changelog: [v0.24.0...v0.25.0](https://github.com/blockaid-official/blockaid-client-node/compare/v0.24.0...v0.25.0)
diff --git a/package.json b/package.json
index 17876f7..18810bd 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "@blockaid/client",
- "version": "0.25.0",
+ "version": "0.26.0",
"description": "The official TypeScript library for the Blockaid API",
"author": "Blockaid ",
"types": "dist/index.d.ts",
diff --git a/src/version.ts b/src/version.ts
index 4931d4f..aa25151 100644
--- a/src/version.ts
+++ b/src/version.ts
@@ -1 +1 @@
-export const VERSION = '0.25.0'; // x-release-please-version
+export const VERSION = '0.26.0'; // x-release-please-version