Skip to content

Commit

Permalink
Clarify push docs (#65)
Browse files Browse the repository at this point in the history
  • Loading branch information
nathanl authored Apr 23, 2024
1 parent 20f22cf commit 195b01f
Showing 1 changed file with 12 additions and 5 deletions.
17 changes: 12 additions & 5 deletions lib/slipstream.ex
Original file line number Diff line number Diff line change
Expand Up @@ -999,16 +999,23 @@ defmodule Slipstream do
Although this request to the remote server is asynchronous, the call to the
transport process to transmit the push is synchronous and will exert
back-pressure on calls to `push/4`, as `push/4` blocks until the message
has been sent by the transport.
has been written to the network socket by the transport.
An `{:ok, ref}` return from `push/4` does not mean the message has been
delivered to the phoenix channel or even that it has been sent on the
network; it only means that the connection was alive as of the most recent
heartbeat and that the given data was therefore written to the network socket
using `:gen_tcp.send/2` or `:ssl.send/2`.
The only way to confirm that a message was delivered to the phoenix channel
is if the channel replies to the message. In order to link push requests to
their replies, store the `ref` string returned from the call to `push/4` and
match on it in `c:handle_reply/3`.
If you are pushing especially large messages, you may need to adjust the
`timeout` argument so that the GenServer call does not exit with `:timeout`.
The default value is `5_000` msec (5 seconds).
A phoenix channel may decide to reply to a message sent with `push/2`. In
order to link push requests to their replies, store the `ref` string returned
from the call to `push/4` and match on it in `c:handle_reply/3`.
## Examples
@impl Slipstream
Expand Down

0 comments on commit 195b01f

Please sign in to comment.