All Downloads are FREE. Search and download functionalities are using the official Maven repository.

swim.mqtt.MqttSubscriptionDecoder Maven / Gradle / Ivy

Go to download

MQTT packet model and wire protocol codec that incrementally decodes and encodes MQTT streams without intermediate buffering

The newest version!
// Copyright 2015-2024 Nstream, inc.
//
// 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.

package swim.mqtt;

import swim.codec.Decoder;
import swim.codec.DecoderException;
import swim.codec.InputBuffer;

final class MqttSubscriptionDecoder extends Decoder {

  final MqttDecoder mqtt;
  final Decoder topicNameDecoder;
  final int step;

  MqttSubscriptionDecoder(MqttDecoder mqtt, Decoder topicNameDecoder, int step) {
    this.mqtt = mqtt;
    this.topicNameDecoder = topicNameDecoder;
    this.step = step;
  }

  MqttSubscriptionDecoder(MqttDecoder mqtt) {
    this(mqtt, null, 1);
  }

  @Override
  public Decoder feed(InputBuffer input) {
    return MqttSubscriptionDecoder.decode(input, this.mqtt, this.topicNameDecoder, this.step);
  }

  static Decoder decode(InputBuffer input, MqttDecoder mqtt,
                                          Decoder topicNameDecoder, int step) {
    if (step == 1) {
      if (topicNameDecoder == null) {
        topicNameDecoder = mqtt.decodeString(input);
      } else {
        topicNameDecoder = topicNameDecoder.feed(input);
      }
      if (topicNameDecoder.isDone()) {
        step = 2;
      } else if (topicNameDecoder.isError()) {
        return topicNameDecoder.asError();
      }
    }
    if (step == 2 && input.isCont()) {
      final int flags = input.head();
      input = input.step();
      return Decoder.done(mqtt.subscription(topicNameDecoder.bind(), flags));
    }
    if (input.isDone()) {
      return Decoder.error(new DecoderException("incomplete"));
    } else if (input.isError()) {
      return Decoder.error(input.trap());
    }
    return new MqttSubscriptionDecoder(mqtt, topicNameDecoder, step);
  }

  static Decoder decode(InputBuffer input, MqttDecoder mqtt) {
    return MqttSubscriptionDecoder.decode(input, mqtt, null, 1);
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy