pub struct X402DiscoveryResource {
pub accepts: Vec<X402PaymentRequirements>,
pub description: Option<String>,
pub extensions: Map<String, Value>,
pub icon_url: Option<Url>,
pub last_updated: Option<DateTime<Utc>>,
pub quality: Option<X402ResourceQuality>,
pub resource: String,
pub service_name: Option<String>,
pub tags: Vec<String>,
pub type_: X402DiscoveryResourceType,
pub x402_version: X402Version,
}Expand description
A single discovered x402 resource.
JSON schema
{
"description": "A single discovered x402 resource.",
"type": "object",
"required": [
"resource",
"type",
"x402Version"
],
"properties": {
"accepts": {
"description": "Payment requirements accepted by the resource.",
"examples": [
[
{
"amount": "1000000",
"asset": "0x036CbD53842c5426634e7929541eC2318f3dCF7e",
"maxTimeoutSeconds": 60,
"network": "eip155:8453",
"payTo": "0x742d35Cc6634C0532925a3b844Bc454e4438f44e",
"scheme": "exact"
}
]
],
"type": "array",
"items": {
"$ref": "#/components/schemas/x402PaymentRequirements"
}
},
"description": {
"description": "A human-readable description of the resource.",
"examples": [
"Real-time weather forecast data"
],
"type": "string"
},
"extensions": {
"description": "Map of x402 protocol extensions supported by the resource, keyed by extension name.",
"examples": [
{
"bazaar": {
"info": {
"input": {
"method": "GET",
"type": "http"
}
},
"schema": {}
}
}
],
"type": "object",
"additionalProperties": true
},
"iconUrl": {
"description": "URL of a square icon representing the service this resource belongs to. Distinct from a\nbrand logo: this is intended for compact, list-view rendering (favicon-style) and is\nnormalized to a square aspect ratio at ingestion. The image is moderated and re-hosted by\nCoinbase, so the URL is stable and safe to render directly in clients. Omitted when the\nprovider did not supply an icon, when the supplied icon failed moderation, or when image\nprocessing was unavailable at ingestion time.\n",
"examples": [
"https://res.cloudinary.com/bdb-prod/image/upload/..."
],
"allOf": [
{
"$ref": "#/components/schemas/Url"
}
]
},
"lastUpdated": {
"description": "Timestamp of the last update.",
"examples": [
"2024-01-15T10:30:00Z"
],
"type": "string",
"format": "date-time"
},
"quality": {
"$ref": "#/components/schemas/x402ResourceQuality"
},
"resource": {
"description": "The URL of the resource.",
"examples": [
"https://api.example.com/weather/forecast"
],
"type": "string"
},
"serviceName": {
"description": "Provider-supplied display name of the service this resource belongs to. This is a free-form\nlabel for grouping and presentation only — it is not a stable identifier, and two resources\nsharing the same `serviceName` are not guaranteed to belong to the same logical service.\n",
"examples": [
"Weather API"
],
"type": "string"
},
"tags": {
"description": "Provider-supplied, low-cardinality string labels associated with the resource for client-side\nfiltering and display. Values are free-form (no controlled vocabulary) and case-sensitive.\nOrder is not significant and duplicates are not expected.\n",
"examples": [
[
"weather",
"data"
]
],
"type": "array",
"items": {
"type": "string"
}
},
"type": {
"description": "Communication protocol (e.g., \"http\", \"mcp\").",
"examples": [
"http"
],
"type": "string",
"enum": [
"http",
"mcp"
]
},
"x402Version": {
"$ref": "#/components/schemas/X402Version"
}
}
}Fields§
§accepts: Vec<X402PaymentRequirements>Payment requirements accepted by the resource.
description: Option<String>A human-readable description of the resource.
extensions: Map<String, Value>Map of x402 protocol extensions supported by the resource, keyed by extension name.
icon_url: Option<Url>URL of a square icon representing the service this resource belongs to. Distinct from a brand logo: this is intended for compact, list-view rendering (favicon-style) and is normalized to a square aspect ratio at ingestion. The image is moderated and re-hosted by Coinbase, so the URL is stable and safe to render directly in clients. Omitted when the provider did not supply an icon, when the supplied icon failed moderation, or when image processing was unavailable at ingestion time.
last_updated: Option<DateTime<Utc>>Timestamp of the last update.
quality: Option<X402ResourceQuality>§resource: StringThe URL of the resource.
service_name: Option<String>Provider-supplied display name of the service this resource belongs to. This is a free-form
label for grouping and presentation only — it is not a stable identifier, and two resources
sharing the same serviceName are not guaranteed to belong to the same logical service.
Provider-supplied, low-cardinality string labels associated with the resource for client-side filtering and display. Values are free-form (no controlled vocabulary) and case-sensitive. Order is not significant and duplicates are not expected.
type_: X402DiscoveryResourceTypeCommunication protocol (e.g., “http”, “mcp”).
x402_version: X402VersionImplementations§
Source§impl X402DiscoveryResource
impl X402DiscoveryResource
pub fn builder() -> X402DiscoveryResource
Trait Implementations§
Source§impl Clone for X402DiscoveryResource
impl Clone for X402DiscoveryResource
Source§fn clone(&self) -> X402DiscoveryResource
fn clone(&self) -> X402DiscoveryResource
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more