From ebe39dfcbc6c36028a761a6e15dd0c1f0680a145 Mon Sep 17 00:00:00 2001 From: Gary Atwal <87947837+garya-bitquill@users.noreply.github.com> Date: Tue, 9 Nov 2021 10:05:29 -0800 Subject: [PATCH] Garya/ad 439/remove timestream from tscommunication class (#10) * [AD-451] Replace AWS ColumnInfo and Row Type with User Types https:/bitquill.atlassian.net/browse/AD-451 * [AD-451] Replace AWS ColumnInfo and Row Type with User Types https:/bitquill.atlassian.net/browse/AD-451 * [AD-451] Correct pedantic syntax https:/bitquill.atlassian.net/browse/AD-451 * [AD-451] Correct pedantic syntax https:/bitquill.atlassian.net/browse/AD-451 * remove datum and timeseries datatype parser * removing extra include * Remove 'TimestreamQuery_EXPORTS.h'. * Remove timeseries related data members and methods. * Add new file QueryStatus.(h,cpp). * Add new file Endpoint.(h,cpp). * Add new file DescribeEndpointsResult.(h,cpp). * Add new file DescribeEndpointsResult.(h,cpp). * Add QueryRequest files. * Add new file DatabaseQueryErrors.(c,cpp). * Add new file DatabaseQueryErrorMarshaller.(h,cpp) * Add new file DatabaseQueryEndpoint.(h,cpp). * Add new file QueryResult.(h,cpp). * Add new file DescribeEndpointsRequest.(h,cpp). * Add new files CancelQueryResult.(h,cpp) and DatabaseQueryClient.(h,cpp). * Fix namespace bug. * Fix error with Endpoint class. * Fix comments in CancelQueryRequest.h. * Fix comments in CancelQueryResult.h. * Remove dependency on aws/timestream-query/... and replace user-defined classes. * Remove word 'Amazon Timestream', add 'TODO' comments. * Remove word 'timestream', add 'TODO' comments. * Remove region authentication field. * Replace 'TSCommunication' with 'DBCommunication'. * Revert "Replace 'TSCommunication' with 'DBCommunication'." This reverts commit 0cc632469fd3da69b9538ad0df10d9903a5dd30f. * Revert "Remove region authentication field." This reverts commit 701e5876af7fb8746742de0519d1a83949f61cce. * Revert "Remove word 'timestream', add 'TODO' comments." This reverts commit 10fb0206b48f39a57c64cb69398b21e97ed1e75e. * Revert "Remove word 'Amazon Timestream', add 'TODO' comments." This reverts commit eb300dfb810bd62ebc1f18d12da9b1a2c9e98072. * Remove IT_REGION. * Replace 'TSCommunication' with 'DBCommunication'. * Change 'Timestream_' to 'Database_'. Co-authored-by: Bruce Irschick Co-authored-by: affonsov --- src/Tests/ITODBCHelper/it_odbc_helper.cpp | 2 - src/Tests/ITODBCHelper/it_odbc_helper.h | 1 - src/Tests/Tests/test_conn.cpp | 12 +- src/odbcdriver/CMakeLists.txt | 25 ++ src/odbcdriver/CancelQueryRequest.cpp | 33 ++ src/odbcdriver/CancelQueryRequest.h | 103 +++++ src/odbcdriver/CancelQueryResult.cpp | 34 ++ src/odbcdriver/CancelQueryResult.h | 101 +++++ src/odbcdriver/ColumnInfo.h | 11 +- src/odbcdriver/DatabaseQueryClient.cpp | 340 +++++++++++++++++ src/odbcdriver/DatabaseQueryClient.h | 304 +++++++++++++++ src/odbcdriver/DatabaseQueryEndpoint.cpp | 49 +++ src/odbcdriver/DatabaseQueryEndpoint.h | 13 + .../DatabaseQueryErrorMarshaller.cpp | 21 ++ src/odbcdriver/DatabaseQueryErrorMarshaller.h | 14 + src/odbcdriver/DatabaseQueryErrors.cpp | 45 +++ src/odbcdriver/DatabaseQueryErrors.h | 77 ++++ src/odbcdriver/DatabaseQueryRequest.h | 39 ++ src/odbcdriver/Datum.h | 20 +- src/odbcdriver/DescribeEndpointsRequest.cpp | 27 ++ src/odbcdriver/DescribeEndpointsRequest.h | 28 ++ src/odbcdriver/DescribeEndpointsResult.cpp | 38 ++ src/odbcdriver/DescribeEndpointsResult.h | 97 +++++ src/odbcdriver/Endpoint.cpp | 50 +++ src/odbcdriver/Endpoint.h | 131 +++++++ src/odbcdriver/QueryRequest.cpp | 51 +++ src/odbcdriver/QueryRequest.h | 357 ++++++++++++++++++ src/odbcdriver/QueryResult.cpp | 60 +++ src/odbcdriver/QueryResult.h | 305 +++++++++++++++ src/odbcdriver/QueryStatus.cpp | 43 +++ src/odbcdriver/QueryStatus.h | 62 +++ src/odbcdriver/Row.h | 56 +-- src/odbcdriver/ScalarType.h | 1 - src/odbcdriver/Type.cpp | 24 +- src/odbcdriver/Type.h | 43 +-- src/odbcdriver/helper.cpp | 2 +- src/odbcdriver/odbc_communication.cpp | 64 ++-- src/odbcdriver/odbc_communication.h | 12 +- src/odbcdriver/odbc_statement.cpp | 2 +- src/odbcdriver/parse_result.cpp | 59 ++- src/odbcdriver/parse_result.h | 10 +- src/odbcdriver/prefetch_queue.cpp | 6 +- src/odbcdriver/prefetch_queue.h | 8 +- src/odbcdriver/types.h | 2 +- 44 files changed, 2593 insertions(+), 189 deletions(-) create mode 100644 src/odbcdriver/CancelQueryRequest.cpp create mode 100644 src/odbcdriver/CancelQueryRequest.h create mode 100644 src/odbcdriver/CancelQueryResult.cpp create mode 100644 src/odbcdriver/CancelQueryResult.h create mode 100644 src/odbcdriver/DatabaseQueryClient.cpp create mode 100644 src/odbcdriver/DatabaseQueryClient.h create mode 100644 src/odbcdriver/DatabaseQueryEndpoint.cpp create mode 100644 src/odbcdriver/DatabaseQueryEndpoint.h create mode 100644 src/odbcdriver/DatabaseQueryErrorMarshaller.cpp create mode 100644 src/odbcdriver/DatabaseQueryErrorMarshaller.h create mode 100644 src/odbcdriver/DatabaseQueryErrors.cpp create mode 100644 src/odbcdriver/DatabaseQueryErrors.h create mode 100644 src/odbcdriver/DatabaseQueryRequest.h create mode 100644 src/odbcdriver/DescribeEndpointsRequest.cpp create mode 100644 src/odbcdriver/DescribeEndpointsRequest.h create mode 100644 src/odbcdriver/DescribeEndpointsResult.cpp create mode 100644 src/odbcdriver/DescribeEndpointsResult.h create mode 100644 src/odbcdriver/Endpoint.cpp create mode 100644 src/odbcdriver/Endpoint.h create mode 100644 src/odbcdriver/QueryRequest.cpp create mode 100644 src/odbcdriver/QueryRequest.h create mode 100644 src/odbcdriver/QueryResult.cpp create mode 100644 src/odbcdriver/QueryResult.h create mode 100644 src/odbcdriver/QueryStatus.cpp create mode 100644 src/odbcdriver/QueryStatus.h diff --git a/src/Tests/ITODBCHelper/it_odbc_helper.cpp b/src/Tests/ITODBCHelper/it_odbc_helper.cpp index a2bbe4775..cb5b30a2f 100644 --- a/src/Tests/ITODBCHelper/it_odbc_helper.cpp +++ b/src/Tests/ITODBCHelper/it_odbc_helper.cpp @@ -285,7 +285,6 @@ void CompareStrNumChar(const test_string& expected, const SQLINTEGER num_chars, test_string conn_string() { std::vector< std::pair< test_string, test_string > > conn_str_pair = { {IT_DRIVER, CREATE_STRING("timestreamodbc")}, - {IT_REGION, CREATE_STRING("us-east-1")}, {IT_AUTH, CREATE_STRING("AWS_PROFILE")}, {IT_LOGLEVEL, CREATE_STRING("5")}}; // DEBUG level logging @@ -301,7 +300,6 @@ test_string conn_string() { test_string perf_conn_string() { std::vector< std::pair< test_string, test_string > > conn_str_pair = { {IT_DRIVER, CREATE_STRING("timestreamodbc")}, - {IT_REGION, CREATE_STRING("us-east-2")}, {IT_AUTH, CREATE_STRING("AWS_PROFILE")}, {IT_LOGLEVEL, CREATE_STRING("0")}}; diff --git a/src/Tests/ITODBCHelper/it_odbc_helper.h b/src/Tests/ITODBCHelper/it_odbc_helper.h index 5db172ff7..d0d98c8c3 100644 --- a/src/Tests/ITODBCHelper/it_odbc_helper.h +++ b/src/Tests/ITODBCHelper/it_odbc_helper.h @@ -75,7 +75,6 @@ test_string to_test_string(const std::string& src); #define IT_DRIVER CREATE_STRING("Driver") #define IT_ACCESSKEYID CREATE_STRING("AccessKeyId") #define IT_SECRETACCESSKEY CREATE_STRING"SecretAccessKey") -#define IT_REGION CREATE_STRING("Region") #define IT_AUTH CREATE_STRING("Auth") #define IT_LOGLEVEL CREATE_STRING("LogLevel") #define IT_LOGOUTPUT CREATE_STRING("LogOutput") diff --git a/src/Tests/Tests/test_conn.cpp b/src/Tests/Tests/test_conn.cpp index 6b6980073..544549523 100644 --- a/src/Tests/Tests/test_conn.cpp +++ b/src/Tests/Tests/test_conn.cpp @@ -31,7 +31,7 @@ TEST(TestConnectionOptions, Good) { options.auth.uid = "UID"; options.auth.pwd = "PWD"; options.auth.auth_type = AUTHTYPE_DEFAULT; - TSCommunication conn; + DBCommunication conn; EXPECT_NO_THROW(conn.Validate(options)); EXPECT_TRUE(conn.Validate(options)); } @@ -41,7 +41,7 @@ TEST(TestConnectionOptions, UID_is_empty) { options.auth.uid = ""; options.auth.pwd = "PWD"; options.auth.auth_type = AUTHTYPE_DEFAULT; - TSCommunication conn; + DBCommunication conn; EXPECT_THROW(conn.Validate(options), std::invalid_argument); } @@ -50,7 +50,7 @@ TEST(TestConnectionOptions, PWD_is_empty) { options.auth.uid = "UID"; options.auth.pwd = ""; options.auth.auth_type = AUTHTYPE_DEFAULT; - TSCommunication conn; + DBCommunication conn; EXPECT_THROW(conn.Validate(options), std::invalid_argument); } @@ -59,7 +59,7 @@ TEST(TestConnectionOptions, Auth_type_is_empty) { options.auth.uid = "UID"; options.auth.pwd = "PWD"; options.auth.auth_type = ""; - TSCommunication conn; + DBCommunication conn; EXPECT_THROW(conn.Validate(options), std::invalid_argument); } @@ -69,12 +69,12 @@ TEST(TestConnectionOptions, Timeout_is_alpha) { options.auth.pwd = "PWD"; options.auth.auth_type = ""; options.conn.timeout = "timeout"; - TSCommunication conn; + DBCommunication conn; EXPECT_THROW(conn.Validate(options), std::invalid_argument); } TEST(TestGetUserAgent, Success) { - TSCommunication conn; + DBCommunication conn; std::string expected = "ts-odbc." TIMESTREAMDRIVERVERSION " [tests]"; EXPECT_EQ(expected, conn.GetUserAgent()); } diff --git a/src/odbcdriver/CMakeLists.txt b/src/odbcdriver/CMakeLists.txt index 1e0d5d0fe..06f63ada9 100644 --- a/src/odbcdriver/CMakeLists.txt +++ b/src/odbcdriver/CMakeLists.txt @@ -56,7 +56,19 @@ set(CPP_SOURCE_FILES communication.cpp utility.cpp odbc_communication.cpp prefetch_queue.cpp + CancelQueryRequest.cpp + CancelQueryResult.cpp ColumnInfo.cpp + DatabaseQueryClient.cpp + DatabaseQueryEndpoint.cpp + DatabaseQueryErrors.cpp + DatabaseQueryErrorMarshaller.cpp + DescribeEndpointsRequest.cpp + DescribeEndpointsResult.cpp + Endpoint.cpp + QueryRequest.cpp + QueryResult.cpp + QueryStatus.cpp Row.cpp ScalarType.cpp Type.cpp @@ -100,7 +112,20 @@ set(CPP_HEADER_FILES communication.h odbc_communication.h prefetch_queue.h version.h + CancelQueryRequest.h + CancelQueryResult.h ColumnInfo.h + DatabaseQueryClient.h + DatabaseQueryEndpoint.h + DatabaseQueryErrors.h + DatabaseQueryErrorMarshaller.h + DatabaseQueryRequest.h + DescribeEndpointsRequest.h + DescribeEndpointsResult.h + Endpoint.h + QueryRequest.h + QueryResult.h + QueryStatus.h Row.h ScalarType.h Type.h diff --git a/src/odbcdriver/CancelQueryRequest.cpp b/src/odbcdriver/CancelQueryRequest.cpp new file mode 100644 index 000000000..e52a955be --- /dev/null +++ b/src/odbcdriver/CancelQueryRequest.cpp @@ -0,0 +1,33 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include "CancelQueryRequest.h" + +#include + +using namespace Aws::Utils::Json; +using namespace Aws::Utils; + +CancelQueryRequest::CancelQueryRequest() : m_queryIdHasBeenSet(false) { +} + +Aws::String CancelQueryRequest::SerializePayload() const { + JsonValue payload; + + if (m_queryIdHasBeenSet) { + payload.WithString("QueryId", m_queryId); + } + + return payload.View().WriteReadable(); +} + +Aws::Http::HeaderValueCollection CancelQueryRequest::GetRequestSpecificHeaders() + const { + Aws::Http::HeaderValueCollection headers; + headers.insert(Aws::Http::HeaderValuePair( + "X-Amz-Target", "Timestream_20181101.CancelQuery")); + return headers; +} \ No newline at end of file diff --git a/src/odbcdriver/CancelQueryRequest.h b/src/odbcdriver/CancelQueryRequest.h new file mode 100644 index 000000000..a201e826e --- /dev/null +++ b/src/odbcdriver/CancelQueryRequest.h @@ -0,0 +1,103 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include + +#include "DatabaseQueryRequest.h" + +#include + +class CancelQueryRequest : public DatabaseQueryRequest { + public: + CancelQueryRequest(); + + // Service request name is the Operation name which will send this request + // out, each operation should has unique request name, so that we can get + // operation's name from this request. Note: this is not true for response, + // multiple operations may have the same response name, so we can not get + // operation's name from response. + inline virtual const char* GetServiceRequestName() const override { + return "CancelQuery"; + } + + Aws::String SerializePayload() const override; + + Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override; + + /** + *

The id of the query that needs to be cancelled. QueryID + * is returned as part of QueryResult.

+ */ + inline const Aws::String& GetQueryId() const { + return m_queryId; + } + + /** + *

The id of the query that needs to be cancelled. QueryID + * is returned as part of QueryResult.

+ */ + inline bool QueryIdHasBeenSet() const { + return m_queryIdHasBeenSet; + } + + /** + *

The id of the query that needs to be cancelled. QueryID + * is returned as part of QueryResult.

+ */ + inline void SetQueryId(const Aws::String& value) { + m_queryIdHasBeenSet = true; + m_queryId = value; + } + + /** + *

The id of the query that needs to be cancelled. QueryID + * is returned as part of QueryResult.

+ */ + inline void SetQueryId(Aws::String&& value) { + m_queryIdHasBeenSet = true; + m_queryId = std::move(value); + } + + /** + *

The id of the query that needs to be cancelled. QueryID + * is returned as part of QueryResult.

+ */ + inline void SetQueryId(const char* value) { + m_queryIdHasBeenSet = true; + m_queryId.assign(value); + } + + /** + *

The id of the query that needs to be cancelled. QueryID + * is returned as part of QueryResult.

+ */ + inline CancelQueryRequest& WithQueryId(const Aws::String& value) { + SetQueryId(value); + return *this; + } + + /** + *

The id of the query that needs to be cancelled. QueryID + * is returned as part of QueryResult.

+ */ + inline CancelQueryRequest& WithQueryId(Aws::String&& value) { + SetQueryId(std::move(value)); + return *this; + } + + /** + *

The id of the query that needs to be cancelled. QueryID + * is returned as part of QueryResult.

+ */ + inline CancelQueryRequest& WithQueryId(const char* value) { + SetQueryId(value); + return *this; + } + + private: + Aws::String m_queryId; + bool m_queryIdHasBeenSet; +}; \ No newline at end of file diff --git a/src/odbcdriver/CancelQueryResult.cpp b/src/odbcdriver/CancelQueryResult.cpp new file mode 100644 index 000000000..002e29164 --- /dev/null +++ b/src/odbcdriver/CancelQueryResult.cpp @@ -0,0 +1,34 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include +#include +#include +#include "CancelQueryResult.h" + +#include + +using namespace Aws::Utils::Json; +using namespace Aws::Utils; +using namespace Aws; + +CancelQueryResult::CancelQueryResult() { +} + +CancelQueryResult::CancelQueryResult( + const Aws::AmazonWebServiceResult< JsonValue >& result) { + *this = result; +} + +CancelQueryResult& CancelQueryResult::operator=( + const Aws::AmazonWebServiceResult< JsonValue >& result) { + JsonView jsonValue = result.GetPayload().View(); + if (jsonValue.ValueExists("CancellationMessage")) { + m_cancellationMessage = jsonValue.GetString("CancellationMessage"); + } + + return *this; +} diff --git a/src/odbcdriver/CancelQueryResult.h b/src/odbcdriver/CancelQueryResult.h new file mode 100644 index 000000000..e1c3eda1c --- /dev/null +++ b/src/odbcdriver/CancelQueryResult.h @@ -0,0 +1,101 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include + +#include + +namespace Aws { +template < typename RESULT_TYPE > +class AmazonWebServiceResult; + +namespace Utils { +namespace Json { +class JsonValue; +} // namespace Json +} // namespace Utils +} // namespace Aws + +class CancelQueryResult { + public: + CancelQueryResult(); + CancelQueryResult( + const Aws::AmazonWebServiceResult< Aws::Utils::Json::JsonValue >& + result); + CancelQueryResult& operator=( + const Aws::AmazonWebServiceResult< Aws::Utils::Json::JsonValue >& + result); + + /** + *

