platform/upstream/libnice.git
19 months agoci: Add code coverage to MRs
Olivier Crête [Mon, 17 Oct 2022 10:47:06 +0000 (12:47 +0200)]
ci: Add code coverage to MRs

19 months agoAdd configuration file for lcov
Patrick Griffis [Thu, 22 Sep 2022 18:53:00 +0000 (13:53 -0500)]
Add configuration file for lcov

This is useful for accurately testing code coverage. You can use this with:

  meson configure -Db_coverage=true
  meson test
  ninja coverage

19 months agoci: Export JUnit report
Olivier Crête [Mon, 17 Oct 2022 11:21:17 +0000 (13:21 +0200)]
ci: Export JUnit report

19 months agoci: Use fdo templates
Olivier Crête [Mon, 17 Oct 2022 14:22:52 +0000 (16:22 +0200)]
ci: Use fdo templates

19 months agoconncheck: Limit ichecks based on property
Olivier Crête [Thu, 18 Aug 2022 13:22:02 +0000 (09:22 -0400)]
conncheck: Limit ichecks based on property

Limit the number of stored incoming checks based on the property
limiting the number of total connectivity checks instead of using
the fixed limit on the number of remote candidates.

22 months agoudp-bsd: Explicitly bind to the interface when creating a socket
Olivier Crête [Fri, 22 Jul 2022 20:55:14 +0000 (16:55 -0400)]
udp-bsd: Explicitly bind to the interface when creating a socket

22 months agointerfaces: Add API to find the interface index from a local address
Olivier Crête [Fri, 22 Jul 2022 20:39:36 +0000 (16:39 -0400)]
interfaces: Add API to find the interface index from a local address

This will find some interface that has the address and will not work
correctly if multiple interfaces have the same address. But in any
case, nothing in libnice expects that and we would need to break the
API to make that work.

2 years agocandidate: Copy stun_server with candidate
Olivier Crête [Wed, 1 Jun 2022 17:53:30 +0000 (13:53 -0400)]
candidate: Copy stun_server with candidate

Bug reported and fix suggested by Masato Takahashi

Fixes #164

2 years agoversion: Add NICE_CHECK_VERSION to the documentation
Olivier Crête [Thu, 26 May 2022 18:23:31 +0000 (14:23 -0400)]
version: Add NICE_CHECK_VERSION to the documentation

2 years agoaddress: Add Boxed Type
Olivier Crête [Thu, 26 May 2022 15:45:15 +0000 (11:45 -0400)]
address: Add Boxed Type

This should make the library more easily usable for bindings

2 years agoagent: Support adding optional headers to HTTP proxy client
Johan Sternerup [Fri, 25 Sep 2020 15:14:52 +0000 (17:14 +0200)]
agent: Support adding optional headers to HTTP proxy client

One use case for this is adding an ALPN header which is a MUST
requirement when a HTTP proxy is used in WebRTC (see RFC8835, section
3.4).

2 years agoConncheck: renomination: set use_candidate for pending check on early inbound STUN...
Andrey Skryabin [Mon, 23 May 2022 09:18:12 +0000 (12:18 +0300)]
Conncheck: renomination: set use_candidate for pending check on early inbound STUN with NOMINATION attr

2 years agoConncheck: always updating remote_consent.last_received for selected pair on keepalive
Andrey Skryabin [Mon, 23 May 2022 09:06:05 +0000 (12:06 +0300)]
Conncheck: always updating remote_consent.last_received for selected pair on keepalive

2 years agoNICE_CHECK_VERSION: fix unexpected "git = next version" assumption
Tim-Philipp Müller [Thu, 26 May 2022 14:01:48 +0000 (15:01 +0100)]
NICE_CHECK_VERSION: fix unexpected "git = next version" assumption

0.1.18.1 should not satisfy a check for 0.1.19, especially not
for libraries that release once a year at best.

If someone needs more control they should do a feature check for
the symbol in the headers or lib.

2 years agoFix NICE_CHECK_VERSION in public install
Tim-Philipp Müller [Thu, 26 May 2022 13:56:43 +0000 (14:56 +0100)]
Fix NICE_CHECK_VERSION in public install

Install a nice-version.h so that the version defines
are available.

https://gitlab.freedesktop.org/libnice/libnice/-/merge_requests/232

