8 #include <azure/core/context.hpp>
9 #include <azure/core/internal/tracing/service_tracing.hpp>
10 #include <azure/core/url.hpp>
13 namespace Azure {
namespace Core {
namespace Http {
namespace _internal {
17 namespace Azure {
namespace Security {
namespace Attestation {
133 std::string
const& endpoint,
134 std::shared_ptr<Core::Credentials::TokenCredential const> credential,
136 Azure::Core::Context
const& constext = Azure::Core::Context{});
152 std::string
const& endpoint,
154 Azure::Core::Context
const& constext = Azure::Core::Context{});
168 std::string
const Endpoint()
const {
return m_endpoint.GetAbsoluteUrl(); }
179 Azure::Core::Context
const& context = Azure::Core::Context::ApplicationContext)
const;
188 Azure::Core::Context
const& context = Azure::Core::Context{})
const;
202 Response<Models::AttestationToken<Models::AttestationResult>>
AttestSgxEnclave(
203 std::vector<uint8_t>
const& sgxQuoteToAttest,
204 AttestSgxEnclaveOptions options = AttestSgxEnclaveOptions{},
205 Azure::Core::Context
const& context = Azure::Core::Context{})
const;
221 std::vector<uint8_t>
const& openEnclaveReportToAttest,
222 AttestOpenEnclaveOptions options = AttestOpenEnclaveOptions{},
223 Azure::Core::Context
const& context = Azure::Core::Context{})
const;
237 Response<Models::TpmAttestationResult>
AttestTpm(
238 std::vector<uint8_t>
const& dataToAttest,
239 AttestTpmOptions
const& options = AttestTpmOptions{},
240 Azure::Core::Context
const& context = Azure::Core::Context{})
const;
243 Azure::Core::Url m_endpoint;
244 std::string m_apiVersion;
245 std::shared_ptr<Azure::Core::Http::_internal::HttpPipeline> m_pipeline;
246 AttestationTokenValidationOptions m_tokenValidationOptions;
247 std::vector<Models::AttestationSigner> m_attestationSigners;
248 Azure::Core::Tracing::_internal::TracingContextFactory m_tracingFactory;
257 std::string
const& endpoint,
258 std::shared_ptr<Core::Credentials::TokenCredential const> credential,
259 AttestationClientOptions options = AttestationClientOptions{});
267 void RetrieveResponseValidationCollateral(
268 Azure::Core::Context
const& context = Azure::Core::Context{});