Skip to main content

TravelRule

Struct TravelRule 

Source
pub struct TravelRule {
    pub beneficiary: Option<TravelRuleBeneficiary>,
    pub is_intermediary: Option<bool>,
    pub is_self: Option<bool>,
    pub originator: Option<TravelRuleOriginator>,
}
Expand description

Required Travel Rule fields differ by region. These requirements are determined based on which Coinbase entity the customer has signed the service agreement for.

JSON schema
{
 "description": "Required Travel Rule fields differ by region. These requirements are determined based on which Coinbase entity the customer has signed the service agreement for.",
 "examples": [
   {
     "beneficiary": {
       "address": {
         "city": "Paris",
         "countryCode": "FR",
         "line1": "456 Oak Ave",
         "postCode": "75001"
       },
       "name": "Jane Smith",
       "walletType": "custodial"
     },
     "isIntermediary": true,
     "isSelf": false,
     "originator": {
       "address": {
         "city": "Luxembourg",
         "countryCode": "LU",
         "line1": "123 Main St",
         "line2": "Unit 201",
         "postCode": "L-1234"
       },
       "financialInstitution": "PayPal, Inc.",
       "name": "John Doe",
       "vasp": {
         "address": {
           "city": "San Francisco",
           "countryCode": "US",
           "line1": "123 Market St",
           "line2": "Suite 400",
           "postCode": "94105",
           "state": "California"
         },
         "identifier": "5493001KJTIIGC8Y1R17",
         "name": "Fidelity Digital Asset Services, LLC"
       }
     }
   }
 ],
 "type": "object",
 "properties": {
   "beneficiary": {
     "$ref": "#/components/schemas/TravelRuleBeneficiary"
   },
   "isIntermediary": {
     "description": "Indicates whether Coinbase is being used as an intermediary Virtual Asset Service Provider (VASP) to send crypto on behalf of your customer.\n\n**Background:**\n\nThe Travel Rule (FATF Recommendation 16) requires VASPs to share originator and beneficiary information for virtual asset transfers. When Coinbase acts as an intermediary, additional Travel Rule data must be provided to satisfy compliance requirements.\n\n**Set to `true` when:**\n\n- Your organization is a VASP using Coinbase to send crypto **on behalf of your end customer**\n- In this scenario, Coinbase acts as an intermediary in the transfer chain and handles Travel Rule data exchange with the beneficiary VASP\n\n**Set to `false` (or omit) when:**\n\n- You are transferring funds directly from your own Coinbase account, where **Coinbase is your primary VASP** rather than an intermediary for another institution\n\n**Impact on required fields:**\n\nWhen `isIntermediary` is `true`, you must provide the `originator` object with details about the original sender, including:\n- Originator name\n- Originator address\n- Your VASP information (`virtualAssetServiceProvider` object with `name`, `address`, and `identifier`)\n",
     "examples": [
       true
     ],
     "type": "boolean"
   },
   "isSelf": {
     "description": "Indicates whether the user attests that the receiving wallet belongs to them.",
     "examples": [
       true
     ],
     "type": "boolean"
   },
   "originator": {
     "$ref": "#/components/schemas/TravelRuleOriginator"
   }
 }
}

Fields§

§beneficiary: Option<TravelRuleBeneficiary>§is_intermediary: Option<bool>

Indicates whether Coinbase is being used as an intermediary Virtual Asset Service Provider (VASP) to send crypto on behalf of your customer.

    **Background:**

    The Travel Rule (FATF Recommendation 16) requires VASPs to share originator and beneficiary information for virtual asset transfers. When Coinbase acts as an intermediary, additional Travel Rule data must be provided to satisfy compliance requirements.

    **Set to `true` when:**

    - Your organization is a VASP using Coinbase to send crypto **on behalf of your end customer**
    - In this scenario, Coinbase acts as an intermediary in the transfer chain and handles Travel Rule data exchange with the beneficiary VASP

    **Set to `false` (or omit) when:**

    - You are transferring funds directly from your own Coinbase account, where **Coinbase is your primary VASP** rather than an intermediary for another institution

    **Impact on required fields:**

    When `isIntermediary` is `true`, you must provide the `originator` object with details about the original sender, including:
    - Originator name
    - Originator address
    - Your VASP information (`virtualAssetServiceProvider` object with `name`, `address`, and `identifier`)
§is_self: Option<bool>

Indicates whether the user attests that the receiving wallet belongs to them.

§originator: Option<TravelRuleOriginator>

Implementations§

Trait Implementations§

Source§

impl Clone for TravelRule

Source§

fn clone(&self) -> TravelRule

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for TravelRule

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for TravelRule

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for TravelRule

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl From<&TravelRule> for TravelRule

Source§

fn from(value: &TravelRule) -> Self

Converts to this type from the input type.
Source§

impl From<TravelRule> for TravelRule

Source§

fn from(value: TravelRule) -> Self

Converts to this type from the input type.
Source§

impl Serialize for TravelRule

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl TryFrom<TravelRule> for TravelRule

Source§

type Error = ConversionError

The type returned in the event of a conversion error.
Source§

fn try_from(value: TravelRule) -> Result<Self, ConversionError>

Performs the conversion.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,