2 years agoConncheck: recheck consent timeout overflow fix
Andrey Skryabin [Fri, 20 May 2022 15:53:50 +0000 (18:53 +0300)]
Conncheck: recheck consent timeout overflow fix

2 years agocandidate: Add utility function to get STUN server address
Philippe Normand [Thu, 5 May 2022 16:27:33 +0000 (17:27 +0100)]
candidate: Add utility function to get STUN server address

Can be useful to know which STUN server was used to discover the given candidate.

2 years agodocs: Add index for symbols added in 0.1.20
Philippe Normand [Thu, 5 May 2022 16:25:38 +0000 (17:25 +0100)]
docs: Add index for symbols added in 0.1.20

2 years agoAdd NICE_CHECK_VERSION macro
Philippe Normand [Thu, 5 May 2022 12:30:54 +0000 (13:30 +0100)]
Add NICE_CHECK_VERSION macro

2 years agoagent: Initialize variable
Olivier Crête [Tue, 3 May 2022 21:50:35 +0000 (17:50 -0400)]
agent: Initialize variable

There is a codepath where it can be used without being filled.
Found by coverity.

2 years agoversion 0.1.19.1
Olivier Crête [Tue, 3 May 2022 21:42:38 +0000 (17:42 -0400)]
version 0.1.19.1

2 years agoversion 0.1.19 0.1.19 upstream/0.1.19
Olivier Crête [Tue, 3 May 2022 21:32:23 +0000 (17:32 -0400)]
version 0.1.19

2 years agocandidate: Add utility function to get TURN relay address
Philippe Normand [Sat, 16 Apr 2022 11:03:46 +0000 (12:03 +0100)]
candidate: Add utility function to get TURN relay address

Can be useful to know which TURN server is being used as relay server for a given candidate.

2 years agoagent: Hold ref while doing async close
Olivier Crête [Fri, 4 Feb 2022 22:20:52 +0000 (17:20 -0500)]
agent: Hold ref while doing async close

It's possible that the callback will be called synchronously during the
close function, in this case, we need to be ready to the last reference
to the agent to be dropped in this callback.

This fix was suggested by Fabrice Bellet

Fixes #153

2 years agoDon't try to use link-local addresses outside local network
Johan Sternerup [Thu, 20 Jan 2022 14:47:11 +0000 (15:47 +0100)]
Don't try to use link-local addresses outside local network

If we have gathered a host IP-address that is link-local we should
never try to use it for anything else than trying to match it with
another link-local address. Some routers seem to have problems with
traffic from link-local addresses destined at external IP-addresses.
By definition link-local addresses should stay local so there's no
reason to access STUN/TURN from it or try to form a candidate with
another address that is not link-local.

2 years agoagent: Fix warning about required glib version
Nirbheek Chauhan [Fri, 18 Mar 2022 07:05:49 +0000 (12:35 +0530)]
agent: Fix warning about required glib version

../agent/discovery.c: In function ‘on_refresh_remove_timeout’:
../agent/discovery.c:203:13: warning: Not available before 2.60
  203 |       G_GNUC_FALLTHROUGH;
      |             ^~~~~~~~~~~~~

../agent/conncheck.c: In function ‘priv_turn_allocate_refresh_retransmissions_tick_agent_locked’:
../agent/conncheck.c:1656:13: warning: Not available before 2.60
 1656 |       G_GNUC_FALLTHROUGH;
      |             ^~~~~~~~~~~~~

The comment /* fall through */ is enough to cause GCC and Clang to not
emit the implicit-fallthrough warning.

2 years agoagent: Convert g_print() to nice_debug()
Nirbheek Chauhan [Mon, 21 Mar 2022 10:50:22 +0000 (16:20 +0530)]
agent: Convert g_print() to nice_debug()

This was probably added by mistake.

2 years agomeson: Fix openssl setting
Olivier Crête [Wed, 26 Jan 2022 18:57:13 +0000 (13:57 -0500)]
meson: Fix openssl setting

This should fix builds on platforms openssl

2 years agogitlab-ci: Allow manual runs
Olivier Crête [Fri, 26 Nov 2021 19:06:18 +0000 (13:06 -0600)]
gitlab-ci: Allow manual runs

2 years agotcp-active: Fix use-after-free in error case
Olivier Crête [Fri, 26 Nov 2021 20:38:53 +0000 (14:38 -0600)]
tcp-active: Fix use-after-free in error case

Fixes issue found by Coverity

