| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #include "ignite/protocol/bitmask_feature.h" |
| #include "ignite/protocol/buffer_adapter.h" |
| #include "ignite/protocol/messages.h" |
| #include "ignite/protocol/reader.h" |
| #include "ignite/protocol/utils.h" |
| #include "ignite/protocol/writer.h" |
| |
| namespace ignite::protocol { |
| |
| std::vector<std::byte> make_handshake_request( |
| std::int8_t client_type, protocol_version ver, std::map<std::string, std::string> extensions) { |
| std::vector<std::byte> message; |
| buffer_adapter buffer(message); |
| buffer.write_raw(bytes_view(MAGIC_BYTES)); |
| |
| write_message_to_buffer(buffer, [=, &extensions](protocol::writer &writer) { |
| writer.write(ver.get_major()); |
| writer.write(ver.get_minor()); |
| writer.write(ver.get_patch()); |
| |
| writer.write(client_type); |
| |
| auto features = all_supported_bitmask_features(); |
| writer.write_binary(features); |
| |
| // Extensions. |
| writer.write_map(extensions); |
| }); |
| |
| return message; |
| } |
| |
| handshake_response parse_handshake_response(bytes_view message) { |
| handshake_response res{}; |
| |
| reader reader(message); |
| |
| auto ver_major = reader.read_int16(); |
| auto ver_minor = reader.read_int16(); |
| auto ver_patch = reader.read_int16(); |
| |
| protocol_version ver(ver_major, ver_minor, ver_patch); |
| res.context.set_version(ver); |
| res.error = try_read_error(reader); |
| |
| if (res.error) |
| return res; |
| |
| res.idle_timeout_ms = reader.read_int64(); |
| reader.skip(); // Cluster node ID. Needed for partition-aware compute. |
| UNUSED_VALUE reader.read_string_nullable(); // Cluster node name. Needed for partition-aware compute. |
| |
| auto cluster_ids_len = reader.read_int32(); |
| if (cluster_ids_len <= 0) { |
| throw ignite_error("Unexpected cluster ids count: " + std::to_string(cluster_ids_len)); |
| } |
| |
| std::vector<uuid> cluster_ids; |
| cluster_ids.reserve(cluster_ids_len); |
| for (std::int32_t i = 0; i < cluster_ids_len; ++i) { |
| cluster_ids.push_back(reader.read_uuid()); |
| } |
| |
| res.context.set_cluster_ids(std::move(cluster_ids)); |
| res.context.set_cluster_name(reader.read_string()); |
| |
| res.observable_timestamp = reader.read_int64(); |
| |
| auto dbms_ver_major = reader.read_uint8(); |
| auto dbms_ver_minor = reader.read_uint8(); |
| auto dbms_ver_maintenance = reader.read_uint8(); |
| auto dbms_ver_patch = reader.read_uint8_nullable(); |
| auto dbms_ver_pre_release = reader.read_string_nullable(); |
| |
| res.context.set_server_version( |
| {dbms_ver_major, dbms_ver_minor, dbms_ver_maintenance, dbms_ver_patch, dbms_ver_pre_release}); |
| |
| auto features = reader.read_binary(); |
| res.context.set_features({features.begin(), features.end()}); |
| |
| reader.skip(); // Extensions. |
| |
| return res; |
| } |
| |
| } // namespace ignite::protocol |