We will sunset v2 of the Content API on March 29th, 2021. To avoid disruptions with your integration, please migrate to v2.1 as soon as possible. For more information, see Migrating to v2.1.

REST Resource: ordertrackingsignals

Resource: OrderTrackingSignal

Represents a merchant trade from which signals are extracted, e.g. shipping.

JSON representation
{
  "orderTrackingSignalId": string,
  "merchantId": string,
  "orderCreatedTime": {
    object (DateTime)
  },
  "orderId": string,
  "shippingInfo": [
    {
      object (ShippingInfo)
    }
  ],
  "lineItems": [
    {
      object (LineItemDetails)
    }
  ],
  "shipmentLineItemMapping": [
    {
      object (ShipmentLineItemMapping)
    }
  ],
  "customerShippingFee": {
    object (PriceAmount)
  },
  "deliveryPostalCode": string,
  "deliveryRegionCode": string
}
Fields
orderTrackingSignalId

string (int64 format)

Output only. The ID that uniquely identifies this order tracking signal.

merchantId

string (int64 format)

The Google merchant ID of this order tracking signal. This value is optional. If left unset, the caller's merchant ID is used. You must request access in order to provide data on behalf of another merchant. For more information, see Submitting Order Tracking Signals.

orderCreatedTime

object (DateTime)

Required. The time when the order was created on the merchant side. Include the year and timezone string, if available.

orderId

string

Required. The ID of the order on the merchant side.

shippingInfo[]

object (ShippingInfo)

The shipping information for the order.

lineItems[]

object (LineItemDetails)

Information about line items in the order.

shipmentLineItemMapping[]

object (ShipmentLineItemMapping)

The mapping of the line items to the shipment information.

customerShippingFee

object (PriceAmount)

The shipping fee of the order; this value should be set to zero in the case of free shipping.

deliveryPostalCode

string

Required. The delivery postal code, as a continuous string without spaces or dashes, e.g. "95016".

deliveryRegionCode

string

Required. The CLDR territory code for the shipping destination.

DateTime

Represents civil time (or occasionally physical time).

This type can represent a civil time in one of a few possible ways:

  • When utcOffset is set and timeZone is unset: a civil time on a calendar day with a particular offset from UTC.
  • When timeZone is set and utcOffset is unset: a civil time on a calendar day in a particular time zone.
  • When neither timeZone nor utcOffset is set: a civil time on a calendar day in local time.

The date is relative to the Proleptic Gregorian Calendar.

If year is 0, the DateTime is considered not to have a specific year. month and day must have valid, non-zero values.

This type may also be used to represent a physical time if all the date and time fields are set and either case of the time_offset oneof is set. Consider using Timestamp message for physical time instead. If your use case also would like to store the user's timezone, that can be done in another field.

This type is more flexible than some applications may want. Make sure to document and validate your application's limitations.

JSON representation
{
  "year": integer,
  "month": integer,
  "day": integer,
  "hours": integer,
  "minutes": integer,
  "seconds": integer,
  "nanos": integer,

  // Union field time_offset can be only one of the following:
  "utcOffset": string,
  "timeZone": {
    object (TimeZone)
  }
  // End of list of possible types for union field time_offset.
}
Fields
year

integer

Optional. Year of date. Must be from 1 to 9999, or 0 if specifying a datetime without a year.

month

integer

Required. Month of year. Must be from 1 to 12.

day

integer

Required. Day of month. Must be from 1 to 31 and valid for the year and month.

hours

integer

Required. Hours of day in 24 hour format. Should be from 0 to 23. An API may choose to allow the value "24:00:00" for scenarios like business closing time.

minutes

integer

Required. Minutes of hour of day. Must be from 0 to 59.

seconds

integer

Required. Seconds of minutes of the time. Must normally be from 0 to 59. An API may allow the value 60 if it allows leap-seconds.

nanos

integer

Required. Fractions of seconds in nanoseconds. Must be from 0 to 999,999,999.