2 years agoagent: Clear the original message pointer instead of a copy
Olivier Crête [Fri, 26 Nov 2021 16:43:24 +0000 (10:43 -0600)]
agent: Clear the original message pointer instead of a copy

In one case, the message pointer gets replaced by the rfc4571_message
one, so it wasn't getting cleared as expected.

2 years agogstnicesink: disable drop out of segment on nicesink
Guillaume Desmottes [Fri, 26 Nov 2021 14:30:21 +0000 (15:30 +0100)]
gstnicesink: disable drop out of segment on nicesink

It's very tricky and unintuitive to have webrtcbin not sending data
because of the segment.

Fix https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/907

2 years agotest-io-stream-common: Avoid CPU starvation by yielding
Ole André Vadla Ravnås [Thu, 4 Nov 2021 21:48:22 +0000 (22:48 +0100)]
test-io-stream-common: Avoid CPU starvation by yielding

Busy-looping is not a good idea, especially not when run under Valgrind,
where such a thread may result in well-behaved threads running thousands
of times slower. While passing --fair-sched=yes to Valgrind avoids the
issue, it's still better to make our busy-looping less aggressive.

2 years agoagent: Consume data before removing disconnected socket
Ole André Vadla Ravnås [Sun, 16 May 2021 10:35:23 +0000 (12:35 +0200)]
agent: Consume data before removing disconnected socket

This was caught by tests randomly failing (timing out).

2 years agoiostream: Implement close() for ICE-TCP also
Ole André Vadla Ravnås [Sat, 15 May 2021 20:20:40 +0000 (22:20 +0200)]
iostream: Implement close() for ICE-TCP also

2 years agocomponent: Clear buffer pointers to avoid potential double free
Ole André Vadla Ravnås [Sat, 15 May 2021 20:19:03 +0000 (22:19 +0200)]
component: Clear buffer pointers to avoid potential double free

In case close() is called more than once.

2 years agotest-io-stream-thread: Handle partial I/O
Ole André Vadla Ravnås [Sat, 15 May 2021 22:22:19 +0000 (00:22 +0200)]
test-io-stream-thread: Handle partial I/O

2 years agotest-io-stream-closing-write: Handle partial I/O
Ole André Vadla Ravnås [Sat, 15 May 2021 22:08:13 +0000 (00:08 +0200)]
test-io-stream-closing-write: Handle partial I/O

2 years agotest-io-stream-closing-read: Handle partial I/O
Ole André Vadla Ravnås [Sat, 15 May 2021 22:07:49 +0000 (00:07 +0200)]
test-io-stream-closing-read: Handle partial I/O

2 years agotest-io-stream-common: Remove incorrect assertion
Ole André Vadla Ravnås [Fri, 14 May 2021 23:38:21 +0000 (01:38 +0200)]
test-io-stream-common: Remove incorrect assertion

We cannot assume that the message will be completely filled even in
reliable mode.

2 years agotest-io-stream-common: Fix GSource callback signature
Ole André Vadla Ravnås [Wed, 12 May 2021 22:28:53 +0000 (00:28 +0200)]
test-io-stream-common: Fix GSource callback signature

Cannot pass g_main_loop_quit as the GSourceFunc as its return type is
void.

2 years agotest-io-stream-common: Remove dead code
Ole André Vadla Ravnås [Wed, 12 May 2021 22:26:58 +0000 (00:26 +0200)]
test-io-stream-common: Remove dead code

Due to off-by-one errors. Since the code added above now handles what
this code tried to handle, we can go ahead and remove it.

2 years agoagent: Add support for bytestream TCP
Ole André Vadla Ravnås [Wed, 12 May 2021 22:47:22 +0000 (00:47 +0200)]
agent: Add support for bytestream TCP

2 years agoconncheck: don't ignore local socket errors
Fabrice Bellet [Fri, 1 Oct 2021 15:35:44 +0000 (17:35 +0200)]
conncheck: don't ignore local socket errors

With this patch we ensure that local socket errors during connection
establishment are properly transmitted to the connection check layer, so
the related pair can be put in state failed when needed. The local
socket errors we are interested in, are those occuring when the local
source address cannot be bound anymore, because the underlying interface
vanished for example.

In particular, we don't ignore errors coming from g_socket_bind() with
tcp active sockets, that perform a bind to *whatever* local address is
available, in case it cannot bind to the specified address.

