| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196 |
- %%--------------------------------------------------------------------
- %% Copyright (c) 2013-2017 EMQ Enterprise, Inc. (http://emqtt.io)
- %%
- %% 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.
- %%--------------------------------------------------------------------
- %%--------------------------------------------------------------------
- %% Banner
- %%--------------------------------------------------------------------
- -define(COPYRIGHT, "Copyright (c) 2013-2017 EMQ Enterprise, Inc.").
- -define(LICENSE_MESSAGE, "Licensed under the Apache License, Version 2.0").
- -define(PROTOCOL_VERSION, "MQTT/5.0").
- -define(ERTS_MINIMUM, "8.0").
- %%--------------------------------------------------------------------
- %% Sys/Queue/Share Topics' Prefix
- %%--------------------------------------------------------------------
- -define(SYSTOP, <<"$SYS/">>). %% System Topic
- -define(QUEUE, <<"$queue/">>). %% Queue Topic
- -define(SHARE, <<"$share/">>). %% Shared Topic
- %%--------------------------------------------------------------------
- %% PubSub
- %%--------------------------------------------------------------------
- -type(pubsub() :: publish | subscribe).
- -define(PS(PS), (PS =:= publish orelse PS =:= subscribe)).
- %%--------------------------------------------------------------------
- %% MQTT Topic
- %%--------------------------------------------------------------------
- -record(mqtt_topic,
- { topic :: binary(),
- flags = [] :: [retained | static]
- }).
- -type(mqtt_topic() :: #mqtt_topic{}).
- %%--------------------------------------------------------------------
- %% MQTT Subscription
- %%--------------------------------------------------------------------
- -record(mqtt_subscription,
- { subid :: binary() | atom(),
- topic :: binary(),
- qos :: 0 | 1 | 2
- }).
- -type(mqtt_subscription() :: #mqtt_subscription{}).
- %%--------------------------------------------------------------------
- %% MQTT Client
- %%--------------------------------------------------------------------
- -type(ws_header_key() :: atom() | binary() | string()).
- -type(ws_header_val() :: atom() | binary() | string() | integer()).
- -record(mqtt_client,
- { client_id :: binary() | undefined,
- client_pid :: pid(),
- username :: binary() | undefined,
- peername :: {inet:ip_address(), inet:port_number()},
- clean_sess :: boolean(),
- proto_ver :: 3 | 4,
- keepalive = 0,
- will_topic :: undefined | binary(),
- ws_initial_headers :: list({ws_header_key(), ws_header_val()}),
- mountpoint :: undefined | binary(),
- connected_at :: erlang:timestamp()
- }).
- -type(mqtt_client() :: #mqtt_client{}).
- %%--------------------------------------------------------------------
- %% MQTT Session
- %%--------------------------------------------------------------------
- -record(mqtt_session,
- { client_id :: binary(),
- sess_pid :: pid(),
- clean_sess :: boolean()
- }).
- -type(mqtt_session() :: #mqtt_session{}).
- %%--------------------------------------------------------------------
- %% MQTT Message
- %%--------------------------------------------------------------------
- -type(mqtt_msg_id() :: binary() | undefined).
- -type(mqtt_pktid() :: 1..16#ffff | undefined).
- -type(mqtt_msg_from() :: atom() | {binary(), undefined | binary()}).
- -record(mqtt_message,
- { %% Global unique message ID
- id :: mqtt_msg_id(),
- %% PacketId
- pktid :: mqtt_pktid(),
- %% ClientId and Username
- from :: mqtt_msg_from(),
- %% Topic that the message is published to
- topic :: binary(),
- %% Message QoS
- qos = 0 :: 0 | 1 | 2,
- %% Message Flags
- flags = [] :: [retain | dup | sys],
- %% Retain flag
- retain = false :: boolean(),
- %% Dup flag
- dup = false :: boolean(),
- %% $SYS flag
- sys = false :: boolean(),
- %% Headers
- headers = [] :: list(),
- %% Payload
- payload :: binary(),
- %% Timestamp
- timestamp :: erlang:timestamp()
- }).
- -type(mqtt_message() :: #mqtt_message{}).
- %%--------------------------------------------------------------------
- %% MQTT Delivery
- %%--------------------------------------------------------------------
- -record(mqtt_delivery,
- { sender :: pid(), %% Pid of the sender/publisher
- message :: mqtt_message(), %% Message
- flows :: list()
- }).
- -type(mqtt_delivery() :: #mqtt_delivery{}).
- %%--------------------------------------------------------------------
- %% MQTT Route
- %%--------------------------------------------------------------------
- -record(mqtt_route,
- { topic :: binary(),
- node :: node()
- }).
- -type(mqtt_route() :: #mqtt_route{}).
- %%--------------------------------------------------------------------
- %% MQTT Alarm
- %%--------------------------------------------------------------------
- -record(mqtt_alarm,
- { id :: binary(),
- severity :: warning | error | critical,
- title :: iolist() | binary(),
- summary :: iolist() | binary(),
- timestamp :: erlang:timestamp()
- }).
- -type(mqtt_alarm() :: #mqtt_alarm{}).
- %%--------------------------------------------------------------------
- %% MQTT Plugin
- %%--------------------------------------------------------------------
- -record(mqtt_plugin, { name, version, descr, active = false }).
- -type(mqtt_plugin() :: #mqtt_plugin{}).
- %%--------------------------------------------------------------------
- %% MQTT CLI Command. For example: 'broker metrics'
- %%--------------------------------------------------------------------
- -record(mqtt_cli, { name, action, args = [], opts = [], usage, descr }).
- -type(mqtt_cli() :: #mqtt_cli{}).
|