xref: /lighttpd1.4/src/sock_addr_cache.c (revision af3df29a)
1655453a1SGlenn Strauss #include "first.h"
2655453a1SGlenn Strauss 
3655453a1SGlenn Strauss #include "sock_addr_cache.h"
4655453a1SGlenn Strauss 
5655453a1SGlenn Strauss #include "sys-socket.h"
6655453a1SGlenn Strauss #include <string.h>
7655453a1SGlenn Strauss 
8655453a1SGlenn Strauss #include "buffer.h"
9655453a1SGlenn Strauss #include "sock_addr.h"
10655453a1SGlenn Strauss 
11655453a1SGlenn Strauss 
sock_addr_cache_inet_ntop_copy_buffer(buffer * const restrict b,const sock_addr * const restrict saddr)12655453a1SGlenn Strauss int sock_addr_cache_inet_ntop_copy_buffer(buffer * const restrict b, const sock_addr * const restrict saddr)
13655453a1SGlenn Strauss {
14655453a1SGlenn Strauss   #define NTOP_CACHE_MAX 4
15655453a1SGlenn Strauss     static int ndx4;
16655453a1SGlenn Strauss     static struct { struct in_addr  ipv4;       } ntop4_cache[NTOP_CACHE_MAX];
17655453a1SGlenn Strauss     static struct { char s[INET_ADDRSTRLEN+1];  } ntop4_strs[NTOP_CACHE_MAX];
18655453a1SGlenn Strauss   #ifdef HAVE_IPV6
19655453a1SGlenn Strauss     static int ndx6;
20655453a1SGlenn Strauss     static struct { struct in6_addr ipv6;       } ntop6_cache[NTOP_CACHE_MAX];
21655453a1SGlenn Strauss     static struct { char s[INET6_ADDRSTRLEN+1]; } ntop6_strs[NTOP_CACHE_MAX];
22655453a1SGlenn Strauss   #endif
23655453a1SGlenn Strauss     switch (saddr->plain.sa_family) {
24655453a1SGlenn Strauss       case AF_INET:
25655453a1SGlenn Strauss         for (int i = 0; i < NTOP_CACHE_MAX; ++i) {
26655453a1SGlenn Strauss             if (ntop4_cache[i].ipv4.s_addr == saddr->ipv4.sin_addr.s_addr) {
27655453a1SGlenn Strauss                 buffer_copy_string(b, ntop4_strs[i].s);
28655453a1SGlenn Strauss                 return 0;
29655453a1SGlenn Strauss             }
30655453a1SGlenn Strauss         }
31655453a1SGlenn Strauss         break;
32655453a1SGlenn Strauss      #ifdef HAVE_IPV6
33655453a1SGlenn Strauss       case AF_INET6:
34655453a1SGlenn Strauss         for (int i = 0; i < NTOP_CACHE_MAX; ++i) {
35655453a1SGlenn Strauss             if (0 == memcmp(ntop6_cache[i].ipv6.s6_addr,
36655453a1SGlenn Strauss                             saddr->ipv6.sin6_addr.s6_addr, 16)) {
37655453a1SGlenn Strauss                 buffer_copy_string(b, ntop6_strs[i].s);
38655453a1SGlenn Strauss                 return 0;
39655453a1SGlenn Strauss             }
40655453a1SGlenn Strauss         }
41655453a1SGlenn Strauss         break;
42655453a1SGlenn Strauss      #endif
43655453a1SGlenn Strauss       default:
44655453a1SGlenn Strauss         break;
45655453a1SGlenn Strauss     }
46655453a1SGlenn Strauss 
47655453a1SGlenn Strauss     if (0 != sock_addr_inet_ntop_copy_buffer(b, saddr)) {
48*af3df29aSGlenn Strauss         buffer_blank(b);
49655453a1SGlenn Strauss         return -1;
50655453a1SGlenn Strauss     }
51655453a1SGlenn Strauss 
52655453a1SGlenn Strauss     switch (saddr->plain.sa_family) {
53655453a1SGlenn Strauss       case AF_INET:
54655453a1SGlenn Strauss         ntop4_cache[ndx4].ipv4.s_addr = saddr->ipv4.sin_addr.s_addr;
55*af3df29aSGlenn Strauss         memcpy(ntop4_strs+ndx4, b->ptr, buffer_clen(b)+1);
56655453a1SGlenn Strauss         if (++ndx4 == NTOP_CACHE_MAX) ndx4 = 0;
57655453a1SGlenn Strauss         break;
58655453a1SGlenn Strauss      #ifdef HAVE_IPV6
59655453a1SGlenn Strauss       case AF_INET6:
60655453a1SGlenn Strauss         memcpy(ntop6_cache[ndx6].ipv6.s6_addr,saddr->ipv6.sin6_addr.s6_addr,16);
61*af3df29aSGlenn Strauss         memcpy(ntop6_strs+ndx6, b->ptr, buffer_clen(b)+1);
62655453a1SGlenn Strauss         if (++ndx6 == NTOP_CACHE_MAX) ndx6 = 0;
63655453a1SGlenn Strauss         break;
64655453a1SGlenn Strauss      #endif
65655453a1SGlenn Strauss       default:
66655453a1SGlenn Strauss         break;
67655453a1SGlenn Strauss     }
68655453a1SGlenn Strauss     return 0;
69655453a1SGlenn Strauss }
70