pub struct CatalogCustomAttributeDefinition {
    pub type: CatalogCustomAttributeDefinitionType,
    pub name: String,
    pub description: Option<String>,
    pub source_application: Option<SourceApplication>,
    pub allowed_object_types: Vec<CatalogObjectType>,
    pub seller_visibility: Option<CatalogCustomAttributeDefinitionSellerVisibility>,
    pub app_visibility: Option<CatalogCustomAttributeDefinitionAppVisibility>,
    pub string_config: Option<CatalogCustomAttributeDefinitionStringConfig>,
    pub number_config: Option<CatalogCustomAttributeDefinitionNumberConfig>,
    pub selection_config: Option<CatalogCustomAttributeDefinitionSelectionConfig>,
    pub custom_attribute_usage_count: Option<i32>,
    pub key: Option<String>,
}
Expand description

Contains information defining a custom attribute.

Custom attributes are intended to store additional information about a catalog object or to associate a catalog object with an entity in another system. Do not use custom attributes to store any sensitive information (personally identifiable information, card details, etc.). Read more about custom attributes

Fields

type: CatalogCustomAttributeDefinitionType

The type of this custom attribute. Cannot be modified after creation. Required.

name: String

The name of this definition for API and seller-facing UI purposes. The name must be unique within the (merchant, application) pair. Required. May not be empty and may not exceed 255 characters. Can be modified after creation.

description: Option<String>

Seller-oriented description of the meaning of this Custom Attribute, any constraints that the seller should observe, etc. May be displayed as a tooltip in Square UIs.

source_application: Option<SourceApplication>

Read only. Contains information about the application that created this custom attribute definition.

allowed_object_types: Vec<CatalogObjectType>

The set of Catalog Object Types that this Custom Attribute may be applied to. Currently, only ITEM and ITEM_VARIATION are allowed. At least one type must be included.

seller_visibility: Option<CatalogCustomAttributeDefinitionSellerVisibility>

The visibility of a custom attribute in seller-facing UIs (including Square Point of Sale applications and Square Dashboard). May be modified.

app_visibility: Option<CatalogCustomAttributeDefinitionAppVisibility>

The visibility of a custom attribute to applications other than the application that created the attribute.

string_config: Option<CatalogCustomAttributeDefinitionStringConfig>

Optionally, populated when type = STRING, unset otherwise.

number_config: Option<CatalogCustomAttributeDefinitionNumberConfig>

Optionally, populated when type = NUMBER, unset otherwise.

selection_config: Option<CatalogCustomAttributeDefinitionSelectionConfig>

Populated when type is set to SELECTION, unset otherwise.

custom_attribute_usage_count: Option<i32>

Read-only. The number of custom attributes that reference this custom attribute definition. Set by the server in response to a ListCatalog request with include_counts set to true. If the actual count is greater than 100, custom_attribute_usage_count will be set to 100.

key: Option<String>

The name of the desired custom attribute key that can be used to access the custom attribute value on catalog objects. Cannot be modified after the custom attribute definition has been created. Must be between 1 and 60 characters, and may only contain the characters [a-zA-Z0-9_-].

Trait Implementations

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Returns the “default value” for a type. Read more
Deserialize this value from the given Serde deserializer. Read more
This method tests for self and other values to be equal, and is used by ==. Read more
This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason. Read more
Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more
Compare self to key and return true if they are equal.

Returns the argument unchanged.

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

Calls U::from(self).

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

The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.
Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more