emqx/apps/emqx_gateway/src/emqx_gateway_app.erl

105 lines
3.0 KiB
Erlang

%%--------------------------------------------------------------------
%% Copyright (c) 2021-2023 EMQ Technologies Co., Ltd. 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.
%%--------------------------------------------------------------------
-module(emqx_gateway_app).
-behaviour(application).
-include_lib("emqx/include/logger.hrl").
-export([start/2, stop/1]).
-elvis([{elvis_style, invalid_dynamic_call, disable}]).
start(_StartType, _StartArgs) ->
{ok, Sup} = emqx_gateway_sup:start_link(),
emqx_gateway_cli:load(),
load_default_gateway_applications(),
load_gateway_by_default(),
emqx_gateway_conf:load(),
{ok, Sup}.
stop(_State) ->
emqx_gateway_conf:unload(),
emqx_gateway_cli:unload(),
ok.
%%--------------------------------------------------------------------
%% Internal funcs
load_default_gateway_applications() ->
Apps = gateway_type_searching(),
lists:foreach(fun reg/1, Apps).
gateway_type_searching() ->
%% FIXME: Hardcoded apps
[
emqx_stomp_impl,
emqx_sn_impl,
emqx_exproto_impl,
emqx_coap_impl,
emqx_lwm2m_impl
].
reg(Mod) ->
try
Mod:reg(),
?SLOG(debug, #{
msg => "register_gateway_succeed",
callback_module => Mod
})
catch
Class:Reason:Stk ->
?SLOG(error, #{
msg => "failed_to_register_gateway",
callback_module => Mod,
reason => {Class, Reason},
stacktrace => Stk
})
end.
load_gateway_by_default() ->
load_gateway_by_default(confs()).
load_gateway_by_default([]) ->
ok;
load_gateway_by_default([{Type, Confs} | More]) ->
case emqx_gateway_registry:lookup(Type) of
undefined ->
?SLOG(error, #{
msg => "skip_to_load_gateway",
gateway_name => Type
});
_ ->
case emqx_gateway:load(Type, Confs) of
{ok, _} ->
?SLOG(debug, #{
msg => "load_gateway_succeed",
gateway_name => Type
});
{error, Reason} ->
?SLOG(error, #{
msg => "load_gateway_failed",
gateway_name => Type,
reason => Reason
})
end
end,
load_gateway_by_default(More).
confs() ->
maps:to_list(emqx_conf:get([gateway], #{})).