当前位置: 首页>>代码示例>>C++>>正文


C++ Subscription::inputHandler方法代码示例

本文整理汇总了C++中Subscription::inputHandler方法的典型用法代码示例。如果您正苦于以下问题:C++ Subscription::inputHandler方法的具体用法?C++ Subscription::inputHandler怎么用?C++ Subscription::inputHandler使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Subscription的用法示例。


在下文中一共展示了Subscription::inputHandler方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: _mqttCallback

void BootNormal::_mqttCallback(char* topic, char* payload) {
  String message = String(payload);
  String unified = String(topic);
  unified.remove(0, strlen(Config.get().mqtt.baseTopic) + strlen(Config.get().deviceId) + 1); // Remove devices/${id}/ --- +1 for /

  // Device properties
  if (Config.get().ota.enabled && unified == "$ota") {
    if (message != this->_interface->firmware.version) {
      Logger.log(F("✴ OTA available (version "));
      Logger.log(message);
      Logger.logln(F(")"));
      if (strlen(payload) + 1 <= MAX_FIRMWARE_VERSION_LENGTH) {
        strcpy(this->_otaVersion, payload);
        this->_flaggedForOta = true;
        Logger.logln(F("Flagged for OTA"));
      } else {
        Logger.logln(F("Version string received is too long"));
      }
    }
    return;
  } else if (unified == "$reset" && message == "true") {
    this->_fillMqttTopic(PSTR("/$reset"));
    MqttClient.publish("false", true);
    this->_flaggedForReset = true;
    Logger.logln(F("Flagged for reset by network"));
    return;
  }

  // Implicit node properties
  unified.remove(unified.length() - 4, 4); // Remove /set
  unsigned int separator = 0;
  for (unsigned int i = 0; i < unified.length(); i++) {
    if (unified.charAt(i) == '/') {
      separator = i;
      break;
    }
  }
  String node = unified.substring(0, separator);
  String property = unified.substring(separator + 1);

  int homieNodeIndex = -1;
  for (int i = 0; i < this->_interface->registeredNodesCount; i++) {
    const HomieNode* homieNode = this->_interface->registeredNodes[i];
    if (node == homieNode->getId()) {
      homieNodeIndex = i;
      break;
    }
  }

  if (homieNodeIndex == -1) {
    Logger.log(F("Node "));
    Logger.log(node);
    Logger.logln(F(" not registered"));
    return;
  }

  const HomieNode* homieNode = this->_interface->registeredNodes[homieNodeIndex];

  int homieNodePropertyIndex = -1;
  for (int i = 0; i < homieNode->getSubscriptionsCount(); i++) {
    Subscription subscription = homieNode->getSubscriptions()[i];
    if (property == subscription.property) {
      homieNodePropertyIndex = i;
      break;
    }
  }

  if (!homieNode->getSubscribeToAll() && homieNodePropertyIndex == -1) {
    Logger.log(F("Node "));
    Logger.log(node);
    Logger.log(F(" not subscribed to "));
    Logger.logln(property);
    return;
  }

  Logger.logln(F("Calling global input handler..."));
  bool handled = this->_interface->globalInputHandler(node, property, message);
  if (handled) return;

  Logger.logln(F("Calling node input handler..."));
  handled = homieNode->getInputHandler()(property, message);
  if (handled) return;

  if (homieNodePropertyIndex != -1) { // might not if subscribed to all only
    Subscription homieNodeSubscription = homieNode->getSubscriptions()[homieNodePropertyIndex];
    Logger.logln(F("Calling property input handler..."));
    handled = homieNodeSubscription.inputHandler(message);
  }

  if (!handled){
    Logger.logln(F("No handlers handled the following packet:"));
    Logger.log(F("  • Node ID: "));
    Logger.logln(node);
    Logger.log(F("  • Property: "));
    Logger.logln(property);
    Logger.log(F("  • Value: "));
    Logger.logln(message);
  }
}
开发者ID:DavidStacer,项目名称:homie-esp8266,代码行数:99,代码来源:BootNormal.cpp

