network_address.c 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. /* libanode: the Anode C reference implementation
  2. * Copyright (C) 2009-2010 Adam Ierymenko <[email protected]>
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation, either version 3 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program. If not, see <http://www.gnu.org/licenses/>. */
  16. #include <netinet/in.h>
  17. #include <arpa/inet.h>
  18. #include "impl/misc.h"
  19. #include "impl/types.h"
  20. #include "anode.h"
  21. const AnodeNetworkAddress AnodeNetworkAddress_ANY4 = {
  22. ANODE_NETWORK_ADDRESS_IPV4,
  23. { 0,0,0,0, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }
  24. };
  25. const AnodeNetworkAddress AnodeNetworkAddress_ANY6 = {
  26. ANODE_NETWORK_ADDRESS_IPV6,
  27. { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }
  28. };
  29. const AnodeNetworkAddress AnodeNetworkAddress_LOCAL4 = {
  30. ANODE_NETWORK_ADDRESS_IPV4,
  31. { 127,0,0,1, 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }
  32. };
  33. const AnodeNetworkAddress AnodeNetworkAddress_LOCAL6 = {
  34. ANODE_NETWORK_ADDRESS_IPV6,
  35. { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1 ,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 }
  36. };
  37. int AnodeNetworkAddress_to_string(const AnodeNetworkAddress *address,char *buf,int len)
  38. {
  39. const char *s;
  40. switch(address->type) {
  41. case ANODE_NETWORK_ADDRESS_IPV4:
  42. s = inet_ntop(AF_INET,(const void *)address->bits,buf,len);
  43. if (s)
  44. return Anode_strlen(s);
  45. else return ANODE_ERR_INVALID_ARGUMENT;
  46. break;
  47. case ANODE_NETWORK_ADDRESS_IPV6:
  48. s = inet_ntop(AF_INET6,address->bits,buf,len);
  49. if (s)
  50. return Anode_strlen(s);
  51. else return ANODE_ERR_INVALID_ARGUMENT;
  52. /*
  53. case ANODE_NETWORK_ADDRESS_ETHERNET:
  54. break;
  55. case ANODE_NETWORK_ADDRESS_USB:
  56. break;
  57. case ANODE_NETWORK_ADDRESS_BLUETOOTH:
  58. break;
  59. case ANODE_NETWORK_ADDRESS_IPC:
  60. break;
  61. case ANODE_NETWORK_ADDRESS_80211S:
  62. break;
  63. case ANODE_NETWORK_ADDRESS_SERIAL:
  64. break;
  65. */
  66. case ANODE_NETWORK_ADDRESS_ANODE_256_40:
  67. return AnodeAddress_to_string((const AnodeAddress *)address->bits,buf,len);
  68. default:
  69. return ANODE_ERR_ADDRESS_TYPE_NOT_SUPPORTED;
  70. }
  71. }
  72. int AnodeNetworkAddress_from_string(const char *str,AnodeNetworkAddress *address)
  73. {
  74. unsigned int dots = Anode_count_char(str,'.');
  75. unsigned int colons = Anode_count_char(str,':');
  76. if ((dots == 3)&&(!colons)) {
  77. address->type = ANODE_NETWORK_ADDRESS_IPV4;
  78. if (inet_pton(AF_INET,str,address->bits) > 0)
  79. return 0;
  80. else return ANODE_ERR_INVALID_ARGUMENT;
  81. } else if ((colons)&&(!dots)) {
  82. address->type = ANODE_NETWORK_ADDRESS_IPV6;
  83. if (inet_pton(AF_INET6,str,address->bits) > 0)
  84. return 0;
  85. else return ANODE_ERR_INVALID_ARGUMENT;
  86. } else {
  87. address->type = ANODE_NETWORK_ADDRESS_ANODE_256_40;
  88. return AnodeAddress_from_string(str,(AnodeAddress *)address->bits);
  89. }
  90. }
  91. int AnodeNetworkEndpoint_from_sockaddr(const void *sockaddr,AnodeNetworkEndpoint *endpoint)
  92. {
  93. switch(((struct sockaddr_storage *)sockaddr)->ss_family) {
  94. case AF_INET:
  95. *((uint32_t *)endpoint->address.bits) = (uint32_t)(((struct sockaddr_in *)sockaddr)->sin_addr.s_addr);
  96. endpoint->port = (int)ntohs(((struct sockaddr_in *)sockaddr)->sin_port);
  97. return 0;
  98. case AF_INET6:
  99. Anode_memcpy(endpoint->address.bits,((struct sockaddr_in6 *)sockaddr)->sin6_addr.s6_addr,16);
  100. endpoint->port = (int)ntohs(((struct sockaddr_in6 *)sockaddr)->sin6_port);
  101. return 0;
  102. default:
  103. return ANODE_ERR_INVALID_ARGUMENT;
  104. }
  105. }
  106. int AnodeNetworkEndpoint_to_sockaddr(const AnodeNetworkEndpoint *endpoint,void *sockaddr,int sockaddr_len)
  107. {
  108. switch(endpoint->address.type) {
  109. case ANODE_NETWORK_ADDRESS_IPV4:
  110. if (sockaddr_len < (int)sizeof(struct sockaddr_in))
  111. return ANODE_ERR_BUFFER_TOO_SMALL;
  112. Anode_zero(sockaddr,sizeof(struct sockaddr_in));
  113. ((struct sockaddr_in *)sockaddr)->sin_family = AF_INET;
  114. ((struct sockaddr_in *)sockaddr)->sin_port = htons((uint16_t)endpoint->port);
  115. ((struct sockaddr_in *)sockaddr)->sin_addr.s_addr = *((uint32_t *)endpoint->address.bits);
  116. return 0;
  117. case ANODE_NETWORK_ADDRESS_IPV6:
  118. if (sockaddr_len < (int)sizeof(struct sockaddr_in6))
  119. return ANODE_ERR_BUFFER_TOO_SMALL;
  120. Anode_zero(sockaddr,sizeof(struct sockaddr_in6));
  121. ((struct sockaddr_in6 *)sockaddr)->sin6_family = AF_INET6;
  122. ((struct sockaddr_in6 *)sockaddr)->sin6_port = htons((uint16_t)endpoint->port);
  123. Anode_memcpy(((struct sockaddr_in6 *)sockaddr)->sin6_addr.s6_addr,endpoint->address.bits,16);
  124. return 0;
  125. default:
  126. return ANODE_ERR_INVALID_ARGUMENT;
  127. }
  128. }