35 |
static int sock; |
static int sock; |
36 |
static struct stream in; |
static struct stream in; |
37 |
static struct stream out; |
static struct stream out; |
38 |
extern int tcp_port_rdp; |
int g_tcp_port_rdp = TCP_PORT_RDP; |
39 |
|
|
40 |
/* Initialise TCP transport data packet */ |
/* Initialise TCP transport data packet */ |
41 |
STREAM |
STREAM |
112 |
return NULL; |
return NULL; |
113 |
|
|
114 |
rcvd = recv(sock, s->end, length, 0); |
rcvd = recv(sock, s->end, length, 0); |
115 |
if (rcvd <= 0) |
if (rcvd < 0) |
116 |
{ |
{ |
117 |
error("recv: %s\n", strerror(errno)); |
error("recv: %s\n", strerror(errno)); |
118 |
return NULL; |
return NULL; |
119 |
} |
} |
120 |
|
else if (rcvd == 0) |
121 |
|
{ |
122 |
|
error("Connection closed\n"); |
123 |
|
return NULL; |
124 |
|
} |
125 |
|
|
126 |
s->end += rcvd; |
s->end += rcvd; |
127 |
length -= rcvd; |
length -= rcvd; |
142 |
struct addrinfo hints, *res, *ressave; |
struct addrinfo hints, *res, *ressave; |
143 |
char tcp_port_rdp_s[10]; |
char tcp_port_rdp_s[10]; |
144 |
|
|
145 |
snprintf(tcp_port_rdp_s, 10, "%d", tcp_port_rdp); |
snprintf(tcp_port_rdp_s, 10, "%d", g_tcp_port_rdp); |
146 |
|
|
147 |
memset(&hints, 0, sizeof(struct addrinfo)); |
memset(&hints, 0, sizeof(struct addrinfo)); |
148 |
hints.ai_family = AF_UNSPEC; |
hints.ai_family = AF_UNSPEC; |
152 |
|
|
153 |
if (n < 0) |
if (n < 0) |
154 |
{ |
{ |
155 |
error("getaddrinfo error:: [%s]\n", gai_strerror(n)); |
error("getaddrinfo: %s\n", gai_strerror(n)); |
156 |
return False; |
return False; |
157 |
} |
} |
158 |
|
|
172 |
} |
} |
173 |
freeaddrinfo(ressave); |
freeaddrinfo(ressave); |
174 |
|
|
175 |
|
if (sock == -1) |
176 |
|
{ |
177 |
|
error("%s: unable to connect\n", server); |
178 |
|
return False; |
179 |
|
} |
180 |
|
|
181 |
#else /* no IPv6 support */ |
#else /* no IPv6 support */ |
182 |
|
|
183 |
struct hostent *nslookup; |
struct hostent *nslookup; |
200 |
} |
} |
201 |
|
|
202 |
servaddr.sin_family = AF_INET; |
servaddr.sin_family = AF_INET; |
203 |
servaddr.sin_port = htons(tcp_port_rdp); |
servaddr.sin_port = htons(g_tcp_port_rdp); |
204 |
|
|
205 |
if (connect(sock, (struct sockaddr *) &servaddr, sizeof(struct sockaddr)) < 0) |
if (connect(sock, (struct sockaddr *) &servaddr, sizeof(struct sockaddr)) < 0) |
206 |
{ |
{ |
228 |
{ |
{ |
229 |
close(sock); |
close(sock); |
230 |
} |
} |
231 |
|
|
232 |
|
char * |
233 |
|
tcp_get_address() |
234 |
|
{ |
235 |
|
static char ipaddr[32]; |
236 |
|
struct sockaddr_in sockaddr; |
237 |
|
size_t len = sizeof(sockaddr); |
238 |
|
if (getsockname(sock, (struct sockaddr *) &sockaddr, &len) == 0) |
239 |
|
{ |
240 |
|
unsigned char *ip = (unsigned char *) &sockaddr.sin_addr; |
241 |
|
sprintf(ipaddr, "%d.%d.%d.%d", ip[0], ip[1], ip[2], ip[3]); |
242 |
|
} |
243 |
|
else |
244 |
|
strcpy(ipaddr, "127.0.0.1"); |
245 |
|
return ipaddr; |
246 |
|
} |