I had a discussion with a friend the other day about if hold is signified with a=sendonly or a=recvonly, which led me to revisiting the RFC to confirm, so here’s an overview of how “Call Hold” works in SIP.
By the Book
According to RFC 6337 a user can hold calls by sending a new SDP offer in an established session (Re-INVITE on active call), with an SDP payload of a=sendonly for each media stream the user want’s to hold.
The SIP Switch / PBX / UAS replies with an updated SDP where each media stream’s SDP contains a=recvonly.
So it’s both, depending on which leg you’re looking at.
In Common Practice
When a UAC puts a call in hold, it does so by sending a SIP re-INVITE, updating the SDP to include the attribute line “sendonly”
data:image/s3,"s3://crabby-images/7c3c4/7c3c426bc83a84b69685eae307f3826c21939bc5" alt=""
See the bottom line of the SDP is a=sendonly ? That’s denoting the call is to be put on hold,
If the call hold was sucesful the UAS sends back a 200 Ok, with the SDP attribute set to recvonly
data:image/s3,"s3://crabby-images/608df/608dfc662e9550c7241efad72bdc16643a01ce37" alt=""
The a=recvonly denotes the call has been held.
To retrieve the call another SIP re-invite is sent by the UAC, this time setting the media attribute back to sendrecv
data:image/s3,"s3://crabby-images/2613e/2613ebf5da765caf13b9014f9ce2b0a87e9265c2" alt=""
If sucesful a 200 OK is sent by the UAS with the a=sendrecv also set.