aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/libfast/filter.h11
-rw-r--r--src/libfast/session.c51
2 files changed, 36 insertions, 26 deletions
diff --git a/src/libfast/filter.h b/src/libfast/filter.h
index d2fb8dd5f..614a2ef58 100644
--- a/src/libfast/filter.h
+++ b/src/libfast/filter.h
@@ -43,13 +43,18 @@ typedef filter_t *(*filter_constructor_t)(context_t* context, void *param);
struct filter_t {
/**
- * Called before the controller handles the request
+ * Called before the controller handles the request.
*
* @param request HTTP request
- * @param controller selected controller, before execution
+ * @param p1 first parameter
+ * @param p2 second parameter
+ * @param p3 third parameter
+ * @param p4 forth parameter
+ * @param p5 fifth parameter
* @return TRUE to continue request handling
*/
- bool (*run)(filter_t *this, request_t *request, controller_t *controller);
+ bool (*run)(filter_t *this, request_t *request,
+ char *p0, char *p1, char *p2, char *p3, char *p4, char *p5);
/**
* Destroy the filter instance.
diff --git a/src/libfast/session.c b/src/libfast/session.c
index bff610772..632313a83 100644
--- a/src/libfast/session.c
+++ b/src/libfast/session.c
@@ -96,22 +96,22 @@ static void create_sid(private_session_t *this, request_t *request)
/**
* run all registered filters
*/
-static bool run_filter(private_session_t *this, request_t *request,
- controller_t *controller)
+static bool run_filter(private_session_t *this, request_t *request, char *p0,
+ char *p1, char *p2, char *p3, char *p4, char *p5)
{
- iterator_t *iterator;
+ enumerator_t *enumerator;
filter_t *filter;
- iterator = this->filters->create_iterator(this->filters, TRUE);
- while (iterator->iterate(iterator, (void**)&filter))
+ enumerator = this->filters->create_enumerator(this->filters);
+ while (enumerator->enumerate(enumerator, &filter))
{
- if (!filter->run(filter, request, controller))
+ if (!filter->run(filter, request, p0, p1, p2, p3, p4, p5))
{
- iterator->destroy(iterator);
+ enumerator->destroy(enumerator);
return FALSE;
}
}
- iterator->destroy(iterator);
+ enumerator->destroy(enumerator);
return TRUE;
}
@@ -121,7 +121,7 @@ static bool run_filter(private_session_t *this, request_t *request,
static void process(private_session_t *this, request_t *request)
{
char *pos, *start, *param[6] = {NULL, NULL, NULL, NULL, NULL, NULL};
- iterator_t *iterator;
+ enumerator_t *enumerator;
bool handled = FALSE;
controller_t *current;
int i = 0;
@@ -134,31 +134,36 @@ static void process(private_session_t *this, request_t *request)
start = request->get_path(request);
if (start)
{
- if (*start == '/') start++;
+ if (*start == '/')
+ {
+ start++;
+ }
while ((pos = strchr(start, '/')) != NULL && i < 5)
{
- param[i++] = strndup(start, pos - start);
+ param[i++] = strndupa(start, pos - start);
start = pos + 1;
}
- param[i] = strdup(start);
- iterator = this->controllers->create_iterator(this->controllers, TRUE);
- while (iterator->iterate(iterator, (void**)&current))
+ param[i] = strdupa(start);
+
+ if (run_filter(this, request, param[0], param[1], param[2], param[3],
+ param[4], param[5]))
{
- if (streq(current->get_name(current), param[0]))
- {
- if (run_filter(this, request, current))
- {
+ enumerator = this->controllers->create_enumerator(this->controllers);
+ while (enumerator->enumerate(enumerator, &current))
+ {
+ if (streq(current->get_name(current), param[0]))
+ {
current->handle(current, request, param[1], param[2],
param[3], param[4], param[5]);
handled = TRUE;
+ break;
}
- break;
}
+ enumerator->destroy(enumerator);
}
- iterator->destroy(iterator);
- for (i = 0; i < 6; i++)
+ else
{
- free(param[i]);
+ handled = TRUE;
}
}
if (!handled)
@@ -186,7 +191,7 @@ static void destroy(private_session_t *this)
{
this->controllers->destroy_offset(this->controllers, offsetof(controller_t, destroy));
this->filters->destroy_offset(this->filters, offsetof(filter_t, destroy));
- if (this->context) this->context->destroy(this->context);
+ DESTROY_IF(this->context);
free(this->sid);
free(this);
}