482cd8f6baaff31cfbfc99391f19d1e739e67114 tdreszer Mon Sep 27 11:59:41 2010 -0700 Moved mdb queries from hgTracks and hgApi to mdb. Made sure the queries exclude files. diff --git src/hg/hgApi/hgApi.c src/hg/hgApi/hgApi.c index bb78e33..2f9e681 100644 --- src/hg/hgApi/hgApi.c +++ src/hg/hgApi/hgApi.c @@ -1,163 +1,158 @@ /* hgApi - provide a JSON based API to the browser. */ #include "common.h" #include "hdb.h" +#include "mdb.h" #include "cheapcgi.h" #include "hPrint.h" #include "dystring.h" #include "hui.h" static char const rcsid[] = "$Id: hgApi.c,v 1.3 2010/05/30 21:11:47 larrym Exp $"; static void fail(char *msg) { puts("Status: 400\n\n"); puts(msg); exit(-1); } void makeIndent(char *buf, int bufLen, int indent) { indent = min(indent, bufLen - 2); memset(buf, '\t', indent); buf[indent] = 0; } static void trackJson(struct dyString *json, struct trackDb *tdb, int *count, int indent) { char tabs[100]; makeIndent(tabs, sizeof(tabs), indent); if((*count)++) dyStringPrintf(json, ",\n"); dyStringPrintf(json, "%s{\n", tabs); makeIndent(tabs, sizeof(tabs), indent + 1); dyStringPrintf(json, "%s\"track\": \"%s\",\n%s\"shortLabel\": \"%s\",\n%s\"longLabel\": \"%s\",\n%s\"group\": \"%s\"", tabs, tdb->track, tabs, tdb->shortLabel, tabs, tdb->longLabel, tabs, tdb->grp); if(tdbIsComposite(tdb) && tdb->subtracks != NULL) { struct trackDb *ptr; dyStringPrintf(json, ",\n%s\"subtracks\":\n%s[\n", tabs, tabs); int count = 0; for (ptr = tdb->subtracks; ptr != NULL; ptr = ptr->next) { trackJson(json, ptr, &count, indent + 2); } dyStringPrintf(json, "\n%s]", tabs); } makeIndent(tabs, sizeof(tabs), indent); dyStringPrintf(json, "\n%s}", tabs); } +#define MDB_VAL_TRUNC_AT 64 + int main(int argc, char *argv[]) { struct dyString *output = newDyString(10000); char *database = cgiOptionalString("db"); char *cmd = cgiOptionalString("cmd"); char *jsonp = cgiOptionalString("jsonp"); if(database) { database = sqlEscapeString(database); if(!hDbExists(database)) fail("Invalid database"); } else fail("Missing 'db' parameter"); if(!cmd) fail("Missing 'cmd' parameter"); if(!strcmp(cmd, "trackList")) { // Return trackList for this assembly // e.g. http://genome.ucsc.edu/hgApi?db=hg18&cmd=trackList struct trackDb *tdb, *tdbList = NULL; tdbList = hTrackDb(database, NULL); dyStringPrintf(output, "[\n"); int count = 0; for (tdb = tdbList; tdb != NULL; tdb = tdb->next) { trackJson(output, tdb, &count, 1); count++; } dyStringAppend(output, "\n]\n"); } else if(!strcmp(cmd, "metaDb")) { // Return list of values for given metaDb var // e.g. http://genome.ucsc.edu/hgApi?db=hg18&cmd=metaDb&var=cell struct sqlConnection *conn = hAllocConn(database); boolean metaDbExists = sqlTableExists(conn, "metaDb"); if(metaDbExists) { - char query[256]; - struct sqlResult *sr = NULL; - char **row; int i; - struct slName *el, *termList = NULL; char *var = cgiOptionalString("var"); if(var) var = sqlEscapeString(var); else fail("Missing var parameter"); - safef(query, sizeof(query), "select distinct val from metaDb where var = '%s'", var); - sr = sqlGetResult(conn, query); - while ((row = sqlNextRow(sr)) != NULL) - slNameAddHead(&termList, row[0]); - sqlFreeResult(&sr); - slSort(&termList, slNameCmpCase); + struct slName *termList = mdbValSearch(conn, var, MDB_VAL_STD_TRUNCATION, TRUE, FALSE); // Tables not files + struct slName *el; dyStringPrintf(output, "[\n"); for (el = termList, i = 0; el != NULL; el = el->next, i++) { if(i) dyStringPrintf(output, ",\n"); dyStringPrintf(output, "'%s'", javaScriptLiteralEncode(el->name)); } dyStringPrintf(output, "\n]\n"); } else fail("Assembly does not support metaDb"); } else if(!strcmp(cmd, "tableMetadata")) { // returns an html table with metadata for a given track char *trackName = cgiOptionalString("track"); boolean showLonglabel = (NULL != cgiOptionalString("showLonglabel")); boolean showShortLabel = (NULL != cgiOptionalString("showShortLabel")); if (trackName != NULL) { struct trackDb *tdb = hTrackDbForTrack(database, trackName); if (tdb != NULL) { char * html = metadataAsHtmlTable(database,tdb,showLonglabel,showShortLabel,NULL); if (html) { dyStringAppend(output,html); freeMem(html); } else dyStringPrintf(output,"No metadata found for track %s.",trackName); } else dyStringPrintf(output,"Track %s not found",trackName); } else dyStringAppend(output,"No track variable found"); } else fail("Unsupported 'cmd' parameter"); // It's debatable whether the type should be text/plain, text/javascript or application/javascript; I think // any of the types containing "javascript" don't work with IE6, so I'm using text/plain puts("Content-Type:text/javascript\n"); //puts("\n"); if(jsonp) printf("%s(%s)", jsonp, dyStringContents(output)); else puts(dyStringContents(output)); return 0; }