public:
Backend(SearchablePtr sptr);
~Backend();
- void connect(std::string zurl, int *error, const char **addinfo);
+ void connect(std::string zurl, int *error, char **addinfo,
+ ODR odr);
void search_pqf(const char *pqf, Odr_int *hits,
- int *error, const char **addinfo);
+ int *error, char **addinfo, ODR odr);
void search_cql(const char *cql, Odr_int *hits,
- int *error, const char **addinfo);
+ int *error, char **addinfo, ODR odr);
void present(Odr_int start, Odr_int number, ZOOM_record *recs,
- int *error, const char **addinfo);
+ int *error, char **addinfo, ODR odr);
void set_option(const char *name, const char *value);
const char *get_option(const char *name);
- void get_zoom_error(int *error, const char **addinfo);
+ void get_zoom_error(int *error, char **addinfo, ODR odr);
};
class Zoom::Frontend : boost::noncopyable {
friend class Impl;
Z_Records *get_records(Odr_int start,
Odr_int number_to_present,
int *error,
- const char **addinfo,
+ char **addinfo,
Odr_int *number_of_records_returned,
ODR odr, BackendPtr b,
Odr_oid *preferredRecordSyntax,
Impl();
~Impl();
void process(metaproxy_1::Package & package);
- void configure(const xmlNode * ptr, bool test_only);
+ void configure(const xmlNode * ptr, bool test_only,
+ const char *path);
private:
void configure_local_records(const xmlNode * ptr, bool test_only);
FrontendPtr get_frontend(mp::Package &package);
std::string torus_url;
std::map<std::string,std::string> fieldmap;
std::string xsldir;
+ std::string file_path;
CCL_bibset bibset;
std::string element_transform;
std::string element_raw;
{ // must have a destructor because of boost::scoped_ptr
}
-void yf::Zoom::configure(const xmlNode *xmlnode, bool test_only)
+void yf::Zoom::configure(const xmlNode *xmlnode, bool test_only,
+ const char *path)
{
- m_p->configure(xmlnode, test_only);
+ m_p->configure(xmlnode, test_only, path);
}
void yf::Zoom::process(mp::Package &package) const
}
-void yf::Zoom::Backend::get_zoom_error(int *error, const char **addinfo)
+void yf::Zoom::Backend::get_zoom_error(int *error, char **addinfo,
+ ODR odr)
{
const char *msg = 0;
- *error = ZOOM_connection_error(m_connection, &msg, addinfo);
+ const char *zoom_addinfo = 0;
+ *error = ZOOM_connection_error(m_connection, &msg, &zoom_addinfo);
if (*error)
{
if (*error >= ZOOM_ERROR_CONNECT)
{
// turn ZOOM diagnostic into a Bib-1 2: with addinfo=zoom err msg
*error = YAZ_BIB1_TEMPORARY_SYSTEM_ERROR;
- if (addinfo)
- *addinfo = msg;
+ *addinfo = (char *) odr_malloc(
+ odr, 20 + strlen(msg) +
+ (zoom_addinfo ? strlen(zoom_addinfo) : 0));
+ strcpy(*addinfo, msg);
+ if (zoom_addinfo)
+ {
+ strcat(*addinfo, ": ");
+ strcat(*addinfo, zoom_addinfo);
+ strcat(*addinfo, " ");
+ }
+ }
+ else
+ {
+ *addinfo = (char *) odr_malloc(
+ odr, 20 + (zoom_addinfo ? strlen(zoom_addinfo) : 0));
+ **addinfo = '\0';
+ if (zoom_addinfo && *zoom_addinfo)
+ {
+ strcpy(*addinfo, zoom_addinfo);
+ strcat(*addinfo, " ");
+ }
+ strcat(*addinfo, "(backend)");
}
}
}
void yf::Zoom::Backend::connect(std::string zurl,
- int *error, const char **addinfo)
+ int *error, char **addinfo,
+ ODR odr)
{
ZOOM_connection_connect(m_connection, zurl.c_str(), 0);
- get_zoom_error(error, addinfo);
+ get_zoom_error(error, addinfo, odr);
}
void yf::Zoom::Backend::search_pqf(const char *pqf, Odr_int *hits,
- int *error, const char **addinfo)
+ int *error, char **addinfo, ODR odr)
{
m_resultset = ZOOM_connection_search_pqf(m_connection, pqf);
- get_zoom_error(error, addinfo);
+ get_zoom_error(error, addinfo, odr);
if (*error == 0)
*hits = ZOOM_resultset_size(m_resultset);
else
}
void yf::Zoom::Backend::search_cql(const char *cql, Odr_int *hits,
- int *error, const char **addinfo)
+ int *error, char **addinfo, ODR odr)
{
ZOOM_query q = ZOOM_query_create();
m_resultset = ZOOM_connection_search(m_connection, q);
ZOOM_query_destroy(q);
- get_zoom_error(error, addinfo);
+ get_zoom_error(error, addinfo, odr);
if (*error == 0)
*hits = ZOOM_resultset_size(m_resultset);
else
void yf::Zoom::Backend::present(Odr_int start, Odr_int number,
ZOOM_record *recs,
- int *error, const char **addinfo)
+ int *error, char **addinfo, ODR odr)
{
ZOOM_resultset_records(m_resultset, recs, start, number);
- get_zoom_error(error, addinfo);
+ get_zoom_error(error, addinfo, odr);
}
void yf::Zoom::Backend::set_option(const char *name, const char *value)
}
}
-void yf::Zoom::Impl::configure(const xmlNode *ptr, bool test_only)
+void yf::Zoom::Impl::configure(const xmlNode *ptr, bool test_only,
+ const char *path)
{
+ if (path && *path)
+ {
+ file_path = path;
+ if (path[strlen(path)-1] != '/')
+ file_path += "/";
+ }
for (ptr = ptr->children; ptr; ptr = ptr->next)
{
if (ptr->type != XML_ELEMENT_NODE)
if (m_backend && m_backend->m_frontend_database == database)
return m_backend;
+ const char *sru_proxy = 0;
std::string db_args;
std::string torus_db;
size_t db_arg_pos = database.find(',');
if (m_p->xsldir.length())
fname = m_p->xsldir + "/" + sptr->transform_xsl_fname;
else
- fname = sptr->transform_xsl_fname;
+ fname = m_p->file_path + sptr->transform_xsl_fname;
xmlDoc *xsp_doc = xmlParseFile(fname.c_str());
if (!xsp_doc)
{
{
// A CF target
b->set_option("user", sptr->cfAuth.c_str());
- if (authentication.length() && db_args.length() == 0)
+ if (db_args.length() == 0)
{
- // no database (auth) args specified already.. and the
- // Torus authentication has it.. Generate the args that CF
- // understands..
- size_t found = authentication.find('/');
- if (found != std::string::npos)
+ if (authentication.length())
{
- db_args += "user=" + mp::util::uri_encode(authentication.substr(0, found))
- + "&password=" + mp::util::uri_encode(authentication.substr(found+1));
+ // no database (auth) args specified already.. and the
+ // Torus authentication has it.. Generate the args that CF
+ // understands..
+ size_t found = authentication.find('/');
+ if (found != std::string::npos)
+ {
+ db_args += "user=" + mp::util::uri_encode(authentication.substr(0, found))
+ + "&password=" + mp::util::uri_encode(authentication.substr(found+1));
+ }
+ else
+ db_args += "user=" + mp::util::uri_encode(authentication);
}
- else
- db_args += "user=" + mp::util::uri_encode(authentication);
+ if (sptr->cfProxy.length())
+ {
+ if (db_args.length())
+ db_args += "&";
+ db_args += "proxy=" + mp::util::uri_encode(sptr->cfProxy);
+ }
+ }
+ if (sptr->cfSubDb.length())
+ {
+ if (db_args.length())
+ db_args += "&";
+ db_args += "subdatabase=" + mp::util::uri_encode(sptr->cfSubDb);
}
}
else
param_user = value;
else if (!strcmp(name, "password"))
param_password = value;
+ else if (!strcmp(name, "proxy"))
+ sru_proxy = value;
else
{
BackendPtr notfound;
b->set_option("user", authentication.c_str());
}
}
- if (sptr->cfProxy.length())
- {
- if (db_args.length())
- db_args += "&";
- db_args += "proxy=" + mp::util::uri_encode(sptr->cfProxy);
- }
- if (sptr->cfSubDb.length())
- {
- if (db_args.length())
- db_args += "&";
- db_args += "subdatabase=" + mp::util::uri_encode(sptr->cfSubDb);
- }
+
+ if (sru_proxy)
+ b->set_option("proxy", sru_proxy);
std::string url;
if (sptr->sru.length())
if (db_args.length())
url += "," + db_args;
yaz_log(YLOG_LOG, "url=%s", url.c_str());
- const char *addinfo_c = 0;
- b->connect(url, error, &addinfo_c);
- if (addinfo_c)
- *addinfo = odr_strdup(odr, addinfo_c);
+ b->connect(url, error, addinfo, odr);
if (*error == 0)
{
m_backend = b;
Z_Records *yf::Zoom::Frontend::get_records(Odr_int start,
Odr_int number_to_present,
int *error,
- const char **addinfo,
+ char **addinfo,
Odr_int *number_of_records_returned,
ODR odr,
BackendPtr b,
b->set_option("elementSetName", element_set_name);
- b->present(start, number_to_present, recs, error, addinfo);
+ b->present(start, number_to_present, recs, error, addinfo, odr);
Odr_int i = 0;
if (!*error)
}
int rec_len;
+ xmlChar *xmlrec_buf = 0;
const char *rec_buf = ZOOM_record_get(recs[i], rec_type_str,
&rec_len);
if (rec_buf && b->xsp && enable_pz2_transform)
rec_res = xsltApplyStylesheet(b->xsp, rec_doc, 0);
if (rec_res)
- xsltSaveResultToString((xmlChar **) &rec_buf, &rec_len,
+ xsltSaveResultToString(&xmlrec_buf, &rec_len,
rec_res, b->xsp);
+ rec_buf = (const char *) xmlrec_buf;
+ xmlFreeDoc(rec_doc);
+ xmlFreeDoc(rec_res);
}
}
if (rec_buf)
{
xmlDoc *doc = xmlParseMemory(rec_buf, rec_len);
- mp::xml::url_recipe_handle(doc, b->sptr->urlRecipe);
+ std::string res =
+ mp::xml::url_recipe_handle(doc, b->sptr->urlRecipe);
+ if (res.length())
+ {
+ xmlNode *ptr = xmlDocGetRootElement(doc);
+ while (ptr && ptr->type != XML_ELEMENT_NODE)
+ ptr = ptr->next;
+ xmlNode *c =
+ xmlNewChild(ptr, 0, BAD_CAST "generated-url", 0);
+ xmlNode * t = xmlNewText(BAD_CAST res.c_str());
+ xmlAddChild(c, t);
+
+ if (xmlrec_buf)
+ xmlFree(xmlrec_buf);
+
+ xmlDocDumpMemory(doc, &xmlrec_buf, &rec_len);
+ rec_buf = (const char *) xmlrec_buf;
+ }
xmlFreeDoc(doc);
}
if (rec_buf)
YAZ_BIB1_SYSTEM_ERROR_IN_PRESENTING_RECORDS,
rec_type_str);
}
+ if (xmlrec_buf)
+ xmlFree(xmlrec_buf);
}
else
{
}
int error = 0;
- char *addinfo_s = 0;
+ char *addinfo = 0;
std::string db(sr->databaseNames[0]);
- BackendPtr b = get_backend_from_databases(db, &error, &addinfo_s, odr);
+ BackendPtr b = get_backend_from_databases(db, &error, &addinfo, odr);
if (error)
{
apdu_res =
- odr.create_searchResponse(
- apdu_req, error, addinfo_s);
+ odr.create_searchResponse(apdu_req, error, addinfo);
package.response() = apdu_res;
return;
}
- const char *addinfo_c = 0;
b->set_option("setname", "default");
Odr_int hits = 0;
if (cn_error)
{
// hopefully we are getting a ptr to a index+relation+term node
- addinfo_c = 0;
+ addinfo = 0;
if (cn_error->which == CQL_NODE_ST)
- addinfo_c = cn_error->u.st.index;
+ addinfo = cn_error->u.st.index;
apdu_res =
odr.create_searchResponse(apdu_req,
YAZ_BIB1_UNSUPP_USE_ATTRIBUTE,
- addinfo_c);
+ addinfo);
package.response() = apdu_res;
return;
}
if (status == 0)
{
yaz_log(YLOG_LOG, "search CQL: %s", wrbuf_cstr(wrb));
- b->search_cql(wrbuf_cstr(wrb), &hits, &error, &addinfo_c);
+ b->search_cql(wrbuf_cstr(wrb), &hits, &error, &addinfo, odr);
}
wrbuf_destroy(wrb);
else
{
yaz_log(YLOG_LOG, "search PQF: %s", wrbuf_cstr(pqf_wrbuf));
- b->search_pqf(wrbuf_cstr(pqf_wrbuf), &hits, &error, &addinfo_c);
+ b->search_pqf(wrbuf_cstr(pqf_wrbuf), &hits, &error, &addinfo, odr);
wrbuf_destroy(pqf_wrbuf);
}
Odr_int number_of_records_returned = 0;
Z_Records *records = get_records(
- 0, number_to_present, &error, &addinfo_c,
+ 0, number_to_present, &error, &addinfo,
&number_of_records_returned, odr, b, sr->preferredRecordSyntax,
element_set_name);
- apdu_res = odr.create_searchResponse(apdu_req, error, addinfo_c);
+ apdu_res = odr.create_searchResponse(apdu_req, error, addinfo);
if (records)
{
apdu_res->u.searchResponse->records = records;
element_set_name = comp->u.simple->u.generic;
Odr_int number_of_records_returned = 0;
int error = 0;
- const char *addinfo = 0;
+ char *addinfo = 0;
Z_Records *records = get_records(
*pr->resultSetStartPoint - 1, *pr->numberOfRecordsRequested,
&error, &addinfo, &number_of_records_returned, odr, m_backend,