A CancellationMessage is returned when a + * CancelQuery request for the query specified by + * QueryId has already been issued.

+ */ + inline const Aws::String& GetCancellationMessage() const { + return m_cancellationMessage; + } + + /** + *

A CancellationMessage is returned when a + * CancelQuery request for the query specified by + * QueryId has already been issued.

+ */ + inline void SetCancellationMessage(const Aws::String& value) { + m_cancellationMessage = value; + } + + /** + *

A CancellationMessage is returned when a + * CancelQuery request for the query specified by + * QueryId has already been issued.

+ */ + inline void SetCancellationMessage(Aws::String&& value) { + m_cancellationMessage = std::move(value); + } + + /** + *

A CancellationMessage is returned when a + * CancelQuery request for the query specified by + * QueryId has already been issued.

+ */ + inline void SetCancellationMessage(const char* value) { + m_cancellationMessage.assign(value); + } + + /** + *

A CancellationMessage is returned when a + * CancelQuery request for the query specified by + * QueryId has already been issued.

+ */ + inline CancelQueryResult& WithCancellationMessage( + const Aws::String& value) { + SetCancellationMessage(value); + return *this; + } + + /** + *

A CancellationMessage is returned when a + * CancelQuery request for the query specified by + * QueryId has already been issued.

+ */ + inline CancelQueryResult& WithCancellationMessage(Aws::String&& value) { + SetCancellationMessage(std::move(value)); + return *this; + } + + /** + *

A CancellationMessage is returned when a + * CancelQuery request for the query specified by + * QueryId has already been issued.

+ */ + inline CancelQueryResult& WithCancellationMessage(const char* value) { + SetCancellationMessage(value); + return *this; + } + + private: + Aws::String m_cancellationMessage; +}; diff --git a/src/odbcdriver/ColumnInfo.h b/src/odbcdriver/ColumnInfo.h index 8d1dc8102..8db0ce465 100644 --- a/src/odbcdriver/ColumnInfo.h +++ b/src/odbcdriver/ColumnInfo.h @@ -4,12 +4,19 @@ */ #pragma once -#include #include -#include #include #include +namespace Aws { +namespace Utils { +namespace Json { +class JsonValue; +class JsonView; +} // namespace Json +} // namespace Utils +} // namespace Aws + class Type; /** diff --git a/src/odbcdriver/DatabaseQueryClient.cpp b/src/odbcdriver/DatabaseQueryClient.cpp new file mode 100644 index 000000000..822714b4b --- /dev/null +++ b/src/odbcdriver/DatabaseQueryClient.cpp @@ -0,0 +1,340 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include "DatabaseQueryClient.h" +#include "DatabaseQueryEndpoint.h" +#include "DatabaseQueryErrorMarshaller.h" +#include "CancelQueryRequest.h" +#include "DescribeEndpointsRequest.h" +#include "QueryRequest.h" + +using namespace Aws; +using namespace Aws::Auth; +using namespace Aws::Client; +using namespace Aws::Http; +using namespace Aws::Utils::Json; + +static const char* SERVICE_NAME = "database"; +static const char* ALLOCATION_TAG = "DatabaseQueryClient"; + +DatabaseQueryClient::DatabaseQueryClient( + const Client::ClientConfiguration& clientConfiguration) + : BASECLASS( + clientConfiguration, + Aws::MakeShared< AWSAuthV4Signer >( + ALLOCATION_TAG, + Aws::MakeShared< DefaultAWSCredentialsProviderChain >( + ALLOCATION_TAG), + SERVICE_NAME, + Aws::Region::ComputeSignerRegion(clientConfiguration.region)), + Aws::MakeShared< DatabaseQueryErrorMarshaller >(ALLOCATION_TAG)), + m_executor(clientConfiguration.executor) { + init(clientConfiguration); +} + +DatabaseQueryClient::DatabaseQueryClient( + const AWSCredentials& credentials, + const Client::ClientConfiguration& clientConfiguration) + : BASECLASS( + clientConfiguration, + Aws::MakeShared< AWSAuthV4Signer >( + ALLOCATION_TAG, + Aws::MakeShared< SimpleAWSCredentialsProvider >(ALLOCATION_TAG, + credentials), + SERVICE_NAME, + Aws::Region::ComputeSignerRegion(clientConfiguration.region)), + Aws::MakeShared< DatabaseQueryErrorMarshaller >(ALLOCATION_TAG)), + m_executor(clientConfiguration.executor) { + init(clientConfiguration); +} + +DatabaseQueryClient::DatabaseQueryClient( + const std::shared_ptr< AWSCredentialsProvider >& credentialsProvider, + const Client::ClientConfiguration& clientConfiguration) + : BASECLASS( + clientConfiguration, + Aws::MakeShared< AWSAuthV4Signer >( + ALLOCATION_TAG, credentialsProvider, SERVICE_NAME, + Aws::Region::ComputeSignerRegion(clientConfiguration.region)), + Aws::MakeShared< DatabaseQueryErrorMarshaller >(ALLOCATION_TAG)), + m_executor(clientConfiguration.executor) { + init(clientConfiguration); +} + +DatabaseQueryClient::~DatabaseQueryClient() { +} + +void DatabaseQueryClient::init(const Client::ClientConfiguration& config) { + SetServiceClientName("Database Query"); + LoadDatabaseQuerySpecificConfig(config); + m_configScheme = SchemeMapper::ToString(config.scheme); + if (config.endpointOverride.empty()) { + m_uri = m_configScheme + "://" + + DatabaseQueryEndpoint::ForRegion(config.region, + config.useDualStack); + } else { + OverrideEndpoint(config.endpointOverride); + } +} + +void DatabaseQueryClient::LoadDatabaseQuerySpecificConfig( + const Aws::Client::ClientConfiguration& clientConfiguration) { + if (!clientConfiguration.endpointOverride.empty()) { + m_enableEndpointDiscovery = false; + } else if (clientConfiguration.enableEndpointDiscovery) { + m_enableEndpointDiscovery = + clientConfiguration.enableEndpointDiscovery.value(); + } else { + m_enableEndpointDiscovery = true; + + Aws::String enableEndpointDiscovery = + Aws::Environment::GetEnv("AWS_ENABLE_ENDPOINT_DISCOVERY"); + if (enableEndpointDiscovery.empty()) { + enableEndpointDiscovery = Aws::Config::GetCachedConfigValue( + clientConfiguration.profileName, "endpoint_discovery_enabled"); + } + + if (enableEndpointDiscovery == "true") { + m_enableEndpointDiscovery = true; + } else if (enableEndpointDiscovery == "false") { + m_enableEndpointDiscovery = false; + } else if (!enableEndpointDiscovery.empty()) { + AWS_LOGSTREAM_WARN( + "DatabaseQueryClient", + R"(Using the SDK default configuration for Endpoint Discovery. )" + R"(Make sure your environment variable "AWS_ENABLE_ENDPOINT_DISCOVERY" or )" + R"(your config file's variable "endpoint_discovery_enabled" are explicitly set to "true" or "false" (case-sensitive) or not set at all.)"); + } + } +} + +void DatabaseQueryClient::OverrideEndpoint(const Aws::String& endpoint) { + if (endpoint.compare(0, 7, "http://") == 0 + || endpoint.compare(0, 8, "https://") == 0) { + m_uri = endpoint; + } else { + m_uri = m_configScheme + "://" + endpoint; + } + m_enableEndpointDiscovery = false; +} + +CancelQueryOutcome DatabaseQueryClient::CancelQuery( + const CancelQueryRequest& request) const { + Aws::Http::URI uri = m_uri; + if (m_enableEndpointDiscovery) { + Aws::String endpointKey = "Shared"; + Aws::String endpoint; + if (m_endpointsCache.Get(endpointKey, endpoint)) { + AWS_LOGSTREAM_TRACE( + "CancelQuery", + "Making request to cached endpoint: " << endpoint); + uri = m_configScheme + "://" + endpoint; + } else { + AWS_LOGSTREAM_TRACE( + "CancelQuery", + "Endpoint discovery is enabled and there is no usable endpoint " + "in cache. Discovering endpoints from service..."); + DescribeEndpointsRequest endpointRequest; + auto endpointOutcome = DescribeEndpoints(endpointRequest); + if (endpointOutcome.IsSuccess() + && !endpointOutcome.GetResult().GetEndpoints().empty()) { + const auto& item = + endpointOutcome.GetResult().GetEndpoints()[0]; + m_endpointsCache.Put( + endpointKey, item.GetAddress(), + std::chrono::minutes(item.GetCachePeriodInMinutes())); + uri = m_configScheme + "://" + item.GetAddress(); + AWS_LOGSTREAM_TRACE("CancelQuery", + "Endpoints cache updated. Address: " + << item.GetAddress() << ". Valid in: " + << item.GetCachePeriodInMinutes() + << " minutes. Making request to newly " + "discovered endpoint."); + } else { + AWS_LOGSTREAM_ERROR("CancelQuery", + "Failed to discover endpoints " + << endpointOutcome.GetError()); + return CancelQueryOutcome( + Aws::Client::AWSError< DatabaseQueryErrors >( + DatabaseQueryErrors::RESOURCE_NOT_FOUND, + "INVALID_ENDPOINT", "Failed to discover endpoint", + false)); + } + } + } else { + Aws::String errorMessage = + R"(Unable to perform "CancelQuery" without endpoint discovery. )" + R"(Make sure your environment variable "AWS_ENABLE_ENDPOINT_DISCOVERY", )" + R"(your config file's variable "endpoint_discovery_enabled" and )" + R"(ClientConfiguration's "enableEndpointDiscovery" are explicitly set to true or not set at all.)"; + return CancelQueryOutcome( + Aws::Client::AWSError< DatabaseQueryErrors >( + DatabaseQueryErrors::INVALID_ACTION, "INVALID_ACTION", + errorMessage, false)); + } + return CancelQueryOutcome(MakeRequest(uri, request, + Aws::Http::HttpMethod::HTTP_POST, + Aws::Auth::SIGV4_SIGNER)); +} + +CancelQueryOutcomeCallable DatabaseQueryClient::CancelQueryCallable( + const CancelQueryRequest& request) const { + auto task = Aws::MakeShared< std::packaged_task< CancelQueryOutcome() > >( + ALLOCATION_TAG, + [this, request]() { return this->CancelQuery(request); }); + auto packagedFunction = [task]() { (*task)(); }; + m_executor->Submit(packagedFunction); + return task->get_future(); +} + +void DatabaseQueryClient::CancelQueryAsync( + const CancelQueryRequest& request, + const CancelQueryResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) + const { + m_executor->Submit([this, request, handler, context]() { + this->CancelQueryAsyncHelper(request, handler, context); + }); +} + +void DatabaseQueryClient::CancelQueryAsyncHelper( + const CancelQueryRequest& request, + const CancelQueryResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) + const { + handler(this, request, CancelQuery(request), context); +} + +DescribeEndpointsOutcome DatabaseQueryClient::DescribeEndpoints( + const DescribeEndpointsRequest& request) const { + Aws::Http::URI uri = m_uri; + return DescribeEndpointsOutcome( + MakeRequest(uri, request, Aws::Http::HttpMethod::HTTP_POST, + Aws::Auth::SIGV4_SIGNER)); +} + +DescribeEndpointsOutcomeCallable +DatabaseQueryClient::DescribeEndpointsCallable( + const DescribeEndpointsRequest& request) const { + auto task = + Aws::MakeShared< std::packaged_task< DescribeEndpointsOutcome() > >( + ALLOCATION_TAG, + [this, request]() { return this->DescribeEndpoints(request); }); + auto packagedFunction = [task]() { (*task)(); }; + m_executor->Submit(packagedFunction); + return task->get_future(); +} + +void DatabaseQueryClient::DescribeEndpointsAsync( + const DescribeEndpointsRequest& request, + const DescribeEndpointsResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) + const { + m_executor->Submit([this, request, handler, context]() { + this->DescribeEndpointsAsyncHelper(request, handler, context); + }); +} + +void DatabaseQueryClient::DescribeEndpointsAsyncHelper( + const DescribeEndpointsRequest& request, + const DescribeEndpointsResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) + const { + handler(this, request, DescribeEndpoints(request), context); +} + +QueryOutcome DatabaseQueryClient::Query(const QueryRequest& request) const { + Aws::Http::URI uri = m_uri; + if (m_enableEndpointDiscovery) { + Aws::String endpointKey = "Shared"; + Aws::String endpoint; + if (m_endpointsCache.Get(endpointKey, endpoint)) { + AWS_LOGSTREAM_TRACE( + "Query", "Making request to cached endpoint: " << endpoint); + uri = m_configScheme + "://" + endpoint; + } else { + AWS_LOGSTREAM_TRACE( + "Query", + "Endpoint discovery is enabled and there is no usable endpoint " + "in cache. Discovering endpoints from service..."); + DescribeEndpointsRequest endpointRequest; + auto endpointOutcome = DescribeEndpoints(endpointRequest); + if (endpointOutcome.IsSuccess() + && !endpointOutcome.GetResult().GetEndpoints().empty()) { + const auto& item = + endpointOutcome.GetResult().GetEndpoints()[0]; + m_endpointsCache.Put( + endpointKey, item.GetAddress(), + std::chrono::minutes(item.GetCachePeriodInMinutes())); + uri = m_configScheme + "://" + item.GetAddress(); + AWS_LOGSTREAM_TRACE("Query", + "Endpoints cache updated. Address: " + << item.GetAddress() << ". Valid in: " + << item.GetCachePeriodInMinutes() + << " minutes. Making request to newly " + "discovered endpoint."); + } else { + AWS_LOGSTREAM_ERROR("Query", "Failed to discover endpoints " + << endpointOutcome.GetError()); + return QueryOutcome( + Aws::Client::AWSError< DatabaseQueryErrors >( + DatabaseQueryErrors::RESOURCE_NOT_FOUND, + "INVALID_ENDPOINT", "Failed to discover endpoint", + false)); + } + } + } else { + Aws::String errorMessage = + R"(Unable to perform "Query" without endpoint discovery. )" + R"(Make sure your environment variable "AWS_ENABLE_ENDPOINT_DISCOVERY", )" + R"(your config file's variable "endpoint_discovery_enabled" and )" + R"(ClientConfiguration's "enableEndpointDiscovery" are explicitly set to true or not set at all.)"; + return QueryOutcome(Aws::Client::AWSError< DatabaseQueryErrors >( + DatabaseQueryErrors::INVALID_ACTION, "INVALID_ACTION", + errorMessage, false)); + } + return QueryOutcome(MakeRequest(uri, request, + Aws::Http::HttpMethod::HTTP_POST, + Aws::Auth::SIGV4_SIGNER)); +} + +QueryOutcomeCallable DatabaseQueryClient::QueryCallable( + const QueryRequest& request) const { + auto task = Aws::MakeShared< std::packaged_task< QueryOutcome() > >( + ALLOCATION_TAG, [this, request]() { return this->Query(request); }); + auto packagedFunction = [task]() { (*task)(); }; + m_executor->Submit(packagedFunction); + return task->get_future(); +} + +void DatabaseQueryClient::QueryAsync( + const QueryRequest& request, const QueryResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) + const { + m_executor->Submit([this, request, handler, context]() { + this->QueryAsyncHelper(request, handler, context); + }); +} + +void DatabaseQueryClient::QueryAsyncHelper( + const QueryRequest& request, const QueryResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) + const { + handler(this, request, Query(request), context); +} diff --git a/src/odbcdriver/DatabaseQueryClient.h b/src/odbcdriver/DatabaseQueryClient.h new file mode 100644 index 000000000..5ae9ddfa2 --- /dev/null +++ b/src/odbcdriver/DatabaseQueryClient.h @@ -0,0 +1,304 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include + +#include "CancelQueryResult.h" +#include "DatabaseQueryErrors.h" +#include "DescribeEndpointsResult.h" +#include "QueryResult.h" + +namespace Aws { + +namespace Http { +class HttpClient; +class HttpClientFactory; +} // namespace Http + +namespace Utils { +template < typename R, typename E > +class Outcome; +namespace Threading { +class Executor; +} // namespace Threading +} // namespace Utils + +namespace Auth { +class AWSCredentials; +class AWSCredentialsProvider; +} // namespace Auth + +namespace Client { +class RetryStrategy; +} // namespace Client +} // namespace Aws + +class CancelQueryRequest; +class DescribeEndpointsRequest; +class QueryRequest; + +typedef Aws::Utils::Outcome< CancelQueryResult, DatabaseQueryError > + CancelQueryOutcome; +typedef Aws::Utils::Outcome< DescribeEndpointsResult, DatabaseQueryError > + DescribeEndpointsOutcome; +typedef Aws::Utils::Outcome< QueryResult, DatabaseQueryError > QueryOutcome; + +typedef std::future< CancelQueryOutcome > CancelQueryOutcomeCallable; +typedef std::future< DescribeEndpointsOutcome > + DescribeEndpointsOutcomeCallable; +typedef std::future< QueryOutcome > QueryOutcomeCallable; + +class DatabaseQueryClient; + +typedef std::function< void( + const DatabaseQueryClient*, const CancelQueryRequest&, + const CancelQueryOutcome&, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >&) > + CancelQueryResponseReceivedHandler; +typedef std::function< void( + const DatabaseQueryClient*, const DescribeEndpointsRequest&, + const DescribeEndpointsOutcome&, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >&) > + DescribeEndpointsResponseReceivedHandler; +typedef std::function< void( + const DatabaseQueryClient*, const QueryRequest&, + const QueryOutcome&, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >&) > + QueryResponseReceivedHandler; + +/** + *

