annotate sparql/mod_audiodb/mod_audiodb.c @ 599:c6debbac3216

End-to-end functioning SPARQL with audioDB storage module * AudioDB RDF storage module now works correctly with dimension and vectors * Apache module now returns a sparql version of the query results. * (including cleanup close/free calls).
author mas01mj
date Thu, 13 Aug 2009 11:20:56 +0000
parents e3790284fd4a
children 337e5962218a
rev   line source
mas01mj@584 1
mas01mj@584 2 #include <httpd.h>
mas01mj@584 3 #include <ap_config.h>
mas01mj@584 4 #include <http_config.h>
mas01mj@584 5 #include <http_protocol.h>
mas01mj@584 6 #include <apr_strings.h>
mas01mj@584 7 #include <librdf.h>
mas01mj@584 8 #include <apreq_module.h>
mas01mj@584 9 #include <apreq_parser.h>
mas01mj@584 10 #include <apreq_param.h>
mas01mj@584 11 #include "apreq2/apreq_module_apache2.h"
mas01mj@599 12 #include <rasqal.h>
mas01mj@584 13
mas01mj@584 14 static int ap_dump_table(void *baton, const char *key, const char *value)
mas01mj@584 15 {
mas01mj@584 16 if (key && value)
mas01mj@584 17 fprintf(stderr, "%s:%s\n", key, value);
mas01mj@584 18 fflush(stderr);
mas01mj@584 19 return 1;
mas01mj@584 20 }
mas01mj@584 21
mas01mj@584 22 static int log_out(void *user_data, librdf_log_message *message)
mas01mj@584 23 {
mas01mj@584 24 fprintf(stderr, "%s\n", librdf_log_message_message(message));
mas01mj@584 25 fflush(stderr);
mas01mj@584 26 return 1;
mas01mj@584 27 }
mas01mj@584 28
mas01mj@584 29 static int adb_handle_sparql_req(request_rec *r) {
mas01mj@584 30 if(strcmp(r->handler, "audiodb-sparql-handler") != 0) {
mas01mj@584 31 return DECLINED;
mas01mj@584 32 }
mas01mj@584 33
mas01mj@584 34 r->content_type = "text/plain";
mas01mj@584 35 r->status = OK;
mas01mj@584 36 r->status_line = "200 OK";
mas01mj@584 37
mas01mj@584 38 if(!r->args) {
mas01mj@584 39 r->args = "";
mas01mj@584 40 }
mas01mj@584 41
mas01mj@584 42 const apr_table_t *form_table;
mas01mj@584 43 apreq_handle_t *h = apreq_handle_apache2(r);
mas01mj@584 44 if(apreq_args(h, &form_table) != APR_SUCCESS)
mas01mj@584 45 return DECLINED;
mas01mj@584 46
mas01mj@584 47 const unsigned char *query_string = apr_table_get(form_table, "query");
mas01mj@584 48
mas01mj@584 49 int rc = 0;
mas01mj@584 50 librdf_world* world = librdf_new_world();
mas01mj@584 51 librdf_world_open(world);
mas01mj@584 52 librdf_world_set_logger(world, NULL, log_out);
mas01mj@599 53 librdf_storage* storage = librdf_new_storage(world, "audiodb", "/tmp/test_database.adb", NULL);
mas01mj@584 54 if(!storage)
mas01mj@584 55 {
mas01mj@584 56 rc = 2;
mas01mj@584 57 goto error;
mas01mj@584 58 }
mas01mj@584 59
mas01mj@584 60 librdf_model *model;
mas01mj@584 61 if (!(model = librdf_new_model(world, storage, NULL)))
mas01mj@584 62 {
mas01mj@584 63 rc = 5;
mas01mj@584 64 goto error;
mas01mj@584 65 }
mas01mj@584 66
mas01mj@584 67 librdf_query *query;
mas01mj@584 68 if (!(query = librdf_new_query(world, "sparql", NULL, query_string, NULL)))
mas01mj@584 69 {
mas01mj@584 70 rc = 3;
mas01mj@584 71 goto error;
mas01mj@584 72 }
mas01mj@584 73
mas01mj@584 74 librdf_query_results *results;
mas01mj@584 75 if (!(results = librdf_query_execute(query, model)))
mas01mj@584 76 {
mas01mj@584 77 rc = 4;
mas01mj@584 78 goto error;
mas01mj@584 79 }
mas01mj@584 80
mas01mj@599 81 librdf_uri *sparql_uri = librdf_new_uri( world, "http://www.w3.org/TR/2006/WD-rdf-sparql-XMLres-20070614/");
mas01mj@599 82
mas01mj@599 83 unsigned char* out = librdf_query_results_to_string(results, sparql_uri, librdf_new_uri(world, "http://purl.org/ontology/af/"));
mas01mj@599 84 librdf_storage_close(storage);
mas01mj@599 85 librdf_free_storage(storage);
mas01mj@599 86 librdf_free_world(world);
mas01mj@599 87 ap_rprintf(r, out);
mas01mj@584 88
mas01mj@584 89 rc = 0;
mas01mj@584 90 return r->status;
mas01mj@584 91
mas01mj@584 92 error:
mas01mj@584 93 ap_rprintf(r, "Fail %d", rc);
mas01mj@584 94 return OK;
mas01mj@584 95 }
mas01mj@584 96
mas01mj@584 97 static void mod_audiodb_register_hooks (apr_pool_t *p) {
mas01mj@584 98 ap_hook_handler(adb_handle_sparql_req, NULL, NULL, APR_HOOK_FIRST);
mas01mj@584 99 }
mas01mj@584 100
mas01mj@584 101 module AP_MODULE_DECLARE_DATA audiodb_module = {
mas01mj@584 102 STANDARD20_MODULE_STUFF,
mas01mj@584 103 NULL,
mas01mj@584 104 NULL,
mas01mj@584 105 NULL,
mas01mj@584 106 NULL,
mas01mj@584 107 NULL,
mas01mj@584 108 mod_audiodb_register_hooks,
mas01mj@584 109 };