emqx/apps/emqx_rule_engine
EMQ-YangM 059fc6e3c7 feat(emqx_rule_events): add field 'is_cache' 2022-03-25 18:05:25 +08:00
..
docs docs: EMQ X -> EMQX 2022-02-15 22:12:46 +01:00
etc chore: rename more descriptive EQM X to EMQX 2022-02-22 11:16:38 +01:00
include fix(rule): fix rpc timeout extend the RPC timeout interval 2021-09-15 08:19:22 +08:00
priv chore(apps): relocate some apps 2021-02-19 11:24:41 +01:00
src feat(emqx_rule_events): add field 'is_cache' 2022-03-25 18:05:25 +08:00
test feat(emqx_rule_events): add field 'is_cache' 2022-03-25 18:05:25 +08:00
.gitignore chore(apps): relocate some apps 2021-02-19 11:24:41 +01:00
README.md docs(README): EMQ X -> EMQX 2022-02-15 16:15:25 +01:00
rebar.config chore(apps): relocate some apps 2021-02-19 11:24:41 +01:00

README.md

emqx-rule-engine

IoT Rule Engine for EMQX Broker.

Concept

iot rule "Rule Name"
  when
     match TopicFilters and Conditions
  select
    para1 = val1
    para2 = val2
  then
    take action(#{para2 => val1, #para2 => val2})

Architecture

          |-----------------|
 Pub ---->| Message Routing |----> Sub
          |-----------------|
               |     /|\
              \|/     |
          |-----------------|
          |   Rule Engine   |
          |-----------------|
               |      |
        Backends Services Bridges

SQL for Rule query statement

select id, time, temperature as t from "topic/a" where t > 50;

License

Copyright (c) 2019-2021 EMQ Technologies Co., Ltd. All Rights Reserved.

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.