aayush bhatnagar wrote:
Go read 5057. The usages are to be handled separately. So this should
*not* provoke the UAC >to clean up its INVITE dialog usage.

I have read the relevant RFC. From 5057:

OK, sorry. It just sounded like you might not have.

-Existing implementations that destroy all other usages in the dialog will continue to function as -they do now, except that peers following the recommendation will attempt to do things with the -other usages and this element will return 481s for each of them until they are all gone.

I think it is more feasible to destroy the entire dialog, than keeping on to 'hung' state until all the dialog usages are all gone as suggested above. I am familiar with implementations that clean up dialog state when they get a 481-dialog does not exist response, even if there were other 'active' usages of that dialog.

I'm not surprised. Its often "more feasible" to do the wrong thing than the right thing. But that doesn't make it right. While its not written in black and white in 3261, there is enough info there to infer that you need to treat them separately.

The reason being, that if an implementation cannot find a matching dialog as characterized by the local tag, remote tag, call-id, local and remote sequence nos etc and has rejected the request by a 481, there is no point in keeping the dialog state at the UAC.

This is all hashed out in 5057. The problem is that the 481 response is *ambiguous*. The way to maximize interop is to treat the 481 as meaning the least serious thing that it could mean - that only the usage has gone away. If it turns out that the whole dialog went away, then you will eventually find that out anyway. Of course it doesn't hurt to treat it as meaning all the usages went away if you would not continue all of them anyway. But if the other usage(s) continue to be of value then it you are hurting yourself by assuming they have gone away when they might not have.

As for example, if you receive a 481 response for a REFER sent within the INVITE dialog, there is no point in keeping the REFER usage alive. You probably sent the REFER to transfer a call, which the server complains that the call itself does not exist (481).

That's not the case of relevance. If you got a 481 for a REFER, the refer of course failed, and so there is no refer usage to keep alive.

We are still, in this thread, trying to decide what a 481 to a REFER means. I think it won't be ambiguous - that it can *only* mean that the whole dialog is gone, since it is never associated with a preexisting usage.

Even so, you would be well advised to probe any existing usages with in-usage messages to verify if they are alive, even though most likely they are not.

Moreover from 5057:

-Processing multiple usages correctly is not completely understood.
-What is understood is difficult to implement and is very likely to
-lead to interoperability problems. The best way to avoid the trouble
-that comes with such complexity is to avoid it altogether.
-When designing new applications or features that use SIP dialogs, do
-not require endpoints to construct multiple usages to participate in
-the application or use the feature.

This is very true. By defining multiple dialog usages, you are essentially extending the dialog state (as defined by 3261) by adding more attributes to it (such as subscription duration etc). I cant think of a practical use case, where a subscription that shared the invite dialog usage still needed to be preserved, even when the original INVITE dialog was no longer active.

We aren't *adding more attributes to it*. It is what it is and has been. It has been implicitly legal in spite of the problems. And it *is* used. There are even reasonable use cases for independent termination of the usages. For instance, a refer usage sharing a dialog with an invite usage may meaningfully survive after the invite usage terminates.

As for example a subscription to the 'conference' event package sent within the scope of an INVITE dialog. If i leave the conference by sending a BYE, and my subscription's duration is still valid for an hour...will i still keep on getting redundant SIP notifications for changes to the membership to that conference ?


In the sense of 5057, the subscribe usage will be preserved until it expires, or until the UAC explicitly un-subscribes, or the conference server has to send me a final NOTIFY with my subsription-state = terminated.

IMO that is exactly as it *should* be. If the subscriber doesn't want to maintain the subscription, it can simply wipe out the state of the subscription. Then when another NOTIFY is received, a 481 will be sent because there is no state, forcing the end of the usage.

But *assuming* that the subscription *should* go away when the invite ends is, IMO, wrong. There may be valid reasons to retain the subscription.

