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:
parent
cd25ca90e2
commit
64d380b6b6
@ -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';
|
||||||
|
Loading…
Reference in New Issue
Block a user