The unique identifier for an object. This ID must be unique across all objects from an issuer. This value should follow the format issuer ID. identifier where the former is issued by Google and latter is chosen by you. Your unique identifier should only include alphanumeric characters, '.', '_', or '-'.
Body Params application/json
appLinkData
object (AppLinkData)Â
optional
Optional information about the partner app link.
androidAppLinkInfo
object (AppLinkDataAppLinkInfo)Â
optional
Optional information about the partner app link. If included, the app link link module will be rendered on the valuable details on the android client.
iosAppLinkInfo
object (AppLinkDataAppLinkInfo)Â
optional
Optional information about the partner app link. If included, the app link link module will be rendered on the valuable details on the ios client.
webAppLinkInfo
object (AppLinkDataAppLinkInfo)Â
optional
Optional information about the partner app link. If included, the app link link module will be rendered on the valuable details on the web client.
barcode
object (Barcode)Â
optional
The barcode type and value.
alternateText
stringÂ
optional
An optional text that will override the default text that shows under the barcode. This field is intended for a human readable equivalent of the barcode value, used when the barcode cannot be scanned.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#barcode".
renderEncoding
enum<string>Â
optional
The render encoding for the barcode. When specified, barcode is rendered in the given encoding. Otherwise best known encoding is chosen by Google.
Allowed values:
RENDER_ENCODING_UNSPECIFIEDUTF_8
showCodeText
object (LocalizedString)Â
optional
Optional text that will be shown when the barcode is hidden behind a click action. This happens in cases where a pass has Smart Tap enabled. If not specified, a default is chosen by Google.
Required. The class associated with this object. The class must be of the same type as this object, must already exist, and must be approved. Class IDs should follow the format issuer ID.identifier where the former is issued by Google and latter is chosen by you.
classReference
object (OfferClass)Â
optional
A copy of the inherited fields of the parent class. These fields are retrieved during a GET.
allowMultipleUsersPerObject
booleanÂ
optional
Deprecated. Use multipleDevicesAndHoldersAllowedStatus instead.
callbackOptions
object (CallbackOptions)Â
optional
Callback options to be used to call the issuer back for every save/delete of an object for this class by the end-user. All objects of this class are eligible for the callback.
classTemplateInfo
object (ClassTemplateInfo)Â
optional
Template information about how the class should be displayed. If unset, Google will fallback to a default set of fields to display.
countryCode
stringÂ
optional
Country code used to display the card's country (when the user is not in that country), as well as to display localized content when content is not available in the user's locale.
details
stringÂ
optional
The details of the offer.
enableSmartTap
booleanÂ
optional
Available only to Smart Tap enabled partners. Contact support for additional guidance.
finePrint
stringÂ
optional
The fine print or terms of the offer, such as "20% off any t-shirt at Adam's Apparel."
helpUri
object (Uri)Â
optional
The help link for the offer, such as http://myownpersonaldomain.com/help
heroImage
object (Image)Â
optional
Optional banner image displayed on the front of the card. If none is present, nothing will be displayed. The image will display at 100% width.
hexBackgroundColor
stringÂ
optional
The background color for the card. If not set the dominant color of the hero image is used, and if no hero image is set, the dominant color of the logo is used. The format is #rrggbb where rrggbb is a hex RGB triplet, such as #ffcc00. You can also use the shorthand version of the RGB triplet which is #rgb, such as #fc0.
homepageUri
object (Uri)Â
optional
The URI of your application's home page. Populating the URI in this field results in the exact same behavior as populating an URI in linksModuleData (when an object is rendered, a link to the homepage is shown in what would usually be thought of as the linksModuleData section of the object).
id
stringÂ
optional
Required. The unique identifier for a class. This ID must be unique across all classes from an issuer. This value should follow the format issuer ID. identifier where the former is issued by Google and latter is chosen by you. Your unique identifier should only include alphanumeric characters, '.', '_', or '-'.
imageModulesData
array[object (ImageModuleData) {2}]Â
optional
Image module data. The maximum number of these fields displayed is 1 from object level and 1 for class object level.
infoModuleData
object (InfoModuleData)Â
optional
Deprecated. Use textModulesData instead.
issuerName
stringÂ
optional
Required. The issuer name. Recommended maximum length is 20 characters to ensure full string is displayed on smaller screens.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#offerClass".
linksModuleData
object (LinksModuleData)Â
optional
Links module data. If links module data is also defined on the object, both will be displayed.
localizedDetails
object (LocalizedString)Â
optional
Translated strings for the details.
localizedFinePrint
object (LocalizedString)Â
optional
Translated strings for the fine_print.
localizedIssuerName
object (LocalizedString)Â
optional
Translated strings for the issuer_name. Recommended maximum length is 20 characters to ensure full string is displayed on smaller screens.
localizedProvider
object (LocalizedString)Â
optional
Translated strings for the provider. Recommended maximum length is 12 characters to ensure full string is displayed on smaller screens.
localizedShortTitle
object (LocalizedString)Â
optional
Translated strings for the short title. Recommended maximum length is 20 characters.
localizedTitle
object (LocalizedString)Â
optional
Translated strings for the title. Recommended maximum length is 60 characters to ensure full string is displayed on smaller screens.
locations
array[object (LatLongPoint) {3}]Â
optional
The list of locations where the object can be used. The platform uses this information to trigger geolocated notifications to users. Note that locations in the object override locations in the class which override locations in the Google Places ID.
messages
array[object (Message) {8}]Â
optional
An array of messages displayed in the app. All users of this object will receive its associated messages. The maximum number of these fields is 10.
multipleDevicesAndHoldersAllowedStatus
enum<string>Â
optional
Identifies whether multiple users and devices will save the same object referencing this class.
Required. The offer provider (either the aggregator name or merchant name). Recommended maximum length is 12 characters to ensure full string is displayed on smaller screens.
redemptionChannel
enum<string>Â
optional
Required. The redemption channels applicable to this offer.
Available only to Smart Tap enabled partners. Contact support for additional guidance.
review
object (Review)Â
optional
The review comments set by the platform when a class is marked approved or rejected.
reviewStatus
enum<string>Â
optional
Required. The status of the class. This field can be set to draft or The status of the class. This field can be set to draft or underReview using the insert, patch, or update API calls. Once the review state is changed from draft it may not be changed back to draft. You should keep this field to draft when the class is under development. A draft class cannot be used to create any object. You should set this field to underReview when you believe the class is ready for use. The platform will automatically set this field to approved and it can be immediately used to create or migrate objects. When updating an already approved class you should keep setting this field to underReview.
A shortened version of the title of the offer, such as "20% off," shown to users as a quick reference to the offer contents. Recommended maximum length is 20 characters.
textModulesData
array[object (TextModuleData) {5}]Â
optional
Text module data. If text module data is also defined on the class, both will be displayed. The maximum number of these fields displayed is 10 from the object and 10 from the class.
title
stringÂ
optional
Required. The title of the offer, such as "20% off any t-shirt." Recommended maximum length is 60 characters to ensure full string is displayed on smaller screens.
titleImage
object (Image)Â
optional
The title image of the offer. This image is displayed in both the details and list views of the app.
version
string <int64>
optional
Deprecated
wordMark
object (Image)Â
optional
Deprecated.
disableExpirationNotification
booleanÂ
optional
Indicates if notifications should explicitly be suppressed. If this field is set to true, regardless of the messages field, expiration notifications to the user will be suppressed. By default, this field is set to false. Currently, this can only be set for offers.
hasLinkedDevice
booleanÂ
optional
Whether this object is currently linked to a single device. This field is set by the platform when a user saves the object, linking it to their device. Intended for use by select partners. Contact support for additional information.
hasUsers
booleanÂ
optional
Indicates if the object has users. This field is set by the platform.
heroImage
object (Image)Â
optional
Optional banner image displayed on the front of the card. If none is present, hero image of the class, if present, will be displayed. If hero image of the class is also not present, nothing will be displayed.
id
stringÂ
optional
Required. The unique identifier for an object. This ID must be unique across all objects from an issuer. This value should follow the format issuer ID.identifier where the former is issued by Google and latter is chosen by you. The unique identifier should only include alphanumeric characters, '.', '_', or '-'.
imageModulesData
array[object (ImageModuleData) {2}]Â
optional
Image module data. The maximum number of these fields displayed is 1 from object level and 1 for class object level.
id
stringÂ
optional
The ID associated with an image module. This field is here to enable ease of management of image modules.
mainImage
object (Image)Â
optional
A 100% width image.
infoModuleData
object (InfoModuleData)Â
optional
Deprecated. Use textModulesData instead.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#offerObject".
linksModuleData
object (LinksModuleData)Â
optional
Links module data. If links module data is also defined on the class, both will be displayed.
locations
array[object (LatLongPoint) {3}]Â
optional
The list of locations where the object can be used. The platform uses this information to trigger geolocated notifications to users. Note that locations in the object override locations in the class which override locations in the Google Places ID.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#latLongPoint".
latitude
number <double>
optional
The latitude specified as any value in the range of -90.0 through +90.0, both inclusive. Values outside these bounds will be rejected.
longitude
number <double>
optional
The longitude specified in the range -180.0 through +180.0, both inclusive. Values outside these bounds will be rejected.
messages
array[object (Message) {8}]Â
optional
An array of messages displayed in the app. All users of this object will receive its associated messages. The maximum number of these fields is 10.
body
stringÂ
optional
The message body.
displayInterval
object (TimeInterval)Â
optional
The period of time that the message will be displayed to users. You can define both a startTime and endTime for each message. A message is displayed immediately after a Wallet Object is inserted unless a startTime is set. The message will appear in a list of messages indefinitely if endTime is not provided.
header
stringÂ
optional
The message header.
id
stringÂ
optional
The ID associated with a message. This field is here to enable ease of management of messages. Notice ID values could possibly duplicate across multiple messages in the same class/instance, and care must be taken to select a reasonable ID for each message.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#walletObjectMessage".
localizedBody
object (LocalizedString)Â
optional
Translated strings for the message body.
localizedHeader
object (LocalizedString)Â
optional
Translated strings for the message header.
messageType
enum<string>Â
optional
The type of the message. Currently, this can only be set for offers.
Available only to Smart Tap enabled partners. Contact support for additional guidance.
state
enum<string>Â
optional
Required. The state of the object. This field is used to determine how an object is displayed in the app. For example, an inactive object is moved to the "Expired passes" section.
Text module data. If text module data is also defined on the class, both will be displayed. The maximum number of these fields displayed is 10 from the object and 10 from the class.
body
stringÂ
optional
The body of the Text Module, which is defined as an uninterrupted string. Recommended maximum length is 500 characters to ensure full string is displayed on smaller screens.
header
stringÂ
optional
The header of the Text Module. Recommended maximum length is 35 characters to ensure full string is displayed on smaller screens.
id
stringÂ
optional
The ID associated with a text module. This field is here to enable ease of management of text modules.
localizedBody
object (LocalizedString)Â
optional
Translated strings for the body. Recommended maximum length is 500 characters to ensure full string is displayed on smaller screens.
localizedHeader
object (LocalizedString)Â
optional
Translated strings for the header. Recommended maximum length is 35 characters to ensure full string is displayed on smaller screens.
validTimeInterval
object (TimeInterval)Â
optional
The time period this object will be active and object can be used. An object's state will be changed to expired when this time period has passed.
version
string <int64>
optional
Deprecated
Examples
Responses
🟢200Successful response
application/json
Body
appLinkData
object (AppLinkData)Â
optional
Optional information about the partner app link.
androidAppLinkInfo
object (AppLinkDataAppLinkInfo)Â
optional
Optional information about the partner app link. If included, the app link link module will be rendered on the valuable details on the android client.
iosAppLinkInfo
object (AppLinkDataAppLinkInfo)Â
optional
Optional information about the partner app link. If included, the app link link module will be rendered on the valuable details on the ios client.
webAppLinkInfo
object (AppLinkDataAppLinkInfo)Â
optional
Optional information about the partner app link. If included, the app link link module will be rendered on the valuable details on the web client.
barcode
object (Barcode)Â
optional
The barcode type and value.
alternateText
stringÂ
optional
An optional text that will override the default text that shows under the barcode. This field is intended for a human readable equivalent of the barcode value, used when the barcode cannot be scanned.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#barcode".
renderEncoding
enum<string>Â
optional
The render encoding for the barcode. When specified, barcode is rendered in the given encoding. Otherwise best known encoding is chosen by Google.
Allowed values:
RENDER_ENCODING_UNSPECIFIEDUTF_8
showCodeText
object (LocalizedString)Â
optional
Optional text that will be shown when the barcode is hidden behind a click action. This happens in cases where a pass has Smart Tap enabled. If not specified, a default is chosen by Google.
Required. The class associated with this object. The class must be of the same type as this object, must already exist, and must be approved. Class IDs should follow the format issuer ID.identifier where the former is issued by Google and latter is chosen by you.
classReference
object (OfferClass)Â
optional
A copy of the inherited fields of the parent class. These fields are retrieved during a GET.
allowMultipleUsersPerObject
booleanÂ
optional
Deprecated. Use multipleDevicesAndHoldersAllowedStatus instead.
callbackOptions
object (CallbackOptions)Â
optional
Callback options to be used to call the issuer back for every save/delete of an object for this class by the end-user. All objects of this class are eligible for the callback.
classTemplateInfo
object (ClassTemplateInfo)Â
optional
Template information about how the class should be displayed. If unset, Google will fallback to a default set of fields to display.
countryCode
stringÂ
optional
Country code used to display the card's country (when the user is not in that country), as well as to display localized content when content is not available in the user's locale.
details
stringÂ
optional
The details of the offer.
enableSmartTap
booleanÂ
optional
Available only to Smart Tap enabled partners. Contact support for additional guidance.
finePrint
stringÂ
optional
The fine print or terms of the offer, such as "20% off any t-shirt at Adam's Apparel."
helpUri
object (Uri)Â
optional
The help link for the offer, such as http://myownpersonaldomain.com/help
heroImage
object (Image)Â
optional
Optional banner image displayed on the front of the card. If none is present, nothing will be displayed. The image will display at 100% width.
hexBackgroundColor
stringÂ
optional
The background color for the card. If not set the dominant color of the hero image is used, and if no hero image is set, the dominant color of the logo is used. The format is #rrggbb where rrggbb is a hex RGB triplet, such as #ffcc00. You can also use the shorthand version of the RGB triplet which is #rgb, such as #fc0.
homepageUri
object (Uri)Â
optional
The URI of your application's home page. Populating the URI in this field results in the exact same behavior as populating an URI in linksModuleData (when an object is rendered, a link to the homepage is shown in what would usually be thought of as the linksModuleData section of the object).
id
stringÂ
optional
Required. The unique identifier for a class. This ID must be unique across all classes from an issuer. This value should follow the format issuer ID. identifier where the former is issued by Google and latter is chosen by you. Your unique identifier should only include alphanumeric characters, '.', '_', or '-'.
imageModulesData
array[object (ImageModuleData) {2}]Â
optional
Image module data. The maximum number of these fields displayed is 1 from object level and 1 for class object level.
infoModuleData
object (InfoModuleData)Â
optional
Deprecated. Use textModulesData instead.
issuerName
stringÂ
optional
Required. The issuer name. Recommended maximum length is 20 characters to ensure full string is displayed on smaller screens.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#offerClass".
linksModuleData
object (LinksModuleData)Â
optional
Links module data. If links module data is also defined on the object, both will be displayed.
localizedDetails
object (LocalizedString)Â
optional
Translated strings for the details.
localizedFinePrint
object (LocalizedString)Â
optional
Translated strings for the fine_print.
localizedIssuerName
object (LocalizedString)Â
optional
Translated strings for the issuer_name. Recommended maximum length is 20 characters to ensure full string is displayed on smaller screens.
localizedProvider
object (LocalizedString)Â
optional
Translated strings for the provider. Recommended maximum length is 12 characters to ensure full string is displayed on smaller screens.
localizedShortTitle
object (LocalizedString)Â
optional
Translated strings for the short title. Recommended maximum length is 20 characters.
localizedTitle
object (LocalizedString)Â
optional
Translated strings for the title. Recommended maximum length is 60 characters to ensure full string is displayed on smaller screens.
locations
array[object (LatLongPoint) {3}]Â
optional
The list of locations where the object can be used. The platform uses this information to trigger geolocated notifications to users. Note that locations in the object override locations in the class which override locations in the Google Places ID.
messages
array[object (Message) {8}]Â
optional
An array of messages displayed in the app. All users of this object will receive its associated messages. The maximum number of these fields is 10.
multipleDevicesAndHoldersAllowedStatus
enum<string>Â
optional
Identifies whether multiple users and devices will save the same object referencing this class.
Required. The offer provider (either the aggregator name or merchant name). Recommended maximum length is 12 characters to ensure full string is displayed on smaller screens.
redemptionChannel
enum<string>Â
optional
Required. The redemption channels applicable to this offer.
Available only to Smart Tap enabled partners. Contact support for additional guidance.
review
object (Review)Â
optional
The review comments set by the platform when a class is marked approved or rejected.
reviewStatus
enum<string>Â
optional
Required. The status of the class. This field can be set to draft or The status of the class. This field can be set to draft or underReview using the insert, patch, or update API calls. Once the review state is changed from draft it may not be changed back to draft. You should keep this field to draft when the class is under development. A draft class cannot be used to create any object. You should set this field to underReview when you believe the class is ready for use. The platform will automatically set this field to approved and it can be immediately used to create or migrate objects. When updating an already approved class you should keep setting this field to underReview.
A shortened version of the title of the offer, such as "20% off," shown to users as a quick reference to the offer contents. Recommended maximum length is 20 characters.
textModulesData
array[object (TextModuleData) {5}]Â
optional
Text module data. If text module data is also defined on the class, both will be displayed. The maximum number of these fields displayed is 10 from the object and 10 from the class.
title
stringÂ
optional
Required. The title of the offer, such as "20% off any t-shirt." Recommended maximum length is 60 characters to ensure full string is displayed on smaller screens.
titleImage
object (Image)Â
optional
The title image of the offer. This image is displayed in both the details and list views of the app.
version
string <int64>
optional
Deprecated
wordMark
object (Image)Â
optional
Deprecated.
disableExpirationNotification
booleanÂ
optional
Indicates if notifications should explicitly be suppressed. If this field is set to true, regardless of the messages field, expiration notifications to the user will be suppressed. By default, this field is set to false. Currently, this can only be set for offers.
hasLinkedDevice
booleanÂ
optional
Whether this object is currently linked to a single device. This field is set by the platform when a user saves the object, linking it to their device. Intended for use by select partners. Contact support for additional information.
hasUsers
booleanÂ
optional
Indicates if the object has users. This field is set by the platform.
heroImage
object (Image)Â
optional
Optional banner image displayed on the front of the card. If none is present, hero image of the class, if present, will be displayed. If hero image of the class is also not present, nothing will be displayed.
id
stringÂ
optional
Required. The unique identifier for an object. This ID must be unique across all objects from an issuer. This value should follow the format issuer ID.identifier where the former is issued by Google and latter is chosen by you. The unique identifier should only include alphanumeric characters, '.', '_', or '-'.
imageModulesData
array[object (ImageModuleData) {2}]Â
optional
Image module data. The maximum number of these fields displayed is 1 from object level and 1 for class object level.
id
stringÂ
optional
The ID associated with an image module. This field is here to enable ease of management of image modules.
mainImage
object (Image)Â
optional
A 100% width image.
infoModuleData
object (InfoModuleData)Â
optional
Deprecated. Use textModulesData instead.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#offerObject".
linksModuleData
object (LinksModuleData)Â
optional
Links module data. If links module data is also defined on the class, both will be displayed.
locations
array[object (LatLongPoint) {3}]Â
optional
The list of locations where the object can be used. The platform uses this information to trigger geolocated notifications to users. Note that locations in the object override locations in the class which override locations in the Google Places ID.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#latLongPoint".
latitude
number <double>
optional
The latitude specified as any value in the range of -90.0 through +90.0, both inclusive. Values outside these bounds will be rejected.
longitude
number <double>
optional
The longitude specified in the range -180.0 through +180.0, both inclusive. Values outside these bounds will be rejected.
messages
array[object (Message) {8}]Â
optional
An array of messages displayed in the app. All users of this object will receive its associated messages. The maximum number of these fields is 10.
body
stringÂ
optional
The message body.
displayInterval
object (TimeInterval)Â
optional
The period of time that the message will be displayed to users. You can define both a startTime and endTime for each message. A message is displayed immediately after a Wallet Object is inserted unless a startTime is set. The message will appear in a list of messages indefinitely if endTime is not provided.
header
stringÂ
optional
The message header.
id
stringÂ
optional
The ID associated with a message. This field is here to enable ease of management of messages. Notice ID values could possibly duplicate across multiple messages in the same class/instance, and care must be taken to select a reasonable ID for each message.
kind
stringÂ
optional
Identifies what kind of resource this is. Value: the fixed string "walletobjects#walletObjectMessage".
localizedBody
object (LocalizedString)Â
optional
Translated strings for the message body.
localizedHeader
object (LocalizedString)Â
optional
Translated strings for the message header.
messageType
enum<string>Â
optional
The type of the message. Currently, this can only be set for offers.
Available only to Smart Tap enabled partners. Contact support for additional guidance.
state
enum<string>Â
optional
Required. The state of the object. This field is used to determine how an object is displayed in the app. For example, an inactive object is moved to the "Expired passes" section.
Text module data. If text module data is also defined on the class, both will be displayed. The maximum number of these fields displayed is 10 from the object and 10 from the class.
body
stringÂ
optional
The body of the Text Module, which is defined as an uninterrupted string. Recommended maximum length is 500 characters to ensure full string is displayed on smaller screens.
header
stringÂ
optional
The header of the Text Module. Recommended maximum length is 35 characters to ensure full string is displayed on smaller screens.
id
stringÂ
optional
The ID associated with a text module. This field is here to enable ease of management of text modules.
localizedBody
object (LocalizedString)Â
optional
Translated strings for the body. Recommended maximum length is 500 characters to ensure full string is displayed on smaller screens.
localizedHeader
object (LocalizedString)Â
optional
Translated strings for the header. Recommended maximum length is 35 characters to ensure full string is displayed on smaller screens.
validTimeInterval
object (TimeInterval)Â
optional
The time period this object will be active and object can be used. An object's state will be changed to expired when this time period has passed.