auth modules
This commit is contained in:
parent
78e79f3279
commit
925b45bb47
|
@ -63,10 +63,9 @@
|
||||||
%% MQTT User Management
|
%% MQTT User Management
|
||||||
%%------------------------------------------------------------------------------
|
%%------------------------------------------------------------------------------
|
||||||
-record(mqtt_user, {
|
-record(mqtt_user, {
|
||||||
clientid :: binary(),
|
|
||||||
ipaddr :: inet:ip_address(),
|
|
||||||
username :: binary(),
|
username :: binary(),
|
||||||
password :: binary()
|
ipaddr :: inet:ip_address(),
|
||||||
|
clientid :: binary()
|
||||||
}).
|
}).
|
||||||
|
|
||||||
-type mqtt_user() :: #mqtt_user{}.
|
-type mqtt_user() :: #mqtt_user{}.
|
||||||
|
|
|
@ -30,47 +30,22 @@
|
||||||
|
|
||||||
-include("emqttd.hrl").
|
-include("emqttd.hrl").
|
||||||
|
|
||||||
-export([start_link/0,
|
-export([start_link/1, check/2]).
|
||||||
add/2,
|
|
||||||
check/1, check/2,
|
|
||||||
delete/1]).
|
|
||||||
|
|
||||||
-behavior(gen_server).
|
-behavior(gen_server).
|
||||||
|
|
||||||
-export([init/1,
|
-export([init/1, handle_call/3, handle_cast/2, handle_info/2, terminate/2, code_change/3]).
|
||||||
handle_call/3,
|
|
||||||
handle_cast/2,
|
|
||||||
handle_info/2,
|
|
||||||
terminate/2,
|
|
||||||
code_change/3]).
|
|
||||||
|
|
||||||
-define(TAB, ?MODULE).
|
-define(AUTH_TABLE, mqtt_auth).
|
||||||
|
|
||||||
start_link() ->
|
start_link(AuthOpts) ->
|
||||||
gen_server:start_link({local, ?MODULE}, ?MODULE, [], []).
|
gen_server:start_link({local, ?MODULE}, ?MODULE, [AuthOpts], []).
|
||||||
|
|
||||||
-spec check({Usename :: binary(), Password :: binary()}) -> true | false.
|
-spec check(mqtt_user(), binary()) -> true | false.
|
||||||
check({Username, Password}) ->
|
check(User, Password) when is_record(User, mqtt_user) ->
|
||||||
execute(check, [Username, Password]).
|
[{_, }] = ets:lookup(?AUTH_TABLE, auth_modules),
|
||||||
|
|
||||||
-spec check(Usename :: binary(), Password :: binary()) -> true | false.
|
init([AuthOpts]) ->
|
||||||
check(Username, Password) ->
|
|
||||||
execute(check, [Username, Password]).
|
|
||||||
|
|
||||||
-spec add(Usename :: binary(), Password :: binary()) -> ok.
|
|
||||||
add(Username, Password) ->
|
|
||||||
execute(add, [Username, Password]).
|
|
||||||
|
|
||||||
-spec delete(Username :: binary()) -> ok.
|
|
||||||
delete(Username) ->
|
|
||||||
execute(delete, [Username]).
|
|
||||||
|
|
||||||
execute(F, Args) ->
|
|
||||||
[{_, M}] = ets:lookup(?TAB, mod),
|
|
||||||
apply(M, F, Args).
|
|
||||||
|
|
||||||
init([]) ->
|
|
||||||
{ok, {Name, Opts}} = application:get_env(auth),
|
|
||||||
AuthMod = authmod(Name),
|
AuthMod = authmod(Name),
|
||||||
ok = AuthMod:init(Opts),
|
ok = AuthMod:init(Opts),
|
||||||
ets:new(?TAB, [named_table, protected]),
|
ets:new(?TAB, [named_table, protected]),
|
||||||
|
|
|
@ -28,13 +28,16 @@
|
||||||
|
|
||||||
-author('feng@emqtt.io').
|
-author('feng@emqtt.io').
|
||||||
|
|
||||||
-export([init/1, add/2, check/2, delete/1]).
|
-export([init/1, add_user/2, check_login/2, del_user/1]).
|
||||||
|
|
||||||
init(_Opts) -> ok.
|
init(_Opts) -> ok.
|
||||||
|
|
||||||
check(_, _) -> true.
|
check_login(_, _) -> true.
|
||||||
|
|
||||||
|
add_user(_, _) -> ok.
|
||||||
|
|
||||||
|
del_user(_Username) -> ok.
|
||||||
|
|
||||||
|
|
||||||
add(_, _) -> ok.
|
|
||||||
|
|
||||||
delete(_Username) -> ok.
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
%%%-----------------------------------------------------------------------------
|
||||||
|
%%% @Copyright (C) 2012-2015, Feng Lee <feng@emqtt.io>
|
||||||
|
%%%
|
||||||
|
%%% Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
%%% of this software and associated documentation files (the "Software"), to deal
|
||||||
|
%%% in the Software without restriction, including without limitation the rights
|
||||||
|
%%% to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
%%% copies of the Software, and to permit persons to whom the Software is
|
||||||
|
%%% furnished to do so, subject to the following conditions:
|
||||||
|
%%%
|
||||||
|
%%% The above copyright notice and this permission notice shall be included in all
|
||||||
|
%%% copies or substantial portions of the Software.
|
||||||
|
%%%
|
||||||
|
%%% THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
%%% IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
%%% FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
%%% AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
%%% LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
%%% OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
%%% SOFTWARE.
|
||||||
|
%%%-----------------------------------------------------------------------------
|
||||||
|
%%% @doc
|
||||||
|
%%% emqttd authentication with clientid.
|
||||||
|
%%%
|
||||||
|
%%% @end
|
||||||
|
%%%-----------------------------------------------------------------------------
|
||||||
|
-module(emqttd_auth_clientid).
|
||||||
|
|
||||||
|
-author('feng@emqtt.io').
|
||||||
|
|
||||||
|
-include("emqttd.hrl").
|
||||||
|
|
||||||
|
-export([init/1]).
|
||||||
|
|
||||||
|
-define(AUTH_CLIENTID_TABLE, mqtt_auth_clientid).
|
||||||
|
|
||||||
|
init(Opts) ->
|
||||||
|
mnesia:create_table(?AUTH_CLIENTID_TABLE, [
|
||||||
|
{disc_copies, [node()]},
|
||||||
|
{attributes, record_info(fields, mqtt_user)}]),
|
||||||
|
mnesia:add_table_copy(?AUTH_CLIENTID_TABLE, node(), ram_copies),
|
||||||
|
{ok, Opts}.
|
||||||
|
|
|
@ -20,11 +20,11 @@
|
||||||
%%% SOFTWARE.
|
%%% SOFTWARE.
|
||||||
%%%-----------------------------------------------------------------------------
|
%%%-----------------------------------------------------------------------------
|
||||||
%%% @doc
|
%%% @doc
|
||||||
%%% emqttd internal authentication.
|
%%% emqttd authentication with username and password.
|
||||||
%%%
|
%%%
|
||||||
%%% @end
|
%%% @end
|
||||||
%%%-----------------------------------------------------------------------------
|
%%%-----------------------------------------------------------------------------
|
||||||
-module(emqttd_auth_internal).
|
-module(emqttd_auth_username).
|
||||||
|
|
||||||
-author('feng@emqtt.io').
|
-author('feng@emqtt.io').
|
||||||
|
|
||||||
|
@ -32,13 +32,15 @@
|
||||||
|
|
||||||
-export([init/1, add/2, check/2, delete/1]).
|
-export([init/1, add/2, check/2, delete/1]).
|
||||||
|
|
||||||
-define(USER_TAB, mqtt_user).
|
-define(AUTH_USER_TABLE, mqtt_auth_username).
|
||||||
|
|
||||||
|
-record(mqtt_auth_username, {username, password}).
|
||||||
|
|
||||||
init(_Opts) ->
|
init(_Opts) ->
|
||||||
mnesia:create_table(?USER_TAB, [
|
mnesia:create_table(?AUTH_USER_TABLE, [
|
||||||
{ram_copies, [node()]},
|
{ram_copies, [node()]},
|
||||||
{attributes, record_info(fields, mqtt_user)}]),
|
{attributes, record_info(fields, mqtt_user)}]),
|
||||||
mnesia:add_table_copy(?USER_TAB, node(), ram_copies),
|
mnesia:add_table_copy(?AUTH_USER_TABLE, node(), ram_copies),
|
||||||
ok.
|
ok.
|
||||||
|
|
||||||
check(undefined, _) -> false;
|
check(undefined, _) -> false;
|
||||||
|
@ -47,19 +49,19 @@ check(_, undefined) -> false;
|
||||||
|
|
||||||
check(Username, Password) when is_binary(Username), is_binary(Password) ->
|
check(Username, Password) when is_binary(Username), is_binary(Password) ->
|
||||||
PasswdHash = crypto:hash(md5, Password),
|
PasswdHash = crypto:hash(md5, Password),
|
||||||
case mnesia:dirty_read(?USER_TAB, Username) of
|
case mnesia:dirty_read(?AUTH_USER_TABLE, Username) of
|
||||||
[#mqtt_user{password=PasswdHash}] -> true;
|
[#mqtt_user{}] -> true; %password=PasswdHash}
|
||||||
_ -> false
|
_ -> false
|
||||||
end.
|
end.
|
||||||
|
|
||||||
add(Username, Password) when is_binary(Username) and is_binary(Password) ->
|
add(Username, Password) when is_binary(Username) and is_binary(Password) ->
|
||||||
mnesia:dirty_write(
|
mnesia:dirty_write(
|
||||||
#mqtt_user{
|
#mqtt_user{
|
||||||
username = Username,
|
username = Username
|
||||||
password = crypto:hash(md5, Password)
|
%password = crypto:hash(md5, Password)
|
||||||
}
|
}
|
||||||
).
|
).
|
||||||
|
|
||||||
delete(Username) when is_binary(Username) ->
|
delete(Username) when is_binary(Username) ->
|
||||||
mnesia:dirty_delete(?USER_TAB, Username).
|
mnesia:dirty_delete(?AUTH_USER_TABLE, Username).
|
||||||
|
|
|
@ -39,7 +39,7 @@
|
||||||
]},
|
]},
|
||||||
{emqttd, [
|
{emqttd, [
|
||||||
%Authetication. Internal, Anonymous Default
|
%Authetication. Internal, Anonymous Default
|
||||||
{auth, {anonymous, []}},
|
{auth, [{anonymous, []}]},
|
||||||
%ACL config
|
%ACL config
|
||||||
{acl, [{file, "etc/acl.config"}]},
|
{acl, [{file, "etc/acl.config"}]},
|
||||||
{packet, [
|
{packet, [
|
||||||
|
@ -85,6 +85,11 @@
|
||||||
{max_clients, 512},
|
{max_clients, 512},
|
||||||
{access, [{allow, "127.0.0.1"}]}
|
{access, [{allow, "127.0.0.1"}]}
|
||||||
]}
|
]}
|
||||||
|
]},
|
||||||
|
% Plugins
|
||||||
|
{plugins, [
|
||||||
|
{emqttd_auth_ldap, [ldap_params]},
|
||||||
|
{emqttd_auth_mysql, [mysql_params]},
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
].
|
].
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
{lib_dirs, ["../apps", "../deps", "../plugins"]},
|
{lib_dirs, ["../apps", "../deps", "../plugins"]},
|
||||||
{erts, [{mod_cond, derived}, {app_file, strip}]},
|
{erts, [{mod_cond, derived}, {app_file, strip}]},
|
||||||
{app_file, strip},
|
{app_file, strip},
|
||||||
{rel, "emqttd", "0.5.0",
|
{rel, "emqttd", "0.5.4",
|
||||||
[
|
[
|
||||||
kernel,
|
kernel,
|
||||||
stdlib,
|
stdlib,
|
||||||
|
@ -58,6 +58,7 @@
|
||||||
{mkdir, "log/"},
|
{mkdir, "log/"},
|
||||||
{mkdir, "etc/"},
|
{mkdir, "etc/"},
|
||||||
{mkdir, "data/"},
|
{mkdir, "data/"},
|
||||||
|
{mkdir, "plugins/"},
|
||||||
{copy, "files/erl", "\{\{erts_vsn\}\}/bin/erl"},
|
{copy, "files/erl", "\{\{erts_vsn\}\}/bin/erl"},
|
||||||
{template, "files/nodetool", "\{\{erts_vsn\}\}/bin/nodetool"},
|
{template, "files/nodetool", "\{\{erts_vsn\}\}/bin/nodetool"},
|
||||||
{template, "files/emqttd", "bin/emqttd"},
|
{template, "files/emqttd", "bin/emqttd"},
|
||||||
|
|
Loading…
Reference in New Issue