collections.mp.microsoft.com/v9.0/collections/publisherQuery
PublisherQuery allows your own services to query a user's products and entitlements including their Xbox Game Pass subscription status. Your service should not regularly poll for user purchases to avoid call rate limits based on a per-user time window. Currently, the limit is 100 query requests within a five-minute window for the same user. Triggering a rate limit causes a 429 HTTP response with information about when the next request can be made.
For specific info on querying a user's Game Pass subscription status, see Detecting Xbox Game Pass subscription access from your service.
Note
PublisherQuery only supports calls from partner services. Client apps or games are not able to call this service directly.
Updates and improvements in PublisherQuery (Collections Query v9)
PublisherQuery is the latest version (v9) of the Collections Query API. If migrating from B2bLicensePreview (Collections v8), please review this document carefully.
PublisherQuery has the following changes and improvements over B2bLicensePreview:
- Ability to query for a user's Xbox Game Pass subscription status
- Requires a pre-defined list of products to return. This was a best practice, but not required with B2bLicensePreview. Titles who did not follow this best practice often had post-release issues where the request would time-out due to the large scope of content based on their query parameters. This prevented users from getting in-game credit until the game's service was updated to specify which ProductIds they wanted within the query request.
- Streamlined response data fields to remove unused or unnecessary values
- Streamlined request parameters based on developer feedback
Removed from the request body:
- Market - All requests will have context for all regions in PublisherQuery
- ExpandSatisfyingItems - All results will expand satisfying entitlements in PublisherQuery
- EntitlementsFilter - Not used as a pre-defined list of productIds of the query are required
Note
PublisherQuery does not support LegacyProductIds (ProductIds generated from the retired Xbox Developer Portal and used as ProductId from the Xbox Inventory service). If migrating your service from Xbox Inventory, you will need to internally map the StoreId (ProductId value from Collections) to the matching LegacyProductId on your own service. Otherwise, you can look at B2bLicensePreview which returns both StoreId and LegacyProductIds.
For more information see the corresponding article Selecting the right Collections Query API for your needs
Prerequisites
To call PublisherQuery, you need to use one of the following authentication type:
- A UserCollectionsID and a Service Access Token with an audience URI of
https://onestore.microsoft.com
- Delegated authorization XSTS token for the Relying Party
http://licensing.xboxlive.com
For more information, see Authenticating your service with the Microsoft Store APIs.
Additionally, the products that you want to be visible to your service require additional configuration in Partner Center based on which type of authentication your service is using to call the Collections service. See the following on how to properly configure your products in Partner Center:
Additional configuration required to view and manage products with a User Store ID / Microsoft Entra ID auth
Additional configuration required to view and manage products with delegated auth XSTS tokens
Note
If the product configuration has not been done and published through Partner Center, the calls to Collections will succeed but there will not be any results in the response.
Request
Request syntax
Method | Request URI |
---|---|
POST |
https://collections.mp.microsoft.com/v9.0/collections/publisherQuery |
Request header
Header | Type | Description |
---|---|---|
Authorization |
string |
Required. Either the delegated authorization XSTS token or the Microsoft Entra ID service access token based on authentication type being used. |
Signature |
string |
Required when authenticating with XSTS tokens. |
User-Agent |
string |
Recommended. Helps identify your service for logging and investigations. |
Host |
string |
Must be set to the value collections.mp.microsoft.com . |
Content-Length |
number |
The length of the request body. |
Content-Type |
string |
Specifies the request and response type. Currently, the only supported value is application/json . |
Request body
Parameter | Type | Description | Required |
---|---|---|---|
productSkuIds |
list<ProductSkuId> |
A list of the products to obtain results for. For more information, see the following table. | Yes |
continuationToken |
string |
If there are multiple sets of products that can't fit within maxPageSize , the response body returns a continuation token when the page limit is reached. Provide that continuation token in the subsequent call to retrieve the remaining products from the previous request's query. |
No |
maxPageSize |
number |
The maximum number of products to return in one response. The default is 100 and maximum value is 200 items per page. | No |
excludeDuplicates |
bool |
Removes duplicate entitlements where the user might be entitled to a single product from multiple sources. | No |
validityType |
string |
When set to All, all products for a user will be returned, including expired items. Valid returns products that have an active status, start date < now, and end date is > now). Invalid returns products that do not meet the requirements of the Valid option. | No |
sbx |
string |
Optional value for authenticating with UserStoreIds that specifies the Sandbox the results should be scoped to. Default without this value is the RETAIL sandbox. X-Token auth does not need this value as the Sandbox is specified within the X-Token. | No |
The ProductSkuId
object contains the following parameters.
Parameter | Type | Description | Required |
---|---|---|---|
productId |
string |
Also refereed to as the Store ID for the product within the Microsoft Store catalog. An example Store ID for a product is 9NBLGGH42CFD. | Yes |
skuId |
string |
The specific SKU identifier if there are multiple offerings of the product in the Microsoft Store catalog. An example Store ID for a SKU is 0010. | No |
Request example
Note
The default maxPageSize is 100, but for this example we set it to only 2. This will ensure that only 2 items are returned per request and we will get a continuationToken to show how to request the remaining items with a follow up request.
POST https://collections.mp.microsoft.com/v9.0/collections/PublisherQuery HTTP/1.1
Host: collections.mp.microsoft.com
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsIng1dCI6Imwzc1...
User-Agent: {identifier string of your service}
Content-Type: application/json; charset=utf-8
Content-Length: 2243
{
"maxPageSize":2,
"excludeDuplicates":true,
"productSkuIds":[
{"productId": "9N30KZZF4BR9"},
{"productId": "9MXL21XPWWWK"},
{"productId": "9PLRFWZWWF91"},
{"productId": "9MZ0MGGFPLTP"}
],
"beneficiaries": [
{
"identitytype": "b2b",
"identityValue": "eyJhbGciOiJSUzI1NiIsImtpZCI6IjYxNTI2OEI4N0YwNEFDQzIzRDdCQ0E2M...",
"localTicketReference": ""
}
],
"sbx":"XDKS.1",
}
Response
Response body
Parameter | Type | Description | Required |
---|---|---|---|
continuationToken |
string |
This token is returned when the page limit is reached. You can specify this continuation token in a subsequent calls to retrieve the remaining products. | No |
items |
PublisherQueryItemContractV9 |
An array of products for the specified user. For more information, see the following table. | No |
The PublisherQueryItemContractV9
object contains the following parameters.
Parameter | Type | Description | Required |
---|---|---|---|
acquiredDate |
datetime |
The date on which the user acquired the item. | Yes |
acquisitionType |
string |
Indicates how the user has this entitlement. For more information, see Product acquisitionType values and meaning. | No |
endDate |
datetime |
The end date of the item. | Yes |
id |
string |
An ID that identifies this collection item from other items that the user owns. This ID is unique per product. | Yes |
modifiedDate |
datetime |
The date that this item was last modified. With consumable products, this value changes when the user's quantity balance changes through an additional purchase of the consumable product or when a consume request is issued. | Yes |
productId |
string |
Also refereed to as the Store ID for the product within the Microsoft Store catalog. An example Store ID for a product is 9NBLGGH42CFD. | Yes |
productKind |
string |
Indicates the product type. For more information, see Product type values and meaning. | Yes |
quantity |
number |
The quantity of the item. For non-consumable products, this is always 1. For consumable products, this represents the remaining balance that can be consumed or fulfilled for the user. | No |
recurrenceId |
string |
ID of the item that can be used to key into recurrence management APIs | Yes |
satisfiedByProductIds |
list<string> |
If this product is entitled because of a bundle or subscription, the ProductIds of those parent products are provided here. |
No |
skuId |
string |
The specific SKU identifier if there are multiple offerings of the product in the Microsoft Store catalog. An example Store ID for a SKU is 0010. | Yes |
startDate |
datetime |
The date that the item starts being valid. | Yes |
status |
string |
The status of the item. For more information, see Product status values and meaning. | Yes |
tags |
string |
N/A. | Yes |
transactionId |
GUID |
The transaction ID as a result of the purchase of this item. Can be used for reporting an item as fulfilled. This value is the OrderID associated to when the user purchased the item. Should not be used as a unique identifier for this user's entitlement | No |
trialData |
TrialInformation |
Information about this product—if it's a trial and the time remaining. | Yes |
The TrialInformation
object contains the parameters that are shown in the following table.
Parameter | Type | Description | Required |
---|---|---|---|
isInTrialPeriod |
bool |
Indicates if the product is in a trial period, such as a subscription | Yes |
isTrial |
bool |
Indicates if this product is licensed through a trial | Yes |
trialTimeRemaining |
timespan |
Indicates the remaining time the trial is valid with the format of DD:HH:MM:SS.MS | No |
Product type values and meaning
Value | Description |
---|---|
Application |
An app within Microsoft Store that isn't listed as a game. |
Consumable |
A consumable product where the user's balance (or quantity) is kept and managed on the Collections service. On purchase, the quantity is added to the user's balance and can then be removed by performing a consume request. Users are able to purchase this type of consumable again without it being fulfilled first. |
Durable |
The downloadable content that's purchased once and owned until the product's end date. |
Game |
A base game product. |
Pass |
Some subscription types such as Game Pass |
UnmanagedConsumable |
A consumable product that when purchased must be fulfilled by the game or the game's service before the user can purchase the product again. |
'Pass' | A Store Managed Subscription. This is different than the add-on subscription type configured under an app's Add-ons page in Partner Center. |
Product status values and meaning
Value | Description |
---|---|
Active |
The product is actively entitled (including pre-ordered items). The user should have access to it. |
Revoked |
Most commonly indicates that the user requested a refund. |
Expired |
The product was part of an entitlement (usually a subscription) that has since expired. |
Banned |
N/A. |
Suspended |
N/A. |
Product acquisitionType values and meaning
Value | Description |
---|---|
Single |
Direct digital purchase or code redemption. |
Recurring |
Owned or entitled through a subscription. |
Conditional |
Owned but requires other products to continue use. Ex: Games With Gold obtained games |
Response example
HTTP/1.1 200 OK
Date: Wed, 10 Nov 2021 02:21:22 GMT
Content-Type: application/json; charset=utf-8
Content-Length: 1115
MS-CorrelationId: d46cbd11-c2cf-4d8b-99b3-ea63ea976f39
MS-RequestId: 76b82179-2c83-41b2-b9f7-6e775f2c0fed
MS-CV: zpiOM+izH0iubCuw.0
{
"continuationToken": "{\"checkSatisfactionIndex\":2}",
"items": [
{
"acquiredDate": "2021-08-30T21:53:08.2565331+00:00",
"acquisitionType": "Single",
"endDate": "2021-08-31T21:53:07.4374279+00:00",
"id": "1046015f83a8478397064c915224e5d3",
"modifiedDate": "2021-08-30T21:53:08.2589804+00:00",
"productId": "9N30KZZF4BR9",
"productKind": "Durable",
"quantity": 1,
"satisfiedByProductIds": [],
"skuId": "0010",
"startDate": "2021-08-30T21:53:07.4374279+00:00",
"status": "Active",
"tags": [],
"transactionId": "995ec667-8114-4ab9-9f11-597a8419a775",
"trialData": {
"isInTrialPeriod": false,
"isTrial": false
}
},
{
"acquiredDate": "2021-08-30T19:55:44.7994325+00:00",
"acquisitionType": "Single",
"endDate": "9999-12-31T23:59:59.9999999+00:00",
"id": "27662ad4749342608ec09130b76601f9",
"modifiedDate": "2021-08-30T19:55:44.8043849+00:00",
"productId": "9MXL21XPWWWK",
"productKind": "Game",
"quantity": 1,
"satisfiedByProductIds": [],
"skuId": "0010",
"startDate": "2021-08-30T19:40:44.7994325+00:00",
"status": "Active",
"tags": [
"4c584d39-3132-3058-c050-5757574b8500"
],
"transactionId": "8d5ed958-6c72-4812-87fc-57b105d3d197",
"trialData": {
"isInTrialPeriod": true,
"isTrial": true,
"trialTimeRemaining": "09:43:52.8580690"
}
}
]
}
Requesting remaining results with the continuation token
If your query has more results than can be returned in a single response (controlled by the maxPageSize), your initial query response will have a continuationToken. You can then use this continuationToken in a follow up request by adding the continuation token to a copy of the previous request body.
Example continuation request:
POST https://collections.mp.microsoft.com/v9.0/collections/PublisherQuery HTTP/1.1
Host: collections.mp.microsoft.com
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsIng1dCI6Imwzc1...
User-Agent: {identifier string of your service}
Content-Type: application/json; charset=utf-8
Content-Length: 2243
{
"continuationToken":"{\"checkSatisfactionIndex\":2}",
"maxPageSize":2,
"excludeDuplicates":true,
"productSkuIds":[
{"productId": "9N30KZZF4BR9"},
{"productId": "9MXL21XPWWWK"},
{"productId": "9PLRFWZWWF91"},
{"productId": "9MZ0MGGFPLTP"}
],
"beneficiaries": [
{
"identitytype": "b2b",
"identityValue": "eyJhbGciOiJSUzI1NiIsImtpZCI6IjYxNTI2OEI4N0YwNEFDQzIzRDdCQ0E2M...",
"localTicketReference": ""
}
],
"sbx":"XDKS.1",
}
Note
Even if you specify the excludeDuplicates flag, when using a continuation token it is possible to get entries of entitlements that have different status. So verify the results for duplicate entries and if they have a status that is not Active.
Related topics
Manage products from your services
Authenticating your service with the Microsoft Store APIs
[
Managing consumable products from your service](../xstore-managing-consumables-and-refunds.md)