XUserGetTokenAndSignatureData
Web 要求に対して取得した Xtoken と署名を指定します。
構文
typedef struct XUserGetTokenAndSignatureData {
size_t tokenSize;
size_t signatureSize;
const char* token;
const char* signature;
} XUserGetTokenAndSignatureData
メンバー
tokenSize
型: size_t
token プロパティ内のバッファーのサイズ (バイト単位)。
signatureSize
型: size_t
signature プロパティ内のバッファーのサイズ (バイト単位)。
token
型: const char*
取得されたトークンを含むバッファー。
signature
型: const char*
取得された署名が格納されるバッファー。
解説
XUserGetTokenAndSignatureAsync の呼び出しの結果を取得するには、XUserGetTokenAndSignatureResult 関数を呼び出します。
XUserGetTokenAndSignatureAsync 関数は、Web 要求の XToken と署名を非同期に取得します。
XUserGetTokenAndSignatureResult 関数は、XUserGetTokenAndSignatureData 構造体へのダブル ポインターを引数として使用します。
次の例は、ユーザーのトークンと署名を非同期で取得する方法を示しています。
HRESULT RequestTokenComplete(XAsyncBlock* abResult)
{
size_t bufferSize;
RETURN_IF_FAILED(XUserGetTokenAndSignatureResultSize(abResult, &bufferSize));
std::vector<uint8_t> buffer(bufferSize);
XUserGetTokenAndSignatureData* data;
if (SUCCEEDED_LOG(XUserGetTokenAndSignatureResult(abResult, buffer.size(), buffer.data(), &data, nullptr /*bufferUsed*/)))
{
appLog.AddLog("Token: %s\n", data->token);
if (data->signature != nullptr)
{
appLog.AddLog("Signature: %s\n", data->signature);
}
}
return S_OK;
}
HRESULT RequestTokenAsync(
XTaskQueueHandle queue,
const char* url,
bool forceRefresh)
{
auto asyncBlock = std::make_unique<XAsyncBlock>();
ZeroMemory(asyncBlock.get(), sizeof(*asyncBlock));
asyncBlock->queue = queue;
asyncBlock->context = this;
asyncBlock->callback = [](XAsyncBlock* ab)
{
LOG_IF_FAILED(static_cast<User*>(ab->context)->RequestTokenComplete(ab));
delete ab;
};
XUserGetTokenAndSignatureOptions options = XUserGetTokenAndSignatureOptions::None;
if (forceRefresh)
{
WI_SET_FLAG(options, XUserGetTokenAndSignatureOptions::ForceRefresh);
}
static const XUserGetTokenAndSignatureHttpHeader headers[] =
{
{ "Accept", "application/json"},
{ "Why", "Because"},
};
if (SUCCEEDED_LOG(XUserGetTokenAndSignatureAsync(
_handle.get(),
options,
"GET",
url,
ARRAYSIZE(headers),
headers,
0,
nullptr,
asyncBlock.get())))
{
// The call succeeded, so release the std::unique_ptr ownership of XAsyncBlock* since the callback will take over ownership.
// If the call fails, the std::unique_ptr will keep ownership and delete the XAsyncBlock*
asyncBlock.release();
}
return S_OK;
}
要件
ヘッダー: XUser.h
サポートされているプラットフォーム: Windows、Xbox One ファミリー本体、Xbox Series 本体