This behaviour was demonstrated with the test-tcp example, that tried
to bind to the IPv4 loopback address on a socket initially created for
the IPv6 loopback.

2 years agomeson: Add agent include dir to uninstalled pkgconfig file
Nirbheek Chauhan [Mon, 15 Nov 2021 08:17:30 +0000 (13:47 +0530)]
meson: Add agent include dir to uninstalled pkgconfig file

Meson picks up the includedirs from the library target that it is
building the pkgconfig file for. Since libnice's headers are split
into the nice/ and agent/ subdirs, we need to add agent/ to
include_directories: so that it's automatically added to the
uninstalled pkgconfig file by Meson.

2 years agoagent: Handle failure to create TCP TURN socket
Ole André Vadla Ravnås [Tue, 2 Nov 2021 22:39:30 +0000 (23:39 +0100)]
agent: Handle failure to create TCP TURN socket

E.g. if the server address is IPv6 but the local system cannot reach it,
so connect() fails right away.

2 years agoconncheck: schedule the connection check in most relevant places
Fabrice Bellet [Fri, 23 Oct 2020 15:38:53 +0000 (17:38 +0200)]
conncheck: schedule the connection check in most relevant places

The patch invokes the conncheck timer creation where it makes most
sense: when a new pair is inserted in the conncheck list, and when a
pair is added to the triggered check list (because the conncheck
scheduler works on these two lists).

2 years agostun: Use a specific variable to enable Win32 crypto
Olivier Crête [Tue, 2 Nov 2021 18:18:57 +0000 (12:18 -0600)]
stun: Use a specific variable to enable Win32 crypto

This should make it possible to use OpenSSL or GnuTLS also on Windows if
required.

2 years agogitlab-ci: Try to disable CI on non-MR/non-master branches
Olivier Crête [Tue, 2 Nov 2021 16:46:06 +0000 (12:46 -0400)]
gitlab-ci: Try to disable CI on non-MR/non-master branches

2 years agogitlab-ci: Add OpenSSL specific build
Olivier Crête [Tue, 2 Nov 2021 02:49:11 +0000 (22:49 -0400)]
gitlab-ci: Add OpenSSL specific build

2 years agomeson: Simplify finding OpenSSL
Olivier Crête [Tue, 2 Nov 2021 17:14:55 +0000 (13:14 -0400)]
meson: Simplify finding OpenSSL

Remove duplicated calls to dependency() so we can have fallback in all
cases.

2 years agomeson: Fix name of variable
Olivier Crête [Tue, 2 Nov 2021 16:33:13 +0000 (12:33 -0400)]
meson: Fix name of variable

This is a fix over the recent fix in commit 574f44b4

2 years agotests: Use g_assert_true() instead of g_assert() everywhere
Olivier Crête [Tue, 2 Nov 2021 02:25:02 +0000 (22:25 -0400)]
tests: Use g_assert_true() instead of g_assert() everywhere

2 years agoRemove g_assert_cmp* macros outside of the unit tests
Olivier Crête [Tue, 2 Nov 2021 02:22:32 +0000 (22:22 -0400)]
Remove g_assert_cmp* macros outside of the unit tests

2 years agoagent: ensure suceeded and discovered pairs fail the same time
Fabrice Bellet [Fri, 1 Oct 2021 10:17:19 +0000 (12:17 +0200)]
agent: ensure suceeded and discovered pairs fail the same time

This patch ensures that related succeeded-discovered pairs change to
state failed simultaneously, to avoid leaving dangling pointers if one
is freeed while the other is still in the conncheck list. Such
transition is very rare, and only occurs in regular nomination mode,
when the network conditions change between the time the pair is
initially discovered and the time it is rechecked with the use-candidate
flag.

2 years agoFix error when crypto/ssl libs are found without pkg-config
Xavier Claessens [Thu, 28 Oct 2021 14:24:39 +0000 (10:24 -0400)]
Fix error when crypto/ssl libs are found without pkg-config

In that case crypto_dep is a list and we can't call .found() method.

2 years agoagent: Unify constructors into nice_agent_new_full
Juan Navarro [Tue, 7 Sep 2021 14:15:03 +0000 (16:15 +0200)]
agent: Unify constructors into nice_agent_new_full

Instead of having 3 independent implementations, make the simpler
versions delegate into the full one.

The simplest constructor needs to pass "no option", for which no
constant exists in the NiceAgentOption enum. Thus the new
NICE_AGENT_OPTION_NONE constant is added to reflect this possibility.