Union field time_offset. Optional. Specifies either the UTC offset or the time zone of the DateTime. Choose carefully between them, considering that time zone data may change in the future (for example, a country modifies their DST start/end dates, and future DateTimes in the affected range had already been stored). If omitted, the DateTime is considered to be in local time. time_offset can be only one of the following:
utcOffset

string (Duration format)

UTC offset. Must be whole seconds, between -18 hours and +18 hours. For example, a UTC offset of -4:00 would be represented as { seconds: -14400 }.

A duration in seconds with up to nine fractional digits, terminated by 's'. Example: "3.5s".

timeZone

object (TimeZone)

Time zone.

TimeZone

Represents a time zone from the IANA Time Zone Database.

JSON representation
{
  "id": string,
  "version": string
}
Fields
id

string

IANA Time Zone Database time zone, e.g. "America/New_York".

version

string

Optional. IANA Time Zone Database version number, e.g. "2019a".

ShippingInfo

The shipping information for the order.

JSON representation
{
  "shipmentId": string,
  "trackingId": string,
  "carrierName": string,
  "carrierServiceName": string,
  "shippedTime": {
    object (DateTime)
  },
  "earliestDeliveryPromiseTime": {
    object (DateTime)
  },
  "latestDeliveryPromiseTime": {
    object (DateTime)
  },
  "actualDeliveryTime": {
    object (DateTime)
  },
  "shippingStatus": enum (ShippingState),
  "originPostalCode": string,
  "originRegionCode": string
}
Fields
shipmentId

string

Required. The shipment ID.

trackingId

string

The tracking ID of the shipment. This field is required if one of the following fields is absent: earliestDeliveryPromiseTime, latestDeliveryPromiseTime, and actualDeliveryTime.

carrierName

string

The name of the shipping carrier for the delivery. This field is required if one of the following fields is absent: earliestDeliveryPromiseTime, latestDeliveryPromiseTime, and actualDeliveryTime.

carrierServiceName

string

The service type for fulfillment, e.g., GROUND, FIRST_CLASS, etc.

shippedTime

object (DateTime)

The time when the shipment was shipped. Include the year and timezone string, if available.

earliestDeliveryPromiseTime

object (DateTime)

The earliest delivery promised time. Include the year and timezone string, if available. This field is required, if one of the following fields is absent: trackingId or carrierName.

latestDeliveryPromiseTime

object (DateTime)

The latest delivery promised time. Include the year and timezone string, if available. This field is required, if one of the following fields is absent: trackingId or carrierName.

actualDeliveryTime

object (DateTime)

The time when the shipment was actually delivered. Include the year and timezone string, if available. This field is required, if one of the following fields is absent: trackingId or carrierName.

shippingStatus

enum (ShippingState)

The status of the shipment.

originPostalCode

string

The origin postal code, as a continuous string without spaces or dashes, e.g. "95016".

originRegionCode

string

The CLDR territory code for the shipping origin.

ShippingState

The current status of the shipments.

Enums
SHIPPING_STATE_UNSPECIFIED The shipping status is not known to merchant.
SHIPPED All items are shipped.
DELIVERED The shipment is already delivered.

LineItemDetails

The line items of the order.

JSON representation
{
  "lineItemId": string,
  "productId": string,
  "gtin": string,
  "mpn": string,
  "quantity": string
}
Fields
lineItemId

string

Required. The ID for this line item.

productId

string

Required. The Content API REST ID of the product, in the form channel:contentLanguage:targetCountry:offerId.

gtin

string

The Global Trade Item Number.

mpn

string

The manufacturer part number.

quantity

string (int64 format)

Required. The quantity of the line item in the order.

ShipmentLineItemMapping

Represents how many items are in the shipment for the given shipmentId and lineItemId.

JSON representation
{
  "shipmentId": string,
  "lineItemId": string,
  "quantity": string
}
Fields
shipmentId

string

Required. The shipment ID.

lineItemId

string

Required. The line item ID.

quantity

string (int64 format)

Required. The line item quantity in the shipment.

PriceAmount

The price represented as a number and currency.

JSON representation
{
  "value": string,
  "currency": string
}
Fields
value

string

The price represented as a number.

currency

string

The currency of the price.

Methods

create

Creates new order tracking signal.