+ */ +class DatabaseQueryClient : public Aws::Client::AWSJsonClient { + public: + typedef Aws::Client::AWSJsonClient BASECLASS; + + /** + * Initializes client to use DefaultCredentialProviderChain, with default + * http client factory, and optional client config. If client config is not + * specified, it will be initialized to default values. + */ + DatabaseQueryClient( + const Aws::Client::ClientConfiguration& clientConfiguration = + Aws::Client::ClientConfiguration()); + + /** + * Initializes client to use SimpleAWSCredentialsProvider, with default http + * client factory, and optional client config. If client config is not + * specified, it will be initialized to default values. + */ + DatabaseQueryClient( + const Aws::Auth::AWSCredentials& credentials, + const Aws::Client::ClientConfiguration& clientConfiguration = + Aws::Client::ClientConfiguration()); + + /** + * Initializes client to use specified credentials provider with specified + * client config. If http client factory is not supplied, the default http + * client factory will be used + */ + DatabaseQueryClient( + const std::shared_ptr< Aws::Auth::AWSCredentialsProvider >& + credentialsProvider, + const Aws::Client::ClientConfiguration& clientConfiguration = + Aws::Client::ClientConfiguration()); + + virtual ~DatabaseQueryClient(); + + /** + *

Cancels a query that has been issued. Cancellation is guaranteed only + * if the query has not completed execution before the cancellation request + * was issued. Because cancellation is an idempotent operation, subsequent + * cancellation requests will return a CancellationMessage, + * indicating that the query has already been canceled.

See + * Also:

AWS + * API Reference

+ */ + virtual CancelQueryOutcome CancelQuery( + const CancelQueryRequest& request) const; + + /** + *

Cancels a query that has been issued. Cancellation is guaranteed only + * if the query has not completed execution before the cancellation request + * was issued. Because cancellation is an idempotent operation, subsequent + * cancellation requests will return a CancellationMessage, + * indicating that the query has already been canceled.

See + * Also:

AWS + * API Reference

+ * + * returns a future to the operation so that it can be executed in parallel + * to other requests. + */ + virtual CancelQueryOutcomeCallable CancelQueryCallable( + const CancelQueryRequest& request) const; + + /** + *

Cancels a query that has been issued. Cancellation is guaranteed only + * if the query has not completed execution before the cancellation request + * was issued. Because cancellation is an idempotent operation, subsequent + * cancellation requests will return a CancellationMessage, + * indicating that the query has already been canceled.

See + * Also:

AWS + * API Reference

+ * + * Queues the request into a thread executor and triggers associated + * callback when operation has finished. + */ + virtual void CancelQueryAsync( + const CancelQueryRequest& request, + const CancelQueryResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& + context = nullptr) const; + + /** + *

DescribeEndpoints returns a list of available endpoints to make + * Timestream API calls against. This API is available through both Write + * and Query.

Because Timestream’s SDKs are designed to transparently + * work with the service’s architecture, including the management and + * mapping of the service endpoints, it is not recommended that you use + * this API unless:

  • Your application uses a programming + * language that does not yet have SDK support

  • You require + * better control over the client-side implementation

For + * detailed information on how to use DescribeEndpoints, see The + * Endpoint Discovery Pattern and REST APIs.

See Also:

AWS + * API Reference

+ */ + virtual DescribeEndpointsOutcome DescribeEndpoints( + const DescribeEndpointsRequest& request) const; + + /** + *

DescribeEndpoints returns a list of available endpoints to make + * Timestream API calls against. This API is available through both Write + * and Query.

Because Timestream’s SDKs are designed to transparently + * work with the service’s architecture, including the management and + * mapping of the service endpoints, it is not recommended that you use + * this API unless:

  • Your application uses a programming + * language that does not yet have SDK support

  • You require + * better control over the client-side implementation

For + * detailed information on how to use DescribeEndpoints, see The + * Endpoint Discovery Pattern and REST APIs.

See Also:

AWS + * API Reference

+ * + * returns a future to the operation so that it can be executed in parallel + * to other requests. + */ + virtual DescribeEndpointsOutcomeCallable DescribeEndpointsCallable( + const DescribeEndpointsRequest& request) const; + + /** + *

DescribeEndpoints returns a list of available endpoints to make + * Timestream API calls against. This API is available through both Write + * and Query.

Because Timestream’s SDKs are designed to transparently + * work with the service’s architecture, including the management and + * mapping of the service endpoints, it is not recommended that you use + * this API unless:

  • Your application uses a programming + * language that does not yet have SDK support

  • You require + * better control over the client-side implementation

For + * detailed information on how to use DescribeEndpoints, see The + * Endpoint Discovery Pattern and REST APIs.

See Also:

AWS + * API Reference

+ * + * Queues the request into a thread executor and triggers associated + * callback when operation has finished. + */ + virtual void DescribeEndpointsAsync( + const DescribeEndpointsRequest& request, + const DescribeEndpointsResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& + context = nullptr) const; + + /** + *

Query is a synchronous operation that enables you to execute a query. + * Query will timeout after 60 seconds. You must update the default timeout + * in the SDK to support a timeout of 60 seconds. The result set will be + * truncated to 1MB. Service quotas apply. For more information, see Quotas + * in the Timestream Developer Guide.

See Also:

AWS + * API Reference

+ */ + virtual QueryOutcome Query(const QueryRequest& request) const; + + /** + *

Query is a synchronous operation that enables you to execute a query. + * Query will timeout after 60 seconds. You must update the default timeout + * in the SDK to support a timeout of 60 seconds. The result set will be + * truncated to 1MB. Service quotas apply. For more information, see Quotas + * in the Timestream Developer Guide.

See Also:

AWS + * API Reference

+ * + * returns a future to the operation so that it can be executed in parallel + * to other requests. + */ + virtual QueryOutcomeCallable QueryCallable( + const QueryRequest& request) const; + + /** + *

Query is a synchronous operation that enables you to execute a query. + * Query will timeout after 60 seconds. You must update the default timeout + * in the SDK to support a timeout of 60 seconds. The result set will be + * truncated to 1MB. Service quotas apply. For more information, see Quotas + * in the Timestream Developer Guide.

See Also:

AWS + * API Reference

+ * + * Queues the request into a thread executor and triggers associated + * callback when operation has finished. + */ + virtual void QueryAsync( + const QueryRequest& request, + const QueryResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& + context = nullptr) const; + + void OverrideEndpoint(const Aws::String& endpoint); + + private: + void init(const Aws::Client::ClientConfiguration& clientConfiguration); + void LoadDatabaseQuerySpecificConfig( + const Aws::Client::ClientConfiguration& clientConfiguration); + void CancelQueryAsyncHelper( + const CancelQueryRequest& request, + const CancelQueryResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) + const; + void DescribeEndpointsAsyncHelper( + const DescribeEndpointsRequest& request, + const DescribeEndpointsResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) + const; + void QueryAsyncHelper( + const QueryRequest& request, + const QueryResponseReceivedHandler& handler, + const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) + const; + + Aws::String m_uri; + mutable Aws::Utils::ConcurrentCache< Aws::String, Aws::String > + m_endpointsCache; + bool m_enableEndpointDiscovery; + Aws::String m_configScheme; + std::shared_ptr< Aws::Utils::Threading::Executor > m_executor; +}; \ No newline at end of file diff --git a/src/odbcdriver/DatabaseQueryEndpoint.cpp b/src/odbcdriver/DatabaseQueryEndpoint.cpp new file mode 100644 index 000000000..10fa0b820 --- /dev/null +++ b/src/odbcdriver/DatabaseQueryEndpoint.cpp @@ -0,0 +1,49 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include +#include "DatabaseQueryEndpoint.h" + +namespace DatabaseQueryEndpoint { +static const int CN_NORTH_1_HASH = + Aws::Utils::HashingUtils::HashString("cn-north-1"); +static const int CN_NORTHWEST_1_HASH = + Aws::Utils::HashingUtils::HashString("cn-northwest-1"); +static const int US_ISO_EAST_1_HASH = + Aws::Utils::HashingUtils::HashString("us-iso-east-1"); +static const int US_ISOB_EAST_1_HASH = + Aws::Utils::HashingUtils::HashString("us-isob-east-1"); + +Aws::String ForRegion(const Aws::String& regionName, bool useDualStack) { + // Fallback to us-east-1 if global endpoint does not exists. + Aws::String region = regionName == Aws::Region::AWS_GLOBAL + ? Aws::Region::US_EAST_1 + : regionName; + auto hash = Aws::Utils::HashingUtils::HashString(region.c_str()); + + Aws::StringStream ss; + ss << "query.database" + << "."; + + if (useDualStack) { + ss << "dualstack."; + } + + ss << region; + + if (hash == CN_NORTH_1_HASH || hash == CN_NORTHWEST_1_HASH) { + ss << ".amazonaws.com.cn"; + } else if (hash == US_ISO_EAST_1_HASH) { + ss << ".c2s.ic.gov"; + } else if (hash == US_ISOB_EAST_1_HASH) { + ss << ".sc2s.sgov.gov"; + } else { + ss << ".amazonaws.com"; + } + + return ss.str(); +} +} // namespace DatabaseQueryEndpoint \ No newline at end of file diff --git a/src/odbcdriver/DatabaseQueryEndpoint.h b/src/odbcdriver/DatabaseQueryEndpoint.h new file mode 100644 index 000000000..c8c6d0d1e --- /dev/null +++ b/src/odbcdriver/DatabaseQueryEndpoint.h @@ -0,0 +1,13 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include +#include + +namespace DatabaseQueryEndpoint +{ +Aws::String ForRegion(const Aws::String& regionName, bool useDualStack = false); +} // namespace DatabaseQueryEndpoint \ No newline at end of file diff --git a/src/odbcdriver/DatabaseQueryErrorMarshaller.cpp b/src/odbcdriver/DatabaseQueryErrorMarshaller.cpp new file mode 100644 index 000000000..ec822d223 --- /dev/null +++ b/src/odbcdriver/DatabaseQueryErrorMarshaller.cpp @@ -0,0 +1,21 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include "DatabaseQueryErrorMarshaller.h" +#include "DatabaseQueryErrors.h" + +using namespace Aws::Client; + +AWSError< CoreErrors > DatabaseQueryErrorMarshaller::FindErrorByName( + const char* errorName) const { + AWSError< CoreErrors > error = + DatabaseQueryErrorMapper::GetErrorForName(errorName); + if (error.GetErrorType() != CoreErrors::UNKNOWN) { + return error; + } + + return AWSErrorMarshaller::FindErrorByName(errorName); +} \ No newline at end of file diff --git a/src/odbcdriver/DatabaseQueryErrorMarshaller.h b/src/odbcdriver/DatabaseQueryErrorMarshaller.h new file mode 100644 index 000000000..a6af2de25 --- /dev/null +++ b/src/odbcdriver/DatabaseQueryErrorMarshaller.h @@ -0,0 +1,14 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once + +#include + +class DatabaseQueryErrorMarshaller : public Aws::Client::JsonErrorMarshaller { + public: + Aws::Client::AWSError< Aws::Client::CoreErrors > FindErrorByName( + const char* exceptionName) const override; +}; \ No newline at end of file diff --git a/src/odbcdriver/DatabaseQueryErrors.cpp b/src/odbcdriver/DatabaseQueryErrors.cpp new file mode 100644 index 000000000..3cd47829a --- /dev/null +++ b/src/odbcdriver/DatabaseQueryErrors.cpp @@ -0,0 +1,45 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include +#include "DatabaseQueryErrors.h" + +using namespace Aws::Client; +using namespace Aws::Utils; + +namespace DatabaseQueryErrorMapper +{ + +static const int INVALID_ENDPOINT_HASH = HashingUtils::HashString("InvalidEndpointException"); +static const int CONFLICT_HASH = HashingUtils::HashString("ConflictException"); +static const int INTERNAL_SERVER_HASH = HashingUtils::HashString("InternalServerException"); +static const int QUERY_EXECUTION_HASH = HashingUtils::HashString("QueryExecutionException"); + + +AWSError GetErrorForName(const char* errorName) +{ + int hashCode = HashingUtils::HashString(errorName); + + if (hashCode == INVALID_ENDPOINT_HASH) + { + return AWSError(static_cast(DatabaseQueryErrors::INVALID_ENDPOINT), false); + } + else if (hashCode == CONFLICT_HASH) + { + return AWSError(static_cast(DatabaseQueryErrors::CONFLICT), false); + } + else if (hashCode == INTERNAL_SERVER_HASH) + { + return AWSError(static_cast(DatabaseQueryErrors::INTERNAL_SERVER), false); + } + else if (hashCode == QUERY_EXECUTION_HASH) + { + return AWSError(static_cast(DatabaseQueryErrors::QUERY_EXECUTION), false); + } + return AWSError(CoreErrors::UNKNOWN, false); +} + +} // namespace DatabaseQueryErrorMapper \ No newline at end of file diff --git a/src/odbcdriver/DatabaseQueryErrors.h b/src/odbcdriver/DatabaseQueryErrors.h new file mode 100644 index 000000000..1da78922f --- /dev/null +++ b/src/odbcdriver/DatabaseQueryErrors.h @@ -0,0 +1,77 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once + +#include +#include + +enum class DatabaseQueryErrors { + // From Core// + ////////////////////////////////////////////////////////////////////////////////////////// + INCOMPLETE_SIGNATURE = 0, + INTERNAL_FAILURE = 1, + INVALID_ACTION = 2, + INVALID_CLIENT_TOKEN_ID = 3, + INVALID_PARAMETER_COMBINATION = 4, + INVALID_QUERY_PARAMETER = 5, + INVALID_PARAMETER_VALUE = 6, + MISSING_ACTION = 7, // SDK should never allow + MISSING_AUTHENTICATION_TOKEN = 8, // SDK should never allow + MISSING_PARAMETER = 9, // SDK should never allow + OPT_IN_REQUIRED = 10, + REQUEST_EXPIRED = 11, + SERVICE_UNAVAILABLE = 12, + THROTTLING = 13, + VALIDATION = 14, + ACCESS_DENIED = 15, + RESOURCE_NOT_FOUND = 16, + UNRECOGNIZED_CLIENT = 17, + MALFORMED_QUERY_STRING = 18, + SLOW_DOWN = 19, + REQUEST_TIME_TOO_SKEWED = 20, + INVALID_SIGNATURE = 21, + SIGNATURE_DOES_NOT_MATCH = 22, + INVALID_ACCESS_KEY_ID = 23, + REQUEST_TIMEOUT = 24, + NETWORK_CONNECTION = 99, + + UNKNOWN = 100, + /////////////////////////////////////////////////////////////////////////////////////////// + + CONFLICT = static_cast< int >( + Aws::Client::CoreErrors::SERVICE_EXTENSION_START_RANGE) + + 1, + INTERNAL_SERVER, + INVALID_ENDPOINT, + QUERY_EXECUTION +}; + +class DatabaseQueryError : public Aws::Client::AWSError< DatabaseQueryErrors > { + public: + DatabaseQueryError() { + } + DatabaseQueryError( + const Aws::Client::AWSError< Aws::Client::CoreErrors >& rhs) + : Aws::Client::AWSError< DatabaseQueryErrors >(rhs) { + } + DatabaseQueryError(Aws::Client::AWSError< Aws::Client::CoreErrors >&& rhs) + : Aws::Client::AWSError< DatabaseQueryErrors >(rhs) { + } + DatabaseQueryError(const Aws::Client::AWSError< DatabaseQueryErrors >& rhs) + : Aws::Client::AWSError< DatabaseQueryErrors >(rhs) { + } + DatabaseQueryError(Aws::Client::AWSError< DatabaseQueryErrors >&& rhs) + : Aws::Client::AWSError< DatabaseQueryErrors >(rhs) { + } + + template < typename T > + T GetModeledError(); +}; + +namespace DatabaseQueryErrorMapper { +Aws::Client::AWSError< Aws::Client::CoreErrors > GetErrorForName( + const char* errorName); +} \ No newline at end of file diff --git a/src/odbcdriver/DatabaseQueryRequest.h b/src/odbcdriver/DatabaseQueryRequest.h new file mode 100644 index 000000000..aee9f760e --- /dev/null +++ b/src/odbcdriver/DatabaseQueryRequest.h @@ -0,0 +1,39 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include +#include +#include + +class DatabaseQueryRequest : public Aws::AmazonSerializableWebServiceRequest { + public: + virtual ~DatabaseQueryRequest() { + } + + void AddParametersToRequest(Aws::Http::HttpRequest& httpRequest) const { + AWS_UNREFERENCED_PARAM(httpRequest); + } + + inline Aws::Http::HeaderValueCollection GetHeaders() const override { + auto headers = GetRequestSpecificHeaders(); + + if (headers.size() == 0 + || (headers.size() > 0 + && headers.count(Aws::Http::CONTENT_TYPE_HEADER) == 0)) { + headers.emplace( + Aws::Http::HeaderValuePair(Aws::Http::CONTENT_TYPE_HEADER, + Aws::AMZN_JSON_CONTENT_TYPE_1_0)); + } + headers.emplace(Aws::Http::HeaderValuePair( + Aws::Http::API_VERSION_HEADER, "2018-11-01")); + return headers; + } + + protected: + virtual Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const { + return Aws::Http::HeaderValueCollection(); + } +}; \ No newline at end of file diff --git a/src/odbcdriver/Datum.h b/src/odbcdriver/Datum.h index 5881c4435..d0e712657 100644 --- a/src/odbcdriver/Datum.h +++ b/src/odbcdriver/Datum.h @@ -4,23 +4,19 @@ */ #pragma once -#include #include #include #include #include -namespace Aws -{ -namespace Utils -{ -namespace Json -{ - class JsonValue; - class JsonView; -} // namespace Json -} // namespace Utils -}// namespace Aws +namespace Aws { +namespace Utils { +namespace Json { +class JsonValue; +class JsonView; +} // namespace Json +} // namespace Utils +} // namespace Aws class Row; diff --git a/src/odbcdriver/DescribeEndpointsRequest.cpp b/src/odbcdriver/DescribeEndpointsRequest.cpp new file mode 100644 index 000000000..82d059e5e --- /dev/null +++ b/src/odbcdriver/DescribeEndpointsRequest.cpp @@ -0,0 +1,27 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include "DescribeEndpointsRequest.h" + +#include + +using namespace Aws::Utils::Json; +using namespace Aws::Utils; + +DescribeEndpointsRequest::DescribeEndpointsRequest() { +} + +Aws::String DescribeEndpointsRequest::SerializePayload() const { + return "{}"; +} + +Aws::Http::HeaderValueCollection +DescribeEndpointsRequest::GetRequestSpecificHeaders() const { + Aws::Http::HeaderValueCollection headers; + headers.insert(Aws::Http::HeaderValuePair( + "X-Amz-Target", "Database_20181101.DescribeEndpoints")); + return headers; +} diff --git a/src/odbcdriver/DescribeEndpointsRequest.h b/src/odbcdriver/DescribeEndpointsRequest.h new file mode 100644 index 000000000..9529af6bc --- /dev/null +++ b/src/odbcdriver/DescribeEndpointsRequest.h @@ -0,0 +1,28 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include "DatabaseQueryRequest.h" + +/** + */ +class DescribeEndpointsRequest + : public DatabaseQueryRequest { + public: + DescribeEndpointsRequest(); + + // Service request name is the Operation name which will send this request + // out, each operation should has unique request name, so that we can get + // operation's name from this request. Note: this is not true for response, + // multiple operations may have the same response name, so we can not get + // operation's name from response. + inline virtual const char* GetServiceRequestName() const override { + return "DescribeEndpoints"; + } + + Aws::String SerializePayload() const override; + + Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override; +}; \ No newline at end of file diff --git a/src/odbcdriver/DescribeEndpointsResult.cpp b/src/odbcdriver/DescribeEndpointsResult.cpp new file mode 100644 index 000000000..da07bf9da --- /dev/null +++ b/src/odbcdriver/DescribeEndpointsResult.cpp @@ -0,0 +1,38 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include +#include +#include +#include "DescribeEndpointsResult.h" + +#include + +using namespace Aws::Utils::Json; +using namespace Aws::Utils; +using namespace Aws; + +DescribeEndpointsResult::DescribeEndpointsResult() { +} + +DescribeEndpointsResult::DescribeEndpointsResult( + const Aws::AmazonWebServiceResult< JsonValue >& result) { + *this = result; +} + +DescribeEndpointsResult& DescribeEndpointsResult::operator=( + const Aws::AmazonWebServiceResult< JsonValue >& result) { + JsonView jsonValue = result.GetPayload().View(); + if (jsonValue.ValueExists("Endpoints")) { + Array< JsonView > endpointsJsonList = jsonValue.GetArray("Endpoints"); + for (unsigned endpointsIndex = 0; + endpointsIndex < endpointsJsonList.GetLength(); ++endpointsIndex) { + m_endpoints.push_back(endpointsJsonList[endpointsIndex].AsObject()); + } + } + + return *this; +} diff --git a/src/odbcdriver/DescribeEndpointsResult.h b/src/odbcdriver/DescribeEndpointsResult.h new file mode 100644 index 000000000..b0f8cb309 --- /dev/null +++ b/src/odbcdriver/DescribeEndpointsResult.h @@ -0,0 +1,97 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include +#include + +#include "Endpoint.h" + +namespace Aws { +template < typename RESULT_TYPE > +class AmazonWebServiceResult; + +namespace Utils { +namespace Json { +class JsonValue; +} // namespace Json +} // namespace Utils +} // namespace Aws + +class DescribeEndpointsResult { + public: + DescribeEndpointsResult(); + DescribeEndpointsResult( + const Aws::AmazonWebServiceResult< Aws::Utils::Json::JsonValue >& + result); + DescribeEndpointsResult& operator=( + const Aws::AmazonWebServiceResult< Aws::Utils::Json::JsonValue >& + result); + + /** + *

