/* * liburtc * Copyright (C) 2019 Chris Hiszpanski * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef URTC_ICE_H #define URTC_ICE_H #include #include #include #include #ifdef __cplusplus extern "C" { #endif /* Maximum number of ICE bases. Each network interface address is a base. */ #define ICE_MAX_BASES 16 /* Maximum number of supported ICE (i.e. STUN or TURN) servers */ #define ICE_MAX_SERVERS 16 ///////////////////////////// TYPE DEFINITIONS ///////////////////////////// // STUN or TURN server typedef struct { char *url; char *username; /* ignored for stun urls */ char *credential; /* ignored for stun urls */ } urtc_ice_server_t; // ICE base typedef struct { } ice_base_t; // ICE component typedef enum { ICE_COMPONENT_NULL = 0, ICE_COMPONENT_RTP, ICE_COMPONENT_RTCP } ice_component_t; // ICE candidate typedef struct { ice_component_t component; uint16_t port; uint32_t priority; } ice_candidate_t; typedef struct { ice_candidate_t local; ice_candidate_t remote; } ice_candidate_pair_t; // See https://tools.ietf.org/html/rfc8445#section-6.1.2.1 typedef enum { CHECKLIST_STATE_RUNNING = 0, CHECKLIST_STATE_COMPLETED, CHECKLIST_STATE_FAILED } ice_checklist_state_t; typedef struct { ice_checklist_state_t state; } ice_checklist_t; // ICE agent object typedef struct { pthread_t thread; ice_checklist_t checklist; ice_base_t bases[ICE_MAX_BASES]; int nfds; fd_set readfds; fd_set writefds; fd_set errorfds; struct timeval ta; bool cancelled; } ice_agent_t; /////////////////////////// FORWARD DECLARATIONS /////////////////////////// /** * Create new ICE agent * * Each agent creates a separate thread for processing network i/o events. * * \param agent[out] Pointer to agent object pointer * * \return 0 on success. Negative on error. */ int ice_agent_create(ice_agent_t **agent); /** * Destroy ICE agent * * Stops agent thread (if running) and frees memory. * * \param agent[in] Pointer to agent object * * \return 0 on success. Negative on error. */ int ice_agent_destroy(ice_agent_t *agent); int ice_gather_host_candidates(); #ifdef __cplusplus } #endif #endif /* URTC_ICE_H */