refactor(cassandra connector): to use emqx_connector_info
This commit refactors the cassandra connector to use the `emqx_connector_info` behavior.
This commit is contained in:
parent
159ab81904
commit
afa3da6d0d
|
@ -8,7 +8,10 @@
|
|||
emqx_resource,
|
||||
ecql
|
||||
]},
|
||||
{env, [{emqx_action_info_modules, [emqx_bridge_cassandra_action_info]}]},
|
||||
{env, [
|
||||
{emqx_action_info_modules, [emqx_bridge_cassandra_action_info]},
|
||||
{emqx_connector_info_modules, [emqx_bridge_cassandra_connector_info]}
|
||||
]},
|
||||
{modules, []},
|
||||
{links, []}
|
||||
]}.
|
||||
|
|
|
@ -1,3 +1,6 @@
|
|||
%%--------------------------------------------------------------------
|
||||
%% Copyright (c) 2023-2024 EMQ Technologies Co., Ltd. All Rights Reserved.
|
||||
%%--------------------------------------------------------------------
|
||||
-module(emqx_bridge_cassandra_action_info).
|
||||
|
||||
-behaviour(emqx_action_info).
|
||||
|
|
|
@ -0,0 +1,42 @@
|
|||
%%--------------------------------------------------------------------
|
||||
%% Copyright (c) 2023-2024 EMQ Technologies Co., Ltd. All Rights Reserved.
|
||||
%%--------------------------------------------------------------------
|
||||
-module(emqx_bridge_cassandra_connector_info).
|
||||
|
||||
-behaviour(emqx_connector_info).
|
||||
|
||||
-export([
|
||||
type_name/0,
|
||||
bridge_types/0,
|
||||
resource_callback_module/0,
|
||||
config_schema/0,
|
||||
schema_module/0,
|
||||
api_schema/1
|
||||
]).
|
||||
|
||||
type_name() ->
|
||||
cassandra.
|
||||
|
||||
bridge_types() ->
|
||||
[cassandra].
|
||||
|
||||
resource_callback_module() ->
|
||||
emqx_bridge_cassandra_connector.
|
||||
|
||||
config_schema() ->
|
||||
{cassandra,
|
||||
hoconsc:mk(
|
||||
hoconsc:map(name, hoconsc:ref(emqx_bridge_cassandra, "config_connector")),
|
||||
#{
|
||||
desc => <<"Cassandra Connector Config">>,
|
||||
required => false
|
||||
}
|
||||
)}.
|
||||
|
||||
schema_module() ->
|
||||
emqx_bridge_cassandra.
|
||||
|
||||
api_schema(Method) ->
|
||||
emqx_connector_schema:api_ref(
|
||||
emqx_bridge_cassandra, <<"cassandra">>, Method ++ "_connector"
|
||||
).
|
|
@ -70,7 +70,8 @@ hard_coded_connector_info_modules_ee() ->
|
|||
emqx_bridge_timescale_connector_info,
|
||||
emqx_bridge_mongodb_connector_info,
|
||||
emqx_bridge_oracle_connector_info,
|
||||
emqx_bridge_influxdb_connector_info
|
||||
emqx_bridge_influxdb_connector_info,
|
||||
emqx_bridge_cassandra_connector_info
|
||||
].
|
||||
-else.
|
||||
hard_coded_connector_info_modules_ee() ->
|
||||
|
|
|
@ -21,8 +21,6 @@
|
|||
|
||||
resource_type(Type) when is_binary(Type) ->
|
||||
resource_type(binary_to_atom(Type, utf8));
|
||||
resource_type(cassandra) ->
|
||||
emqx_bridge_cassandra_connector;
|
||||
resource_type(clickhouse) ->
|
||||
emqx_bridge_clickhouse_connector;
|
||||
resource_type(mysql) ->
|
||||
|
@ -81,14 +79,6 @@ fields(connectors) ->
|
|||
|
||||
connector_structs() ->
|
||||
[
|
||||
{cassandra,
|
||||
mk(
|
||||
hoconsc:map(name, ref(emqx_bridge_cassandra, "config_connector")),
|
||||
#{
|
||||
desc => <<"Cassandra Connector Config">>,
|
||||
required => false
|
||||
}
|
||||
)},
|
||||
{clickhouse,
|
||||
mk(
|
||||
hoconsc:map(name, ref(emqx_bridge_clickhouse, "config_connector")),
|
||||
|
@ -213,7 +203,6 @@ connector_structs() ->
|
|||
|
||||
schema_modules() ->
|
||||
[
|
||||
emqx_bridge_cassandra,
|
||||
emqx_bridge_clickhouse,
|
||||
emqx_bridge_mysql,
|
||||
emqx_bridge_syskeeper_connector,
|
||||
|
@ -236,7 +225,6 @@ api_schemas(Method) ->
|
|||
[
|
||||
%% We need to map the `type' field of a request (binary) to a
|
||||
%% connector schema module.
|
||||
api_ref(emqx_bridge_cassandra, <<"cassandra">>, Method ++ "_connector"),
|
||||
api_ref(emqx_bridge_clickhouse, <<"clickhouse">>, Method ++ "_connector"),
|
||||
api_ref(emqx_bridge_mysql, <<"mysql">>, Method ++ "_connector"),
|
||||
api_ref(emqx_bridge_syskeeper_connector, <<"syskeeper_forwarder">>, Method),
|
||||
|
|
|
@ -127,8 +127,6 @@ connector_info_schema_modules() ->
|
|||
|
||||
%% @doc Return old bridge(v1) and/or connector(v2) type
|
||||
%% from the latest connector type name.
|
||||
connector_type_to_bridge_types(cassandra) ->
|
||||
[cassandra];
|
||||
connector_type_to_bridge_types(clickhouse) ->
|
||||
[clickhouse];
|
||||
connector_type_to_bridge_types(mysql) ->
|
||||
|
|
Loading…
Reference in New Issue