1
0
mirror of https://gitlab.xiph.org/xiph/icecast-server.git synced 2025-01-03 14:56:34 -05:00

Feature: Added basic ping request support

This commit is contained in:
Philipp Schafft 2023-02-27 01:21:29 +00:00
parent 91ea5d0f79
commit 3c352746ab
2 changed files with 94 additions and 10 deletions

View File

@ -12,6 +12,7 @@
#endif
#include <stdbool.h>
#include <stdlib.h>
#include "thread/thread.h"
@ -21,16 +22,72 @@
#define CATMODULE "ping"
static bool ping_running = false;
static thread_type *_ping_thread_id;
static mutex_t _ping_mutex;
typedef struct ping_queue_tag ping_queue_t;
static void *_ping_thread(void *arg)
struct ping_queue_tag {
CURL *curl;
ping_queue_t *next;
};
static bool ping_running = false;
static thread_type *ping_thread_id;
static mutex_t ping_mutex;
static ping_queue_t *ping_queue;
static void on_done(ping_queue_t *entry)
{
icecast_curl_free(entry->curl);
free(entry);
}
static void *ping_thread(void *arg)
{
CURLM *curl_multi = curl_multi_init();
while (ping_running) {
ping_queue_t *take;
int status;
thread_mutex_lock(&ping_mutex);
take = ping_queue;
ping_queue = NULL;
thread_mutex_unlock(&ping_mutex);
while (take) {
ping_queue_t *entry = take;
take = take->next;
entry->next = NULL;
curl_easy_setopt(entry->curl, CURLOPT_PRIVATE, entry);
curl_multi_add_handle(curl_multi, entry->curl);
}
if (curl_multi_perform(curl_multi, &status) != CURLM_OK)
break;
if (!status) {
thread_sleep(100000);
continue;
}
if (curl_multi_wait(curl_multi, NULL, 0, 1000, &status) != CURLM_OK)
break;
while (true) {
struct CURLMsg *m = curl_multi_info_read(curl_multi, &status);
if (!m)
break;
if (m->msg == CURLMSG_DONE) {
ping_queue_t *entry = NULL;
CURL *e = m->easy_handle;
curl_multi_remove_handle(curl_multi, e);
curl_easy_getinfo(e, CURLINFO_PRIVATE, &entry);
on_done(entry);
}
}
}
curl_multi_cleanup(curl_multi);
@ -38,15 +95,39 @@ static void *_ping_thread(void *arg)
return NULL;
}
static void ping_add_to_queue(ping_queue_t *entry)
{
thread_mutex_lock(&ping_mutex);
entry->next = ping_queue;
ping_queue = entry;
thread_mutex_unlock(&ping_mutex);
}
void ping_simple(const char *url)
{
ping_queue_t *entry = calloc(1, sizeof(*entry));
if (!entry)
return;
entry->curl = icecast_curl_new(url, NULL);
if (!entry->curl) {
free(entry);
return;
}
ping_add_to_queue(entry);
}
void ping_initialize(void)
{
if (ping_running)
return;
thread_mutex_create(&_ping_mutex);
thread_mutex_create(&ping_mutex);
ping_running = true;
_ping_thread_id = thread_create("Ping Thread", _ping_thread, NULL, THREAD_ATTACHED);
ping_thread_id = thread_create("Ping Thread", ping_thread, NULL, THREAD_ATTACHED);
}
void ping_shutdown(void)
@ -55,7 +136,8 @@ void ping_shutdown(void)
return;
ping_running = false;
ICECAST_LOG_DEBUG("waiting for ping thread");
thread_join(_ping_thread_id);
thread_mutex_destroy(&_ping_mutex);
ICECAST_LOG_DEBUG("Waiting for ping thread");
thread_join(ping_thread_id);
thread_mutex_destroy(&ping_mutex);
ICECAST_LOG_DEBUG("Joined ping thread, good job!");
}

View File

@ -12,4 +12,6 @@
void ping_initialize(void);
void ping_shutdown(void);
void ping_simple(const char *url);
#endif /* __PING_H__ */