diff options
author | Adam Chlipala <adamc@hcoop.net> | 2009-03-24 15:35:46 -0400 |
---|---|---|
committer | Adam Chlipala <adamc@hcoop.net> | 2009-03-24 15:35:46 -0400 |
commit | 7d66aadb65a25a97e2a28de797e1328f88498513 (patch) | |
tree | d793977e8a9a16b88dc9decb0fef10c82be4fa78 /src/c/urweb.c | |
parent | 7eb964977ab596340f904388ced6a2dd6f39f943 (diff) |
Variable timeouts and client keep-alive
Diffstat (limited to 'src/c/urweb.c')
-rw-r--r-- | src/c/urweb.c | 27 |
1 files changed, 18 insertions, 9 deletions
diff --git a/src/c/urweb.c b/src/c/urweb.c index 6cc786ef..5fa2af42 100644 --- a/src/c/urweb.c +++ b/src/c/urweb.c @@ -220,10 +220,8 @@ void uw_client_connect(size_t id, int pass, int sock) { } if (c->data.used.sock != -1) { - pthread_mutex_unlock(&c->data.used.lock); - close(sock); - fprintf(stderr, "Duplicate client connection (%d)\n", (int)id); - return; + close(c->data.used.sock); + c->data.used.sock = -1; } c->data.used.last_contact = time(NULL); @@ -288,11 +286,13 @@ static void uw_free_client(client *c) { } } -void uw_prune_clients(time_t timeout) { +extern int uw_timeout; + +void uw_prune_clients() { size_t i; time_t cutoff; - cutoff = time(NULL) - timeout; + cutoff = time(NULL) - uw_timeout; pthread_mutex_lock(&clients_mutex); @@ -507,6 +507,8 @@ struct uw_context { size_t n_deltas; channel_delta *deltas; + int timeout; + char error_message[ERROR_BUF_LEN]; }; @@ -541,6 +543,8 @@ uw_context uw_init(size_t outHeaders_len, size_t script_len, size_t page_len, si ctx->n_deltas = 0; ctx->deltas = malloc(0); + ctx->timeout = uw_timeout; + return ctx; } @@ -834,10 +838,15 @@ const char *uw_Basis_get_script(uw_context ctx, uw_unit u) { int pass; client *c = uw_new_client(&pass); - char *r = uw_malloc(ctx, strlen(ctx->script_header) + 56 + 2 * INTS_MAX + buf_used(&ctx->script) + char *r = uw_malloc(ctx, strlen(ctx->script_header) + 65 + 3 * INTS_MAX + buf_used(&ctx->script) + strlen(ctx->url_prefix)); - sprintf(r, "%s<script>client_id=%d;client_pass=%d;url_prefix=\"%s\";%s</script>", - ctx->script_header, (int)c->id, c->data.used.pass, ctx->url_prefix, ctx->script.start); + sprintf(r, "%s<script>client_id=%d;client_pass=%d;url_prefix=\"%s\";timeout=%d;%s</script>", + ctx->script_header, + (int)c->id, + c->data.used.pass, + ctx->url_prefix, + ctx->timeout, + ctx->script.start); return r; } } |