2 years agoUse native crypto support on Windows by default
Ole André Vadla Ravnås [Tue, 6 Apr 2021 20:47:17 +0000 (22:47 +0200)]
Use native crypto support on Windows by default

As we only need a few primitives there isn't much OS-specific code
needed, and for applications that don't already depend on OpenSSL or
GnuTLS it simplifies the build process quite a lot.

Note that we use the vintage WinCrypt APIs as the Cryptography Next
Generation APIs are only available on Vista and newer.

2 years agocomponent: reset the stun agent on ice restart
Fabrice Bellet [Fri, 1 Oct 2021 10:41:29 +0000 (12:41 +0200)]
component: reset the stun agent on ice restart

The stun agent may contain references to the password previously stored
in some remote candidates, freeed by nice_component_restart(), that were
used by keep-alive stun requests. These stun replies may arrive later
after ice has been restarted. Since the remote candidates are freeed
when ice is restarted, the stun agent must be reset to get rid of these
related references.

2 years agogitlab-ci: Update Windows image
Olivier Crête [Fri, 1 Oct 2021 14:08:29 +0000 (10:08 -0400)]
gitlab-ci: Update Windows image

2 years agogitlab-ci: Update ci-fairy to upstream recommended script
Olivier Crête [Fri, 1 Oct 2021 14:03:49 +0000 (10:03 -0400)]
gitlab-ci: Update ci-fairy to upstream recommended script

2 years agonice: Bring new symbols to 0.1.19
Olivier Crête [Thu, 19 Aug 2021 19:12:23 +0000 (15:12 -0400)]
nice: Bring new symbols to 0.1.19

It's not released yet and we don't do even/odd in this project.

2 years agonice: Export nice_candidate_transport_to_string
Olivier Crête [Thu, 19 Aug 2021 18:43:13 +0000 (14:43 -0400)]
nice: Export nice_candidate_transport_to_string

Also update the Since to 0.1.19, because it's not really usable now

2 years agonice: Export nice_candidate_type_to_string
Olivier Crête [Thu, 19 Aug 2021 18:42:28 +0000 (14:42 -0400)]
nice: Export nice_candidate_type_to_string

Also update the Since to 0.1.19, because it's not really usable now

2 years agostun: Make the headers usable from C++ code
abhijeetbhagat [Sun, 6 Jun 2021 06:39:09 +0000 (12:09 +0530)]
stun: Make the headers usable from C++ code

Add the relevant ifdef extern C bits

2 years agoagent: Simplify accepting state changes to FAILED
Olivier Crête [Tue, 20 Jul 2021 17:06:58 +0000 (13:06 -0400)]
agent: Simplify accepting state changes to FAILED

The component can go from any state to FAILED, so simplify
that and make it explicit.

2 years agoagent: Accept any transition back to the gathering state
Olivier Crête [Tue, 20 Jul 2021 17:04:17 +0000 (13:04 -0400)]
agent: Accept any transition back to the gathering state

When doing a ICE restart, which can be done from any state, we can
always go back into the gathering state.

This fixes a regression introduced by b20ac5ba7b731f2cc698f26e8def28a518de058e

2 years agogitlab-ci: Allow msys CI to fail
Olivier Crête [Tue, 20 Jul 2021 20:55:41 +0000 (16:55 -0400)]
gitlab-ci: Allow msys CI to fail

It just won't work for now.

2 years agosubprojects: Get zlib from Qt mirror
Olivier Crête [Tue, 20 Jul 2021 17:30:09 +0000 (13:30 -0400)]
subprojects: Get zlib from Qt mirror

Getting it from the upstream mirror seems to fail miserably

2 years agogitlab-ci: Remove meson update
Olivier Crête [Tue, 20 Jul 2021 17:25:13 +0000 (13:25 -0400)]
gitlab-ci: Remove meson update

2 years agoUpdate Windows image
Olivier Crête [Tue, 20 Jul 2021 17:14:11 +0000 (13:14 -0400)]
Update Windows image

3 years agotest-restart: fix potential stack buffer overflow with new candidate API
Fabrice Bellet [Sat, 13 Feb 2021 13:16:10 +0000 (14:16 +0100)]
test-restart: fix potential stack buffer overflow with new candidate API

3 years agotest-consent: fix potential stack buffer overflow with new candidate API
Fabrice Bellet [Sat, 13 Feb 2021 13:15:58 +0000 (14:15 +0100)]
test-consent: fix potential stack buffer overflow with new candidate API

