emqx_authn.hrl 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. %%--------------------------------------------------------------------
  2. %% Copyright (c) 2020-2024 EMQ Technologies Co., Ltd. All Rights Reserved.
  3. %%
  4. %% Licensed under the Apache License, Version 2.0 (the "License");
  5. %% you may not use this file except in compliance with the License.
  6. %% You may obtain a copy of the License at
  7. %%
  8. %% http://www.apache.org/licenses/LICENSE-2.0
  9. %%
  10. %% Unless required by applicable law or agreed to in writing, software
  11. %% distributed under the License is distributed on an "AS IS" BASIS,
  12. %% WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. %% See the License for the specific language governing permissions and
  14. %% limitations under the License.
  15. %%--------------------------------------------------------------------
  16. -ifndef(EMQX_AUTHN_HRL).
  17. -define(EMQX_AUTHN_HRL, true).
  18. -include("emqx_authn_chains.hrl").
  19. -include_lib("emqx/include/emqx_placeholder.hrl").
  20. -define(AUTHN, emqx_authn_chains).
  21. %% has to be the same as the root field name defined in emqx_schema
  22. -define(CONF_NS, ?EMQX_AUTHENTICATION_CONFIG_ROOT_NAME).
  23. -define(CONF_NS_ATOM, ?EMQX_AUTHENTICATION_CONFIG_ROOT_NAME_ATOM).
  24. -define(CONF_NS_BINARY, ?EMQX_AUTHENTICATION_CONFIG_ROOT_NAME_BINARY).
  25. -type authenticator_id() :: binary().
  26. -define(AUTHN_RESOURCE_GROUP, <<"authn">>).
  27. %% VAR_NS_CLIENT_ATTRS is added here because it can be initialized before authn.
  28. %% NOTE: authn return may add more to (or even overwrite) client_attrs.
  29. -define(AUTHN_DEFAULT_ALLOWED_VARS, [
  30. ?VAR_USERNAME,
  31. ?VAR_CLIENTID,
  32. ?VAR_PASSWORD,
  33. ?VAR_PEERHOST,
  34. ?VAR_CERT_SUBJECT,
  35. ?VAR_CERT_CN_NAME,
  36. ?VAR_CERT_PEM,
  37. ?VAR_ZONE,
  38. ?VAR_NS_CLIENT_ATTRS
  39. ]).
  40. -endif.