/*
- * $Id: http_command.c,v 1.4 2007-01-04 02:35:42 quinn Exp $
+ * $Id: http_command.c,v 1.9 2007-01-08 12:43:41 adam Exp $
*/
#include <stdio.h>
#include <ctype.h>
#include <sys/time.h>
+#if HAVE_CONFIG_H
+#include <cconfig.h>
+#endif
+
#include <yaz/yaz-util.h>
-#include "command.h"
#include "util.h"
#include "eventl.h"
#include "pazpar2.h"
http_send_response(c);
}
+// Compares two hitsbytarget nodes by hitcount
+static int cmp_ht(const void *p1, const void *p2)
+{
+ const struct hitsbytarget *h1 = p1;
+ const struct hitsbytarget *h2 = p2;
+ return h2->hits - h1->hits;
+}
+
+// This implements functionality somewhat similar to 'bytarget', but in a termlist form
+static void targets_termlist(WRBUF wrbuf, struct session *se)
+{
+ struct hitsbytarget *ht;
+ int count, i;
+
+ if (!(ht = hitsbytarget(se, &count)))
+ return;
+ qsort(ht, count, sizeof(struct hitsbytarget), cmp_ht);
+ for (i = 0; i < count && i < 15; i++)
+ {
+ wrbuf_puts(wrbuf, "\n<term>\n");
+ wrbuf_printf(wrbuf, "<name>%s</name>\n", ht[i].id);
+ wrbuf_printf(wrbuf, "<frequency>%d</frequency>\n", ht[i].hits);
+ wrbuf_printf(wrbuf, "<state>%s</state>\n", ht[i].state);
+ wrbuf_printf(wrbuf, "<diagnostic>%d</diagnostic>\n", ht[i].diagnostic);
+ wrbuf_puts(wrbuf, "\n</term>\n");
+ }
+}
+
static void cmd_termlist(struct http_channel *c)
{
struct http_response *rs = c->response;
int len;
int i;
char *name = http_argbyname(rq, "name");
- int status = session_active_clients(s->psession);
+ int status;
if (!s)
return;
+ status = session_active_clients(s->psession);
+
if (!name)
name = "subject";
if (strlen(name) > 255)
strncpy(tname, name, tp - name);
tname[tp - name] = '\0';
- p = termlist(s->psession, tname, &len);
wrbuf_printf(c->wrbuf, "\n<list name=\"%s\">\n", tname);
- if (p)
- for (i = 0; i < len; i++)
- {
- wrbuf_puts(c->wrbuf, "\n<term>");
- wrbuf_printf(c->wrbuf, "<name>%s</name>", p[i]->term);
- wrbuf_printf(c->wrbuf, "<frequency>%d</frequency>", p[i]->frequency);
- wrbuf_puts(c->wrbuf, "</term>");
- }
+ if (!strcmp(tname, "xtargets"))
+ targets_termlist(c->wrbuf, s->psession);
+ else
+ {
+ p = termlist(s->psession, tname, &len);
+ if (p)
+ for (i = 0; i < len; i++)
+ {
+ wrbuf_puts(c->wrbuf, "\n<term>");
+ wrbuf_printf(c->wrbuf, "<name>%s</name>", p[i]->term);
+ wrbuf_printf(c->wrbuf, "<frequency>%d</frequency>", p[i]->frequency);
+ wrbuf_puts(c->wrbuf, "</term>");
+ }
+ }
wrbuf_puts(c->wrbuf, "\n</list>");
name = tp;
if (*name == ',')
struct http_response *rs = c->response;
struct http_session *s = locate_session(rq, rs);
char *block = http_argbyname(rq, "block");
- int status = session_active_clients(s->psession);
+ int status;
if (!s)
return;
+ status = session_active_clients(s->psession);
+
if (block)
{
if (status && (!s->psession->reclist || !s->psession->reclist->num_records))
struct http_response *rs = c->response;
struct http_session *s = locate_session(rq, rs);
struct statistics stat;
+ int clients;
if (!s)
return;
+ clients = session_active_clients(s->psession);
statistics(s->psession, &stat);
wrbuf_rewind(c->wrbuf);
wrbuf_puts(c->wrbuf, "<stat>");
+ wrbuf_printf(c->wrbuf, "<activeclients>%d</activeclients>\n", clients);
wrbuf_printf(c->wrbuf, "<hits>%d</hits>\n", stat.num_hits);
wrbuf_printf(c->wrbuf, "<records>%d</records>\n", stat.num_records);
wrbuf_printf(c->wrbuf, "<clients>%d</clients>\n", stat.num_clients);