3 years agotest-io-stream-pollable: Handle partial reads
Ole André Vadla Ravnås [Tue, 11 May 2021 08:52:55 +0000 (10:52 +0200)]
test-io-stream-pollable: Handle partial reads

3 years agopseudotcp: Disable Nagle algorithm by default
Ole André Vadla Ravnås [Mon, 10 May 2021 10:37:18 +0000 (12:37 +0200)]
pseudotcp: Disable Nagle algorithm by default

To be consistent with what we do for ICE-TCP.

3 years agotcp-bsd: Handle send before connect() completes
Ole André Vadla Ravnås [Sun, 9 May 2021 21:55:07 +0000 (23:55 +0200)]
tcp-bsd: Handle send before connect() completes

3 years agoagent: Remove duplicated early return
Olivier Crête [Mon, 3 May 2021 21:04:34 +0000 (17:04 -0400)]
agent: Remove duplicated early return

The type is already checked to not be peer reflexive earlier.

3 years agoagent: Avoid leak on programming error
Olivier Crête [Mon, 3 May 2021 21:01:59 +0000 (17:01 -0400)]
agent: Avoid leak on programming error

Even if the agent is invalid, don't leak.

This makes coverity a little happier.

3 years agoconncheck: Free password in more obvious way
Olivier Crête [Mon, 3 May 2021 21:00:51 +0000 (17:00 -0400)]
conncheck: Free password in more obvious way

This should make Coverity's job a little easier. And also fix a little
leak in the error path.

3 years agoudp-turn: Remove request before freeing it
Olivier Crête [Mon, 3 May 2021 20:58:01 +0000 (16:58 -0400)]
udp-turn: Remove request before freeing it

As removing the request from the queue looks into the SendRequest, one
needs to unqueue it before freeing it.

3 years agoagent: avoid leak of all turn refreshes when disposing the agent
Fabrice Bellet [Sat, 19 Dec 2020 16:56:16 +0000 (17:56 +0100)]
agent: avoid leak of all turn refreshes when disposing the agent

With this patch we free all outstanding refreshes when the agent dispose
method is called, even those that are in the way to be discarded
asynchronously, when a stream is removed.

We also make the final user callback of the refresh proces synchronous,
so we don't have to deal with an heap use-after-free problem. This also
requires to order some parts of code.

3 years agodiscovery: fix asynchronous agent refreshes pruning
Fabrice Bellet [Thu, 17 Dec 2020 11:06:38 +0000 (12:06 +0100)]
discovery: fix asynchronous agent refreshes pruning

Asynchronous refreshes pruning may occur when the agent async close
function is called, but also when a stream is closed. A flag
'discarding' is used in the CandidateRefresh object to determine
if a refresh is already on the way to be asynchronously freed. A refresh
definitely freed is removed from agent refresh_list.

When the agent async close function is called, it is passed a user
callback that will be invoked when all refreshes have been freed.

This is not exactly how things work currently, because right now, the
callback function is also invoked when all CandidateRefresh objects have
the discarding flag set, with the test 'data->items_to_free==0'. In that
case, clearly not all refreshes have been freed, as some are still there
in the refresh_list with the discarding flag set.

This is probably not what the user expects from the function
nice_agent_close_async(), where the callback is supposed to be invoked
after all refreshes have been freed: and including those asynchronously
pruned by nice_prune_stream_async().

This patch adds a supplementary timeout when closing the agent async,
that waits until the agent refresh list becomes empty.

3 years agoagent: avoid leak of turn refreshes
Fabrice Bellet [Sun, 13 Dec 2020 16:59:41 +0000 (17:59 +0100)]
agent: avoid leak of turn refreshes

We keep refreshes having the discarding flag set. They may be freed later
if the agent main context remains alive after agent deletion.

3 years agoagent: warn when closing the agent with alive turn refreshes
Fabrice Bellet [Sat, 12 Dec 2020 20:12:52 +0000 (21:12 +0100)]
agent: warn when closing the agent with alive turn refreshes

This patch suggests the developer to close its alive reservations on
the turn server before disposing the agent.

Not removing reservations on the turn server, will make them alive until
their default timeout, generally 300 seconds, which is not fair for the
turn server resources, but also it may cause a fatal error 437,
"Mismatched allocation: wrong transaction ID", when another agent tries
to contact the same turn server using the same nat mapping before this
delay expires.

