2 * Copyright (c) 2009, 2010 Nicira Networks.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at:
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
20 /* This is an implementation of the JSON-RPC 1.0 specification defined at
21 * http://json-rpc.org/wiki/specification. */
29 struct reconnect_stats;
32 /* API for a JSON-RPC stream. */
34 /* Default port numbers.
36 * There is nothing standard about these port numbers. They are simply what
38 #define JSONRPC_TCP_PORT 6632
39 #define JSONRPC_SSL_PORT 6632
41 int jsonrpc_stream_open(const char *name, struct stream **);
42 int jsonrpc_pstream_open(const char *name, struct pstream **);
44 struct jsonrpc *jsonrpc_open(struct stream *);
45 void jsonrpc_close(struct jsonrpc *);
47 void jsonrpc_run(struct jsonrpc *);
48 void jsonrpc_wait(struct jsonrpc *);
50 void jsonrpc_error(struct jsonrpc *, int error);
51 int jsonrpc_get_status(const struct jsonrpc *);
52 size_t jsonrpc_get_backlog(const struct jsonrpc *);
53 const char *jsonrpc_get_name(const struct jsonrpc *);
55 int jsonrpc_send(struct jsonrpc *, struct jsonrpc_msg *);
56 int jsonrpc_recv(struct jsonrpc *, struct jsonrpc_msg **);
57 void jsonrpc_recv_wait(struct jsonrpc *);
59 int jsonrpc_send_block(struct jsonrpc *, struct jsonrpc_msg *);
60 int jsonrpc_recv_block(struct jsonrpc *, struct jsonrpc_msg **);
61 int jsonrpc_transact_block(struct jsonrpc *, struct jsonrpc_msg *,
62 struct jsonrpc_msg **);
65 enum jsonrpc_msg_type {
66 JSONRPC_REQUEST, /* Request. */
67 JSONRPC_NOTIFY, /* Notification. */
68 JSONRPC_REPLY, /* Successful reply. */
69 JSONRPC_ERROR /* Error reply. */
73 enum jsonrpc_msg_type type;
74 char *method; /* Request or notification only. */
75 struct json *params; /* Request or notification only. */
76 struct json *result; /* Successful reply only. */
77 struct json *error; /* Error reply only. */
78 struct json *id; /* Request or reply only. */
81 struct jsonrpc_msg *jsonrpc_create_request(const char *method,
84 struct jsonrpc_msg *jsonrpc_create_notify(const char *method,
86 struct jsonrpc_msg *jsonrpc_create_reply(struct json *result,
87 const struct json *id);
88 struct jsonrpc_msg *jsonrpc_create_error(struct json *error,
89 const struct json *id);
91 const char *jsonrpc_msg_type_to_string(enum jsonrpc_msg_type);
92 char *jsonrpc_msg_is_valid(const struct jsonrpc_msg *);
93 void jsonrpc_msg_destroy(struct jsonrpc_msg *);
95 char *jsonrpc_msg_from_json(struct json *, struct jsonrpc_msg **);
96 struct json *jsonrpc_msg_to_json(struct jsonrpc_msg *);
98 /* A JSON-RPC session with reconnection. */
100 struct jsonrpc_session *jsonrpc_session_open(const char *name);
101 struct jsonrpc_session *jsonrpc_session_open_unreliably(struct jsonrpc *);
102 void jsonrpc_session_close(struct jsonrpc_session *);
104 void jsonrpc_session_run(struct jsonrpc_session *);
105 void jsonrpc_session_wait(struct jsonrpc_session *);
107 size_t jsonrpc_session_get_backlog(const struct jsonrpc_session *);
108 const char *jsonrpc_session_get_name(const struct jsonrpc_session *);
110 int jsonrpc_session_send(struct jsonrpc_session *, struct jsonrpc_msg *);
111 struct jsonrpc_msg *jsonrpc_session_recv(struct jsonrpc_session *);
112 void jsonrpc_session_recv_wait(struct jsonrpc_session *);
114 bool jsonrpc_session_is_alive(const struct jsonrpc_session *);
115 bool jsonrpc_session_is_connected(const struct jsonrpc_session *);
116 unsigned int jsonrpc_session_get_seqno(const struct jsonrpc_session *);
117 int jsonrpc_session_get_status(const struct jsonrpc_session *);
118 void jsonrpc_session_get_reconnect_stats(const struct jsonrpc_session *,
119 struct reconnect_stats *);
121 void jsonrpc_session_force_reconnect(struct jsonrpc_session *);
123 void jsonrpc_session_set_max_backoff(struct jsonrpc_session *,
125 void jsonrpc_session_set_probe_interval(struct jsonrpc_session *,
128 #endif /* jsonrpc.h */