X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=ovsdb%2Fjsonrpc-server.h;h=e4048700156c105eb41bc43796dea4bf8ef0bdd3;hb=f2cc621bacf07a48e65e163e3420c7594fd65cfd;hp=6c4acd7f349db7060d9766c94fbb5f60bfa68af4;hpb=5f55c39b21e69025045437ffbd3bb98fe6ce2e89;p=sliver-openvswitch.git diff --git a/ovsdb/jsonrpc-server.h b/ovsdb/jsonrpc-server.h index 6c4acd7f3..e40487001 100644 --- a/ovsdb/jsonrpc-server.h +++ b/ovsdb/jsonrpc-server.h @@ -16,15 +16,37 @@ #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 state_elapsed; + 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 *);