chiark / gitweb /
lib/addr.c, etc.: Return plain addresses from `netaddress_resolve'.
[disorder] / lib / client-common.c
... / ...
CommitLineData
1/*
2 * This file is part of DisOrder
3 * Copyright (C) 2004-7, 2009, 2011-13 Richard Kettlewell
4 *
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18/** @file lib/client-common.c
19 * @brief Common code to client APIs
20 */
21
22#include "common.h"
23
24#if HAVE_NETINET_IN_H
25# include <netinet/in.h>
26#endif
27#if HAVE_SYS_UN_H
28# include <sys/un.h>
29#endif
30#include <errno.h>
31#if HAVE_NETDB_H
32# include <netdb.h>
33#endif
34#if HAVE_UNISTD_H
35# include <unistd.h>
36#endif
37#if HAVE_WS2TCPIP_H
38# include <Ws2tcpip.h>
39#endif
40
41#include "log.h"
42#include "configuration.h"
43#include "client-common.h"
44#include "addr.h"
45#include "mem.h"
46
47/** @brief Figure out what address to connect to
48 * @param c Configuration to honor
49 * @param flags Flags to guide the choice
50 * @param sap Where to store pointer to sockaddr
51 * @param namep Where to store socket name
52 * @return Socket length, or (socklen_t)-1
53 */
54socklen_t disorder_find_server(struct config *c, unsigned flags,
55 struct sockaddr **sap, char **namep) {
56 struct sockaddr *sa;
57#if !_WIN32
58 struct sockaddr_un su;
59#endif
60 struct resolved *res;
61 size_t nres;
62 char *name = NULL;
63 socklen_t len;
64
65 if(c->connect.af != -1) {
66 if(netaddress_resolve(&c->connect, 0, SOCK_STREAM, &res, &nres))
67 return -1;
68 sa = res->sa;
69 len = res->len;
70 } else {
71#if _WIN32
72 disorder_fatal(0, "local connections are not supported on Windows");
73#else
74 /* use the private socket if possible (which it should be) */
75 if (!(flags & DISORDER_FS_NOTPRIV)) {
76 name = config_get_file2(c, "private/socket");
77 if(access(name, R_OK) != 0) {
78 xfree(name);
79 name = NULL;
80 }
81 }
82 if(!name)
83 name = config_get_file2(c, "socket");
84 if(strlen(name) >= sizeof su.sun_path) {
85 disorder_error(0, "socket path is too long");
86 return -1;
87 }
88 memset(&su, 0, sizeof su);
89 su.sun_family = AF_UNIX;
90 strcpy(su.sun_path, name);
91 sa = (struct sockaddr *)&su;
92 len = sizeof su;
93 res = 0;
94 xfree(name);
95#endif
96 }
97 *sap = xmalloc_noptr(len);
98 memcpy(*sap, sa, len);
99 if(namep)
100 *namep = format_sockaddr(sa);
101 if(res)
102 netaddress_free_resolved(res, nres);
103 return len;
104}
105
106/** @brief Figure out what address to connect to
107 * @param c Configuration to honor
108 * @param sap Where to store pointer to sockaddr
109 * @param namep Where to store socket name
110 * @return Socket length, or (socklen_t)-1
111 *
112 * The function disorder_find_server() isn't a namespace violation, and has
113 * more functionality. This function is equivalent, to disorder_find_server()
114 * with a zero @c flags argument.
115 */
116socklen_t find_server(struct config *c,
117 struct sockaddr **sap, char **namep) {
118 return disorder_find_server(c, 0, sap, namep);
119}
120
121const char disorder__body[1];
122const char disorder__list[1];
123const char disorder__integer[1];
124const char disorder__time[1];
125
126/*
127Local Variables:
128c-basic-offset:2
129comment-column:40
130fill-column:79
131indent-tabs-mode:nil
132End:
133*/