XMLWordPrintable

    Details

    • Type: Improvement
    • Status: Closed
    • Priority: Major
    • Resolution: Fixed
    • Affects Version/s: 3.1.1
    • Fix Version/s: 3.1.1
    • Component/s: core
    • Labels:
      None
    • Proposal:
      Hide

      Add the following to UNSUBSCRIBE 3.10.3 "Response"

      1. The Topic Filter (whether containing a wild-card or not) supplied in an unsubscribe MUST be compared byte-for-byte with the current set of Topic Filters held by the Server for the Client. If any filter matches exactly then it is deleted, otherwise no additional processing occurs.

      2. Even where no Topic Filters are deleted, the server MUST respond with an UNSUBACK.

      Show
      Add the following to UNSUBSCRIBE 3.10.3 "Response" 1. The Topic Filter (whether containing a wild-card or not) supplied in an unsubscribe MUST be compared byte-for-byte with the current set of Topic Filters held by the Server for the Client. If any filter matches exactly then it is deleted, otherwise no additional processing occurs. 2. Even where no Topic Filters are deleted, the server MUST respond with an UNSUBACK.
    • Resolution:
      Hide

      Resolved in WD13

      Show
      Resolved in WD13

      Description

      This issue is related to MQTT-58

      The meaning of unsubscribe is clear in cases where the topic name(s) that it contains precisely match with topic names that have appeared in earlier subscribe commands, but what happens in other cases? In particular

      1. Unsubscribe contains an absolute (non-wildcarded) Topic Name, but the client has no subscription (wildcarded or otherwise) currently matching that topic (i.e. the client is not currently receiving any messages that were published to this topic).

      2. Unsubscribe contains a wildcarded Topic Expression, but the client has no current subscription that overlaps this expression

      3. Unsubscribe contains a wildcarded Topic Expression, but the client has one or more absolute topic subscriptions that come within the scope of this wildcard expression

      4. Unsubscribe contains an absolute or wildcarded Topic Expression that has a non-zero ovelap with one or more current subscriptions.

      There are two subcases of the above which we might want to consider as special cases:

      5. The client has no current subscriptions at all

      6. Unsubscribe to #

      We need words that will cover each of these cases and determine whether the server should

      i) Take no action, but respond positively by sending a SUBACK
      ii) Delete some portion of the client's current subscriptions and then send a SUBACK
      iii) Terminate the client

      It might be helpful to use the conceptual model that I proposed in a comment to issue 58, namely that a client has a single subscription which is the logical disjunction of a set of filters, each filter containing a Topic Expression (absolute or wildcarded). The effect of subscribe is to add a filter to the list (unless there's one already there with the same expression). My cases then boil down to asking what unsubscribe should do if

      a) None of the filters in the list intersect at all with the expression in the unsubscribe
      b) One or more of the filters are completely contained by the expression in the unsubscribe
      c) The expression in the unsubscribe is completely contained by one or more fo the filters in the list
      d) There is a partial overlap between the expression in the unsubscribe and one or more of the filters in the list.
      e) Mixtures of the above

        Attachments

          Activity

            People

            • Assignee:
              andrew_banks Andrew Banks (Inactive)
              Reporter:
              peterniblett Peter Niblett (Inactive)
            • Watchers:
              0 Start watching this issue

              Dates

              • Created:
                Updated:
                Resolved: