projects
/
metaproxy-moved-to-github.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Scope classes, tweak for TIME_UTC
[metaproxy-moved-to-github.git]
/
src
/
torus.cpp
diff --git
a/src/torus.cpp
b/src/torus.cpp
index
6ee010f
..
1313984
100644
(file)
--- a/
src/torus.cpp
+++ b/
src/torus.cpp
@@
-29,13
+29,20
@@
namespace mp = metaproxy_1;
xmlDoc *mp::get_searchable(mp::Package &package,
std::string url_template, const std::string &db,
xmlDoc *mp::get_searchable(mp::Package &package,
std::string url_template, const std::string &db,
+ const std::string &query,
const std::string &realm,
const std::string &proxy)
{
const std::string &realm,
const std::string &proxy)
{
- // http://newmk2.indexdata.com/torus2/searchable.ebsco/records/?query=udb=aberdeenUni
+ // http://mk2.indexdata.com/torus2/searchable/records/?query=udb%3d%db
+ // or
+ // http://mk2.indexdata.com/torus2/searchable/records/?query=%query
xmlDoc *doc = 0;
size_t found;
xmlDoc *doc = 0;
size_t found;
+ found = url_template.find("%query");
+ if (found != std::string::npos)
+ url_template.replace(found, 6, mp::util::uri_encode(query));
+
found = url_template.find("%db");
if (found != std::string::npos)
url_template.replace(found, 3, mp::util::uri_encode(db));
found = url_template.find("%db");
if (found != std::string::npos)
url_template.replace(found, 3, mp::util::uri_encode(db));
@@
-46,7
+53,7
@@
xmlDoc *mp::get_searchable(mp::Package &package,
Z_HTTP_Header *http_headers = 0;
mp::odr odr;
Z_HTTP_Header *http_headers = 0;
mp::odr odr;
-
+
z_HTTP_header_add(odr, &http_headers, "Accept","application/xml");
yaz_url_t url_p = yaz_url_create();
z_HTTP_header_add(odr, &http_headers, "Accept","application/xml");
yaz_url_t url_p = yaz_url_create();
@@
-60,21
+67,28
@@
xmlDoc *mp::get_searchable(mp::Package &package,
0, /* content buf */
0 /* content_len */
);
0, /* content buf */
0 /* content_len */
);
- if (http_response && http_response->code == 200 &&
+ if (http_response && http_response->code == 200 &&
http_response->content_buf)
{
http_response->content_buf)
{
- package.log("zoom", YLOG_LOG, "Torus: %s OK", url_template.c_str());
doc = xmlParseMemory(http_response->content_buf,
http_response->content_len);
doc = xmlParseMemory(http_response->content_buf,
http_response->content_len);
-
+ if (doc)
+ package.log("zoom", YLOG_LOG, "Torus: %s OK",
+ url_template.c_str());
+ else
+ package.log("zoom", YLOG_WARN, "Torus: %s FAIL. XML parse failed",
+ url_template.c_str());
}
else
{
}
else
{
- package.log("zoom", YLOG_WARN, "Torus: %s FAIL", url_template.c_str());
if (http_response)
{
if (http_response)
{
- package.log("zoom", YLOG_LOG, "HTTP code: %d", http_response->code);
+ package.log("zoom", YLOG_WARN, "Torus: %s FAIL. HTTP code %d",
+ url_template.c_str(), http_response->code);
}
}
+ else
+ package.log("zoom", YLOG_WARN, "Torus: %s FAIL. No HTTP response",
+ url_template.c_str());
}
if (http_response && http_response->content_buf)
}
if (http_response && http_response->content_buf)