API de tarification commerciale
Cet article décrit diverses API de tarification fournies par le moteur de tarification Microsoft Dynamics 365 Commerce.
Le moteur de tarification Dynamics 365 Commerce fournit les API suivantes au serveur de vente au détail qui peuvent être utilisées par des applications externes pour prendre en charge divers scénarios de tarification :
- GetActivePrices – Cette API obtient le prix calculé d’un produit, y compris les remises simples.
- CalculateSalesDocument : cette API calcule les prix et les remises pour les produits en quantités données s’ils sont achetés ensemble.
- GetAvailablePromotions – Cette API obtient les remises applicables pour les produits du panier.
- AddCoupons – Cette API ajoute des coupons à un panier.
- RemoveCoupons – Cette API supprime les coupons d’un panier.
Pour plus d’informations sur l’utilisation des API au serveur de vente au détail dans des applications externes, consultez Utiliser les API au serveur de vente au détail dans des applications externes.
GetActivePrices
L’API GetActivePrices a été introduite dans la version 10.0.4 de Commerce. Cette API obtient le prix calculé d’un produit, y compris les remises simples. Elle ne calcule pas les remises multilignes et suppose que chaque produit d’une demande d’API a une quantité de 1. Cette API peut également prendre une liste de produits en entrée et consulter le prix de produits individuels en masse.
L’API GetActivePrices prend en charge les rôles Commerce Employé, Client, Anonyme, et Application.
Le principal cas d’utilisation des API GetActivePrices est la page de détails du produit (PDP), où les détaillants présentent le meilleur prix pour un produit, y compris les remises effectives.
Remarque
Si vous voyez moins de produits retournés pour un appel GetActivePrices
, vous pouvez suivre Validateur de la configuration du commerce de canal pour valider vos configurations de commerce.
Le tableau suivant montre les paramètres d’entrée pour l’API GetActivePrices.
Name | Sous-nom | Type | Obligatoire/Facultatif | Description |
---|---|---|---|---|
projectDomain | ProjectionDomain | Requis | ||
ChannelId | long | Obligatoire | ||
CatalogId | long | Obligatoire | ||
productIds | IEnumerable<long> | Obligatoire | La liste des produits pour lesquels calculer les prix. | |
activeDate | DateTimeOffset | Requis | La date à laquelle les prix sont calculés. | |
customerId | chaîne | Facultatif | Numéro du compte client. | |
affiliationLoyaltyTiers | IEnumerable<AffiliationLoyaltyTier> | Facultatif | Les niveaux d’affiliation et de fidélité | |
AffiliationId | long | Requis | L'ID d'affiliation. | |
LoyaltyTierId | long | Facultatif | L'ID du niveau de fidélité. | |
includeSimpleDiscountsInContextualPrice | bool | Facultatif | Définissez ce paramètre sur vrai pour inclure des remises simples dans le calcul du prix. La valeur par défaut est false. | |
includeVariantPriceRange | bool | Facultatif | Définissez ce paramètre sur vrai pour obtenir les prix minimum et maximum parmi toutes les variantes d’un produit maître. La valeur par défaut est false. | |
includeAttainablePricesAndDiscounts | bool | Facultatif | Définissez ce paramètre sur vrai pour obtenir des prix et des remises accessibles. La valeur par défaut est false. |
Exemple de corps de requête
{
"projectDomain":
{
"ChannelId": 5637144592,
"CatalogId": 0
},
"productIds":
[
68719489871
],
"activeDate": "2022-06-20T14:40:05.873+08:00",
"includeSimpleDiscountsInContextualPrice": true,
"includeVariantPriceRange": false
}
Exemple de corps de réponse
{
"value":
[
{
"ProductId": 68719489871,
"ListingId": 68719489871,
"BasePrice": 0,
"TradeAgreementPrice": 0,
"AdjustedPrice": 0,
"MaxVariantPrice": 0,
"MinVariantPrice": 0,
"CustomerContextualPrice": 0,
"DiscountAmount": 0,
"CurrencyCode": "USD",
"ItemId": "82000",
"InventoryDimensionId": null,
"UnitOfMeasure": "ea",
"ValidFrom": "2022-06-20T01:40:05.873-05:00",
"ProductLookupId": 0,
"ChannelId": 5637144592,
"CatalogId": 0,
"SalesAgreementPrice": 0,
"PriceSourceTypeValue": 1,
"DiscountLines": [],
"AttainablePriceLines": [],
}
]
}
Utiliser PriceLookupContext
La classe PriceLookupContext a été introduite dans la version 10.0.37 de Commerce. La classe contient tous les critères de recherche pour l’API GetActivePrices et remplace les paramètres précédents de productIds, activeDate, customerId et affiliationLoyaltyTiers. La classe possède également des propriétés supplémentaires que les développeurs peuvent utiliser pour filtrer les remises lors de la recherche de remise.
Selon les besoins de votre organisation, l’API GetActivePrices peut accepter soit les paramètres précédents, soit les nouveaux paramètres associés à la classe PriceLookupContext.
Paramètres d’entrée
Name | Sous-nom | Type | Obligatoire/Facultatif | Description |
---|---|---|---|---|
projectDomain | ProjectionDomain | Requis | ||
ChannelId | long | Requis | ||
CatalogId | long | Requis | ||
priceLookupContext | PriceLookupContext | Requis | ||
HeaderContext | PriceLookupHeaderContext | Requis | Contient CustomerAccountNumber, AffiliationLoyaltyTierLines et SalesOrderProperties | |
LineContexts | IEnumerable<PriceLookupLineContext> | Requis | Contient ProductRecordId, UnitOfMeasureSymbol, InventorySiteId, InventoryLocationId, DeliveryMode, CatalogId et SalesLineProperties. | |
includeSimpleDiscountsInContextualPrice | bool | Facultatif | Définissez ce paramètre sur vrai pour inclure des remises simples dans le calcul du prix. La valeur par défaut est false. | |
includeVariantPriceRange | bool | Facultatif | Définissez ce paramètre sur vrai pour obtenir les prix minimum et maximum parmi toutes les variantes d’un produit maître. La valeur par défaut est false. | |
includeAttainablePricesAndDiscounts | bool | Facultatif | Définissez ce paramètre sur vrai pour obtenir des prix et des remises accessibles. La valeur par défaut est false. |
Pour plus d’informations, voir la rubrique PriceLookupContext.
CalculateSalesDocument
L’API CalculateSalesDocument a été introduite dans la version 10.0.25 de Commerce. Cette API calcule les prix et les remises pour les produits à des quantités données s’ils sont achetés ensemble dans une commande. Le calcul des prix derrière l’API CalculateSalesDocument prend en compte à la fois les remises sur une seule ligne et les remises sur plusieurs lignes.
Le principal cas d’utilisation pour l’API CalculateSalesDocument est le calcul de prix dans des scénarios où le contexte du panier complet ne persiste pas (comme les devis de vente). Les scénarios e-commerce en point de vente (PDV) et Commerce peuvent également bénéficier de ce cas d’utilisation. Un prix total inférieur lorsque les articles du panier sont calculés comme un ensemble (par exemple, pour des offres groupées discrètes, des produits liés ou recommandés, ou des produits qui ont déjà été ajoutés au panier) peut persuader les clients d’ajouter des produits au panier.
Le modèle de données pour la demande et la réponse de l’API CalculateSalesDocument est Panier. Cependant, dans le contexte de cette API, le modèle de données est nommé SalesDocument. Étant donné que la plupart des propriétés sont facultatives et que seules quelques-unes d’entre elles affectent le calcul du prix, seuls les champs liés au prix sont affichés dans le tableau suivant. Nous vous déconseillons d’impliquer d’autres champs dans la demande d’API.
La portée de l’API CalculateSalesDocument n’est que le calcul des prix et des remises. Les taxes et les frais ne sont pas impliqués.
Le tableau suivant montre les paramètres d’entrée à l’intérieur de l’objet nommé salesDocument.
Name | Sous-nom | Type | Obligatoire/Facultatif | Description |
---|---|---|---|---|
ID | chaîne | Requis | L’identificateur du document des ventes. | |
CartLines | IList<CartLine> | Facultatif | La liste des lignes pour lesquelles calculer les prix et les remises. | |
ID produit | long | Requis dans l'étendue de CartLine | L'ID d'enregistrement de produit. | |
ItemId | chaîne | Facultatif | L'identificateur de l'article. Si une valeur est fournie, elle doit correspondre à la valeur du paramètre ProductId. | |
InventoryDimensionId | chaîne | Facultatif | L'identificateur de la dimension de stock. Si une valeur est fournie, la combinaison des valeurs ItemId et InventoryDimensionId doivent correspondre à la valeur du paramètre ProductId. | |
Quantity | decimal | Requis dans l'étendue de CartLine | La quantité du produit. | |
UnitOfMeasureSymbol | chaîne | Facultatif | L'unité du produit. Par défaut, si aucune valeur n’est fournie, l’API utilise l’unité de vente du produit. | |
CustomerId | chaîne | Facultatif | Numéro du compte client. | |
LoyaltyCardId | chaîne | Facultatif | L'identificateur de la carte de fidélité. Tout compte client associé à la carte de fidélité doit correspondre à la valeur du paramètre CustomerId (s’il est fourni). La carte de fidélité ne sera pas prise en compte si elle est introuvable ou si son statut est Bloqué. | |
AffiliationLines | IList<AffiliationLoyaltyTier> | Facultatif | Les lignes du niveau d’affiliation de la fidélité. Si les valeurs CustomerId et/ou LoyaltyCardId sont fournies, les lignes de niveau d’affiliation de fidélité correspondantes seront fusionnées avec les lignes fournies dans la valeur AffiliationLines. | |
AffiliationId | long | Requis dans l'étendue de AffiliationLoyaltyTier | L'ID d'enregistrement de l'affiliation. | |
LoyaltyTierId | long | Requis dans l'étendue de AffiliationLoyaltyTier | L'ID de l'enregistrement du niveau de fidélité. | |
AffiliationTypeValue | int | Requis dans l'étendue de AffiliationLoyaltyTier | Une valeur qui indique si la ligne d’affiliation est du type General (0) ou du type Loyalty (1). Si ce paramètre est réglé sur 0, l’API prend la valeur AffiliationId comme identificateur et ignore la valeur LoyaltyTierId. Si ce paramètre est réglé sur 1, l’API prend la valeur LoyaltyTierId comme identificateur et ignore la valeur AffiliationId. | |
ReasonCodeLines | Collection<ReasonCodeLine> | Requis dans l’étendue de AffiliationLoyaltyTier | Lignes de code Reason. Ce paramètre n’a aucun effet sur le calcul du prix mais est requis dans le cadre de l’objet AffiliationLoyaltyTier. | |
CustomerId | chaîne | Requis dans l’étendue de AffiliationLoyaltyTier | Numéro du compte client. | |
Coupons | IList<Coupon> | Facultatif | Les coupons qui ne sont pas applicables (inactifs, expirés ou introuvables) ne seront pas pris en compte dans le calcul du prix. | |
Code | chaîne | Requis dans l’étendue de Coupon | Le code de coupon. | |
CodeId | chaîne | Facultatif | L'identificateur du code de coupon. Si une valeur est fournie, elle doit correspondre à la valeur du paramètre Code. | |
DiscountOfferId | chaîne | Facultatif | L’identificateur de la remise. Si une valeur est fournie, elle doit correspondre à la valeur du paramètre Code. |
Exemple de corps de requête
{
"salesDocument":
{
"Id": "CalculateSalesDocument",
"CartLines":
[
{
"ProductId": 68719491408,
"ItemId": "91003",
"InventoryDimensionId": "",
"Quantity": 1,
"UnitOfMeasureSymbol": "ea"
},
{
"ProductId": 68719493014,
"Quantity": 2,
"UnitOfMeasureSymbol": "ea"
}
],
"CustomerId": "3003",
"AffiliationLines":
[
{
"AffiliationId": 68719476742,
"LoyaltyTierId": 0,
"AffiliationTypeValue": 0,
"ReasonCodeLines": [],
"CustomerId": null
}
],
"LoyaltyCardId": "55103",
"Coupons":
[
{
"CodeId": "CODE-0005",
"Code": "CPN0004",
"DiscountOfferId": "ST100077"
}
]
}
}
L’objet cart entier est renvoyé comme corps de réponse. Pour vérifier les prix et les remises, vous devez vous concentrer sur les champs du tableau suivant.
Name | Sous-nom | Type | Description |
---|---|---|---|
NetPrice | decimal | Le prix net de l’ensemble du document de vente avant application des remises. | |
DiscountAmount | decimal | Le montant total de la remise de l’ensemble du document de vente. | |
TotalAmount | decimal | Le montant total de l’ensemble du document de vente. | |
CartLines | IList<CartLine> | Lignes calculées qui incluent les détails du prix et de la remise. | |
Prix | decimal | Le prix du produit à l’unité. | |
NetPrice | decimal | Le prix net de la ligne avant application des remises (= Prix x Quantité). | |
DiscountAmount | decimal | Le montant de la remise. | |
TotalAmount | decimal | Le résultat final de la tarification totale de la ligne. | |
PriceLines | IList<PriceLine> | Détails du prix, y compris la source du prix (prix de base, ajustement de prix ou accord commercial) et le montant. | |
DiscountLines | IList<DiscountLine> | Détails de la remise. |
GetAvailablePromotions
Il existe deux API GetAvailablePromotions similaires :
- Carts/GetAvailablePromotions accepte une liste d’identificateurs de ligne de panier comme paramètre.
- GetAvailablePromotions accepte un objet DiscountsSearchCriteria comme paramètre.
Carts/GetAvailablePromotions
Étant donné un panier comportant plusieurs lignes de panier, l’API Carts/GetAvailablePromotions renvoie toutes les remises applicables pour les lignes de panier.
Le principal cas d’utilisation de l’API Carts/GetAvailablePromotions est la page du panier, où les détaillants présentent les remises appliquées ou les coupons disponibles pour le panier actuel.
Le tableau suivant répertorie les paramètres d’entrée pour l’API Carts/GetAvailablePromotions.
Name | Type | Obligatoire/Facultatif | Description |
---|---|---|---|
clé | chaîne | Obligatoire | L’ID du panier. |
cartLineIds | IEnumerable<string> | Facultatif | Définissez ce paramètre pour renvoyer les remises uniquement pour les lignes de panier sélectionnées. |
Exemple de corps de réponse
{
"value":
[
{
"LineId": "f495ffa507bc4f63a47a409cd8713dd7",
"Promotion": {
"OfferId": "ST100012",
"OfferName": "Loyalty 5% off over $100",
"PeriodicDiscountTypeValue": 4,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": null,
"AdditionalRestrictions": null,
"Description": "All loyalty members get 5% with transaction total above $10 unless some exclusive or best price discounts are already applied on the transaction",
"ValidFromDate": "2022-06-20T06:52:56.2460219Z",
"ValidToDate": "2022-06-20T06:52:56.2460224Z",
"CouponCodes": [],
"ValidationPeriod": null
}
}
]
}
GetAvailablePromotions
L’API GetAvailablePromotions renvoie toutes les remises applicables pour le canal donné.
Le principal cas d’utilisation de l’API GetAvailablePromotions est la page « Toutes les remises », où les détaillants présentent toutes les remises pour le canal actuel.
Le tableau suivant répertorie les paramètres d’entrée pour l’API GetAvailablePromotions.
Name | Sous-nom | Type | Obligatoire/Facultatif | Description |
---|---|---|---|---|
searchCriteria | DiscountsSearchCriteria | Requis | ||
ChannelId | long | Requis | ||
Mot clé | chaîne | Facultatif | ||
IsDiscountCodeRequired | bool | Facultatif | Indique si le code de coupon est requis ou non. Si la valeur null est transmise, toutes les remises sont récupérées, quelles que soient les exigences du code de coupon. | |
StartDate | DateTimeOffset | Requis | Date de début (incluse). | |
EndDate | DateTimeOffset | Requis | Date de fin (incluse). |
Exemple de corps de requête
{
"searchCriteria": {
"ChannelId": 5637144592,
"StartDate": "1900-01-01T00:00:00Z",
"EndDate": "2154-12-31T00:00:00Z"
}
}
Exemple de corps de réponse
{
"@odata.context": "https://usnconeboxax1ret.cloud.onebox.dynamics.com/Commerce/$metadata#Collection(Microsoft.Dynamics.Commerce.Runtime.DataModel.Promotion)",
"value": [
{
"OfferId": "ST100024",
"OfferName": "Weekly ad",
"PeriodicDiscountTypeValue": 2,
"IsDiscountCodeRequired": true,
"ValidationPeriodId": "",
"AdditionalRestrictions": "",
"Description": "",
"ValidFromDate": "1900-01-01T00:00:00Z",
"ValidToDate": "2154-12-31T00:00:00Z",
"CouponCodes": [],
"ExtensionProperties": [
{
"Key": "DATAAREAID",
"Value": {
"StringValue": "usrt"
}
},
{
"Key": "DATEVALIDATIONTYPE",
"Value": {
"IntegerValue": 1
}
}
]
},
{
"OfferId": "ST100019",
"OfferName": "Take 20 off anything",
"PeriodicDiscountTypeValue": 2,
"IsDiscountCodeRequired": true,
"ValidationPeriodId": "",
"AdditionalRestrictions": "",
"Description": "",
"ValidFromDate": "1900-01-01T00:00:00Z",
"ValidToDate": "2154-12-31T00:00:00Z",
"CouponCodes": [],
"ExtensionProperties": [
{
"Key": "DATAAREAID",
"Value": {
"StringValue": "usrt"
}
},
{
"Key": "DATEVALIDATIONTYPE",
"Value": {
"IntegerValue": 1
}
}
]
},
{
"OfferId": "ST100015",
"OfferName": "Watches",
"PeriodicDiscountTypeValue": 2,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": "",
"AdditionalRestrictions": "",
"Description": "",
"ValidFromDate": "1900-01-01T00:00:00Z",
"ValidToDate": "2154-12-31T00:00:00Z",
"CouponCodes": [],
"ExtensionProperties": [
{
"Key": "DATAAREAID",
"Value": {
"StringValue": "usrt"
}
},
{
"Key": "DATEVALIDATIONTYPE",
"Value": {
"IntegerValue": 1
}
}
]
},
{
"OfferId": "ST100012",
"OfferName": "Loyalty 5% off over $100",
"PeriodicDiscountTypeValue": 4,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": "",
"AdditionalRestrictions": "",
"Description": "All loyalty members get 5% with transaction total above $10 unless some exclusive or best price discounts are already applied on the transaction",
"ValidFromDate": "1900-01-01T00:00:00Z",
"ValidToDate": "2154-12-31T00:00:00Z",
"CouponCodes": [],
"ExtensionProperties": [
{
"Key": "DATAAREAID",
"Value": {
"StringValue": "usrt"
}
},
{
"Key": "DATEVALIDATIONTYPE",
"Value": {
"IntegerValue": 1
}
}
]
},
{
"OfferId": "ST100011",
"OfferName": "Loyalty 50% off sunglasses",
"PeriodicDiscountTypeValue": 1,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": "",
"AdditionalRestrictions": "",
"Description": "Gold tier Loyalty customers get 50% on Sunglasses when purchased with a Top, Scarf or Men's Casual shirts",
"ValidFromDate": "1900-01-01T00:00:00Z",
"ValidToDate": "2154-12-31T00:00:00Z",
"CouponCodes": [],
"ExtensionProperties": [
{
"Key": "DATAAREAID",
"Value": {
"StringValue": "usrt"
}
},
{
"Key": "DATEVALIDATIONTYPE",
"Value": {
"IntegerValue": 1
}
}
]
},
{
"OfferId": "ST100009",
"OfferName": "Student discount",
"PeriodicDiscountTypeValue": 2,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": "",
"AdditionalRestrictions": "",
"Description": "Students get 10% off for on Jeans and Backpacks",
"ValidFromDate": "1900-01-01T00:00:00Z",
"ValidToDate": "2154-12-31T00:00:00Z",
"CouponCodes": [],
"ExtensionProperties": [
{
"Key": "DATAAREAID",
"Value": {
"StringValue": "usrt"
}
},
{
"Key": "DATEVALIDATIONTYPE",
"Value": {
"IntegerValue": 1
}
}
]
},
{
"OfferId": "ST100004",
"OfferName": "Soccer sale",
"PeriodicDiscountTypeValue": 3,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": "",
"AdditionalRestrictions": "",
"Description": "Providing you great discounts ranging from 10% to 20% on all branded Soccer balls. We carry a full line of soccer balls. Buy one for yourself or gift it to someone. We promise you that you won't be disappointed. If you don't see something that you are looking for please call us. This offer is only valid at our Retail Malls.",
"ValidFromDate": "1900-01-01T00:00:00Z",
"ValidToDate": "2154-12-31T00:00:00Z",
"CouponCodes": [],
"ExtensionProperties": [
{
"Key": "DATAAREAID",
"Value": {
"StringValue": "usrt"
}
},
{
"Key": "DATEVALIDATIONTYPE",
"Value": {
"IntegerValue": 1
}
}
]
},
{
"OfferId": "ST100003",
"OfferName": "BMX helmet sale",
"PeriodicDiscountTypeValue": 0,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": "",
"AdditionalRestrictions": "",
"Description": "Get 20% off on all branded youth BMX helmets when you buy two or more. Choose from our great selection of BMX bike helmets from top brands, including ProTec, Giro, Bell and SixSixOne BMX helmets. This offer is only available at our Retail Mall stores",
"ValidFromDate": "1900-01-01T00:00:00Z",
"ValidToDate": "2154-12-31T00:00:00Z",
"CouponCodes": [],
"ExtensionProperties": [
{
"Key": "DATAAREAID",
"Value": {
"StringValue": "usrt"
}
},
{
"Key": "DATEVALIDATIONTYPE",
"Value": {
"IntegerValue": 1
}
}
]
}
]
}
AddCoupons
L’API AddCoupons prend en charge l’ajout d’une liste de coupons à un panier. Il renvoie l’objet panier après l’ajout des coupons.
Le tableau suivant montre les paramètres d’entrée pour l’API AddCoupons.
Name | Type | Obligatoire/facultatif | Description |
---|---|---|---|
clé | chaîne | Obligatoire | L’ID du panier. |
couponCodes | IEnumerable<string> | Obligatoire | Les codes de coupon à ajouter au panier. |
isLegacyDiscountCode | bool | Facultatif | Définissez ce paramètre sur vrai pour indiquer que le coupon est un code de remise hérité. La valeur par défaut est false. |
RemoveCoupons
L’API RemoveCoupons prend en charge la suppression d’une liste de coupons d’un panier. Elle renvoie l’objet panier après la suppression des coupons.
Le tableau suivant montre les paramètres d’entrée pour l’API RemoveCoupons.
Name | Type | Obligatoire/facultatif | Description |
---|---|---|---|
clé | chaîne | Obligatoire | L’ID du panier. |
couponCodes | IEnumerable<string> | Requis | Les codes de coupon à supprimer du panier. |
GetProductPromotions
L’API GetProductPromotions a été introduite dans la version 10.0.38 de Commerce. Cette API obtient une liste de produits promotionnels avec des remises sur les produits données, et peut également prendre une liste d’identifiants de remise sur les produits et le contexte de tarification en entrée et interroger les produits promotionnels associés. Le principal cas d’utilisation de l’API GetProductPromotions concerne les pages de listes de produits, où les détaillants présentent des produits bénéficiant de remises. Cette API prend en charge à la fois le modèle de tarification basé sur la propriété et l’ancien modèle de tarification.
Le tableau suivant montre les paramètres d’entrée pour l’API GetProductPromotions.
Name | Sous-nom | Type | Obligatoire/Facultatif | Description |
---|---|---|---|---|
productDiscountIds | IEnumerable<string> | Requis | La liste des identifiants de remise sur les produits à rechercher pour les produits promotionnels. | |
priceLookupContext | PriceLookupContext | Requis | Le contexte de la tarification. | |
activeDate | DateTimeOffset | Facultatif | Date de prise en compte de la promotion. |
Restrictions et limitations :
- Ne peut accepter qu’un maximum de cinq identifiants de remise sur les produits en entrée.
- Seules les remises simples sont prises en charge.
Exemple de corps de requête
{
{
"productDiscountIds":
[
"ST100009",
"ST100024"
],
"priceLookupContext":
{
"HeaderContext":
{
"AffiliationLoyaltyTierLines":
[
{
"AffiliationId": 5637144577,
"LoyaltyTierId": 0,
"AffiliationTypeValue": 0,
"ReasonCodeLines": [],
"CustomerId": "2001"
}
]
},
"LineContexts": []
},
"activeDate": "2023-08-20T14:40:05.873+08:00",
},
}
Exemple de corps de réponse
{
"value":
[
{
"ProductId": 68719489871,
"ProductDiscounts":
[
{
"OfferId": "ST100009",
"OfferName": "Student discount",
"PeriodicDiscountTypeValue": 2,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": null,
"AdditionalRestrictions": null,
"Description": "Students get 10% off on Jeans and Backpacks",
"ValidFromDate": "1900-01-01T00:00:00.0000000Z",
"ValidToDate": "2154-12-31T00:00:00.0000000Z",
"CouponCodes": [],
"DateValidationTypeValue": 1
},
{
"OfferId": "ST100024",
"OfferName": "Weekly ad",
"PeriodicDiscountTypeValue": 2,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": null,
"AdditionalRestrictions": null,
"Description": "",
"ValidFromDate": "1900-01-01T00:00:00.0000000Z",
"ValidToDate": "2154-12-31T00:00:00.0000000Z",
"CouponCodes": [],
"DateValidationTypeValue": 1
}
]
},
{
"ProductId": 68719489872,
"ProductDiscounts":
[
{
"OfferId": "ST100009",
"OfferName": "Student discount",
"PeriodicDiscountTypeValue": 2,
"IsDiscountCodeRequired": false,
"ValidationPeriodId": null,
"AdditionalRestrictions": null,
"Description": "Students get 10% off on Jeans and Backpacks",
"ValidFromDate": "1900-01-01T00:00:00.0000000Z",
"ValidToDate": "2154-12-31T00:00:00.0000000Z",
"CouponCodes": [],
"DateValidationTypeValue": 1
}
]
}
]
}
Pour plus d’informations, voir la rubrique PriceLookupContext.
PriceLookupContext
La classe PriceLookupContext est utilisée pour le modèle de tarification basé sur la propriété dans les API GetProductPromotions et GetActivePrices .
La structure de la classe PriceLookupContext est illustrée dans l’exemple suivant.
{
HeaderContext: PriceLookupHeaderContext
{
CustomerAccountNumber: string
AffiliationLoyaltyTierLines: IEnumerable<AffiliationLoyaltyTier>
ChannelId: long?
SalesOrderProperties: IEnumerable<AttributeValueBase>
},
LineContexts: IEnumerable<PriceLookupLineContext>
[
{
ProductRecordId: string
UnitOfMeasureSymbol: string
InventorySiteId: string
InventoryLocationId: string
DeliveryMode: string
CatalogId: string
SalesLineProperties: IEnumerable<AttributeValueBase>
},
]
}
Exemple de corps de requête
"PriceLookupContext":
{
"HeaderContext":
{
"CustomerAccount": 2001,
"AffiliationLoyaltyTierLines":
[
{
"AffiliationId": 5637144577,
"LoyaltyTierId": 0,
"AffiliationTypeValue": 0,
"ReasonCodeLines": [],
"CustomerId": "2001"
}
],
"SalesOrderProperties":
[
{
"@odata.type": "#Microsoft.Dynamics.Commerce.Runtime.DataModel.AttributeTextValue",
"Name": "CalcDate",
"TextValue": "2022-10-10"
}
]
},
"LineContexts": []
}
Remarque
- Aucun groupe de clients n’est spécifié dans le paramètre PriceLookupHeaderContext, car il a été déduit du numéro de compte client.
- Le ChannelId peut être spécifié dans le paramètre PriceLookupHeaderContext. S’il n’est pas spécifié, le ChannelId du contexte de demande (le canal actuel lors de l’utilisation de Store Commerce) est utilisé.