mirror of
https://gitlab.xiph.org/xiph/icecast-server.git
synced 2025-01-03 14:56:34 -05:00
immediately release auth_t if authentication fails, that way we don't
trigger release_client like listener_remove event in the url auth. Add lock in auth_t so that refcount changes are not a race possibility. svn path=/icecast/trunk/icecast/; revision=9926
This commit is contained in:
parent
0903dd68ed
commit
32691f498a
13
src/auth.c
13
src/auth.c
@ -85,8 +85,10 @@ static void auth_client_setup (mount_proxy *mountinfo, client_t *client)
|
||||
|
||||
} while (0);
|
||||
|
||||
thread_mutex_lock (&mountinfo->auth->lock);
|
||||
client->auth = mountinfo->auth;
|
||||
client->auth->refcount++;
|
||||
thread_mutex_unlock (&mountinfo->auth->lock);
|
||||
}
|
||||
|
||||
|
||||
@ -108,13 +110,19 @@ void auth_release (auth_t *authenticator)
|
||||
if (authenticator == NULL)
|
||||
return;
|
||||
|
||||
thread_mutex_lock (&authenticator->lock);
|
||||
authenticator->refcount--;
|
||||
if (authenticator->refcount)
|
||||
{
|
||||
thread_mutex_unlock (&authenticator->lock);
|
||||
return;
|
||||
}
|
||||
|
||||
if (authenticator->free)
|
||||
authenticator->free (authenticator);
|
||||
xmlFree (authenticator->type);
|
||||
thread_mutex_unlock (&authenticator->lock);
|
||||
thread_mutex_destroy (&authenticator->lock);
|
||||
free (authenticator);
|
||||
}
|
||||
|
||||
@ -148,8 +156,12 @@ static void auth_new_listener (auth_client *auth_user)
|
||||
if (client->auth->authenticate)
|
||||
{
|
||||
if (client->auth->authenticate (auth_user) != AUTH_OK)
|
||||
{
|
||||
auth_release (client->auth);
|
||||
client->auth = NULL;
|
||||
return;
|
||||
}
|
||||
}
|
||||
if (auth_postprocess_client (auth_user) < 0)
|
||||
INFO1 ("client %lu failed", client->con->id);
|
||||
}
|
||||
@ -512,6 +524,7 @@ auth_t *auth_get_authenticator (xmlNodePtr node)
|
||||
}
|
||||
auth->type = xmlGetProp (node, "type");
|
||||
get_authenticator (auth, options);
|
||||
thread_mutex_create (&auth->lock);
|
||||
while (options)
|
||||
{
|
||||
config_options_t *opt = options;
|
||||
|
@ -66,6 +66,7 @@ typedef struct auth_tag
|
||||
auth_result (*deleteuser)(struct auth_tag *auth, const char *username);
|
||||
auth_result (*listuser)(struct auth_tag *auth, xmlNodePtr srcnode);
|
||||
|
||||
mutex_t lock;
|
||||
int refcount;
|
||||
int allow_duplicate_users;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user