]> asedeno.scripts.mit.edu Git - PuTTY.git/blob - be_misc.c
Log the setup of proxied network connections.
[PuTTY.git] / be_misc.c
1 /*
2  * be_misc.c: helper functions shared between main network backends.
3  */
4
5 #include "putty.h"
6 #include "network.h"
7
8 void backend_socket_log(void *frontend, int type, SockAddr addr, int port,
9                         const char *error_msg, int error_code)
10 {
11     char addrbuf[256], *msg;
12
13     switch (type) {
14       case 0:
15         sk_getaddr(addr, addrbuf, lenof(addrbuf));
16         if (sk_addr_needs_port(addr)) {
17             msg = dupprintf("Connecting to %s port %d", addrbuf, port);
18         } else {
19             msg = dupprintf("Connecting to %s", addrbuf);
20         }
21         break;
22       case 1:
23         sk_getaddr(addr, addrbuf, lenof(addrbuf));
24         msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
25         break;
26       case 2:
27         /* Proxy-related log messages have their own identifying
28          * prefix already, put on by our caller. */
29         msg = dupstr(error_msg);
30         break;
31       default:
32         msg = NULL;  /* shouldn't happen, but placate optimiser */
33         break;
34     }
35
36     if (msg) {
37         logevent(frontend, msg);
38         sfree(msg);
39     }
40 }
41