mirror of
https://gitlab.xiph.org/xiph/icecast-server.git
synced 2025-01-03 14:56:34 -05:00
Feature: Added support to "static" auth to alter the client
This commit is contained in:
parent
0392b4a32f
commit
d0b23fb8c6
@ -20,6 +20,7 @@
|
|||||||
#include "auth.h"
|
#include "auth.h"
|
||||||
#include "cfgfile.h"
|
#include "cfgfile.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
#include "logging.h"
|
#include "logging.h"
|
||||||
#define CATMODULE "auth_static"
|
#define CATMODULE "auth_static"
|
||||||
@ -27,6 +28,8 @@
|
|||||||
typedef struct auth_static {
|
typedef struct auth_static {
|
||||||
char *username;
|
char *username;
|
||||||
char *password;
|
char *password;
|
||||||
|
auth_alter_t action;
|
||||||
|
char *arg;
|
||||||
} auth_static_t;
|
} auth_static_t;
|
||||||
|
|
||||||
static auth_result static_auth(auth_client *auth_user)
|
static auth_result static_auth(auth_client *auth_user)
|
||||||
@ -45,19 +48,25 @@ static auth_result static_auth(auth_client *auth_user)
|
|||||||
if (!client->password)
|
if (!client->password)
|
||||||
return AUTH_NOMATCH;
|
return AUTH_NOMATCH;
|
||||||
|
|
||||||
if (strcmp(auth_info->password, client->password) == 0)
|
if (strcmp(auth_info->password, client->password) != 0)
|
||||||
return AUTH_OK;
|
|
||||||
|
|
||||||
return AUTH_FAILED;
|
return AUTH_FAILED;
|
||||||
|
|
||||||
|
|
||||||
|
if (auth_info->action != AUTH_ALTER_NOOP) {
|
||||||
|
if (auth_alter_client(auth, auth_user, auth_info->action, auth_info->arg) != 0) {
|
||||||
|
ICECAST_LOG_ERROR("Can not alter client.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return AUTH_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void clear_auth (auth_t *auth)
|
static void clear_auth (auth_t *auth)
|
||||||
{
|
{
|
||||||
auth_static_t *auth_info = auth->state;
|
auth_static_t *auth_info = auth->state;
|
||||||
if (auth_info->username)
|
|
||||||
free(auth_info->username);
|
free(auth_info->username);
|
||||||
if (auth_info->password)
|
|
||||||
free(auth_info->password);
|
free(auth_info->password);
|
||||||
|
free(auth_info->arg);
|
||||||
free(auth_info);
|
free(auth_info);
|
||||||
auth->state = NULL;
|
auth->state = NULL;
|
||||||
}
|
}
|
||||||
@ -106,6 +115,15 @@ int auth_get_static_auth (auth_t *authenticator, config_options_t *options)
|
|||||||
if (auth_info->password)
|
if (auth_info->password)
|
||||||
free(auth_info->password);
|
free(auth_info->password);
|
||||||
auth_info->password = strdup(options->value);
|
auth_info->password = strdup(options->value);
|
||||||
|
} else if (strcmp(options->name, "action") == 0) {
|
||||||
|
auth_info->action = auth_str2alter(options->value);
|
||||||
|
if (auth_info->action == AUTH_ALTER_NOOP) {
|
||||||
|
ICECAST_LOG_ERROR("Invalid action given.");
|
||||||
|
clear_auth(authenticator);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
} else if (strcmp(options->name, "argument") == 0) {
|
||||||
|
replace_string(&(auth_info->arg), options->value);
|
||||||
} else {
|
} else {
|
||||||
ICECAST_LOG_ERROR("Unknown option: %s", options->name);
|
ICECAST_LOG_ERROR("Unknown option: %s", options->name);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user