An Endpoints object is returned when a + * DescribeEndpoints request is made.

+ */ + inline const Aws::Vector< Endpoint >& GetEndpoints() const { + return m_endpoints; + } + + /** + *

An Endpoints object is returned when a + * DescribeEndpoints request is made.

+ */ + inline void SetEndpoints(const Aws::Vector< Endpoint >& value) { + m_endpoints = value; + } + + /** + *

An Endpoints object is returned when a + * DescribeEndpoints request is made.

+ */ + inline void SetEndpoints(Aws::Vector< Endpoint >&& value) { + m_endpoints = std::move(value); + } + + /** + *

An Endpoints object is returned when a + * DescribeEndpoints request is made.

+ */ + inline DescribeEndpointsResult& WithEndpoints( + const Aws::Vector< Endpoint >& value) { + SetEndpoints(value); + return *this; + } + + /** + *

An Endpoints object is returned when a + * DescribeEndpoints request is made.

+ */ + inline DescribeEndpointsResult& WithEndpoints( + Aws::Vector< Endpoint >&& value) { + SetEndpoints(std::move(value)); + return *this; + } + + /** + *

An Endpoints object is returned when a + * DescribeEndpoints request is made.

+ */ + inline DescribeEndpointsResult& AddEndpoints(const Endpoint& value) { + m_endpoints.push_back(value); + return *this; + } + + /** + *

An Endpoints object is returned when a + * DescribeEndpoints request is made.

+ */ + inline DescribeEndpointsResult& AddEndpoints(Endpoint&& value) { + m_endpoints.push_back(std::move(value)); + return *this; + } + + private: + Aws::Vector< Endpoint > m_endpoints; +}; \ No newline at end of file diff --git a/src/odbcdriver/Endpoint.cpp b/src/odbcdriver/Endpoint.cpp new file mode 100644 index 000000000..0e7badf7c --- /dev/null +++ b/src/odbcdriver/Endpoint.cpp @@ -0,0 +1,50 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include "Endpoint.h" + +#include + +using namespace Aws::Utils::Json; +using namespace Aws::Utils; + +Endpoint::Endpoint() + : m_addressHasBeenSet(false) { +} + +Endpoint::Endpoint(JsonView jsonValue) + : m_addressHasBeenSet(false) { + *this = jsonValue; +} + +Endpoint& Endpoint::operator=(JsonView jsonValue) { + if (jsonValue.ValueExists("Address")) { + m_address = jsonValue.GetString("Address"); + m_addressHasBeenSet = true; + } + + if (jsonValue.ValueExists("CachePeriodInMinutes")) { + m_cachePeriodInMinutes = jsonValue.GetInt64("CachePeriodInMinutes"); + + m_cachePeriodInMinutesHasBeenSet = true; + } + + return *this; +} + +JsonValue Endpoint::Jsonize() const { + JsonValue payload; + + if (m_addressHasBeenSet) { + payload.WithString("Address", m_address); + } + + if (m_cachePeriodInMinutesHasBeenSet) { + payload.WithInt64("CachePeriodInMinutes", m_cachePeriodInMinutes); + } + + return payload; +} \ No newline at end of file diff --git a/src/odbcdriver/Endpoint.h b/src/odbcdriver/Endpoint.h new file mode 100644 index 000000000..c82bf7df9 --- /dev/null +++ b/src/odbcdriver/Endpoint.h @@ -0,0 +1,131 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include + +#include + +namespace Aws { +namespace Utils { +namespace Json { +class JsonValue; +class JsonView; +} // namespace Json +} // namespace Utils +} // namespace Aws + +/** + *

