event manager
This commit is contained in:
parent
e5ba03c9e0
commit
bcd354f77d
|
@ -96,6 +96,7 @@ start_servers(Sup) ->
|
||||||
?PRINT_MSG("[done]~n")
|
?PRINT_MSG("[done]~n")
|
||||||
end,
|
end,
|
||||||
[{"emqttd config", emqttd_config},
|
[{"emqttd config", emqttd_config},
|
||||||
|
{"emqttd event", emqttd_event},
|
||||||
{"emqttd server", emqttd_server, RetainOpts},
|
{"emqttd server", emqttd_server, RetainOpts},
|
||||||
{"emqttd client manager", emqttd_cm},
|
{"emqttd client manager", emqttd_cm},
|
||||||
{"emqttd session manager", emqttd_sm},
|
{"emqttd session manager", emqttd_sm},
|
||||||
|
|
|
@ -26,8 +26,95 @@
|
||||||
%%%-----------------------------------------------------------------------------
|
%%%-----------------------------------------------------------------------------
|
||||||
-module(emqttd_event).
|
-module(emqttd_event).
|
||||||
|
|
||||||
-export([start_link/0]).
|
-include("emqttd_packet.hrl").
|
||||||
|
|
||||||
|
%% API Function Exports
|
||||||
|
-export([start_link/0,
|
||||||
|
add_handler/2]).
|
||||||
|
|
||||||
|
%% gen_event Function Exports
|
||||||
|
-export([init/1,
|
||||||
|
handle_event/2,
|
||||||
|
handle_call/2,
|
||||||
|
handle_info/2,
|
||||||
|
terminate/2,
|
||||||
|
code_change/3]).
|
||||||
|
|
||||||
|
-record(state, {systop}).
|
||||||
|
|
||||||
|
%%------------------------------------------------------------------------------
|
||||||
|
%% @doc
|
||||||
|
%% Start emqttd event manager.
|
||||||
|
%%
|
||||||
|
%% @end
|
||||||
|
%%------------------------------------------------------------------------------
|
||||||
|
-spec start_link() -> {ok, pid()} | {error, any()}.
|
||||||
start_link() ->
|
start_link() ->
|
||||||
gen_event:start_link({local, ?MODULE}).
|
case gen_event:start_link({local, ?MODULE}) of
|
||||||
|
{ok, Pid} ->
|
||||||
|
add_handler(?MODULE, []),
|
||||||
|
{ok, Pid};
|
||||||
|
{error, Reason} ->
|
||||||
|
{error, Reason}
|
||||||
|
end.
|
||||||
|
|
||||||
|
add_handler(Handler, Args) ->
|
||||||
|
gen_event:add_handler(?MODULE, Handler, Args).
|
||||||
|
|
||||||
|
%%%=============================================================================
|
||||||
|
%%% gen_event callbacks
|
||||||
|
%%%=============================================================================
|
||||||
|
|
||||||
|
init([]) ->
|
||||||
|
SysTop = list_to_binary(lists:concat(["$SYS/brokers/", node()])),
|
||||||
|
{ok, #state{systop = SysTop}}.
|
||||||
|
|
||||||
|
handle_event({connected, ClientId, Params}, State = #state{systop = SysTop}) ->
|
||||||
|
Topic = <<SysTop/binary, "clients/", ClientId/binary, "/connected">>,
|
||||||
|
Msg = #mqtt_message{topic = Topic, payload = payload(connected, Params)},
|
||||||
|
emqttd_pubsub:publish(Msg),
|
||||||
|
{ok, State};
|
||||||
|
|
||||||
|
handle_event({disconnectd, ClientId, Reason}, State = #state{systop = SysTop}) ->
|
||||||
|
Topic = <<SysTop/binary, "clients/", ClientId/binary, "/disconnected">>,
|
||||||
|
Msg = #mqtt_message{topic = Topic, payload = payload(disconnected, Reason)},
|
||||||
|
emqttd_pubsub:publish(Msg),
|
||||||
|
{ok, State};
|
||||||
|
|
||||||
|
handle_event({subscribed, ClientId, TopicTable}, State) ->
|
||||||
|
lager:error("TODO: subscribed ~s, ~p", [ClientId, TopicTable]),
|
||||||
|
{ok, State};
|
||||||
|
|
||||||
|
handle_event({unsubscribed, ClientId, Topics}, State) ->
|
||||||
|
lager:error("TODO: unsubscribed ~s, ~p", [ClientId, Topics]),
|
||||||
|
{ok, State};
|
||||||
|
|
||||||
|
handle_event(_Event, State) ->
|
||||||
|
{ok, State}.
|
||||||
|
|
||||||
|
handle_call(_Request, State) ->
|
||||||
|
Reply = ok,
|
||||||
|
{ok, Reply, State}.
|
||||||
|
|
||||||
|
handle_info(_Info, State) ->
|
||||||
|
{ok, State}.
|
||||||
|
|
||||||
|
terminate(_Reason, _State) ->
|
||||||
|
ok.
|
||||||
|
|
||||||
|
code_change(_OldVsn, State, _Extra) ->
|
||||||
|
{ok, State}.
|
||||||
|
|
||||||
|
%% ------------------------------------------------------------------
|
||||||
|
%% Internal Function Definitions
|
||||||
|
%% ------------------------------------------------------------------
|
||||||
|
|
||||||
|
payload(connected, Params) ->
|
||||||
|
From = proplists:get_value(from, Params),
|
||||||
|
Proto = proplists:get_value(protocol, Params),
|
||||||
|
Sess = proplists:get_value(session, Params),
|
||||||
|
iolist_to_binary(io_lib:format("from: ~s~nprotocol: ~p~nsession: ~s", [From, Proto, Sess]));
|
||||||
|
|
||||||
|
payload(disconnected, Reason) ->
|
||||||
|
list_to_binary(lists:concat(["reason: ", Reason])).
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue