X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=ovsdb%2Fjsonrpc-server.h;h=dc786352ef07c4f1df760eb373d3d26038f44e1d;hb=57483aeda3e10a190d401275c7b3dcde4cd121b4;hp=6c4acd7f349db7060d9766c94fbb5f60bfa68af4;hpb=a4af00400a835eb87569ba40e21874c05e872c0f;p=sliver-openvswitch.git diff --git a/ovsdb/jsonrpc-server.h b/ovsdb/jsonrpc-server.h index 6c4acd7f3..dc786352e 100644 --- a/ovsdb/jsonrpc-server.h +++ b/ovsdb/jsonrpc-server.h @@ -16,15 +16,38 @@ #ifndef OVSDB_JSONRPC_SERVER_H #define OVSDB_JSONRPC_SERVER_H 1 +#include + struct ovsdb; struct shash; struct ovsdb_jsonrpc_server *ovsdb_jsonrpc_server_create(struct ovsdb *); void ovsdb_jsonrpc_server_destroy(struct ovsdb_jsonrpc_server *); +/* Options for a remote. */ +struct ovsdb_jsonrpc_options { + int max_backoff; /* Maximum reconnection backoff, in msec. */ + int probe_interval; /* Max idle time before probing, in msec. */ +}; +struct ovsdb_jsonrpc_options *ovsdb_jsonrpc_default_options(void); + void ovsdb_jsonrpc_server_set_remotes(struct ovsdb_jsonrpc_server *, const struct shash *); +/* Status of a single remote connection. */ +struct ovsdb_jsonrpc_remote_status { + const char *state; + int last_error; + unsigned int sec_since_connect; + unsigned int sec_since_disconnect; + bool is_connected; +}; +void ovsdb_jsonrpc_server_get_remote_status( + const struct ovsdb_jsonrpc_server *, + struct shash * /* of 'struct ovsdb_jsonrpc_remote_status' */ ); + +void ovsdb_jsonrpc_server_reconnect(struct ovsdb_jsonrpc_server *); + void ovsdb_jsonrpc_server_run(struct ovsdb_jsonrpc_server *); void ovsdb_jsonrpc_server_wait(struct ovsdb_jsonrpc_server *);