Represents an available endpoint against which to make API calls agaisnt, + * as well as the TTL for that endpoint.

See Also:

AWS + * API Reference

+ */ +class Endpoint { + public: + Endpoint(); + Endpoint(Aws::Utils::Json::JsonView jsonValue); + Endpoint& operator=(Aws::Utils::Json::JsonView jsonValue); + Aws::Utils::Json::JsonValue Jsonize() const; + + /** + *

An endpoint address.

+ */ + inline const Aws::String& GetAddress() const { + return m_address; + } + + /** + *

An endpoint address.

+ */ + inline bool AddressHasBeenSet() const { + return m_addressHasBeenSet; + } + + /** + *

An endpoint address.

+ */ + inline void SetAddress(const Aws::String& value) { + m_addressHasBeenSet = true; + m_address = value; + } + + /** + *

An endpoint address.

+ */ + inline void SetAddress(Aws::String&& value) { + m_addressHasBeenSet = true; + m_address = std::move(value); + } + + /** + *

An endpoint address.

+ */ + inline void SetAddress(const char* value) { + m_addressHasBeenSet = true; + m_address.assign(value); + } + + /** + *

An endpoint address.

+ */ + inline Endpoint& WithAddress(const Aws::String& value) { + SetAddress(value); + return *this; + } + + /** + *

An endpoint address.

+ */ + inline Endpoint& WithAddress(Aws::String&& value) { + SetAddress(std::move(value)); + return *this; + } + + /** + *

An endpoint address.

+ */ + inline Endpoint& WithAddress(const char* value) { + SetAddress(value); + return *this; + } + + /** + *

The TTL for the endpoint, in minutes.

+ */ + inline long long GetCachePeriodInMinutes() const{ + return m_cachePeriodInMinutes; + } + + /** + *

The TTL for the endpoint, in minutes.

+ */ + inline bool CachePeriodInMinutesHasBeenSet() const { + return m_cachePeriodInMinutesHasBeenSet; + } + + /** + *

The TTL for the endpoint, in minutes.

+ */ + inline void SetCachePeriodInMinutes(long long value) { + m_cachePeriodInMinutesHasBeenSet = true; + m_cachePeriodInMinutes = value; + } + + /** + *

The TTL for the endpoint, in minutes.

+ */ + inline Endpoint& WithCachePeriodInMinutes(long long value) { + SetCachePeriodInMinutes(value); + return *this; + } + + private: + Aws::String m_address; + bool m_addressHasBeenSet; + + long long m_cachePeriodInMinutes; + bool m_cachePeriodInMinutesHasBeenSet; +}; \ No newline at end of file diff --git a/src/odbcdriver/QueryRequest.cpp b/src/odbcdriver/QueryRequest.cpp new file mode 100644 index 000000000..12b7cbe71 --- /dev/null +++ b/src/odbcdriver/QueryRequest.cpp @@ -0,0 +1,51 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include "QueryRequest.h" + +#include + +using namespace Aws::Utils::Json; +using namespace Aws::Utils; + +QueryRequest::QueryRequest() + : m_queryStringHasBeenSet(false), + m_clientToken(Aws::Utils::UUID::RandomUUID()), + m_clientTokenHasBeenSet(true), + m_nextTokenHasBeenSet(false), + m_maxRows(0), + m_maxRowsHasBeenSet(false) { +} + +Aws::String QueryRequest::SerializePayload() const { + JsonValue payload; + + if (m_queryStringHasBeenSet) { + payload.WithString("QueryString", m_queryString); + } + + if (m_clientTokenHasBeenSet) { + payload.WithString("ClientToken", m_clientToken); + } + + if (m_nextTokenHasBeenSet) { + payload.WithString("NextToken", m_nextToken); + } + + if (m_maxRowsHasBeenSet) { + payload.WithInteger("MaxRows", m_maxRows); + } + + return payload.View().WriteReadable(); +} + +Aws::Http::HeaderValueCollection QueryRequest::GetRequestSpecificHeaders() + const { + Aws::Http::HeaderValueCollection headers; + headers.insert(Aws::Http::HeaderValuePair("X-Amz-Target", + "Timestream_20181101.Query")); + return headers; +} diff --git a/src/odbcdriver/QueryRequest.h b/src/odbcdriver/QueryRequest.h new file mode 100644 index 000000000..bb4848aed --- /dev/null +++ b/src/odbcdriver/QueryRequest.h @@ -0,0 +1,357 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include "DatabaseQueryRequest.h" + +#include +#include + +#include + +/** + */ +class QueryRequest : public DatabaseQueryRequest { + public: + QueryRequest(); + + // Service request name is the Operation name which will send this request + // out, each operation should has unique request name, so that we can get + // operation's name from this request. Note: this is not true for response, + // multiple operations may have the same response name, so we can not get + // operation's name from response. + inline virtual const char* GetServiceRequestName() const override { + return "Query"; + } + + Aws::String SerializePayload() const override; + + Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override; + + /** + *

The query to be executed by Timestream.

+ */ + inline const Aws::String& GetQueryString() const { + return m_queryString; + } + + /** + *

The query to be executed by Timestream.

+ */ + inline bool QueryStringHasBeenSet() const { + return m_queryStringHasBeenSet; + } + + /** + *

The query to be executed by Timestream.

+ */ + inline void SetQueryString(const Aws::String& value) { + m_queryStringHasBeenSet = true; + m_queryString = value; + } + + /** + *

The query to be executed by Timestream.

+ */ + inline void SetQueryString(Aws::String&& value) { + m_queryStringHasBeenSet = true; + m_queryString = std::move(value); + } + + /** + *

The query to be executed by Timestream.

+ */ + inline void SetQueryString(const char* value) { + m_queryStringHasBeenSet = true; + m_queryString.assign(value); + } + + /** + *

The query to be executed by Timestream.

+ */ + inline QueryRequest& WithQueryString(const Aws::String& value) { + SetQueryString(value); + return *this; + } + + /** + *

The query to be executed by Timestream.

+ */ + inline QueryRequest& WithQueryString(Aws::String&& value) { + SetQueryString(std::move(value)); + return *this; + } + + /** + *

The query to be executed by Timestream.

+ */ + inline QueryRequest& WithQueryString(const char* value) { + SetQueryString(value); + return *this; + } + + /** + *

Unique, case-sensitive string of up to 64 ASCII characters that you + * specify when you make a Query request. Providing a + * ClientToken makes the call to Query idempotent, + * meaning that multiple identical calls have the same effect as one single + * call.

Your query request will fail in the following cases:

+ *
  • If you submit a request with the same client token outside + * the 5-minute idepotency window.

  • If you submit a + * request with the same client token but a change in other parameters + * within the 5-minute idempotency window.

After 4 + * hours, any request with the same client token is treated as a new + * request.

+ */ + inline const Aws::String& GetClientToken() const { + return m_clientToken; + } + + /** + *

Unique, case-sensitive string of up to 64 ASCII characters that you + * specify when you make a Query request. Providing a + * ClientToken makes the call to Query idempotent, + * meaning that multiple identical calls have the same effect as one single + * call.

Your query request will fail in the following cases:

+ *
  • If you submit a request with the same client token outside + * the 5-minute idepotency window.

  • If you submit a + * request with the same client token but a change in other parameters + * within the 5-minute idempotency window.

After 4 + * hours, any request with the same client token is treated as a new + * request.

+ */ + inline bool ClientTokenHasBeenSet() const { + return m_clientTokenHasBeenSet; + } + + /** + *

Unique, case-sensitive string of up to 64 ASCII characters that you + * specify when you make a Query request. Providing a + * ClientToken makes the call to Query idempotent, + * meaning that multiple identical calls have the same effect as one single + * call.

Your query request will fail in the following cases:

+ *
  • If you submit a request with the same client token outside + * the 5-minute idepotency window.

  • If you submit a + * request with the same client token but a change in other parameters + * within the 5-minute idempotency window.

After 4 + * hours, any request with the same client token is treated as a new + * request.

+ */ + inline void SetClientToken(const Aws::String& value) { + m_clientTokenHasBeenSet = true; + m_clientToken = value; + } + + /** + *

Unique, case-sensitive string of up to 64 ASCII characters that you + * specify when you make a Query request. Providing a + * ClientToken makes the call to Query idempotent, + * meaning that multiple identical calls have the same effect as one single + * call.

Your query request will fail in the following cases:

+ *
  • If you submit a request with the same client token outside + * the 5-minute idepotency window.

  • If you submit a + * request with the same client token but a change in other parameters + * within the 5-minute idempotency window.

After 4 + * hours, any request with the same client token is treated as a new + * request.

+ */ + inline void SetClientToken(Aws::String&& value) { + m_clientTokenHasBeenSet = true; + m_clientToken = std::move(value); + } + + /** + *

Unique, case-sensitive string of up to 64 ASCII characters that you + * specify when you make a Query request. Providing a + * ClientToken makes the call to Query idempotent, + * meaning that multiple identical calls have the same effect as one single + * call.

Your query request will fail in the following cases:

+ *
  • If you submit a request with the same client token outside + * the 5-minute idepotency window.

  • If you submit a + * request with the same client token but a change in other parameters + * within the 5-minute idempotency window.

After 4 + * hours, any request with the same client token is treated as a new + * request.

+ */ + inline void SetClientToken(const char* value) { + m_clientTokenHasBeenSet = true; + m_clientToken.assign(value); + } + + /** + *

Unique, case-sensitive string of up to 64 ASCII characters that you + * specify when you make a Query request. Providing a + * ClientToken makes the call to Query idempotent, + * meaning that multiple identical calls have the same effect as one single + * call.

Your query request will fail in the following cases:

+ *
  • If you submit a request with the same client token outside + * the 5-minute idepotency window.

  • If you submit a + * request with the same client token but a change in other parameters + * within the 5-minute idempotency window.

After 4 + * hours, any request with the same client token is treated as a new + * request.

+ */ + inline QueryRequest& WithClientToken(const Aws::String& value) { + SetClientToken(value); + return *this; + } + + /** + *

Unique, case-sensitive string of up to 64 ASCII characters that you + * specify when you make a Query request. Providing a + * ClientToken makes the call to Query idempotent, + * meaning that multiple identical calls have the same effect as one single + * call.

Your query request will fail in the following cases:

+ *
  • If you submit a request with the same client token outside + * the 5-minute idepotency window.

  • If you submit a + * request with the same client token but a change in other parameters + * within the 5-minute idempotency window.

After 4 + * hours, any request with the same client token is treated as a new + * request.

+ */ + inline QueryRequest& WithClientToken(Aws::String&& value) { + SetClientToken(std::move(value)); + return *this; + } + + /** + *

Unique, case-sensitive string of up to 64 ASCII characters that you + * specify when you make a Query request. Providing a + * ClientToken makes the call to Query idempotent, + * meaning that multiple identical calls have the same effect as one single + * call.

Your query request will fail in the following cases:

+ *
  • If you submit a request with the same client token outside + * the 5-minute idepotency window.

  • If you submit a + * request with the same client token but a change in other parameters + * within the 5-minute idempotency window.

After 4 + * hours, any request with the same client token is treated as a new + * request.

+ */ + inline QueryRequest& WithClientToken(const char* value) { + SetClientToken(value); + return *this; + } + + /** + *

A pagination token passed to get a set of results.

+ */ + inline const Aws::String& GetNextToken() const { + return m_nextToken; + } + + /** + *

A pagination token passed to get a set of results.

+ */ + inline bool NextTokenHasBeenSet() const { + return m_nextTokenHasBeenSet; + } + + /** + *

A pagination token passed to get a set of results.

+ */ + inline void SetNextToken(const Aws::String& value) { + m_nextTokenHasBeenSet = true; + m_nextToken = value; + } + + /** + *

A pagination token passed to get a set of results.

+ */ + inline void SetNextToken(Aws::String&& value) { + m_nextTokenHasBeenSet = true; + m_nextToken = std::move(value); + } + + /** + *

A pagination token passed to get a set of results.

+ */ + inline void SetNextToken(const char* value) { + m_nextTokenHasBeenSet = true; + m_nextToken.assign(value); + } + + /** + *

A pagination token passed to get a set of results.

+ */ + inline QueryRequest& WithNextToken(const Aws::String& value) { + SetNextToken(value); + return *this; + } + + /** + *

A pagination token passed to get a set of results.

+ */ + inline QueryRequest& WithNextToken(Aws::String&& value) { + SetNextToken(std::move(value)); + return *this; + } + + /** + *

A pagination token passed to get a set of results.

+ */ + inline QueryRequest& WithNextToken(const char* value) { + SetNextToken(value); + return *this; + } + + /** + *

The total number of rows to return in the output. If the total number + * of rows available is more than the value specified, a NextToken is + * provided in the command's output. To resume pagination, provide the + * NextToken value in the starting-token argument of a subsequent command. + *

+ */ + inline int GetMaxRows() const { + return m_maxRows; + } + + /** + *

The total number of rows to return in the output. If the total number + * of rows available is more than the value specified, a NextToken is + * provided in the command's output. To resume pagination, provide the + * NextToken value in the starting-token argument of a subsequent command. + *

+ */ + inline bool MaxRowsHasBeenSet() const { + return m_maxRowsHasBeenSet; + } + + /** + *

The total number of rows to return in the output. If the total number + * of rows available is more than the value specified, a NextToken is + * provided in the command's output. To resume pagination, provide the + * NextToken value in the starting-token argument of a subsequent command. + *

+ */ + inline void SetMaxRows(int value) { + m_maxRowsHasBeenSet = true; + m_maxRows = value; + } + + /** + *

The total number of rows to return in the output. If the total number + * of rows available is more than the value specified, a NextToken is + * provided in the command's output. To resume pagination, provide the + * NextToken value in the starting-token argument of a subsequent command. + *

+ */ + inline QueryRequest& WithMaxRows(int value) { + SetMaxRows(value); + return *this; + } + + private: + Aws::String m_queryString; + bool m_queryStringHasBeenSet; + + Aws::String m_clientToken; + bool m_clientTokenHasBeenSet; + + Aws::String m_nextToken; + bool m_nextTokenHasBeenSet; + + int m_maxRows; + bool m_maxRowsHasBeenSet; +}; diff --git a/src/odbcdriver/QueryResult.cpp b/src/odbcdriver/QueryResult.cpp new file mode 100644 index 000000000..ae2216c09 --- /dev/null +++ b/src/odbcdriver/QueryResult.cpp @@ -0,0 +1,60 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include +#include +#include +#include "QueryResult.h" + +#include + +using namespace Aws::Utils::Json; +using namespace Aws::Utils; +using namespace Aws; + +QueryResult::QueryResult() { +} + +QueryResult::QueryResult( + const Aws::AmazonWebServiceResult< JsonValue >& result) { + *this = result; +} + +QueryResult& QueryResult::operator=( + const Aws::AmazonWebServiceResult< JsonValue >& result) { + JsonView jsonValue = result.GetPayload().View(); + if (jsonValue.ValueExists("QueryId")) { + m_queryId = jsonValue.GetString("QueryId"); + } + + if (jsonValue.ValueExists("NextToken")) { + m_nextToken = jsonValue.GetString("NextToken"); + } + + if (jsonValue.ValueExists("Rows")) { + Array< JsonView > rowsJsonList = jsonValue.GetArray("Rows"); + for (unsigned rowsIndex = 0; rowsIndex < rowsJsonList.GetLength(); + ++rowsIndex) { + m_rows.push_back(rowsJsonList[rowsIndex].AsObject()); + } + } + + if (jsonValue.ValueExists("ColumnInfo")) { + Array< JsonView > columnInfoJsonList = jsonValue.GetArray("ColumnInfo"); + for (unsigned columnInfoIndex = 0; + columnInfoIndex < columnInfoJsonList.GetLength(); + ++columnInfoIndex) { + m_columnInfo.push_back( + columnInfoJsonList[columnInfoIndex].AsObject()); + } + } + + if (jsonValue.ValueExists("QueryStatus")) { + m_queryStatus = jsonValue.GetObject("QueryStatus"); + } + + return *this; +} diff --git a/src/odbcdriver/QueryResult.h b/src/odbcdriver/QueryResult.h new file mode 100644 index 000000000..cf822def9 --- /dev/null +++ b/src/odbcdriver/QueryResult.h @@ -0,0 +1,305 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +#include +#include + +#include +#include "ColumnInfo.h" +#include "QueryStatus.h" +#include "Row.h" + +namespace Aws { +template < typename RESULT_TYPE > +class AmazonWebServiceResult; + +namespace Utils { +namespace Json { +class JsonValue; +} // namespace Json +} // namespace Utils +} // namespace Aws + +class QueryResult { + public: + QueryResult(); + QueryResult( + const Aws::AmazonWebServiceResult< Aws::Utils::Json::JsonValue >& + result); + QueryResult& operator=( + const Aws::AmazonWebServiceResult< Aws::Utils::Json::JsonValue >& + result); + + /** + *

