metaproxy 1.22.1
torus.cpp
Go to the documentation of this file.
1/* This file is part of Metaproxy.
2 Copyright (C) Index Data
3
4Metaproxy is free software; you can redistribute it and/or modify it under
5the terms of the GNU General Public License as published by the Free
6Software Foundation; either version 2, or (at your option) any later
7version.
8
9Metaproxy is distributed in the hope that it will be useful, but WITHOUT ANY
10WARRANTY; without even the implied warranty of MERCHANTABILITY or
11FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12for more details.
13
14You should have received a copy of the GNU General Public License
15along with this program; if not, write to the Free Software
16Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
17*/
18
19#include <metaproxy/xmlutil.hpp>
20
21#include <string.h>
22#include <yaz/wrbuf.h>
23#include <yaz/log.h>
24#include <yaz/url.h>
25#include <metaproxy/util.hpp>
26#include "torus.hpp"
27
28namespace mp = metaproxy_1;
29
30xmlDoc *mp::get_searchable(mp::Package &package,
31 std::string url_template, const std::string &db,
32 const std::string &query,
33 const std::string &realm,
34 const std::string &proxy,
35 std::string &addinfo)
36{
37 // http://mk2.indexdata.com/torus2/searchable/records/?query=udb%3d%db
38 // or
39 // http://mk2.indexdata.com/torus2/searchable/records/?query=%query
40 xmlDoc *doc = 0;
41 size_t found;
42
43 found = url_template.find("%query");
44 if (found != std::string::npos)
45 url_template.replace(found, 6, mp::util::uri_encode(query));
46
47 found = url_template.find("%db");
48 if (found != std::string::npos)
49 url_template.replace(found, 3, mp::util::uri_encode(db));
50
51 found = url_template.find("%realm");
52 if (found != std::string::npos)
53 url_template.replace(found, 6, mp::util::uri_encode(realm));
54
55 Z_HTTP_Header *http_headers = 0;
56 mp::odr odr;
57
58 z_HTTP_header_add(odr, &http_headers, "Accept","application/xml");
59
60 yaz_url_t url_p = yaz_url_create();
61 if (proxy.length())
62 yaz_url_set_proxy(url_p, proxy.c_str());
63
64 Z_HTTP_Response *http_response = yaz_url_exec(url_p,
65 url_template.c_str(),
66 "GET",
67 http_headers,
68 0, /* content buf */
69 0 /* content_len */
70 );
71 if (http_response && http_response->code == 200 &&
72 http_response->content_buf)
73 {
74 doc = xmlParseMemory(http_response->content_buf,
75 http_response->content_len);
76 if (doc)
77 package.log("zoom", YLOG_LOG, "Torus: %s OK",
78 url_template.c_str());
79 else
80 {
81 package.log("zoom", YLOG_WARN, "Torus: %s FAIL. XML parse failed",
82 url_template.c_str());
83 addinfo = "Torus: XML parse failed";
84 }
85 }
86 else
87 {
88 addinfo = "Torus: ";
89 if (http_response)
90 {
91 package.log("zoom", YLOG_WARN, "Torus: %s FAIL. HTTP code %d",
92 url_template.c_str(), http_response->code);
93 addinfo += std::string(http_response->content_buf,
94 http_response->content_len);
95 }
96 else
97 {
98 addinfo += "unknown error";
99 package.log("zoom", YLOG_WARN, "Torus: %s FAIL. No HTTP response",
100 url_template.c_str());
101 }
102 }
103
104 if (http_response && http_response->content_buf)
105 {
106 package.log("zoom", YLOG_LOG, "HTTP content");
107 package.log_write(http_response->content_buf,
108 http_response->content_len);
109 }
110 yaz_url_destroy(url_p);
111 return doc;
112}
113
114/*
115 * Local variables:
116 * c-basic-offset: 4
117 * c-file-style: "Stroustrup"
118 * indent-tabs-mode: nil
119 * End:
120 * vim: shiftwidth=4 tabstop=8 expandtab
121 */
122
xmlDoc * get_searchable(Package &package, std::string url_template, const std::string &db, const std::string &query, const std::string &realm, const std::string &proxy, std::string &addinfo)