1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
|
// THIS FILE IS GENERATED - ANY EDITS WILL BE OVERWRITTEN
#pragma once
#include <Quotient/csapi/definitions/openid_token.h>
#include <Quotient/jobs/basejob.h>
namespace Quotient {
//! \brief Get an OpenID token object to verify the requester's identity.
//!
//! Gets an OpenID token object that the requester may supply to another
//! service to verify their identity in Matrix. The generated token is only
//! valid for exchanging for user information from the federation API for
//! OpenID.
//!
//! The access token generated is only valid for the OpenID API. It cannot
//! be used to request another OpenID access token or call `/sync`, for
//! example.
class QUOTIENT_API RequestOpenIdTokenJob : public BaseJob {
public:
//! \param userId
//! The user to request an OpenID token for. Should be the user who
//! is authenticated for the request.
//!
//! \param dontUse
//! An empty object. Reserved for future expansion.
explicit RequestOpenIdTokenJob(const QString& userId, const QJsonObject& dontUse = {});
// Result properties
//! OpenID token information. This response is nearly compatible with the
//! response documented in the
//! [OpenID Connect 1.0
//! Specification](http://openid.net/specs/openid-connect-core-1_0.html#TokenResponse) with the
//! only difference being the lack of an `id_token`. Instead, the Matrix homeserver's name is
//! provided.
OpenIdCredentials tokenData() const { return fromJson<OpenIdCredentials>(jsonData()); }
};
inline auto collectResponse(const RequestOpenIdTokenJob* job) { return job->tokenData(); }
} // namespace Quotient
|