emqx/apps/emqx_connector
Thales Macedo Garitezi ccd8a2f9d7
fixing machine boot
2021-12-19 15:23:07 -03:00
..
etc feat(connector): add new option 'mode' to mqtt connectors 2021-12-07 09:56:57 +08:00
include chore: rename required function to not_empty 2021-07-09 14:18:41 +08:00
src fix(dialyzer): some dialyzer issue 2021-12-07 09:56:57 +08:00
test fix(connector): create different schema for POST,PUT,GET methods 2021-12-07 09:56:57 +08:00
.formatter.exs feat: add mix.exs for all applications 2021-06-26 19:53:18 -07:00
.gitignore Revert "chore: mv emqx_connector to emqx_data_bridge" 2021-06-17 19:11:10 +08:00
README.md Revert "chore: mv emqx_connector to emqx_data_bridge" 2021-06-17 19:11:10 +08:00
mix.exs fixing machine boot 2021-12-19 15:23:07 -03:00
mix.exs2 wip 2021-12-07 15:29:57 -03:00
rebar.config feat(mongo srv): support srv record for mongo connector 2021-11-17 12:12:30 +08:00

README.md

emqx_connector

This application is a collection of connectors.

A connector is a callback module of emqx_resource that maintains the data related to external resources. Put all resource related callback modules in a single application is good as we can put some util functions/modules here for reusing purpose.

For example, a mysql connector is an emqx resource that maintains all the mysql connection related parameters (configs) and the TCP connections to the mysql server.

An mysql connector can be used as following:

(emqx@127.0.0.1)5> emqx_resource:list_instances_verbose().
[#{config =>
       #{auto_reconnect => true,cacertfile => [],certfile => [],
         database => "mqtt",keyfile => [],password => "public",
         pool_size => 1,
         server => {{127,0,0,1},3306},
         ssl => false,user => "root",verify => false},
   id => <<"mysql-abc">>,mod => emqx_connector_mysql,
   state => #{poolname => 'mysql-abc'},
   status => started}]
(emqx@127.0.0.1)6> emqx_resource:query(<<"mysql-abc">>, {sql, <<"SELECT count(1)">>}).
{ok,[<<"count(1)">>],[[1]]}