示例2: _onMqttMessage


//.........这里部分代码省略.........
        }

        _flaggedForOta = false;
        _interface->mqttClient->unsubscribe(_prefixMqttTopic(PSTR("/$ota/payload")));
      }
    } else {
      _interface->logger->log(F("Receiving OTA payload but not requested, skipping..."));
    }
    return;
  }

  if (_mqttPayloadBuffer == nullptr) _mqttPayloadBuffer = std::unique_ptr<char[]>(new char[total + 1]);

  memcpy(_mqttPayloadBuffer.get() + index, payload, len);

  if (index + len != total) return;
  _mqttPayloadBuffer.get()[total] = '\0';

  if (strcmp_P(topic, PSTR("$ota")) == 0) { // If this is the $ota announcement
    if (strcmp(_mqttPayloadBuffer.get(), _interface->firmware.version) != 0) {
      _interface->logger->log(F("✴ OTA available (version "));
      _interface->logger->log(_mqttPayloadBuffer.get());
      _interface->logger->logln(F(")"));

      _interface->logger->logln(F("Subscribing to OTA payload..."));
      _interface->mqttClient->subscribe(_prefixMqttTopic(PSTR("/$ota/payload")), 0);
      _flaggedForOta = true;
    }

    return;
  }

  if (strcmp_P(topic, PSTR("$reset")) == 0 && strcmp(_mqttPayloadBuffer.get(), "true") == 0) {
    _interface->mqttClient->publish(_prefixMqttTopic(PSTR("/$reset")), 1, true, "false");
    _flaggedForReset = true;
    _interface->logger->logln(F("Flagged for reset by network"));
    return;
  }

  // Implicit node properties
  topic[strlen(topic) - 4] = '\0'; // Remove /set
  uint16_t separator = 0;
  for (uint16_t i = 0; i < strlen(topic); i++) {
    if (topic[i] == '/') {
      separator = i;
      break;
    }
  }
  char* node = topic;
  node[separator] = '\0';
  char* property = topic + separator + 1;
  HomieNode* homieNode = HomieNode::find(node);
  if (!homieNode) {
    _interface->logger->log(F("Node "));
    _interface->logger->log(node);
    _interface->logger->logln(F(" not registered"));
    return;
  }

  Subscription subscription;
  bool subscriptionFound = false;
  for (Subscription iSubscription : homieNode->getSubscriptions()) {
    if (strcmp(property, iSubscription.property) == 0) {
      subscription = iSubscription;
      subscriptionFound = true;
      break;
    }
  }

  if (!homieNode->isSubscribedToAll() && !subscriptionFound) {
    _interface->logger->log(F("Node "));
    _interface->logger->log(node);
    _interface->logger->log(F(" not subscribed to "));
    _interface->logger->logln(property);
    return;
  }

  _interface->logger->logln(F("Calling global input handler..."));
  bool handled = _interface->globalInputHandler(String(node), String(property), String(_mqttPayloadBuffer.get()));
  if (handled) return;

  _interface->logger->logln(F("Calling node input handler..."));
  handled = homieNode->handleInput(String(property), String(_mqttPayloadBuffer.get()));
  if (handled) return;

  if (subscriptionFound) { // might not if subscribed to all only
    _interface->logger->logln(F("Calling property input handler..."));
    handled = subscription.inputHandler(String(_mqttPayloadBuffer.get()));
  }

  if (!handled){
    _interface->logger->logln(F("No handlers handled the following packet:"));
    _interface->logger->log(F("  • Node ID: "));
    _interface->logger->logln(node);
    _interface->logger->log(F("  • Property: "));
    _interface->logger->logln(property);
    _interface->logger->log(F("  • Value: "));
    _interface->logger->logln(_mqttPayloadBuffer.get());
  }
}
开发者ID:Dietmar-Franken,项目名称:homie-esp8266,代码行数:101,代码来源:BootNormal.cpp


注:本文中的Subscription::inputHandler方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。