connection.h revision 4487c66123ca4830f8afbf4efcd7a260848d0e05
3ed2d0f6b5e67e2663d44489d9da3176823789a8Timo Sirainen /* not disconnected yet */
8e371a3ce32bd64288786855b8ce0cb63f19f7d1Timo Sirainen /* normal requested disconnection */
8e371a3ce32bd64288786855b8ce0cb63f19f7d1Timo Sirainen /* input buffer full */
8e371a3ce32bd64288786855b8ce0cb63f19f7d1Timo Sirainen /* connection got disconnected */
8e371a3ce32bd64288786855b8ce0cb63f19f7d1Timo Sirainen /* connect() timed out */
fdc557286bc9f92c5f3bb49096ff6e2bcec0ea79Timo Sirainen /* remote didn't send input */
0cb2e8eb55e70f8ebe1e8349bdf49e4cbe5d8834Timo Sirainen /* For UNIX socket clients this gets called immediately (unless
563273bdac80393af63b9520cbf4d24cc0efd028Timo Sirainen delayed_unix_client_connected_callback=TRUE) with success=TRUE,
563273bdac80393af63b9520cbf4d24cc0efd028Timo Sirainen for IP connections it gets called later:
2615df45a8027948a474abe5e817b34b0499c171Timo Sirainen If connect() fails, sets success=FALSE and errno. Streams aren't
2615df45a8027948a474abe5e817b34b0499c171Timo Sirainen initialized in that situation either. destroy() is called after
2615df45a8027948a474abe5e817b34b0499c171Timo Sirainen the callback. */
2615df45a8027948a474abe5e817b34b0499c171Timo Sirainen void (*client_connected)(struct connection *conn, bool success);
1d2b188f0eedc3cab6e27ceac5425a037f38042eTimo Sirainen /* implement one of the input*() methods.
1d2b188f0eedc3cab6e27ceac5425a037f38042eTimo Sirainen They return 1 = ok, continue. 0 = ok, but stop processing more
c0a87e5f3316a57e6f915882fa1951d0fbb74a61Timo Sirainen lines, -1 = error, disconnect the client. */
3e564425db51f3921ce4de11859777135fdedd15Timo Sirainen int (*input_line)(struct connection *conn, const char *line);
fdc557286bc9f92c5f3bb49096ff6e2bcec0ea79Timo Sirainen int (*input_args)(struct connection *conn, const char *const *args);
e15b305e90c9834734ccf35ed78f0ad29d570ee9Timo Sirainen /* Don't call client_connected() immediately on
e15b305e90c9834734ccf35ed78f0ad29d570ee9Timo Sirainen connection_client_connect() with UNIX sockets. This is mainly
e15b305e90c9834734ccf35ed78f0ad29d570ee9Timo Sirainen to make the functionality identical with inet sockets, which may
563273bdac80393af63b9520cbf4d24cc0efd028Timo Sirainen simplify the calling code. */
fdc557286bc9f92c5f3bb49096ff6e2bcec0ea79Timo Sirainen /* If connect() to UNIX socket fails with EAGAIN, retry for this many
57a8c6a95e4bce3eeaba36985adb81c07dd683ffTimo Sirainen milliseconds before giving up (0 = try once) */
ff7056842f14fd3b30a2d327dfab165b9d15dd30Timo Sirainen /* for IP client: */
f1743785713e7632459d623d5df2108f4b93accbTimo Sirainen unsigned int port;
70ead6466f9baa8294e71fc2fba0a4f54f488b5eTimo Sirainen /* received minor version */
ccc895c0358108d2304239063e940b7d75f364abTimo Sirainen enum connection_disconnect_reason disconnect_reason;
b9f564d00b7a115f465ffd6840341c7b8f9bfc8aTimo Sirainenvoid connection_init_server(struct connection_list *list,
6ef7e31619edfaa17ed044b45861d106a86191efTimo Sirainenvoid connection_init_client_ip(struct connection_list *list,
cff1f182205e674285cf3ff446a0dcf7afea277dTimo Sirainenvoid connection_init_client_unix(struct connection_list *list,
1d2b188f0eedc3cab6e27ceac5425a037f38042eTimo Sirainenvoid connection_init_from_streams(struct connection_list *list,
e03d986a74128f5ba30fcfda9f6e36578f5d8decTimo Sirainen struct istream *input, struct ostream *output);
17ad2164c747cedbf81dae1893063e71a3df0356Timo Sirainenint connection_client_connect(struct connection *conn);
17ad2164c747cedbf81dae1893063e71a3df0356Timo Sirainenvoid connection_disconnect(struct connection *conn);
61b0637759146621cbb7edcbd0b03a71cfd66dfeTimo Sirainenvoid connection_deinit(struct connection *conn);
2649b237dd4690575e75a30b2bf3b39ebd37b835Timo Sirainen/* Returns -1 = disconnected, 0 = nothing new, 1 = something new.
17ad2164c747cedbf81dae1893063e71a3df0356Timo Sirainen If input_full_behavior is ALLOW, may return also -2 = buffer full. */
d3280fe317a4598c0868cc440e7a1191c06d0db3Timo Sirainenint connection_input_read(struct connection *conn);
d3280fe317a4598c0868cc440e7a1191c06d0db3Timo Sirainen/* Verify that VERSION input matches what we expect. */
51327f2489a4e0e615eb9f7d921473cf8512bb79Timo Sirainenint connection_verify_version(struct connection *conn, const char *const *args);
51327f2489a4e0e615eb9f7d921473cf8512bb79Timo Sirainen/* Returns human-readable reason for why connection was disconnected. */
0cb2e8eb55e70f8ebe1e8349bdf49e4cbe5d8834Timo Sirainenconst char *connection_disconnect_reason(struct connection *conn);
d3442384ca53d4b18a493db7dd0b000f470419cfTimo Sirainenvoid connection_switch_ioloop(struct connection *conn);
d3442384ca53d4b18a493db7dd0b000f470419cfTimo Sirainenconnection_list_init(const struct connection_settings *set,
c0d069950af1dbc6a4e5c3de3bf2e437796e3ae0Timo Sirainenvoid connection_list_deinit(struct connection_list **list);
c0d069950af1dbc6a4e5c3de3bf2e437796e3ae0Timo Sirainenvoid connection_input_default(struct connection *conn);
d3442384ca53d4b18a493db7dd0b000f470419cfTimo Sirainenint connection_input_line_default(struct connection *conn, const char *line);