diff --git a/src/common/plugin/fulltext/FTUtils.h b/src/common/plugin/fulltext/FTUtils.h index fea6d89f261..3e2382641c8 100644 --- a/src/common/plugin/fulltext/FTUtils.h +++ b/src/common/plugin/fulltext/FTUtils.h @@ -38,15 +38,19 @@ struct HttpClient { HostAddr host; std::string user; std::string password; + std::string connType{"http"}; HttpClient() = default; ~HttpClient() = default; explicit HttpClient(HttpClient&& v) noexcept - : host(std::move(v.host)), user(std::move(v.user)), password(std::move(v.password)) {} + : host(std::move(v.host)), + user(std::move(v.user)), + password(std::move(v.password)), + connType(std::move(v.connType)) {} explicit HttpClient(const HttpClient& v) noexcept - : host(v.host), user(v.user), password(v.password) {} + : host(v.host), user(v.user), password(v.password), connType(v.connType) {} explicit HttpClient(HostAddr&& h) noexcept : host(std::move(h)) {} @@ -58,10 +62,20 @@ struct HttpClient { HttpClient(const HostAddr& h, const std::string& u, const std::string& p) noexcept : host(h), user(u), password(p) {} + HttpClient(HostAddr&& h, std::string&& u, std::string&& p, std::string&& c) noexcept + : host(std::move(h)), user(std::move(u)), password(std::move(p)), connType(std::move(c)) {} + + HttpClient(const HostAddr& h, + const std::string& u, + const std::string& p, + const std::string& c) noexcept + : host(h), user(u), password(p), connType(std::move(c)) {} + void clear() { host.clear(); user.clear(); password.clear(); + connType.clear(); } std::string toString() const { @@ -72,7 +86,7 @@ struct HttpClient { os << ":" << password; } } - os << " \"http://" << host.host << ":" << host.port << "/"; + os << " -k \"" << connType << "://" << host.host << ":" << host.port << "/"; return os.str(); } }; diff --git a/src/common/plugin/fulltext/test/FulltextPluginTest.cpp b/src/common/plugin/fulltext/test/FulltextPluginTest.cpp index c79550da633..d62a372924e 100644 --- a/src/common/plugin/fulltext/test/FulltextPluginTest.cpp +++ b/src/common/plugin/fulltext/test/FulltextPluginTest.cpp @@ -41,7 +41,7 @@ TEST(FulltextPluginTest, ESIndexCheckTest) { auto ret = ESGraphAdapter().indexExistsCmd(client, "test_index"); auto expected = "/usr/bin/curl -H \"Content-Type: application/json; charset=utf-8\" " - "-XGET \"http://127.0.0.1:9200/_cat/indices/test_index?format=json\""; + "-XGET -k \"http://127.0.0.1:9200/_cat/indices/test_index?format=json\""; ASSERT_EQ(expected, ret); } @@ -51,7 +51,7 @@ TEST(FulltextPluginTest, ESCreateIndexTest) { auto ret = ESGraphAdapter().createIndexCmd(client, "test_index"); auto expected = "/usr/bin/curl -H \"Content-Type: application/json; charset=utf-8\" " - "-XPUT \"http://127.0.0.1:9200/test_index\""; + "-XPUT -k \"http://127.0.0.1:9200/test_index\""; ASSERT_EQ(expected, ret); } @@ -61,7 +61,7 @@ TEST(FulltextPluginTest, ESDropIndexTest) { auto ret = ESGraphAdapter().dropIndexCmd(client, "test_index"); auto expected = "/usr/bin/curl -H \"Content-Type: application/json; charset=utf-8\" " - "-XDELETE \"http://127.0.0.1:9200/test_index\""; + "-XDELETE -k \"http://127.0.0.1:9200/test_index\""; ASSERT_EQ(expected, ret); } @@ -72,7 +72,7 @@ TEST(FulltextPluginTest, ESPutTest) { auto header = ESStorageAdapter().putHeader(hc, item); std::string expected = "/usr/bin/curl -H \"Content-Type: application/json; charset=utf-8\" " - "-XPUT \"http://127.0.0.1:9200/index1/_doc/" + "-XPUT -k \"http://127.0.0.1:9200/index1/_doc/" "00000000018c43de7b01bca674276c43e09b3ec5baYWFhYQ==\""; ASSERT_EQ(expected, header); @@ -97,7 +97,7 @@ TEST(FulltextPluginTest, ESBulkTest) { auto header = ESStorageAdapter().bulkHeader(hc); std::string expected = "/usr/bin/curl -H \"Content-Type: application/x-ndjson; " - "charset=utf-8\" -XPOST \"http://127.0.0.1:9200/_bulk\""; + "charset=utf-8\" -XPOST -k \"http://127.0.0.1:9200/_bulk\""; ASSERT_EQ(expected, header); std::vector bodies; @@ -251,7 +251,7 @@ TEST(FulltextPluginTest, ESPrefixTest) { auto header = ESGraphAdapter().header(client, item, limit); std::string expected = "/usr/bin/curl -H \"Content-Type: application/json; charset=utf-8\" " - "-XGET \"http://127.0.0.1:9200/index1/_search?timeout=10ms\""; + "-XGET -k \"http://127.0.0.1:9200/index1/_search?timeout=10ms\""; ASSERT_EQ(expected, header); auto body = ESGraphAdapter().prefixBody("aa"); diff --git a/src/graph/executor/admin/ShowTSClientsExecutor.cpp b/src/graph/executor/admin/ShowTSClientsExecutor.cpp index b23292abbc5..f5981a6c1f3 100644 --- a/src/graph/executor/admin/ShowTSClientsExecutor.cpp +++ b/src/graph/executor/admin/ShowTSClientsExecutor.cpp @@ -25,9 +25,12 @@ folly::Future ShowTSClientsExecutor::showTSClients() { return resp.status(); } auto value = std::move(resp).value(); - DataSet v({"Host", "Port"}); + DataSet v({"Host", "Port", "Connection type"}); for (const auto &client : value) { - nebula::Row r({client.host.host, client.host.port}); + nebula::Row r; + r.values.emplace_back(client.host.host); + r.values.emplace_back(client.host.port); + r.values.emplace_back(client.conn_type_ref().has_value() ? *client.get_conn_type() : "http"); v.emplace_back(std::move(r)); } return finish(std::move(v)); diff --git a/src/graph/util/FTIndexUtils.cpp b/src/graph/util/FTIndexUtils.cpp index 683ad437291..289d0d20606 100644 --- a/src/graph/util/FTIndexUtils.cpp +++ b/src/graph/util/FTIndexUtils.cpp @@ -42,6 +42,7 @@ StatusOr> FTIndexUtils::getTSClients( hc.user = *c.user_ref(); hc.password = *c.pwd_ref(); } + hc.connType = c.conn_type_ref().has_value() ? *c.get_conn_type() : "http"; tsClients.emplace_back(std::move(hc)); } return tsClients; diff --git a/src/interface/meta.thrift b/src/interface/meta.thrift index f75e5751bf1..166d738623c 100644 --- a/src/interface/meta.thrift +++ b/src/interface/meta.thrift @@ -991,6 +991,7 @@ struct FTClient { 1: required common.HostAddr host, 2: optional binary user, 3: optional binary pwd, + 4: optional binary conn_type, } struct SignInFTServiceReq { diff --git a/src/kvstore/plugins/elasticsearch/ESListener.cpp b/src/kvstore/plugins/elasticsearch/ESListener.cpp index 767298d7dbf..2d899d61a6c 100644 --- a/src/kvstore/plugins/elasticsearch/ESListener.cpp +++ b/src/kvstore/plugins/elasticsearch/ESListener.cpp @@ -31,6 +31,7 @@ void ESListener::init() { hc.user = *c.user_ref(); hc.password = *c.pwd_ref(); } + hc.connType = c.conn_type_ref().has_value() ? *c.get_conn_type() : "http"; esClients_.emplace_back(std::move(hc)); } diff --git a/src/parser/AdminSentences.cpp b/src/parser/AdminSentences.cpp index e85079af095..54f4f29dea2 100644 --- a/src/parser/AdminSentences.cpp +++ b/src/parser/AdminSentences.cpp @@ -299,6 +299,13 @@ std::string SignInTextServiceSentence::toString() const { buf += client.get_host().host; buf += ":"; buf += std::to_string(client.get_host().port); + if (client.conn_type_ref().has_value()) { + std::string connType = *client.get_conn_type(); + auto toupper = [](auto c) { return ::toupper(c); }; + std::transform(connType.begin(), connType.end(), connType.begin(), toupper); + buf += ", "; + buf += connType; + } if (client.user_ref().has_value() && !(*client.user_ref()).empty()) { buf += ", \""; buf += *client.get_user(); @@ -310,10 +317,10 @@ std::string SignInTextServiceSentence::toString() const { buf += "\""; } buf += ")"; - buf += ","; + buf += ", "; } if (!buf.empty()) { - buf.resize(buf.size() - 1); + buf.resize(buf.size() - 2); } return buf; } diff --git a/src/parser/parser.yy b/src/parser/parser.yy index 135fa4335b4..0d2c2695029 100644 --- a/src/parser/parser.yy +++ b/src/parser/parser.yy @@ -194,7 +194,7 @@ static constexpr size_t kCommentLengthLimit = 256; %token KW_UNWIND KW_SKIP KW_OPTIONAL %token KW_CASE KW_THEN KW_ELSE KW_END %token KW_GROUP KW_ZONE KW_GROUPS KW_ZONES KW_INTO -%token KW_LISTENER KW_ELASTICSEARCH KW_FULLTEXT +%token KW_LISTENER KW_ELASTICSEARCH KW_FULLTEXT KW_HTTPS KW_HTTP %token KW_AUTO KW_FUZZY KW_PREFIX KW_REGEXP KW_WILDCARD %token KW_TEXT KW_SEARCH KW_CLIENTS KW_SIGN KW_SERVICE KW_TEXT_SEARCH %token KW_ANY KW_SINGLE KW_NONE @@ -532,6 +532,8 @@ unreserved_keyword | KW_POINT { $$ = new std::string("point"); } | KW_LINESTRING { $$ = new std::string("linestring"); } | KW_POLYGON { $$ = new std::string("polygon"); } + | KW_HTTP { $$ = new std::string("http"); } + | KW_HTTPS { $$ = new std::string("https"); } ; expression @@ -1807,6 +1809,18 @@ text_search_client_item $$->set_host(*$2); delete $2; } + | L_PAREN host_item COMMA KW_HTTP R_PAREN { + $$ = new nebula::meta::cpp2::FTClient(); + $$->set_host(*$2); + $$->set_conn_type("http"); + delete $2; + } + | L_PAREN host_item COMMA KW_HTTPS R_PAREN { + $$ = new nebula::meta::cpp2::FTClient(); + $$->set_host(*$2); + $$->set_conn_type("https"); + delete $2; + } | L_PAREN host_item COMMA STRING COMMA STRING R_PAREN { $$ = new nebula::meta::cpp2::FTClient(); $$->set_host(*$2); @@ -1816,6 +1830,26 @@ text_search_client_item delete $4; delete $6; } + | L_PAREN host_item COMMA KW_HTTP COMMA STRING COMMA STRING R_PAREN { + $$ = new nebula::meta::cpp2::FTClient(); + $$->set_host(*$2); + $$->set_user(*$6); + $$->set_pwd(*$8); + $$->set_conn_type("http"); + delete $2; + delete $6; + delete $8; + } + | L_PAREN host_item COMMA KW_HTTPS COMMA STRING COMMA STRING R_PAREN { + $$ = new nebula::meta::cpp2::FTClient(); + $$->set_host(*$2); + $$->set_user(*$6); + $$->set_pwd(*$8); + $$->set_conn_type("https"); + delete $2; + delete $6; + delete $8; + } ; text_search_client_list diff --git a/src/parser/scanner.lex b/src/parser/scanner.lex index ffe942cfec8..87be1d017eb 100644 --- a/src/parser/scanner.lex +++ b/src/parser/scanner.lex @@ -233,6 +233,8 @@ IP_OCTET ([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]) "INTO" { return TokenType::KW_INTO; } "LISTENER" { return TokenType::KW_LISTENER; } "ELASTICSEARCH" { return TokenType::KW_ELASTICSEARCH; } +"HTTP" { return TokenType::KW_HTTP; } +"HTTPS" { return TokenType::KW_HTTPS; } "FULLTEXT" { return TokenType::KW_FULLTEXT; } "AUTO" { return TokenType::KW_AUTO; } "FUZZY" { return TokenType::KW_FUZZY; } diff --git a/src/parser/test/ParserTest.cpp b/src/parser/test/ParserTest.cpp index 2fbbc03a56f..5267339a4c2 100644 --- a/src/parser/test/ParserTest.cpp +++ b/src/parser/test/ParserTest.cpp @@ -2945,23 +2945,69 @@ TEST_F(ParserTest, FullTextServiceTest) { std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200)"; auto result = parse(query); ASSERT_TRUE(result.ok()) << result.status(); + ASSERT_EQ(result.value()->toString(), query); + } + { + std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200, HTTP)"; + auto result = parse(query); + ASSERT_TRUE(result.ok()) << result.status(); + ASSERT_EQ(result.value()->toString(), query); + } + { + std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200, HTTPS)"; + auto result = parse(query); + ASSERT_TRUE(result.ok()) << result.status(); + ASSERT_EQ(result.value()->toString(), query); + } + { + std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200, HTTPS, \"user\")"; + auto result = parse(query); + ASSERT_FALSE(result.ok()); } { std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200), (127.0.0.1:9300)"; auto result = parse(query); ASSERT_TRUE(result.ok()) << result.status(); + ASSERT_EQ(result.value()->toString(), query); + } + { + std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200, HTTPS), (127.0.0.1:9300)"; + auto result = parse(query); + ASSERT_TRUE(result.ok()) << result.status(); + ASSERT_EQ(result.value()->toString(), query); } { std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200, \"user\", \"password\")"; auto result = parse(query); ASSERT_TRUE(result.ok()) << result.status(); } + { + std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200, HTTP, \"user\", \"password\")"; + auto result = parse(query); + ASSERT_TRUE(result.ok()) << result.status(); + ASSERT_EQ(result.value()->toString(), query); + } + { + std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200, HTTPS, \"user\", \"password\")"; + auto result = parse(query); + ASSERT_TRUE(result.ok()) << result.status(); + ASSERT_EQ(result.value()->toString(), query); + } { std::string query = "SIGN IN TEXT SERVICE (127.0.0.1:9200, \"user\", \"password\"), " "(127.0.0.1:9200, \"user\", \"password\")"; auto result = parse(query); ASSERT_TRUE(result.ok()) << result.status(); + ASSERT_EQ(result.value()->toString(), query); + } + { + std::string query = + "SIGN IN TEXT SERVICE (127.0.0.1:9200, HTTP, \"user\", \"password\"), " + "(127.0.0.1:9200, HTTPS, \"user\", \"password\")"; + auto result = parse(query); + ASSERT_TRUE(result.ok()) << result.status(); + ASSERT_EQ(result.value()->toString(), query); } { std::string query = "SIGN OUT TEXT SERVICE";