/* This file is part of Pazpar2.
- Copyright (C) 2006-2013 Index Data
+ Copyright (C) Index Data
Pazpar2 is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
static int log_level = YLOG_LOG;
-void perform_getaddrinfo(struct work *w)
+static void perform_getaddrinfo(struct work *w)
{
struct addrinfo hints, *res;
char host[512], *cp;
- const char *port = 0;
+ char *port = "210";
int error;
hints.ai_flags = 0;
hints.ai_canonname = NULL;
hints.ai_next = NULL;
- strncpy(host, w->hostport, sizeof(host)-1);
+ if (!strncmp(w->hostport, "http://", 7))
+ {
+ port = "80";
+ strncpy(host, w->hostport + 7, sizeof(host)-1);
+ }
+ else if (!strncmp(w->hostport, "https://", 8))
+ {
+ port = "443";
+ strncpy(host, w->hostport + 8, sizeof(host)-1);
+ }
+ else
+ {
+ strncpy(host, w->hostport, sizeof(host)-1);
+ }
host[sizeof(host)-1] = 0;
if ((cp = strrchr(host, ':')))
{
*cp = '\0';
port = cp + 1;
}
- error = getaddrinfo(host, port ? port : "210", &hints, &res);
+ error = getaddrinfo(host, port, &hints, &res);
if (error)
{
yaz_log(YLOG_WARN, "Failed to resolve %s: %s",
}
else
{
+ char n_host[512];
if (getnameinfo((struct sockaddr *) res->ai_addr, res->ai_addrlen,
- host, sizeof(host)-1,
+ n_host, sizeof(n_host)-1,
0, 0,
NI_NUMERICHOST) == 0)
{
- w->ipport = xmalloc(strlen(host) + (port ? strlen(port) : 0) + 2);
- strcpy(w->ipport, host);
+ w->ipport = xmalloc(strlen(n_host) + (port ? strlen(port) : 0) + 2);
+ strcpy(w->ipport, n_host);
if (port)
{
strcat(w->ipport, ":");
int host_getaddrinfo(struct host *host, iochan_man_t iochan_man)
{
struct work *w = xmalloc(sizeof(*w));
- int use_thread = 0; /* =0 to disable threading entirely */
+ int use_thread = 1; /* =0 to disable threading entirely */
w->hostport = host->tproxy ? host->tproxy : host->proxy;
w->ipport = 0;