/**
 * Copyright (c) Huawei Technologies Co., Ltd. 2022. All rights reserved.
 *
 * Licensed 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.
 */
#ifndef DATASYSTEM_UTILS_CONNECTION_H
#define DATASYSTEM_UTILS_CONNECTION_H

#include <string>

#include "datasystem/object/object_enum.h"
#include "datasystem/utils/sensitive_value.h"
#include "datasystem/utils/string_view.h"
#include "datasystem/utils/service_discovery.h"

namespace datasystem {
struct ConnectOptions {
    void SetAkSkAuth(const std::string &accessKey, const SensitiveValue &secretKey, const std::string &tenantId)
    {
        this->accessKey = accessKey;
        this->secretKey = secretKey;
        this->tenantId = tenantId;
    }

    std::string host;
    int32_t port;
    int32_t connectTimeoutMs = 60 * 1000;  // 60s
    int32_t requestTimeoutMs = 0;
    SensitiveValue token = "";
    std::string clientPublicKey = "";
    SensitiveValue clientPrivateKey = "";
    std::string serverPublicKey = "";
    std::string accessKey = "";
    SensitiveValue secretKey = "";
    std::string tenantId = "";
    bool enableCrossNodeConnection = false;
    bool enableExclusiveConnection = false;
    bool enableRemoteH2D = false;
    std::shared_ptr<ServiceDiscovery> serviceDiscovery = nullptr;
    uint64_t fastTransportMemSize = 256 * 1024 * 1024;  // 256M
    std::string deviceId = "";
};
}  // namespace datasystem

#endif  // DATASYSTEM_UTILS_CONNECTION_H