aboutsummaryrefslogtreecommitdiffstats
path: root/src/libfast/dispatcher.c
diff options
context:
space:
mode:
authorMartin Willi <martin@revosec.ch>2012-07-06 14:17:01 +0200
committerMartin Willi <martin@revosec.ch>2012-07-16 14:53:37 +0200
commit76a98ee2a1578a7f1f95b63846cefffad9b1df63 (patch)
treefe00bce63566fe8fbdcd7b6b9aaaa2066c27d494 /src/libfast/dispatcher.c
parent71c41410fc0b3c9022f1fe59f7b988363b84abea (diff)
downloadstrongswan-76a98ee2a1578a7f1f95b63846cefffad9b1df63.tar.bz2
strongswan-76a98ee2a1578a7f1f95b63846cefffad9b1df63.tar.xz
Check rng return value when generating libfast session COOKIEs
Diffstat (limited to 'src/libfast/dispatcher.c')
-rw-r--r--src/libfast/dispatcher.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/src/libfast/dispatcher.c b/src/libfast/dispatcher.c
index e5fca7074..63c872e35 100644
--- a/src/libfast/dispatcher.c
+++ b/src/libfast/dispatcher.c
@@ -179,10 +179,16 @@ static session_entry_t *session_entry_create(private_dispatcher_t *this,
char *host)
{
session_entry_t *entry;
+ session_t *session;
+ session = load_session(this);
+ if (!session)
+ {
+ return NULL;
+ }
INIT(entry,
.cond = condvar_create(CONDVAR_TYPE_DEFAULT),
- .session = load_session(this),
+ .session = session,
.host = strdup(host),
.used = time_monotonic(NULL),
);
@@ -324,6 +330,12 @@ static void dispatch(private_dispatcher_t *this)
else
{ /* create a new session if not found */
found = session_entry_create(this, request->get_host(request));
+ if (!found)
+ {
+ request->destroy(request);
+ this->mutex->unlock(this->mutex);
+ continue;
+ }
sid = found->session->get_sid(found->session);
this->sessions->put(this->sessions, sid, found);
}