the following image shows the basic call flow of a sip session.

given below is a step-by-step explanation of the above call flow −
an invite request that is sent to a proxy server is responsible for initiating a session.
the proxy server sendsa 100 trying response immediately to the caller (alice) to stop the re-transmissions of the invite request.
the proxy server searches the address of bob in the location server. after getting the address, it forwards the invite request further.
thereafter, 180 ringing (provisional responses) generated by bob is returned back to alice.
a 200 ok response is generated soon after bob picks the phone up.
bob receives an ack from the alice, once it gets 200 ok.
at the same time, the session gets established and rtp packets (conversations) start flowing from both ends.
after the conversation, any participant (alice or bob) can send a bye request to terminate the session.
bye reaches directly from alice to bob bypassing the proxy server.
finally, bob sends a 200 ok response to confirm the bye and the session is terminated.
in the above basic call flow, three transactions are (marked as 1, 2, 3) available.
the complete call (from invite to 200 ok) is known as a dialog.
sip trapezoid
how does a proxy help to connect one user with another? let us find out with the help of the following diagram.

the topology shown in the diagram is known as a sip trapezoid. the process takes place as follows −
when a caller initiates a call, an invite message is sent to the proxy server. upon receiving the invite, the proxy server attempts to resolve the address of the callee with the help of the dns server.
after getting the next route, caller’s proxy server (proxy 1, also known as outbound proxy server) forwards the invite request to the callee’s proxy server which acts as an inbound proxy server (proxy 2) for the callee.
the inbound proxy server contacts the location server to get information about the callee’s address where the user registered.
after getting information from the location server, it forwards the call to its destination.
once the user agents get to know their address, they can bypass the call, i.e., conversations pass directly.