From 4ce2d84d8fad105d5d39d615c15d3f9da1f09978 Mon Sep 17 00:00:00 2001 From: Carlos Date: Tue, 17 Oct 2023 10:24:34 -0300 Subject: [PATCH] Comment summarizing the reason for the fallback --- storeapi/base/impl/StoreContext.cpp | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/storeapi/base/impl/StoreContext.cpp b/storeapi/base/impl/StoreContext.cpp index 54ed91f61..bc78431a4 100644 --- a/storeapi/base/impl/StoreContext.cpp +++ b/storeapi/base/impl/StoreContext.cpp @@ -106,6 +106,12 @@ std::string StoreContext::GenerateUserJwt(std::string token, auto hUserId = winrt::to_hstring(userId); auto hJwt = self.GetCustomerPurchaseIdAsync(hToken, hUserId).get(); if (hJwt.empty()) { + // Although the preferred API for the MS Store is the one exported in the + // `Windows::Services::Store` namespace, it has consistently and silently + // failed to generate the user JWT, producing just an empty string. The old + // (deprecated) `Windows::ApplicationModel::Store` namespace, on the other + // hand, succeeded consistently in my tests, as long as the app is deployed + // (throwing exceptions otherwise). hJwt = winrt::Windows::ApplicationModel::Store::CurrentApp:: GetCustomerPurchaseIdAsync(hToken, hUserId) .get();