MqttMsgPuback.cs 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /*
  2. Copyright (c) 2013, 2014 Paolo Patierno
  3. All rights reserved. This program and the accompanying materials
  4. are made available under the terms of the Eclipse Public License v1.0
  5. and Eclipse Distribution License v1.0 which accompany this distribution.
  6. The Eclipse Public License is available at
  7. http://www.eclipse.org/legal/epl-v10.html
  8. and the Eclipse Distribution License is available at
  9. http://www.eclipse.org/org/documents/edl-v10.php.
  10. Contributors:
  11. Paolo Patierno - initial API and implementation and/or initial documentation
  12. */
  13. namespace uPLibrary.Networking.M2Mqtt.Messages
  14. {
  15. /// <summary>
  16. /// Class for PUBACK message from broker to client
  17. /// </summary>
  18. public class MqttMsgPuback : MqttMsgBase
  19. {
  20. #region Properties...
  21. /// <summary>
  22. /// Message identifier for the publish message
  23. /// that is acknowledged
  24. /// </summary>
  25. public ushort MessageId
  26. {
  27. get { return this.messageId; }
  28. set { this.messageId = value; }
  29. }
  30. #endregion
  31. // message identifier
  32. private ushort messageId;
  33. /// <summary>
  34. /// Constructor
  35. /// </summary>
  36. public MqttMsgPuback()
  37. {
  38. this.type = MQTT_MSG_PUBACK_TYPE;
  39. }
  40. public override byte[] GetBytes()
  41. {
  42. int fixedHeaderSize = 0;
  43. int varHeaderSize = 0;
  44. int payloadSize = 0;
  45. int remainingLength = 0;
  46. byte[] buffer;
  47. int index = 0;
  48. // message identifier
  49. varHeaderSize += MESSAGE_ID_SIZE;
  50. remainingLength += (varHeaderSize + payloadSize);
  51. // first byte of fixed header
  52. fixedHeaderSize = 1;
  53. int temp = remainingLength;
  54. // increase fixed header size based on remaining length
  55. // (each remaining length byte can encode until 128)
  56. do
  57. {
  58. fixedHeaderSize++;
  59. temp = temp / 128;
  60. } while (temp > 0);
  61. // allocate buffer for message
  62. buffer = new byte[fixedHeaderSize + varHeaderSize + payloadSize];
  63. // first fixed header byte
  64. buffer[index++] = (MQTT_MSG_PUBACK_TYPE << MSG_TYPE_OFFSET);
  65. // encode remaining length
  66. index = this.encodeRemainingLength(remainingLength, buffer, index);
  67. // get message identifier
  68. buffer[index++] = (byte)((this.messageId >> 8) & 0x00FF); // MSB
  69. buffer[index++] = (byte)(this.messageId & 0x00FF); // LSB
  70. return buffer;
  71. }
  72. /// <summary>
  73. /// Parse bytes for a PUBACK message
  74. /// </summary>
  75. /// <param name="fixedHeaderFirstByte">First fixed header byte</param>
  76. /// <param name="channel">Channel connected to the broker</param>
  77. /// <returns>PUBACK message instance</returns>
  78. public static MqttMsgPuback Parse(byte fixedHeaderFirstByte, IMqttNetworkChannel channel)
  79. {
  80. byte[] buffer;
  81. int index = 0;
  82. MqttMsgPuback msg = new MqttMsgPuback();
  83. // get remaining length and allocate buffer
  84. int remainingLength = MqttMsgBase.decodeRemainingLength(channel);
  85. buffer = new byte[remainingLength];
  86. // read bytes from socket...
  87. channel.Receive(buffer);
  88. // message id
  89. msg.messageId = (ushort)((buffer[index++] << 8) & 0xFF00);
  90. msg.messageId |= (buffer[index++]);
  91. return msg;
  92. }
  93. public override string ToString()
  94. {
  95. #if TRACE
  96. return this.GetTraceString(
  97. "PUBACK",
  98. new object[] { "messageId" },
  99. new object[] { this.messageId });
  100. #else
  101. return base.ToString();
  102. #endif
  103. }
  104. }
  105. }