X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fhttp_command.c;h=f44fdf372477ba6a29e8046db48cf54a44d16599;hb=197410f262777b4955b23be723afe80d5f63cf77;hp=b68aa36273b37ec8cd420de7b0a0eab14e25a372;hpb=c70eb36a1e27ba0439a9ddc2f46188933c55be7a;p=pazpar2-moved-to-github.git diff --git a/src/http_command.c b/src/http_command.c index b68aa36..f44fdf3 100644 --- a/src/http_command.c +++ b/src/http_command.c @@ -1,4 +1,4 @@ -/* $Id: http_command.c,v 1.35 2007-04-15 03:26:47 quinn Exp $ +/* $Id: http_command.c,v 1.40 2007-04-19 16:07:20 adam Exp $ Copyright (c) 2006-2007, Index Data. This file is part of Pazpar2. @@ -20,7 +20,7 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA */ /* - * $Id: http_command.c,v 1.35 2007-04-15 03:26:47 quinn Exp $ + * $Id: http_command.c,v 1.40 2007-04-19 16:07:20 adam Exp $ */ #include @@ -46,8 +46,8 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA #include "http_command.h" #include "settings.h" -extern struct parameters global_parameters; -extern IOCHAN channel_list; +// Update this when the protocol changes +#define PAZPAR2_PROTOCOL_VERSION "1" struct http_session { IOCHAN timeout_iochan; // NOTE: This is NOT associated with a socket @@ -82,8 +82,8 @@ struct http_session *http_session_create() r->timeout_iochan = iochan_create(-1, session_timeout, 0); iochan_setdata(r->timeout_iochan, r); iochan_settimeout(r->timeout_iochan, global_parameters.session_timeout); - r->timeout_iochan->next = channel_list; - channel_list = r->timeout_iochan; + + pazpar2_add_channel(r->timeout_iochan); return r; } @@ -201,7 +201,8 @@ static void cmd_init(struct http_channel *c) s->session_id = sesid; if (process_settings(s->psession, c->request, c->response) < 0) return; - sprintf(buf, "OK%u", sesid); + sprintf(buf, "OK%u" + "" PAZPAR2_PROTOCOL_VERSION "", sesid); rs->payload = nmem_strdup(c->nmem, buf); http_send_response(c); } @@ -362,7 +363,7 @@ static void write_metadata(WRBUF w, struct conf_service *service, continue; for (md = ml[imeta]; md; md = md->next) { - wrbuf_printf(w, "", cmd->name); + wrbuf_printf(w, "\n", cmd->name); switch (cmd->type) { case Metadata_type_generic: @@ -386,7 +387,7 @@ static void write_subrecord(struct record *r, WRBUF w, { char *name = session_setting_oneval(r->client->database, PZ_NAME); - wrbuf_printf(w, "\n", + wrbuf_printf(w, "", r->client->database->database->url, *name ? name : "Unknown"); if (show_details)