Skip to content

Commit

Permalink
Add experimental code for dynamic discovery (only if ENABLE_EXPERIMEN…
Browse files Browse the repository at this point in the history
…TAL_DYNDISC).

Patch from Ralf Paffrath <paffrath@dfn.de>.
  • Loading branch information
Linus Nordberg committed Apr 26, 2012
1 parent c6d3367 commit 0723851
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 4 deletions.
45 changes: 41 additions & 4 deletions radsecproxy.c
Original file line number Diff line number Diff line change
Expand Up @@ -327,8 +327,13 @@ void freeserver(struct server *server, uint8_t destroymutex) {
if (server->rbios)
freebios(server->rbios);
free(server->dynamiclookuparg);
if (server->ssl)
SSL_free(server->ssl);
if (server->ssl) {
#if defined ENABLE_EXPERIMENTAL_DYNDISC
if (server->sock >= 0)
close(server->sock);
#endif
SSL_free(server->ssl);
}
if (destroymutex) {
pthread_mutex_destroy(&server->lock);
pthread_cond_destroy(&server->newrq_cond);
Expand Down Expand Up @@ -768,7 +773,12 @@ int hasdynamicserver(struct list *srvconfs) {
struct list_node *entry;

for (entry = list_first(srvconfs); entry; entry = list_next(entry))
if (((struct clsrvconf *)entry->data)->dynamiclookupcommand)
#if defined ENABLE_EXPERIMENTAL_DYNDISC
if (((struct clsrvconf *)entry->data)->dynamiclookupcommand
|| ((struct clsrvconf *)entry->data)->servers->in_use)
#else
if (((struct clsrvconf *)entry->data)->dynamiclookupcommand)
#endif
return 1;
return 0;
}
Expand Down Expand Up @@ -1764,12 +1774,17 @@ void *clientwr(void *arg) {
dynconffail = 1;
server->dynstartup = 0;
server->dynfailing = 1;
#if defined ENABLE_EXPERIMENTAL_DYNDISC
pthread_mutex_unlock(&server->lock);
#endif
debug(DBG_WARN, "%s: dynamicconfig(%s) failed, sleeping %ds",
__func__, server->conf->name, ZZZ);
sleep(ZZZ);
goto errexit;
}

#if defined ENABLE_EXPERIMENTAL_DYNDISC
pthread_mutex_unlock(&server->lock);
#endif
/* FIXME: Is resolving not always done by compileserverconfig(),
* either as part of static configuration setup or by
* dynamicconfig() above? */
Expand Down Expand Up @@ -1798,6 +1813,9 @@ void *clientwr(void *arg) {
goto errexit;
}
server->connectionok = 1;
#if defined ENABLE_EXPERIMENTAL_DYNDISC
server->in_use = 1;
#endif
if (pthread_create(&clientrdth, NULL, conf->pdef->clientconnreader, (void *)server)) {
debugerrno(errno, DBG_ERR, "clientwr: pthread_create failed");
goto errexit;
Expand Down Expand Up @@ -1907,6 +1925,9 @@ void *clientwr(void *arg) {
}
}
errexit:
#if defined ENABLE_EXPERIMENTAL_DYNDISC
server->in_use = 0;
#endif
conf->servers = NULL;
if (server->dynamiclookuparg) {
removeserversubrealms(realms, conf);
Expand Down Expand Up @@ -2201,12 +2222,28 @@ struct list *createsubrealmservers(struct realm *realm, struct list *srvconfs) {
srvconf->servers->dynstartup = 1;
debug(DBG_DBG, "%s: new client writer for %s",
__func__, srvconf->servers->conf->name);
#if defined ENABLE_EXPERIMENTAL_DYNDISC
pthread_mutex_lock(&srvconf->servers->lock);
#endif
if (pthread_create(&clientth, NULL, clientwr, (void *)(srvconf->servers))) {
#if defined ENABLE_EXPERIMENTAL_DYNDISC
pthread_mutex_unlock(&srvconf->servers->lock);
#endif
debugerrno(errno, DBG_ERR, "pthread_create failed");
freeserver(srvconf->servers, 1);
srvconf->servers = NULL;
#if defined ENABLE_EXPERIMENTAL_DYNDISC
conf = srvconf;
continue;
#endif
} else
pthread_detach(clientth);

#if defined ENABLE_EXPERIMENTAL_DYNDISC
/* If clientwr() could not find a NAPTR we have to
* wait for dynfailing=1 what is set in clientwr(). */
pthread_mutex_lock(&srvconf->servers->lock);
#endif
}
conf = srvconf;
}
Expand Down
3 changes: 3 additions & 0 deletions radsecproxy.h
Original file line number Diff line number Diff line change
Expand Up @@ -164,6 +164,9 @@ struct server {
uint8_t lostrqs;
uint8_t dynstartup;
uint8_t dynfailing;
#if defined ENABLE_EXPERIMENTAL_DYNDISC
uint8_t in_use;
#endif
char *dynamiclookuparg;
int nextid;
struct timeval lastrcv;
Expand Down

0 comments on commit 0723851

Please sign in to comment.