Add copyright statement missing from recently added files.
[trust_router.git] / include / trp_internal.h
1 /*
2  * Copyright (c) 2016, JANET(UK)
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  *
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * 3. Neither the name of JANET(UK) nor the names of its contributors
17  *    may be used to endorse or promote products derived from this software
18  *    without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24  * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
25  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
27  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
29  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
31  * OF THE POSSIBILITY OF SUCH DAMAGE.
32  *
33  */
34
35 #ifndef TRP_INTERNAL_H
36 #define TRP_INTERNAL_H
37
38 #include <pthread.h>
39 #include <talloc.h>
40
41 #include <gsscon.h>
42 #include <tr_mq.h>
43 #include <tr_msg.h>
44 #include <trp_ptable.h>
45 #include <trp_rtable.h>
46 #include <trust_router/trp.h>
47
48 /* info records */
49 /* TRP update record types */
50 typedef struct trp_inforec_route {
51   TR_NAME *comm;
52   TR_NAME *realm;
53   TR_NAME *trust_router;
54   TR_NAME *next_hop;
55   unsigned int next_hop_port;
56   unsigned int metric;
57   unsigned int interval;
58 } TRP_INFOREC_ROUTE;
59
60 /* TODO: define struct trp_msg_info_community */
61
62 typedef union trp_inforec_data {
63   TRP_INFOREC_ROUTE *route;
64   /* TRP_INFOREC_COMM *comm; */
65 } TRP_INFOREC_DATA;
66
67 struct trp_inforec {
68   TRP_INFOREC *next;
69   TRP_INFOREC_TYPE type;
70   TRP_INFOREC_DATA data; /* contains pointer to one of the record types */
71 };
72
73 struct trp_update {
74   TRP_INFOREC *records;
75   TR_NAME *peer; /* who did this update come from? */
76 };
77
78 struct trp_req {
79   TR_NAME *comm;
80   TR_NAME *realm;
81   TR_NAME *peer; /* who did this req come from? */
82 };
83
84
85 typedef struct trps_instance TRPS_INSTANCE;
86
87 typedef enum trp_connection_status {
88   TRP_CONNECTION_CLOSED=0,
89   TRP_CONNECTION_DOWN,  
90   TRP_CONNECTION_AUTHORIZING,  
91   TRP_CONNECTION_UP,
92   TRP_CONNECTION_UNKNOWN,
93 } TRP_CONNECTION_STATUS;
94
95 typedef struct trp_connection TRP_CONNECTION;
96 struct trp_connection {
97   pthread_mutex_t mutex; /* protects status attribute */
98   TRP_CONNECTION *next;
99   pthread_t *thread; /* thread servicing this connection */
100   int fd;
101   TR_NAME *gssname;
102   TR_NAME *peer; /* TODO: why is there a peer and a gssname? jlr */
103   gss_ctx_id_t *gssctx;
104   TRP_CONNECTION_STATUS status;
105   void (*status_change_cb)(TRP_CONNECTION *conn, void *cookie);
106   void *status_change_cookie;
107 };
108
109 typedef TRP_RC (*TRPS_MSG_FUNC)(TRPS_INSTANCE *, TRP_CONNECTION *, TR_MSG *);
110 typedef void (*TRP_RESP_FUNC)();
111 /*typedef int (*TRP_AUTH_FUNC)(gss_name_t client_name, TR_NAME *display_name, void *cookie);*/
112 typedef client_cb_fn TRP_AUTH_FUNC;
113
114 /* function to look up comm/realm entries */
115 typedef TRP_ROUTE *(TRP_LOOKUP_FUNC)(TR_NAME *, TR_NAME *, void *);
116
117
118 /* TRP Client Instance Data */
119 typedef struct trpc_instance TRPC_INSTANCE;
120 struct trpc_instance {
121   TRPC_INSTANCE *next;
122   TR_NAME *gssname;
123   char *server;
124   unsigned int port;
125   TRP_CONNECTION *conn;
126   TR_MQ *mq; /* msgs from master to trpc */
127 };
128
129 /* TRP Server Instance Data */
130 struct trps_instance {
131   char *hostname;
132   unsigned int port;
133   TRP_AUTH_FUNC auth_handler;
134   TRPS_MSG_FUNC msg_handler;
135   void *cookie;
136   TRP_CONNECTION *conn; /* connections from peers */
137   TRPC_INSTANCE *trpc; /* connections to peers */
138   TR_MQ *mq; /* incoming message queue */
139   TRP_PTABLE *ptable; /* peer table */
140   TRP_RTABLE *rtable; /* route table */
141   struct timeval connect_interval; /* interval between connection refreshes */
142   struct timeval update_interval; /* interval between scheduled updates */
143   struct timeval sweep_interval; /* interval between route table sweeps */
144 };
145
146 typedef enum trp_update_type {
147   TRP_UPDATE_SCHEDULED=0,
148   TRP_UPDATE_TRIGGERED,
149   TRP_UPDATE_REQUESTED
150 } TRP_UPDATE_TYPE;
151
152 TRP_CONNECTION *trp_connection_new(TALLOC_CTX *mem_ctx);
153 void trp_connection_free(TRP_CONNECTION *conn);
154 void trp_connection_close(TRP_CONNECTION *conn);
155 int trp_connection_lock(TRP_CONNECTION *conn);
156 int trp_connection_unlock(TRP_CONNECTION *conn);
157 int trp_connection_get_fd(TRP_CONNECTION *conn);
158 void trp_connection_set_fd(TRP_CONNECTION *conn, int fd);
159 TR_NAME *trp_connection_get_peer(TRP_CONNECTION *conn);
160 TR_NAME *trp_connection_get_gssname(TRP_CONNECTION *conn);
161 void trp_connection_set_gssname(TRP_CONNECTION *conn, TR_NAME *gssname);
162 gss_ctx_id_t *trp_connection_get_gssctx(TRP_CONNECTION *conn);
163 void trp_connection_set_gssctx(TRP_CONNECTION *conn, gss_ctx_id_t *gssctx);
164 TRP_CONNECTION_STATUS trp_connection_get_status(TRP_CONNECTION *conn);
165 pthread_t *trp_connection_get_thread(TRP_CONNECTION *conn);
166 void trp_connection_set_thread(TRP_CONNECTION *conn, pthread_t *thread);
167 TRP_CONNECTION *trp_connection_get_next(TRP_CONNECTION *conn);
168 TRP_CONNECTION *trp_connection_remove(TRP_CONNECTION *conn, TRP_CONNECTION *remove);
169 void trp_connection_append(TRP_CONNECTION *conn, TRP_CONNECTION *new);
170 int trp_connection_auth(TRP_CONNECTION *conn, TRP_AUTH_FUNC auth_callback, void *callback_data);
171 TRP_CONNECTION *trp_connection_accept(TALLOC_CTX *mem_ctx, int listen, TR_NAME *gssname);
172 TRP_RC trp_connection_initiate(TRP_CONNECTION *conn, char *server, unsigned int port);
173
174 TRPC_INSTANCE *trpc_new (TALLOC_CTX *mem_ctx);
175 void trpc_free (TRPC_INSTANCE *trpc);
176 TRP_CONNECTION *trpc_get_conn(TRPC_INSTANCE *trpc);
177 void trpc_set_conn(TRPC_INSTANCE *trpc, TRP_CONNECTION *conn);
178 TRPC_INSTANCE *trpc_get_next(TRPC_INSTANCE *trpc);
179 void trpc_set_next(TRPC_INSTANCE *trpc, TRPC_INSTANCE *next);
180 TRPC_INSTANCE *trpc_remove(TRPC_INSTANCE *trpc, TRPC_INSTANCE *remove);
181 void trpc_append(TRPC_INSTANCE *trpc, TRPC_INSTANCE *new);
182 char *trpc_get_server(TRPC_INSTANCE *trpc);
183 void trpc_set_server(TRPC_INSTANCE *trpc, char *server);
184 TR_NAME *trpc_get_gssname(TRPC_INSTANCE *trpc);
185 void trpc_set_gssname(TRPC_INSTANCE *trpc, TR_NAME *gssname);
186 unsigned int trpc_get_port(TRPC_INSTANCE *trpc);
187 void trpc_set_port(TRPC_INSTANCE *trpc, unsigned int port);
188 TRP_CONNECTION_STATUS trpc_get_status(TRPC_INSTANCE *trpc);
189 TR_MQ *trpc_get_mq(TRPC_INSTANCE *trpc);
190 void trpc_set_mq(TRPC_INSTANCE *trpc, TR_MQ *mq);
191 void trpc_mq_add(TRPC_INSTANCE *trpc, TR_MQ_MSG *msg);
192 TR_MQ_MSG *trpc_mq_pop(TRPC_INSTANCE *trpc);
193 void trpc_mq_clear(TRPC_INSTANCE *trpc);
194 void trpc_master_mq_add(TRPC_INSTANCE *trpc, TR_MQ_MSG *msg);
195 TR_MQ_MSG *trpc_master_mq_pop(TRPC_INSTANCE *trpc);
196 TRP_RC trpc_connect(TRPC_INSTANCE *trpc);
197 TRP_RC trpc_send_msg(TRPC_INSTANCE *trpc, const char *msg_content);
198
199 TRPS_INSTANCE *trps_new (TALLOC_CTX *mem_ctx);
200 void trps_free (TRPS_INSTANCE *trps);
201 void trps_set_ptable(TRPS_INSTANCE *trps, TRP_PTABLE *ptable);
202 void trps_set_peer_status_callback(TRPS_INSTANCE *trps, void (*cb)(TRP_PEER *, void *), void *cookie);
203 TRP_RC trps_init_rtable(TRPS_INSTANCE *trps);
204 void trps_clear_rtable(TRPS_INSTANCE *trps);
205 void trps_set_connect_interval(TRPS_INSTANCE *trps, unsigned int interval);
206 unsigned int trps_get_connect_interval(TRPS_INSTANCE *trps);
207 void trps_set_update_interval(TRPS_INSTANCE *trps, unsigned int interval);
208 unsigned int trps_get_update_interval(TRPS_INSTANCE *trps);
209 void trps_set_sweep_interval(TRPS_INSTANCE *trps, unsigned int interval);
210 unsigned int trps_get_sweep_interval(TRPS_INSTANCE *trps);
211 TRPC_INSTANCE *trps_find_trpc(TRPS_INSTANCE *trps, TRP_PEER *peer);
212 TRP_RC trps_send_msg (TRPS_INSTANCE *trps, TRP_PEER *peer, const char *msg);
213 void trps_add_connection(TRPS_INSTANCE *trps, TRP_CONNECTION *new);
214 void trps_remove_connection(TRPS_INSTANCE *trps, TRP_CONNECTION *remove);
215 void trps_add_trpc(TRPS_INSTANCE *trps, TRPC_INSTANCE *trpc);
216 void trps_remove_trpc(TRPS_INSTANCE *trps, TRPC_INSTANCE *remove);
217 int trps_get_listener(TRPS_INSTANCE *trps,
218                       TRPS_MSG_FUNC msg_handler,
219                       TRP_AUTH_FUNC auth_handler,
220                       const char *hostname,
221                       unsigned int port,
222                       void *cookie);
223 TR_MQ_MSG *trps_mq_pop(TRPS_INSTANCE *trps);
224 void trps_mq_add(TRPS_INSTANCE *trps, TR_MQ_MSG *msg);
225 TRP_RC trps_authorize_connection(TRPS_INSTANCE *trps, TRP_CONNECTION *conn);
226 void trps_handle_connection(TRPS_INSTANCE *trps, TRP_CONNECTION *conn);
227 TRP_RC trps_update_active_routes(TRPS_INSTANCE *trps);
228 TRP_RC trps_handle_tr_msg(TRPS_INSTANCE *trps, TR_MSG *tr_msg);
229 TRP_ROUTE *trps_get_route(TRPS_INSTANCE *trps, TR_NAME *comm, TR_NAME *realm, TR_NAME *peer);
230 TRP_ROUTE *trps_get_selected_route(TRPS_INSTANCE *trps, TR_NAME *comm, TR_NAME *realm);
231 TR_NAME *trps_get_next_hop(TRPS_INSTANCE *trps, TR_NAME *comm, TR_NAME *realm);
232 TRP_RC trps_sweep_routes(TRPS_INSTANCE *trps);
233 TRP_RC trps_add_route(TRPS_INSTANCE *trps, TRP_ROUTE *route);
234 TRP_RC trps_add_peer(TRPS_INSTANCE *trps, TRP_PEER *peer);
235 TRP_PEER *trps_get_peer_by_gssname(TRPS_INSTANCE *trps, TR_NAME *gssname);
236 TRP_PEER *trps_get_peer_by_servicename(TRPS_INSTANCE *trps, TR_NAME *servicename);
237 TRP_RC trps_update(TRPS_INSTANCE *trps, TRP_UPDATE_TYPE type);
238 int trps_peer_connected(TRPS_INSTANCE *trps, TRP_PEER *peer);
239 TRP_RC trps_wildcard_route_req(TRPS_INSTANCE *trps, TR_NAME *peer_gssname);
240 #endif /* TRP_INTERNAL_H */