blob: 469d43148ea494cecfb0b40d6ee4faf7333595ff [file] [log] [blame]
Philipp Maier87bd9be2017-08-22 16:35:41 +02001/* Endpoint types */
2
3/*
4 * (C) 2017 by sysmocom s.f.m.c. GmbH <info@sysmocom.de>
5 * All Rights Reserved
6 *
7 * Author: Philipp Maier
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU Affero General Public License as published by
11 * the Free Software Foundation; either version 3 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Affero General Public License for more details.
18 *
19 * You should have received a copy of the GNU Affero General Public License
20 * along with this program. If not, see <http://www.gnu.org/licenses/>.
21 *
22 */
23
24#pragma once
25
26struct sockaddr_in;
27struct mgcp_conn;
Philipp Maieredc00f42018-01-24 11:58:56 +010028struct mgcp_endpoint;
Philipp Maier87bd9be2017-08-22 16:35:41 +020029
Neels Hofmeyr3243c7c2018-09-30 05:01:20 +020030#define LOG_ENDP(endp, level, fmt, args...) \
31 LOGP(DRTP, level, "%x@ " fmt, ENDPOINT_NUMBER(endp), ## args)
32
Philipp Maier87bd9be2017-08-22 16:35:41 +020033/* Callback type for RTP dispatcher functions
34 (e.g mgcp_dispatch_rtp_bridge_cb, see below) */
Philipp Maier36a81122018-01-24 11:52:34 +010035typedef int (*mgcp_dispatch_rtp_cb) (int proto, struct sockaddr_in *addr,
Neels Hofmeyr3243c7c2018-09-30 05:01:20 +020036 struct msgb *payload,
Philipp Maier36a81122018-01-24 11:52:34 +010037 struct mgcp_conn *conn);
Philipp Maier87bd9be2017-08-22 16:35:41 +020038
Philipp Maierdf5d2192018-01-24 11:39:32 +010039/* Callback type for endpoint specific cleanup actions. This function
40 * is automatically executed when a connection is freed (see mgcp_conn_free()
41 * in mgcp_conn.c). Depending on the type of the endpoint there may be endpoint
42 * specific things to take care of once a connection has been removed. */
43typedef void (*mgcp_cleanup_cp) (struct mgcp_endpoint *endp,
44 struct mgcp_conn *conn);
45
Philipp Maier87bd9be2017-08-22 16:35:41 +020046/*! MGCP endpoint properties */
47struct mgcp_endpoint_type {
Neels Hofmeyr8838c622018-06-26 00:05:53 +020048 /*! maximum number of connections */
Philipp Maier87bd9be2017-08-22 16:35:41 +020049 int max_conns;
50
Neels Hofmeyr8838c622018-06-26 00:05:53 +020051 /*! callback that defines how to dispatch incoming RTP data */
Philipp Maier87bd9be2017-08-22 16:35:41 +020052 mgcp_dispatch_rtp_cb dispatch_rtp_cb;
Philipp Maierdf5d2192018-01-24 11:39:32 +010053
Neels Hofmeyr8838c622018-06-26 00:05:53 +020054 /*! callback that implements endpoint specific cleanup actions */
Philipp Maierdf5d2192018-01-24 11:39:32 +010055 mgcp_cleanup_cp cleanup_cb;
Philipp Maier87bd9be2017-08-22 16:35:41 +020056};
57
58/*! MGCP endpoint typeset */
59struct mgcp_endpoint_typeset {
60 struct mgcp_endpoint_type rtp;
61};
62
63/*! static MGCP endpoint typeset (pre-initalized, read-only) */
64extern const struct mgcp_endpoint_typeset ep_typeset;
Philipp Maieredc00f42018-01-24 11:58:56 +010065
Philipp Maierfdd603c2018-02-01 13:31:15 +010066/*! MGCP endpoint model */
67struct mgcp_endpoint {
68
Neels Hofmeyr8838c622018-06-26 00:05:53 +020069 /*! Call identifier string (as supplied by the call agant) */
Philipp Maierfdd603c2018-02-01 13:31:15 +010070 char *callid;
71
Neels Hofmeyr8838c622018-06-26 00:05:53 +020072 /*! Local connection options (see mgcp_internal.h) */
Philipp Maierfdd603c2018-02-01 13:31:15 +010073 struct mgcp_lco local_options;
74
Neels Hofmeyrf0504e82018-08-28 21:12:59 +020075 /*! List of struct mgcp_conn, of the connections active on this endpoint */
Philipp Maierfdd603c2018-02-01 13:31:15 +010076 struct llist_head conns;
77
Neels Hofmeyr8838c622018-06-26 00:05:53 +020078 /*! Backpointer to the MGW configuration */
Philipp Maierfdd603c2018-02-01 13:31:15 +010079 struct mgcp_config *cfg;
80
Neels Hofmeyr8838c622018-06-26 00:05:53 +020081 /*! Backpointer to the Trunk specific configuration */
Philipp Maierfdd603c2018-02-01 13:31:15 +010082 struct mgcp_trunk_config *tcfg;
83
Neels Hofmeyr8838c622018-06-26 00:05:53 +020084 /*! Endpoint properties (see above) */
Philipp Maierfdd603c2018-02-01 13:31:15 +010085 const struct mgcp_endpoint_type *type;
86
Neels Hofmeyr8838c622018-06-26 00:05:53 +020087 /*! Last MGCP transmission (in case re-transmission is required) */
Philipp Maierfdd603c2018-02-01 13:31:15 +010088 char *last_trans;
89
Neels Hofmeyr8838c622018-06-26 00:05:53 +020090 /*! Last MGCP response (in case re-transmission is required) */
Philipp Maierfdd603c2018-02-01 13:31:15 +010091 char *last_response;
92
Neels Hofmeyr8838c622018-06-26 00:05:53 +020093 /*! Memorize if this endpoint was choosen by the MGW (wildcarded, true)
Philipp Maierfdd603c2018-02-01 13:31:15 +010094 * or if the user has choosen the particular endpoint explicitly. */
Philipp Maier207ab512018-02-02 14:19:26 +010095 bool wildcarded_req;
Neels Hofmeyre6d8e912018-08-23 16:36:48 +020096
97 /*! MGCP_X_OSMO_IGN_* flags from 'X-Osmo-IGN:' header */
98 uint32_t x_osmo_ign;
Philipp Maierfdd603c2018-02-01 13:31:15 +010099};
100
101/*! Extract endpoint number for a given endpoint */
102#define ENDPOINT_NUMBER(endp) abs((int)(endp - endp->tcfg->endpoints))
103
Philipp Maier1355d7e2018-02-01 14:30:06 +0100104void mgcp_endp_release(struct mgcp_endpoint *endp);
105