A unique ID for the given query.

+ */ + inline const Aws::String& GetQueryId() const { + return m_queryId; + } + + /** + *

A unique ID for the given query.

+ */ + inline void SetQueryId(const Aws::String& value) { + m_queryId = value; + } + + /** + *

A unique ID for the given query.

+ */ + inline void SetQueryId(Aws::String&& value) { + m_queryId = std::move(value); + } + + /** + *

A unique ID for the given query.

+ */ + inline void SetQueryId(const char* value) { + m_queryId.assign(value); + } + + /** + *

A unique ID for the given query.

+ */ + inline QueryResult& WithQueryId(const Aws::String& value) { + SetQueryId(value); + return *this; + } + + /** + *

A unique ID for the given query.

+ */ + inline QueryResult& WithQueryId(Aws::String&& value) { + SetQueryId(std::move(value)); + return *this; + } + + /** + *

A unique ID for the given query.

+ */ + inline QueryResult& WithQueryId(const char* value) { + SetQueryId(value); + return *this; + } + + /** + *

A pagination token that can be used again on a Query + * call to get the next set of results.

+ */ + inline const Aws::String& GetNextToken() const { + return m_nextToken; + } + + /** + *

A pagination token that can be used again on a Query + * call to get the next set of results.

+ */ + inline void SetNextToken(const Aws::String& value) { + m_nextToken = value; + } + + /** + *

A pagination token that can be used again on a Query + * call to get the next set of results.

+ */ + inline void SetNextToken(Aws::String&& value) { + m_nextToken = std::move(value); + } + + /** + *

A pagination token that can be used again on a Query + * call to get the next set of results.

+ */ + inline void SetNextToken(const char* value) { + m_nextToken.assign(value); + } + + /** + *

A pagination token that can be used again on a Query + * call to get the next set of results.

+ */ + inline QueryResult& WithNextToken(const Aws::String& value) { + SetNextToken(value); + return *this; + } + + /** + *

A pagination token that can be used again on a Query + * call to get the next set of results.

+ */ + inline QueryResult& WithNextToken(Aws::String&& value) { + SetNextToken(std::move(value)); + return *this; + } + + /** + *

A pagination token that can be used again on a Query + * call to get the next set of results.

+ */ + inline QueryResult& WithNextToken(const char* value) { + SetNextToken(value); + return *this; + } + + /** + *

The result set rows returned by the query.

+ */ + inline const Aws::Vector< Row >& GetRows() const { + return m_rows; + } + + /** + *

The result set rows returned by the query.

+ */ + inline void SetRows(const Aws::Vector< Row >& value) { + m_rows = value; + } + + /** + *

The result set rows returned by the query.

+ */ + inline void SetRows(Aws::Vector< Row >&& value) { + m_rows = std::move(value); + } + + /** + *

The result set rows returned by the query.

+ */ + inline QueryResult& WithRows(const Aws::Vector< Row >& value) { + SetRows(value); + return *this; + } + + /** + *

The result set rows returned by the query.

+ */ + inline QueryResult& WithRows(Aws::Vector< Row >&& value) { + SetRows(std::move(value)); + return *this; + } + + /** + *

The result set rows returned by the query.

+ */ + inline QueryResult& AddRows(const Row& value) { + m_rows.push_back(value); + return *this; + } + + /** + *

The result set rows returned by the query.

+ */ + inline QueryResult& AddRows(Row&& value) { + m_rows.push_back(std::move(value)); + return *this; + } + + /** + *

The column data types of the returned result set.

+ */ + inline const Aws::Vector< ColumnInfo >& GetColumnInfo() const { + return m_columnInfo; + } + + /** + *

The column data types of the returned result set.

+ */ + inline void SetColumnInfo(const Aws::Vector< ColumnInfo >& value) { + m_columnInfo = value; + } + + /** + *

The column data types of the returned result set.

+ */ + inline void SetColumnInfo(Aws::Vector< ColumnInfo >&& value) { + m_columnInfo = std::move(value); + } + + /** + *

The column data types of the returned result set.

+ */ + inline QueryResult& WithColumnInfo(const Aws::Vector< ColumnInfo >& value) { + SetColumnInfo(value); + return *this; + } + + /** + *

The column data types of the returned result set.

+ */ + inline QueryResult& WithColumnInfo(Aws::Vector< ColumnInfo >&& value) { + SetColumnInfo(std::move(value)); + return *this; + } + + /** + *

The column data types of the returned result set.

+ */ + inline QueryResult& AddColumnInfo(const ColumnInfo& value) { + m_columnInfo.push_back(value); + return *this; + } + + /** + *

The column data types of the returned result set.

+ */ + inline QueryResult& AddColumnInfo(ColumnInfo&& value) { + m_columnInfo.push_back(std::move(value)); + return *this; + } + + /** + *

Information about the status of the query, including progress and + * bytes scannned.

+ */ + inline const QueryStatus& GetQueryStatus() const { + return m_queryStatus; + } + + /** + *

Information about the status of the query, including progress and + * bytes scannned.

+ */ + inline void SetQueryStatus(const QueryStatus& value) { + m_queryStatus = value; + } + + /** + *

Information about the status of the query, including progress and + * bytes scannned.

+ */ + inline void SetQueryStatus(QueryStatus&& value) { + m_queryStatus = std::move(value); + } + + /** + *

Information about the status of the query, including progress and + * bytes scannned.

+ */ + inline QueryResult& WithQueryStatus(const QueryStatus& value) { + SetQueryStatus(value); + return *this; + } + + /** + *

Information about the status of the query, including progress and + * bytes scannned.

+ */ + inline QueryResult& WithQueryStatus(QueryStatus&& value) { + SetQueryStatus(std::move(value)); + return *this; + } + + private: + Aws::String m_queryId; + + Aws::String m_nextToken; + + Aws::Vector< Row > m_rows; + + Aws::Vector< ColumnInfo > m_columnInfo; + + QueryStatus m_queryStatus; +}; \ No newline at end of file diff --git a/src/odbcdriver/QueryStatus.cpp b/src/odbcdriver/QueryStatus.cpp new file mode 100644 index 000000000..38ae304dd --- /dev/null +++ b/src/odbcdriver/QueryStatus.cpp @@ -0,0 +1,43 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#include +#include "QueryStatus.h" + +#include + +using namespace Aws::Utils::Json; +using namespace Aws::Utils; + +QueryStatus::QueryStatus() + : m_progressPercentage(0.0), + m_progressPercentageHasBeenSet(false) { +} + +QueryStatus::QueryStatus(JsonView jsonValue) + : m_progressPercentage(0.0), + m_progressPercentageHasBeenSet(false) { + *this = jsonValue; +} + +QueryStatus& QueryStatus::operator=(JsonView jsonValue) { + if (jsonValue.ValueExists("ProgressPercentage")) { + m_progressPercentage = jsonValue.GetDouble("ProgressPercentage"); + + m_progressPercentageHasBeenSet = true; + } + + return *this; +} + +JsonValue QueryStatus::Jsonize() const { + JsonValue payload; + + if (m_progressPercentageHasBeenSet) { + payload.WithDouble("ProgressPercentage", m_progressPercentage); + } + + return payload; +} diff --git a/src/odbcdriver/QueryStatus.h b/src/odbcdriver/QueryStatus.h new file mode 100644 index 000000000..44b6f685b --- /dev/null +++ b/src/odbcdriver/QueryStatus.h @@ -0,0 +1,62 @@ +/** + * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. + * SPDX-License-Identifier: Apache-2.0. + */ + +#pragma once +namespace Aws { +namespace Utils { +namespace Json { +class JsonValue; +class JsonView; +} // namespace Json +} // namespace Utils +} // namespace Aws + +/** + *

Information about the status of the query, including progress and bytes + * scannned.

See Also:

AWS + * API Reference

+ */ +class QueryStatus { + public: + QueryStatus(); + QueryStatus(Aws::Utils::Json::JsonView jsonValue); + QueryStatus& operator=(Aws::Utils::Json::JsonView jsonValue); + Aws::Utils::Json::JsonValue Jsonize() const; + + /** + *

The progress of the query, expressed as a percentage.

+ */ + inline double GetProgressPercentage() const { + return m_progressPercentage; + } + + /** + *

The progress of the query, expressed as a percentage.

+ */ + inline bool ProgressPercentageHasBeenSet() const { + return m_progressPercentageHasBeenSet; + } + + /** + *

The progress of the query, expressed as a percentage.

+ */ + inline void SetProgressPercentage(double value) { + m_progressPercentageHasBeenSet = true; + m_progressPercentage = value; + } + + /** + *

The progress of the query, expressed as a percentage.

+ */ + inline QueryStatus& WithProgressPercentage(double value) { + SetProgressPercentage(value); + return *this; + } + + private: + double m_progressPercentage; + bool m_progressPercentageHasBeenSet; +}; \ No newline at end of file diff --git a/src/odbcdriver/Row.h b/src/odbcdriver/Row.h index 5d4e77723..0f01f1e65 100644 --- a/src/odbcdriver/Row.h +++ b/src/odbcdriver/Row.h @@ -4,40 +4,51 @@ */ #pragma once -#include #include -#include +#include "Datum.h" #include - /** - *

Represents a single row in the query results.

See Also:

AWS - * API Reference

