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

Update: Converted url auth client remove to ping request

This commit is contained in:
Philipp Schafft 2023-03-20 09:41:54 +00:00
parent cd25ca90e2
commit 64d380b6b6

View File

@ -73,6 +73,7 @@
#include "util.h" #include "util.h"
#include "curl.h" #include "curl.h"
#include "ping.h"
#include "auth.h" #include "auth.h"
#include "source.h" #include "source.h"
#include "client.h" #include "client.h"
@ -331,7 +332,7 @@ static size_t handle_returned_header(void *ptr,
return len; return len;
} }
static auth_result url_add_params(auth_client *auth_user, bool is_remove) static string_renderer_t * url_add_params(auth_client *auth_user, bool is_remove)
{ {
client_t *client = auth_user->client; client_t *client = auth_user->client;
auth_t *auth = client->auth; auth_t *auth = client->auth;
@ -345,7 +346,7 @@ static auth_result url_add_params(auth_client *auth_user, bool is_remove)
*next_header; *next_header;
if (igloo_ro_new(&renderer, string_renderer_t, igloo_instance) != igloo_ERROR_NONE) if (igloo_ro_new(&renderer, string_renderer_t, igloo_instance) != igloo_ERROR_NONE)
return AUTH_FAILED; return NULL;
string_renderer_start_list_formdata(renderer); string_renderer_start_list_formdata(renderer);
@ -409,10 +410,7 @@ static auth_result url_add_params(auth_client *auth_user, bool is_remove)
string_renderer_end_list(renderer); string_renderer_end_list(renderer);
curl_easy_setopt(url->handle, CURLOPT_COPYPOSTFIELDS, string_renderer_to_string_zero_copy(renderer)); return renderer;
igloo_ro_unref(&renderer);
return AUTH_OK;
} }
static auth_result url_remove_client(auth_client *auth_user) static auth_result url_remove_client(auth_client *auth_user)
@ -420,44 +418,25 @@ static auth_result url_remove_client(auth_client *auth_user)
client_t *client = auth_user->client; client_t *client = auth_user->client;
auth_t *auth = client->auth; auth_t *auth = client->auth;
auth_url *url = auth->state; auth_url *url = auth->state;
char *userpwd = NULL; string_renderer_t *renderer;
if (url->removeurl == NULL) if (url->removeurl == NULL)
return AUTH_OK; return AUTH_OK;
if (strchr (url->removeurl, '@') == NULL) { if (!(renderer = url_add_params(auth_user, true)))
if (url->userpwd) {
curl_easy_setopt(url->handle, CURLOPT_USERPWD, url->userpwd);
} else {
/* auth'd requests may not have a user/pass, but may use query args */
if (client->username && client->password) {
size_t len = strlen(client->username) +
strlen(client->password) + 2;
userpwd = malloc(len);
snprintf(userpwd, len, "%s:%s",
client->username, client->password);
curl_easy_setopt(url->handle, CURLOPT_USERPWD, userpwd);
} else {
curl_easy_setopt(url->handle, CURLOPT_USERPWD, "");
}
}
} else {
/* url has user/pass but libcurl may need to clear any existing settings */
curl_easy_setopt(url->handle, CURLOPT_USERPWD, "");
}
if (url_add_params(auth_user, true) != AUTH_OK)
return AUTH_FAILED; return AUTH_FAILED;
curl_easy_setopt(url->handle, CURLOPT_URL, url->removeurl); if (strchr (url->removeurl, '@') != NULL) {
curl_easy_setopt(url->handle, CURLOPT_WRITEHEADER, auth_user); ping_simple(url->removeurl, NULL, NULL, renderer);
} else {
if (url->username) {
ping_simple(url->removeurl, url->username, url->password, renderer);
} else {
ping_simple(url->removeurl, client->username, client->password, renderer);
}
}
if (curl_easy_perform (url->handle)) igloo_ro_unref(&renderer);
ICECAST_LOG_WARN("auth to server %s failed with %s",
url->removeurl, url->errormsg);
free(userpwd);
auth_user_url_clear(auth_user);
return AUTH_OK; return AUTH_OK;
} }
@ -470,6 +449,7 @@ static auth_result url_add_client(auth_client *auth_user)
auth_url *url = auth->state; auth_url *url = auth->state;
int res = 0; int res = 0;
char *userpwd = NULL; char *userpwd = NULL;
string_renderer_t *renderer;
if (url->addurl == NULL) if (url->addurl == NULL)
return AUTH_OK; return AUTH_OK;
@ -494,9 +474,12 @@ static auth_result url_add_client(auth_client *auth_user)
curl_easy_setopt(url->handle, CURLOPT_USERPWD, ""); curl_easy_setopt(url->handle, CURLOPT_USERPWD, "");
} }
if (url_add_params(auth_user, false) != AUTH_OK) if (!(renderer = url_add_params(auth_user, false)))
return AUTH_FAILED; return AUTH_FAILED;
curl_easy_setopt(url->handle, CURLOPT_COPYPOSTFIELDS, string_renderer_to_string_zero_copy(renderer));
igloo_ro_unref(&renderer);
curl_easy_setopt(url->handle, CURLOPT_URL, url->addurl); curl_easy_setopt(url->handle, CURLOPT_URL, url->addurl);
curl_easy_setopt(url->handle, CURLOPT_WRITEHEADER, auth_user); curl_easy_setopt(url->handle, CURLOPT_WRITEHEADER, auth_user);
url->errormsg[0] = '\0'; url->errormsg[0] = '\0';