3 years agoagent: Verify the source before dereferencing the pointer
Olivier Crête [Tue, 20 Apr 2021 19:09:11 +0000 (15:09 -0400)]
agent: Verify the source before dereferencing the pointer

The reason is that the component object could have been destroyed in the
mean time.

3 years agoagent: don't allocate large arrays on the stack
Fabrice Bellet [Sun, 6 Dec 2020 18:12:48 +0000 (19:12 +0100)]
agent: don't allocate large arrays on the stack

3 years agoudp-turn: don't allocate large arrays on the stack
Fabrice Bellet [Sun, 6 Dec 2020 18:09:33 +0000 (19:09 +0100)]
udp-turn: don't allocate large arrays on the stack

3 years agoagent: keep a track of the candidate refreshes being pruned
Fabrice Bellet [Mon, 6 Jul 2020 11:53:44 +0000 (13:53 +0200)]
agent: keep a track of the candidate refreshes being pruned

Refreshes with zero lifetime sent over tcp transport may cause the
removal of the underlying socket when the remote peer closes the
connection taking our request into account. These refreshes must be
tracked and freeed on our side to avoid retransmission attempt on a
closed socket and a heap-use-after-free error in that case.

3 years agointerfaces: Skip special interfaces on Apple OSes
Ole André Vadla Ravnås [Mon, 19 Apr 2021 19:05:51 +0000 (21:05 +0200)]
interfaces: Skip special interfaces on Apple OSes

Including unused utun devices.

3 years agointerfaces: Skip special interfaces on Apple OSes
Ole André Vadla Ravnås [Mon, 19 Apr 2021 19:05:51 +0000 (21:05 +0200)]
interfaces: Skip special interfaces on Apple OSes

Including unused utun devices.

3 years agogitlab-ci: Accept double pipeline otherwise MRs arent mergeable
Olivier Crête [Tue, 20 Apr 2021 00:06:37 +0000 (20:06 -0400)]
gitlab-ci: Accept double pipeline otherwise MRs arent mergeable

3 years agogitlab-ci: Stop base msvc build on msys
Olivier Crête [Mon, 19 Apr 2021 23:50:21 +0000 (19:50 -0400)]
gitlab-ci: Stop base msvc build on msys

3 years agogitlab-ci: Mark all tasks as interruptible
Olivier Crête [Mon, 19 Apr 2021 23:35:42 +0000 (19:35 -0400)]
gitlab-ci: Mark all tasks as interruptible

3 years agogitlab-ci: Move pacman setup to before_script
Olivier Crête [Mon, 19 Apr 2021 23:10:13 +0000 (19:10 -0400)]
gitlab-ci: Move pacman setup to before_script

3 years agogitlab-ci: Run meson, ninja and meson test separately
Olivier Crête [Mon, 19 Apr 2021 22:09:04 +0000 (18:09 -0400)]
gitlab-ci: Run meson, ninja and meson test separately

3 years agogitlab-ci: Just skip the msys global upgrade
Olivier Crête [Mon, 19 Apr 2021 20:48:40 +0000 (16:48 -0400)]
gitlab-ci: Just skip the msys global upgrade

3 years agogitlab-ci: Update to 2021-02-04 Windows image
Olivier Crête [Mon, 19 Apr 2021 20:33:03 +0000 (16:33 -0400)]
gitlab-ci: Update to 2021-02-04 Windows image

3 years agogitlab-ci: Verify that allow-edit is set
Olivier Crête [Mon, 19 Apr 2021 20:37:31 +0000 (16:37 -0400)]
gitlab-ci: Verify that allow-edit is set

3 years agoagent: reset remote credentials when restarting ice
Fabrice Bellet [Sun, 21 Feb 2021 10:10:12 +0000 (11:10 +0100)]
agent: reset remote credentials when restarting ice

The remote credentials recorded in the streams should be reset,
in the case the restarted conncheck begins with new remote candidates
*before* the updated remote credentials are received.

3 years agoagent: transition to state gathering when restarting ice
Fabrice Bellet [Sun, 21 Feb 2021 10:06:00 +0000 (11:06 +0100)]
agent: transition to state gathering when restarting ice

The state of the component is downgraded to gathering state, so it can
really restart a new conncheck from scratch. It'll transition to state
connecting when receiving the updated remote candidates.