- */ - class Row - { - public: +namespace Aws { +namespace Utils { +namespace Json { +class JsonValue; +class JsonView; +} // namespace Json +} // namespace Utils +} // namespace Aws + +/** + *

Represents a single row in the query results.

See Also:

AWS + * API Reference

+ */ +class Row { + public: Row(); Row(Aws::Utils::Json::JsonView jsonValue); Row& operator=(Aws::Utils::Json::JsonView jsonValue); Aws::Utils::Json::JsonValue Jsonize() const; - /** *

List of data points in a single row of the result set.

*/ - inline const Aws::Vector& GetData() const{ return m_data; } + inline const Aws::Vector< Datum >& GetData() + const { + return m_data; + } /** *

List of data points in a single row of the result set.

*/ - inline bool DataHasBeenSet() const { return m_dataHasBeenSet; } + inline bool DataHasBeenSet() const { + return m_dataHasBeenSet; + } /** *

List of data points in a single row of the result set.

*/ inline void SetData( - const Aws::Vector< Aws::TimestreamQuery::Model::Datum >& value) { + const Aws::Vector< Datum >& value) { m_dataHasBeenSet = true; m_data = value; } @@ -46,7 +57,7 @@ *

List of data points in a single row of the result set.

*/ inline void SetData( - Aws::Vector< Aws::TimestreamQuery::Model::Datum >&& value) { + Aws::Vector< Datum >&& value) { m_dataHasBeenSet = true; m_data = std::move(value); } @@ -55,7 +66,7 @@ *

List of data points in a single row of the result set.

*/ inline Row& WithData( - const Aws::Vector< Aws::TimestreamQuery::Model::Datum >& value) { + const Aws::Vector< Datum >& value) { SetData(value); return *this; } @@ -64,7 +75,7 @@ *

List of data points in a single row of the result set.

*/ inline Row& WithData( - Aws::Vector< Aws::TimestreamQuery::Model::Datum >&& value) { + Aws::Vector< Datum >&& value) { SetData(std::move(value)); return *this; } @@ -72,7 +83,7 @@ /** *

List of data points in a single row of the result set.

*/ - inline Row& AddData(const Aws::TimestreamQuery::Model::Datum& value) { + inline Row& AddData(const Datum& value) { m_dataHasBeenSet = true; m_data.push_back(value); return *this; @@ -81,14 +92,13 @@ /** *

List of data points in a single row of the result set.

*/ - inline Row& AddData(Aws::TimestreamQuery::Model::Datum&& value) { + inline Row& AddData(Datum&& value) { m_dataHasBeenSet = true; m_data.push_back(std::move(value)); return *this; } - private: - - Aws::Vector< Aws::TimestreamQuery::Model::Datum > m_data; + private: + Aws::Vector< Datum > m_data; bool m_dataHasBeenSet; - }; +}; diff --git a/src/odbcdriver/ScalarType.h b/src/odbcdriver/ScalarType.h index d64e10967..ce2a22268 100644 --- a/src/odbcdriver/ScalarType.h +++ b/src/odbcdriver/ScalarType.h @@ -4,7 +4,6 @@ */ #pragma once -#include #include enum class ScalarType { diff --git a/src/odbcdriver/Type.cpp b/src/odbcdriver/Type.cpp index a507ddb8e..b0d1fb745 100644 --- a/src/odbcdriver/Type.cpp +++ b/src/odbcdriver/Type.cpp @@ -17,7 +17,6 @@ Type::Type() : m_scalarType(ScalarType::NOT_SET), m_scalarTypeHasBeenSet(false), m_arrayColumnInfoHasBeenSet(false), - m_timeSeriesMeasureValueColumnInfoHasBeenSet(false), m_rowColumnInfoHasBeenSet(false) { } @@ -26,7 +25,6 @@ Type::Type(JsonView jsonValue) : m_scalarType(ScalarType::NOT_SET), m_scalarTypeHasBeenSet(false), m_arrayColumnInfoHasBeenSet(false), - m_timeSeriesMeasureValueColumnInfoHasBeenSet(false), m_rowColumnInfoHasBeenSet(false) { *this = jsonValue; @@ -39,13 +37,6 @@ void Type::SetArrayColumnInfo(ColumnInfo&& value) { m_arrayColumnInfoHasBeenSet Type& Type::WithArrayColumnInfo(const ColumnInfo& value) { SetArrayColumnInfo(value); return *this;} Type& Type::WithArrayColumnInfo(ColumnInfo&& value) { SetArrayColumnInfo(std::move(value)); return *this;} -const ColumnInfo& Type::GetTimeSeriesMeasureValueColumnInfo() const{ return *m_timeSeriesMeasureValueColumnInfo; } -bool Type::TimeSeriesMeasureValueColumnInfoHasBeenSet() const { return m_timeSeriesMeasureValueColumnInfoHasBeenSet; } -void Type::SetTimeSeriesMeasureValueColumnInfo(const ColumnInfo& value) { m_timeSeriesMeasureValueColumnInfoHasBeenSet = true; m_timeSeriesMeasureValueColumnInfo = Aws::MakeShared("Type", value); } -void Type::SetTimeSeriesMeasureValueColumnInfo(ColumnInfo&& value) { m_timeSeriesMeasureValueColumnInfoHasBeenSet = true; m_timeSeriesMeasureValueColumnInfo = Aws::MakeShared("Type", std::move(value)); } -Type& Type::WithTimeSeriesMeasureValueColumnInfo(const ColumnInfo& value) { SetTimeSeriesMeasureValueColumnInfo(value); return *this;} -Type& Type::WithTimeSeriesMeasureValueColumnInfo(ColumnInfo&& value) { SetTimeSeriesMeasureValueColumnInfo(std::move(value)); return *this;} - Type& Type::operator =(JsonView jsonValue) { if(jsonValue.ValueExists("ScalarType")) @@ -62,13 +53,6 @@ Type& Type::operator =(JsonView jsonValue) m_arrayColumnInfoHasBeenSet = true; } - if(jsonValue.ValueExists("TimeSeriesMeasureValueColumnInfo")) - { - m_timeSeriesMeasureValueColumnInfo = Aws::MakeShared("Type", jsonValue.GetObject("TimeSeriesMeasureValueColumnInfo")); - - m_timeSeriesMeasureValueColumnInfoHasBeenSet = true; - } - if(jsonValue.ValueExists("RowColumnInfo")) { Array rowColumnInfoJsonList = jsonValue.GetArray("RowColumnInfo"); @@ -97,12 +81,6 @@ JsonValue Type::Jsonize() const } - if(m_timeSeriesMeasureValueColumnInfoHasBeenSet) - { - payload.WithObject("TimeSeriesMeasureValueColumnInfo", m_timeSeriesMeasureValueColumnInfo->Jsonize()); - - } - if(m_rowColumnInfoHasBeenSet) { Array rowColumnInfoJsonList(m_rowColumnInfo.size()); @@ -115,4 +93,4 @@ JsonValue Type::Jsonize() const } return payload; -} +} \ No newline at end of file diff --git a/src/odbcdriver/Type.h b/src/odbcdriver/Type.h index 54801e236..ce421715e 100644 --- a/src/odbcdriver/Type.h +++ b/src/odbcdriver/Type.h @@ -5,12 +5,20 @@ #pragma once #include -#include #include #include #include "ScalarType.h" #include "ColumnInfo.h" +namespace Aws { +namespace Utils { +namespace Json { +class JsonValue; +class JsonView; +} // namespace Json +} // namespace Utils +} // namespace Aws + /** *

Contains the data type of a column in a query result set. The data type can * be scalar or complex. The supported scalar data types are integers, boolean, @@ -108,36 +116,6 @@ class Type { */ Type& WithArrayColumnInfo(ColumnInfo&& value); - /** - *

Indicates if the column is a timeseries data type.

- */ - const ColumnInfo& GetTimeSeriesMeasureValueColumnInfo() const; - - /** - *

Indicates if the column is a timeseries data type.

- */ - bool TimeSeriesMeasureValueColumnInfoHasBeenSet() const; - - /** - *

Indicates if the column is a timeseries data type.

- */ - void SetTimeSeriesMeasureValueColumnInfo(const ColumnInfo& value); - - /** - *

Indicates if the column is a timeseries data type.

- */ - void SetTimeSeriesMeasureValueColumnInfo(ColumnInfo&& value); - - /** - *

Indicates if the column is a timeseries data type.

- */ - Type& WithTimeSeriesMeasureValueColumnInfo(const ColumnInfo& value); - - /** - *

Indicates if the column is a timeseries data type.

- */ - Type& WithTimeSeriesMeasureValueColumnInfo(ColumnInfo&& value); - /** *

Indicates if the column is a row.

*/ @@ -209,9 +187,6 @@ class Type { std::shared_ptr< ColumnInfo > m_arrayColumnInfo; bool m_arrayColumnInfoHasBeenSet; - std::shared_ptr< ColumnInfo > m_timeSeriesMeasureValueColumnInfo; - bool m_timeSeriesMeasureValueColumnInfoHasBeenSet; - Aws::Vector< ColumnInfo > m_rowColumnInfo; bool m_rowColumnInfoHasBeenSet; }; diff --git a/src/odbcdriver/helper.cpp b/src/odbcdriver/helper.cpp index 63fdbae22..476d37e2e 100644 --- a/src/odbcdriver/helper.cpp +++ b/src/odbcdriver/helper.cpp @@ -24,7 +24,7 @@ #include "odbc_statement.h" void* ConnectDBParams(const runtime_options& rt_opts) { - auto conn = new TSCommunication(); + auto conn = new DBCommunication(); if (conn != nullptr) { try { conn->Setup(rt_opts); diff --git a/src/odbcdriver/odbc_communication.cpp b/src/odbcdriver/odbc_communication.cpp index 124a8d622..115c221cd 100644 --- a/src/odbcdriver/odbc_communication.cpp +++ b/src/odbcdriver/odbc_communication.cpp @@ -30,12 +30,10 @@ #include #include #include -#include -#include +#include "CancelQueryRequest.h" +#include "QueryRequest.h" // clang-format on -using namespace Aws::TimestreamQuery; - namespace { /** * A helper class to initialize/shutdown AWS API once per DLL load/unload. @@ -72,14 +70,14 @@ namespace { const Aws::String UA_ID_PREFIX = Aws::String("ts-odbc."); const std::string DEFAULT_CREATOR_TYPE = "DEFAULT"; - typedef std::function< std::unique_ptr< TimestreamQueryClient >( + typedef std::function< std::unique_ptr< DatabaseQueryClient >( const runtime_options& options, const Aws::Client::ClientConfiguration& config) > QueryClientCreator; QueryClientCreator default_creator = [](const runtime_options& , const Aws::Client::ClientConfiguration& config) { - return std::unique_ptr< TimestreamQueryClient >(new TimestreamQueryClient(config)); + return std::unique_ptr< DatabaseQueryClient >(new DatabaseQueryClient(config)); }; std::unordered_map< std::string, QueryClientCreator > creators = { @@ -87,15 +85,15 @@ namespace { }; } -TSCommunication::TSCommunication() { +DBCommunication::DBCommunication() { ++AWS_SDK_HELPER; } -TSCommunication::~TSCommunication() { +DBCommunication::~DBCommunication() { --AWS_SDK_HELPER; } -bool TSCommunication::Validate(const runtime_options& options) { +bool DBCommunication::Validate(const runtime_options& options) { if (options.auth.auth_type != AUTHTYPE_DEFAULT) { throw std::invalid_argument("Unknown authentication type: \"" + options.auth.auth_type + "\"."); } @@ -111,7 +109,7 @@ bool TSCommunication::Validate(const runtime_options& options) { return true; } -std::unique_ptr< Aws::TimestreamQuery::TimestreamQueryClient > TSCommunication::CreateQueryClient(const runtime_options& options) { +std::unique_ptr< DatabaseQueryClient > DBCommunication::CreateQueryClient(const runtime_options& options) { Aws::Client::ClientConfiguration config; config.userAgent = GetUserAgent(); @@ -161,8 +159,8 @@ std::unique_ptr< Aws::TimestreamQuery::TimestreamQueryClient > TSCommunication:: } } -bool TSCommunication::TestQueryClient() { - Aws::TimestreamQuery::Model::QueryRequest req; +bool DBCommunication::TestQueryClient() { + QueryRequest req; req.SetQueryString("select 1"); auto outcome = m_client->Query(req); if (!outcome.IsSuccess()) { @@ -175,16 +173,16 @@ bool TSCommunication::TestQueryClient() { return true; } -bool TSCommunication::Connect(const runtime_options& options) { +bool DBCommunication::Connect(const runtime_options& options) { m_client = CreateQueryClient(options); if (m_client == nullptr) { - throw std::runtime_error("Unable to create TimestreamQueryClient."); + throw std::runtime_error("Unable to create DatabaseQueryClient."); } return TestQueryClient(); } -void TSCommunication::Disconnect() { - LogMsg(LOG_DEBUG, "Disconnecting Timestream connection."); +void DBCommunication::Disconnect() { + LogMsg(LOG_DEBUG, "Disconnecting Database connection."); if (m_client) { m_client.reset(); } @@ -194,15 +192,15 @@ void TSCommunication::Disconnect() { } } -std::string TSCommunication::GetVersion() { +std::string DBCommunication::GetVersion() { return TIMESTREAMDRIVERVERSION; } -std::string TSCommunication::GetErrorPrefix() { +std::string DBCommunication::GetErrorPrefix() { return "[Timestream][SQL ODBC Driver] "; } -void TSCommunication::StopResultRetrieval(StatementClass* stmt) { +void DBCommunication::StopResultRetrieval(StatementClass* stmt) { // Call Cancel logic CancelQuery(stmt); // Clean the queue @@ -211,7 +209,7 @@ void TSCommunication::StopResultRetrieval(StatementClass* stmt) { } } -Aws::String TSCommunication::GetUserAgent() { +Aws::String DBCommunication::GetUserAgent() { Aws::String program_name(GetExeProgramName()); Aws::String name_suffix = " [" + program_name + "]"; Aws::String msg = "Name of the application using the driver: " + name_suffix; @@ -228,7 +226,7 @@ class Context : public Aws::Client::AsyncCallerContext { /** * Parameterized constructor for the context */ - Context(PrefetchQueue* q, StatementClass* s, std::promise< Aws::TimestreamQuery::Model::QueryOutcome > p) + Context(PrefetchQueue* q, StatementClass* s, std::promise< QueryOutcome > p) : Aws::Client::AsyncCallerContext(), queue_(q), stmt_(s), promise_(std::move(p)) { } /** @@ -249,7 +247,7 @@ class Context : public Aws::Client::AsyncCallerContext { * Make promise * @param outcome const Aws::TimestreamQuery::Model::QueryOutcome& */ - void MakePromise(const Aws::TimestreamQuery::Model::QueryOutcome& outcome) { + void MakePromise(const QueryOutcome& outcome) { promise_.set_value(outcome); } private: @@ -265,14 +263,14 @@ class Context : public Aws::Client::AsyncCallerContext { * Promise made by the request * Wait to be fullfilled in the QueryCallback function */ - std::promise< Aws::TimestreamQuery::Model::QueryOutcome > promise_; + std::promise< QueryOutcome > promise_; }; // Callback function of QueryAsync operation by aws-sdk-cpp timestream-query void QueryCallback( - const Aws::TimestreamQuery::TimestreamQueryClient* client, - const Aws::TimestreamQuery::Model::QueryRequest& request, - const Aws::TimestreamQuery::Model::QueryOutcome& outcome, + const DatabaseQueryClient* client, + const QueryRequest& request, + const QueryOutcome& outcome, const std::shared_ptr< const Aws::Client::AsyncCallerContext >& context) { auto ctxt = (std::static_pointer_cast< const Context >(context)); auto p = const_cast< Context* >(ctxt.get()); @@ -288,8 +286,8 @@ void QueryCallback( SC_UnsetQueryId(sc); sc->query_id = strdup(outcome.GetResult().GetQueryId().c_str()); } - Aws::TimestreamQuery::Model::QueryRequest next_request(request); - std::promise next_promise; + QueryRequest next_request(request); + std::promise next_promise; auto success = p->GetPrefetchQueue()->Push(next_promise.get_future()); if (success) { // Issue next request @@ -307,7 +305,7 @@ void QueryCallback( } } -bool TSCommunication::ExecDirect(StatementClass* sc, const char* query) { +bool DBCommunication::ExecDirect(StatementClass* sc, const char* query) { CSTR func = "ExecDirect"; std::string statement(query); std::string msg = "Attempting to execute a query \"" + statement + "\""; @@ -318,10 +316,10 @@ bool TSCommunication::ExecDirect(StatementClass* sc, const char* query) { PrefetchQueue* pPrefetchQueue = prefetch_queues_map[sc].get(); pPrefetchQueue->Reset(); // Issue request - Aws::TimestreamQuery::Model::QueryRequest request; + QueryRequest request; request.SetQueryString(statement.c_str()); // Use QueryAsync - std::promise< Aws::TimestreamQuery::Model::QueryOutcome > promise; + std::promise< QueryOutcome > promise; pPrefetchQueue->SetRetrieving(true); auto success = pPrefetchQueue->Push(promise.get_future()); if (success) { @@ -337,7 +335,7 @@ bool TSCommunication::ExecDirect(StatementClass* sc, const char* query) { } } -bool TSCommunication::CancelQuery(StatementClass* stmt) { +bool DBCommunication::CancelQuery(StatementClass* stmt) { if (stmt == nullptr) return false; auto prefetch_queue_iterator = prefetch_queues_map.find(stmt); @@ -347,7 +345,7 @@ bool TSCommunication::CancelQuery(StatementClass* stmt) { } // Try to cancel current query (Not guaranteed in Timestream service) if (stmt->query_id != nullptr && strlen(stmt->query_id) != 0) { - Aws::TimestreamQuery::Model::CancelQueryRequest cancel_request; + CancelQueryRequest cancel_request; cancel_request.SetQueryId(stmt->query_id); auto outcome = m_client->CancelQuery(cancel_request); if (outcome.IsSuccess()) { diff --git a/src/odbcdriver/odbc_communication.h b/src/odbcdriver/odbc_communication.h index 1af8d5e49..122ccac2e 100644 --- a/src/odbcdriver/odbc_communication.h +++ b/src/odbcdriver/odbc_communication.h @@ -17,7 +17,7 @@ #ifndef DB_COMMUNICATION #define DB_COMMUNICATION -#include +#include "DatabaseQueryClient.h" #include #include @@ -29,11 +29,11 @@ /** * AWS Timestream communication class */ -class TSCommunication : public Communication { +class DBCommunication : public Communication { public: - TSCommunication(); + DBCommunication(); - ~TSCommunication(); + ~DBCommunication(); /** * Validate options @@ -96,7 +96,7 @@ class TSCommunication : public Communication { * @param options const runtime_options& * @return std::unique_ptr< Aws::TimestreamQuery::TimestreamQueryClient > */ - std::unique_ptr< Aws::TimestreamQuery::TimestreamQueryClient > + std::unique_ptr< DatabaseQueryClient > CreateQueryClient(const runtime_options& options); /** @@ -108,7 +108,7 @@ class TSCommunication : public Communication { /** * Timestream query client */ - std::unique_ptr< Aws::TimestreamQuery::TimestreamQueryClient > m_client; + std::unique_ptr< DatabaseQueryClient > m_client; }; #endif diff --git a/src/odbcdriver/odbc_statement.cpp b/src/odbcdriver/odbc_statement.cpp index 762079036..98f4d3c18 100644 --- a/src/odbcdriver/odbc_statement.cpp +++ b/src/odbcdriver/odbc_statement.cpp @@ -21,7 +21,7 @@ #include "helper.h" #include "misc.h" #include "statement.h" -#include +#include "DatabaseQueryClient.h" extern "C" void *common_cs; diff --git a/src/odbcdriver/parse_result.cpp b/src/odbcdriver/parse_result.cpp index 8e27822a6..22acf81b6 100644 --- a/src/odbcdriver/parse_result.cpp +++ b/src/odbcdriver/parse_result.cpp @@ -27,7 +27,7 @@ typedef std::vector< std::pair< std::string, OID > > schema_type; bool _CC_from_TSResult( QResultClass *q_res, ConnectionClass *conn, StatementClass *stmt, const char *next_token, - const Aws::TimestreamQuery::Model::QueryOutcome &result); + const QueryOutcome &result); /** * Responsible for looping through columns, allocating memory for column fields @@ -37,7 +37,7 @@ bool _CC_from_TSResult( * @return true if successfully assigned */ bool AssignColumnHeaders(QResultClass *q_res, - const Aws::TimestreamQuery::Model::QueryOutcome &result); + const QueryOutcome &result); /** * Responsible for looping through rows, allocating tuples and passing rows for @@ -47,7 +47,7 @@ bool AssignColumnHeaders(QResultClass *q_res, * @param fields ColumnInfoClass to get information about columns * @return true if successfully assigned */ -bool AssignTableData(const Aws::TimestreamQuery::Model::QueryOutcome &result, +bool AssignTableData(const QueryOutcome &result, QResultClass *q_res, ColumnInfoClass &fields); /** @@ -58,7 +58,7 @@ bool AssignTableData(const Aws::TimestreamQuery::Model::QueryOutcome &result, * @param col_size size of the column * @return true if successfully assigned */ -bool AssignRowData(const Aws::TimestreamQuery::Model::Row &row, +bool AssignRowData(const Row &row, QResultClass *q_res, ColumnInfoClass &fields, const size_t &col_size); void UpdateResultFields(QResultClass *q_res, const ConnectionClass *conn, @@ -75,7 +75,7 @@ void ClearError(); * @param datum_value String representation of the datum to fill in recursively * @param column_attr_id Column attribute ID */ -void ParseDatum(const Aws::TimestreamQuery::Model::Datum &datum, +void ParseDatum(const Datum &datum, std::string &datum_value, OID column_attr_id); /** @@ -86,7 +86,7 @@ void ParseDatum(const Aws::TimestreamQuery::Model::Datum &datum, * @param array_value String representation of the datum to fill in recursively * @param column_attr_id Column attribute ID */ -void ParseArray(const Aws::Vector< Aws::TimestreamQuery::Model::Datum > &datums, +void ParseArray(const Aws::Vector< Datum > &datums, std::string &array_value, OID column_attr_id); /** @@ -97,7 +97,7 @@ void ParseArray(const Aws::Vector< Aws::TimestreamQuery::Model::Datum > &datums, * @param row_value String representation of the datum to fill in recursively * @param column_attr_id Column attribute ID */ -void ParseRow(const Aws::Vector< Aws::TimestreamQuery::Model::Datum > &datums, +void ParseRow(const Aws::Vector< Datum > &datums, std::string &row_value, OID column_attr_id); @@ -115,30 +115,30 @@ static const std::string JSON_KW_CURSOR = "cursor"; #define DB_VARCHAR_SIZE (-2) -const std::map< Aws::TimestreamQuery::Model::ScalarType, +const std::map< ScalarType, std::pair< OID, int16_t > > scalar_type_to_oid_size_map = { - {Aws::TimestreamQuery::Model::ScalarType::BIGINT, + {ScalarType::BIGINT, std::make_pair(DB_TYPE_BIGINT, (int16_t)8)}, - {Aws::TimestreamQuery::Model::ScalarType::BOOLEAN, + {ScalarType::BOOLEAN, std::make_pair(DB_TYPE_BOOLEAN, (int16_t)1)}, - {Aws::TimestreamQuery::Model::ScalarType::DATE, + {ScalarType::DATE, std::make_pair(DB_TYPE_DATE, (int16_t)6)}, - {Aws::TimestreamQuery::Model::ScalarType::DOUBLE, + {ScalarType::DOUBLE, std::make_pair(DB_TYPE_DOUBLE, (int16_t)8)}, - {Aws::TimestreamQuery::Model::ScalarType::INTEGER, + {ScalarType::INTEGER, std::make_pair(DB_TYPE_INTEGER, (int16_t)4)}, - {Aws::TimestreamQuery::Model::ScalarType::INTERVAL_DAY_TO_SECOND, + {ScalarType::INTERVAL_DAY_TO_SECOND, std::make_pair(DB_TYPE_VARCHAR, (int16_t)DB_VARCHAR_SIZE)}, - {Aws::TimestreamQuery::Model::ScalarType::INTERVAL_YEAR_TO_MONTH, + {ScalarType::INTERVAL_YEAR_TO_MONTH, std::make_pair(DB_TYPE_VARCHAR, (int16_t)DB_VARCHAR_SIZE)}, - {Aws::TimestreamQuery::Model::ScalarType::TIME, + {ScalarType::TIME, std::make_pair(DB_TYPE_TIME, (int16_t)6)}, - {Aws::TimestreamQuery::Model::ScalarType::TIMESTAMP, + {ScalarType::TIMESTAMP, std::make_pair(DB_TYPE_TIMESTAMP, (int16_t)16)}, - {Aws::TimestreamQuery::Model::ScalarType::VARCHAR, + {ScalarType::VARCHAR, std::make_pair(DB_TYPE_VARCHAR, (int16_t)DB_VARCHAR_SIZE)}, - {Aws::TimestreamQuery::Model::ScalarType::UNKNOWN, + {ScalarType::UNKNOWN, std::make_pair(DB_TYPE_VARCHAR, (int16_t)DB_VARCHAR_SIZE)}, }; @@ -159,14 +159,14 @@ std::string GetResultParserError() { BOOL CC_from_TSResult( QResultClass *q_res, ConnectionClass *conn, StatementClass *stmt, const char *next_token, - const Aws::TimestreamQuery::Model::QueryOutcome &result) { + const QueryOutcome &result) { ClearError(); return _CC_from_TSResult(q_res, conn, stmt, next_token, result) ? TRUE : FALSE; } BOOL CC_Append_Table_Data( - const Aws::TimestreamQuery::Model::QueryOutcome &result, + const QueryOutcome &result, QResultClass *q_res, ColumnInfoClass &fields) { ClearError(); return AssignTableData(result, q_res, fields) @@ -177,7 +177,7 @@ BOOL CC_Append_Table_Data( bool _CC_from_TSResult( QResultClass *q_res, ConnectionClass *conn, StatementClass *stmt, const char *next_token, - const Aws::TimestreamQuery::Model::QueryOutcome &result) { + const QueryOutcome &result) { CSTR func = "_CC_from_TSResult"; // Note - NULL conn and/or cursor is valid if (q_res == NULL) @@ -210,7 +210,7 @@ bool _CC_from_TSResult( } bool AssignColumnHeaders(QResultClass *q_res, - const Aws::TimestreamQuery::Model::QueryOutcome &outcome) { + const QueryOutcome &outcome) { // Allocte memory for column fields const auto &column_info = outcome.GetResult().GetColumnInfo(); QR_set_num_fields(q_res, (uint16_t)column_info.size()); @@ -244,9 +244,6 @@ bool AssignColumnHeaders(QResultClass *q_res, } else if (type.RowColumnInfoHasBeenSet()) { column_type_id = DB_TYPE_VARCHAR; column_size = DB_VARCHAR_SIZE; - } else if (type.TimeSeriesMeasureValueColumnInfoHasBeenSet()) { - column_type_id = DB_TYPE_VARCHAR; - column_size = DB_VARCHAR_SIZE; } else { throw std::runtime_error("Unsupported Timestream type."); } @@ -261,7 +258,7 @@ bool AssignColumnHeaders(QResultClass *q_res, return true; } -bool AssignTableData(const Aws::TimestreamQuery::Model::QueryOutcome &outcome, +bool AssignTableData(const QueryOutcome &outcome, QResultClass *q_res, ColumnInfoClass &fields) { auto rows = outcome.GetResult().GetRows(); auto col_size = outcome.GetResult().GetColumnInfo().size(); @@ -277,7 +274,7 @@ bool AssignTableData(const Aws::TimestreamQuery::Model::QueryOutcome &outcome, return true; } -void ParseDatum(const Aws::TimestreamQuery::Model::Datum &datum, +void ParseDatum(const Datum &datum, std::string &datum_value, OID column_attr_id) { if (datum.ScalarValueHasBeenSet()) { auto scalar_value = datum.GetScalarValue(); @@ -302,7 +299,7 @@ void ParseDatum(const Aws::TimestreamQuery::Model::Datum &datum, } } -void ParseArray(const Aws::Vector< Aws::TimestreamQuery::Model::Datum > & datums, std::string& array_value, OID column_attr_id) { +void ParseArray(const Aws::Vector< Datum > & datums, std::string& array_value, OID column_attr_id) { if (datums.size() == 0) { array_value += "-"; } else { @@ -321,7 +318,7 @@ void ParseArray(const Aws::Vector< Aws::TimestreamQuery::Model::Datum > & datums } } -void ParseRow(const Aws::Vector< Aws::TimestreamQuery::Model::Datum > &datums, +void ParseRow(const Aws::Vector< Datum > &datums, std::string &row_value, OID column_attr_id) { row_value += "("; for (auto &datum : datums) { @@ -337,7 +334,7 @@ void ParseRow(const Aws::Vector< Aws::TimestreamQuery::Model::Datum > &datums, row_value += ")"; } -bool AssignRowData(const Aws::TimestreamQuery::Model::Row &row, +bool AssignRowData(const Row &row, QResultClass *q_res, ColumnInfoClass &fields, const size_t &col_size) { TupleField *tuple = diff --git a/src/odbcdriver/parse_result.h b/src/odbcdriver/parse_result.h index 44ec9ed0e..4695ecae6 100644 --- a/src/odbcdriver/parse_result.h +++ b/src/odbcdriver/parse_result.h @@ -28,16 +28,16 @@ extern "C" { #ifdef __cplusplus #include "helper.h" -#include -#include -#include +#include "Type.h" +#include "ScalarType.h" +#include "DatabaseQueryClient.h" // const char* is used instead of string for the cursor, because a NULL cursor // is sometimes used Cannot pass q_res as reference because it breaks qresult.h // macros that expect to use -> operator BOOL CC_from_TSResult( QResultClass *q_res, ConnectionClass *conn, StatementClass *stmt, const char *next_token, - const Aws::TimestreamQuery::Model::QueryOutcome &result); -BOOL CC_Append_Table_Data(const Aws::TimestreamQuery::Model::QueryOutcome &result, QResultClass *q_res, ColumnInfoClass &fields); + const QueryOutcome &result); +BOOL CC_Append_Table_Data(const QueryOutcome &result, QResultClass *q_res, ColumnInfoClass &fields); #endif #endif diff --git a/src/odbcdriver/prefetch_queue.cpp b/src/odbcdriver/prefetch_queue.cpp index f7124c845..0d4ed0f01 100644 --- a/src/odbcdriver/prefetch_queue.cpp +++ b/src/odbcdriver/prefetch_queue.cpp @@ -15,7 +15,7 @@ */ #include "prefetch_queue.h" -bool PrefetchQueue::Push(std::shared_future< Aws::TimestreamQuery::Model::QueryOutcome > future_outcome) { +bool PrefetchQueue::Push(std::shared_future< QueryOutcome > future_outcome) { std::unique_lock< std::mutex > lock(mutex); condition_variable.wait( lock, [&]() { return queue.size() < CAPACITY || !retrieving; }); @@ -38,7 +38,7 @@ void PrefetchQueue::Pop() { condition_variable.notify_one(); } -Aws::TimestreamQuery::Model::QueryOutcome PrefetchQueue::Front() { +QueryOutcome PrefetchQueue::Front() { auto outcome = queue.front().get(); return outcome; } @@ -80,4 +80,4 @@ bool PrefetchQueue::IsRetrieving() { void PrefetchQueue::NotifyOne() { condition_variable.notify_one(); -} +} \ No newline at end of file diff --git a/src/odbcdriver/prefetch_queue.h b/src/odbcdriver/prefetch_queue.h index ebf965960..cda2f91c3 100644 --- a/src/odbcdriver/prefetch_queue.h +++ b/src/odbcdriver/prefetch_queue.h @@ -18,7 +18,7 @@ #include #include -#include +#include "DatabaseQueryClient.h" /** * PrefetchQueue class for query @@ -34,7 +34,7 @@ class PrefetchQueue { * @param future_outcome std::shared_future< Aws::TimestreamQuery::Model::QueryOutcome > * @return bool */ - bool Push(std::shared_future< Aws::TimestreamQuery::Model::QueryOutcome > future_outcome); + bool Push(std::shared_future< QueryOutcome > future_outcome); /** * Pop function * @return void @@ -44,7 +44,7 @@ class PrefetchQueue { * Front function * @return Aws::TimestreamQuery::Model::QueryOutcome */ - Aws::TimestreamQuery::Model::QueryOutcome Front(); + QueryOutcome Front(); /** * Check the readiness of the front * It could be interrupted by if the caller cancels @@ -83,7 +83,7 @@ class PrefetchQueue { * The queue storing the future object * If future object is not ready, it means AWS is still processing the corresponding query request */ - std::queue< std::shared_future< Aws::TimestreamQuery::Model::QueryOutcome > > queue; + std::queue< std::shared_future< QueryOutcome > > queue; /** * If true, it is in retrieving state */ diff --git a/src/odbcdriver/types.h b/src/odbcdriver/types.h index c6b80c5f3..951546319 100644 --- a/src/odbcdriver/types.h +++ b/src/odbcdriver/types.h @@ -20,7 +20,7 @@ #include "dlg_specific.h" #include "odbc.h" #ifdef __cplusplus -#include +#include "QueryResult.h" extern "C" { #endif /* the type numbers are defined by the OID's of the types' rows */