It is not important that 5057 is allowing us many theoretical possibilities by presenting multiple dialog usages. What is more important is what extra do we get by reusing a dialog, and how do implementations leverage upon such a possibility and create meaningful applications around it ?

I would like to share some examples:

1. As for example an application that can practically leverage upon 5057 may send a SUBSCRIBE to the 'dialog' event package (rfc 4235) that reuses the INVITE dialog can be used for creating SIP call tracing applications. 2. Other Implementations may include automatic callback applications by this mechanism (ring back when my sip phone is idle) etc.

3. Yet another application may send me by pre-paid account balance after i disconnect my ongoing dialog, as it is subscribed to my dialog state.

In all these example applications, the endpoint receiving the SUBSCRIBE will need to send a NOTIFY that re-uses its existing INVITE dialog (NOTIFY acting as a target refresh in the sense of 5057).

Sounds like you are in favor of dialog reuse.

        Paul

Best Regards

aayush


On Wed, Mar 25, 2009 at 7:36 PM, Paul Kyzivat <[email protected] <mailto:[email protected]>> wrote:



    aayush bhatnagar wrote:

        If you send an in dialog request (REFER in our case), then you
        cannot
        decouple its semantics with the existing dialog usage.


    You say "*the* dialog usage" as if there can be only one. There
    could be more than one. It might be coupled to:
    - the *only* existing usage
    - to *one* of several existing usages
    - to *none* of the one or more existing usages

    For instance, I could have a dialog with just an INVITE usage (the
    common case) and within that dialog send a REFER of a MESSAGE. That
    MESSAGE really has nothing to do with the INVITE usage.


        So saying that
        even if i send a REFER within an existing dialog, and still decouple
        it from the existing dialog usage will not be possible.
        If there were such a requirement, then REFER should have been
        sent as
        a standalone dialog creating request outside the INVITE usage.


    One can argue that it *should* have been. But that isn't the point
    of this discussion. In many cases using the same dialog as been an
    expedient to ensure reaching the same UA when you aren't sure the
    remote target url for the dialog is in fact routable.


        The recipient of the in dialog REFER will treat it like it
        should any
        in dialog request. It has no way to decide if this request
        potentially
        had nothing to do with the existing dialog usage.


    You are being sloppy in your use of "dialog" and "dialog usage", as
    if you are not familiar with RFC 5057. If you aren't, please read it.


        i agree with you when you say that an indialog refer receiving a 481
        would mean that the INVITE dialog has been torn down.


    See my reply to Dale.


        However, a refer dialog usage can also terminate, if the UAC sends a
        481 in response to the NOTIFY sent by the UAS (Suppose the
        transaction
        did not match).


    You need to spell out more details of the case. If it were the
    *first* NOTIFY, resulting from an in-dialog REFER, then that
    response would be indicative of a screwup somewhere.

    However, if there had been a prior NOTIFY on the refer subscription
    that indicated that the subscription was over, and then somehow
    *another* NOTIFY was sent, the 481 would be appropriate, indicating
    that the refer-usage was no longer present.


        This scenario may happen irrespective of whether the
        REFER was within the invite usage or created its own distinct
        dialog.
        If this happens when REFER was sent within an Invite dialog,
        then the
        UAC will be mistaken to clean up its INVITE dialog state.


    Go read 5057. The usages are to be handled separately. So this
    should *not* provoke the UAC to clean up its INVITE dialog usage.


        I  did not understand one part in the paradox above when you said...
        "A REFER within an established dialog having no invite usage to be
        considered as an out of dialog REFER"
        Do you mean to imply a REFER in some other Subscribe event package
        dialog for example?


    Yes, that is what I meant. I don't have any meaningful cases in
    mind, but it is a theoretical possibility.

           Paul


        aayush.

        On 3/25/09, Dale Worley <[email protected]
        <mailto:[email protected]>> wrote:

            On Mon, 2009-03-23 at 21:32 -0400, Paul Kyzivat wrote:

                    I would argue that the REFER is part of the INVITE
                    usage, because REFER
                    in that context is intimately related to the INVITE
                    usage -- it is
                    intended to transfer the INVITE usage/dialog
                    transferred to a different
                    destination.

                Well, I guess there is that implied association. (Part
                of the "do what
                *I* had in mind" approach that REFER has.) Since this
                was never spelled
                out, it could also be simply "while this isn't part of
                an INVITE usage,
                if there happens to be an INVITE usage, please refer
                that one."

                I guess the question is: would it be valid to send a
                REFER within an
                existing dialog that had no INVITE usage? If it were
                valid, presumably
                it would have the same meaning as sending one outside a
                dialog, except
                that the resulting subscription would share the dialog.
                I expect that is
                a usage it would be difficult to find in the wild.

            That's a nice pathological case.  But within the context of
            the current
            5 possible meanings of REFER, it seems to be most parallel
            to the
            out-of-dialog REFER.

                Ah, but now I want to reconsider. Remember that REFER
                can take a method
                name. So, rather than referring an INVITE, I could be
                referring MESSAGE,
                OPTIONS, BYE, or maybe (????) SUBSCRIBE. In some of
                those cases, the
                association to the INVITE usage is probably meaningless.
                (Of course its
                meaningful for BYE.)

            A fascinating possibility!  But I'm not sure that we've ever
            defined how
            a REFER within a simple INVITE dialog, specifying a
            non-INVITE method
            should act.  So there's no analog to follow.

                    And it seems quite safe that if the REFER receives a
                    481 response, the
                    INVITE usage must not be functional any more, since
                    the far end of that
                    usage has denied that it can act on the REFER.

                IIRC, 5057 decided that each dialog usage must get its
                own 481 before it
                goes away. I don't think there are any cases where a
                single 481 response
                can make multiple usages go away.

                So the important question is whether the REFER is part
                of the INVITE
                usage and so its 481 takes down the INVITE usage or not.
                That gets
                especially interesting if  the dialog already had both
                an INVITE usage
                and a SUBSCRIBE usage. Does it make sense that the refer
                take down the
                INVITE usage and leave up the SUBSCRIBE usage?

            I think we're a victim of sloppy terminology here.  If I
            send a REFER,
            and the far end responds 481, then clearly the far end knows
            of no
            INVITE usage, or otherwise it would not have responded 481.
             So I should
            delete my belief that there is an INVITE usage.  Whether we
            consider the
            REFER in question to be "part of" the INVITE usage or not
            doesn't change
            anything -- the 481 is evidence that the far end has no
            knowledge of the
            usage.

            However, we do have this fine paradox:  If we assume that a
            REFER within
            an established dialog that has no INVITE usage is to be
            treated as an
            out-of-dialog REFER, then *no* REFER will receive a 481
            response!
            Indeed, if I send a REFER thinking that there is an active
            INVITE usage,
            but the far end believes the INVITE usage has ended, will
            cause the far
            end to do something (initiate an independent dialog) that is
            considerably different from what I expected (transfer the
            current INVITE
            usage).

            Dale


            _______________________________________________
            Sip mailing list  https://www.ietf.org/mailman/listinfo/sip
            This list is for NEW development of the core SIP Protocol
            Use [email protected]
            <mailto:[email protected]> for questions on
            current sip
            Use [email protected] <mailto:[email protected]> for new
            developments on the application of sip

        _______________________________________________
        Sip mailing list  https://www.ietf.org/mailman/listinfo/sip
        This list is for NEW development of the core SIP Protocol
        Use [email protected]
        <mailto:[email protected]> for questions on
        current sip
        Use [email protected] <mailto:[email protected]> for new
        developments on the application of sip


_______________________________________________
Sip mailing list  https://www.ietf.org/mailman/listinfo/sip
This list is for NEW development of the core SIP Protocol
Use [email protected] for questions on current sip
Use [email protected] for new developments on the application of sip

Reply via email to