/lib/libisc/inet_aton.c

https://gitlab.com/envieidoc/Openswan · C · 190 lines · 78 code · 11 blank · 101 comment · 38 complexity · 09fb501d382dc148a8459c78f8881ce4 MD5 · raw file

  1. /*
  2. * Portions Copyright (C) 2004 Internet Systems Consortium, Inc. ("ISC")
  3. * Portions Copyright (C) 1996-2001 Internet Software Consortium.
  4. *
  5. * Permission to use, copy, modify, and distribute this software for any
  6. * purpose with or without fee is hereby granted, provided that the above
  7. * copyright notice and this permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
  10. * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
  11. * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
  12. * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
  13. * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
  14. * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  15. * PERFORMANCE OF THIS SOFTWARE.
  16. */
  17. /*
  18. * Copyright (c) 1983, 1990, 1993
  19. * The Regents of the University of California. All rights reserved.
  20. *
  21. * Redistribution and use in source and binary forms, with or without
  22. * modification, are permitted provided that the following conditions
  23. * are met:
  24. * 1. Redistributions of source code must retain the above copyright
  25. * notice, this list of conditions and the following disclaimer.
  26. * 2. Redistributions in binary form must reproduce the above copyright
  27. * notice, this list of conditions and the following disclaimer in the
  28. * documentation and/or other materials provided with the distribution.
  29. * 3. All advertising materials mentioning features or use of this software
  30. * must display the following acknowledgement:
  31. * This product includes software developed by the University of
  32. * California, Berkeley and its contributors.
  33. * 4. Neither the name of the University nor the names of its contributors
  34. * may be used to endorse or promote products derived from this software
  35. * without specific prior written permission.
  36. *
  37. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  38. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  39. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  40. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  41. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  42. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  43. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  44. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  45. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  46. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  47. * SUCH DAMAGE.
  48. */
  49. /*
  50. * Portions Copyright (c) 1993 by Digital Equipment Corporation.
  51. *
  52. * Permission to use, copy, modify, and distribute this software for any
  53. * purpose with or without fee is hereby granted, provided that the above
  54. * copyright notice and this permission notice appear in all copies, and that
  55. * the name of Digital Equipment Corporation not be used in advertising or
  56. * publicity pertaining to distribution of the document or software without
  57. * specific, written prior permission.
  58. *
  59. * THE SOFTWARE IS PROVIDED "AS IS" AND DIGITAL EQUIPMENT CORP. DISCLAIMS ALL
  60. * WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES
  61. * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL DIGITAL EQUIPMENT
  62. * CORPORATION BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  63. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  64. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
  65. * ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
  66. * SOFTWARE.
  67. */
  68. #include <config.h>
  69. #include <ctype.h>
  70. #include <stddef.h> /* Required for NULL. */
  71. #include <isc/types.h>
  72. #include <isc/net.h>
  73. /*
  74. * Check whether "cp" is a valid ascii representation
  75. * of an Internet address and convert to a binary address.
  76. * Returns 1 if the address is valid, 0 if not.
  77. * This replaces inet_addr, the return value from which
  78. * cannot distinguish between failure and a local broadcast address.
  79. */
  80. int
  81. isc_net_aton(const char *cp, struct in_addr *addr) {
  82. unsigned long val;
  83. int base, n;
  84. unsigned char c;
  85. isc_uint8_t parts[4];
  86. isc_uint8_t *pp = parts;
  87. int digit;
  88. c = *cp;
  89. for (;;) {
  90. /*
  91. * Collect number up to ``.''.
  92. * Values are specified as for C:
  93. * 0x=hex, 0=octal, isdigit=decimal.
  94. */
  95. if (!isdigit(c & 0xff))
  96. return (0);
  97. val = 0; base = 10; digit = 0;
  98. if (c == '0') {
  99. c = *++cp;
  100. if (c == 'x' || c == 'X')
  101. base = 16, c = *++cp;
  102. else {
  103. base = 8;
  104. digit = 1;
  105. }
  106. }
  107. for (;;) {
  108. /*
  109. * isascii() is valid for all integer values, and
  110. * when it is true, c is known to be in scope
  111. * for isdigit(). No cast necessary. Similar
  112. * comment applies for later ctype uses.
  113. */
  114. if (isascii(c) && isdigit(c)) {
  115. if (base == 8 && (c == '8' || c == '9'))
  116. return (0);
  117. val = (val * base) + (c - '0');
  118. c = *++cp;
  119. digit = 1;
  120. } else if (base == 16 && isascii(c) && isxdigit(c)) {
  121. val = (val << 4) |
  122. (c + 10 - (islower(c) ? 'a' : 'A'));
  123. c = *++cp;
  124. digit = 1;
  125. } else
  126. break;
  127. }
  128. if (c == '.') {
  129. /*
  130. * Internet format:
  131. * a.b.c.d
  132. * a.b.c (with c treated as 16 bits)
  133. * a.b (with b treated as 24 bits)
  134. */
  135. if (pp >= parts + 3 || val > 0xff)
  136. return (0);
  137. *pp++ = (isc_uint8_t)val;
  138. c = *++cp;
  139. } else
  140. break;
  141. }
  142. /*
  143. * Check for trailing characters.
  144. */
  145. if (c != '\0' && (!isascii(c) || !isspace(c)))
  146. return (0);
  147. /*
  148. * Did we get a valid digit?
  149. */
  150. if (!digit)
  151. return (0);
  152. /*
  153. * Concoct the address according to
  154. * the number of parts specified.
  155. */
  156. n = pp - parts + 1;
  157. switch (n) {
  158. case 1: /* a -- 32 bits */
  159. break;
  160. case 2: /* a.b -- 8.24 bits */
  161. if (val > 0xffffff)
  162. return (0);
  163. val |= parts[0] << 24;
  164. break;
  165. case 3: /* a.b.c -- 8.8.16 bits */
  166. if (val > 0xffff)
  167. return (0);
  168. val |= (parts[0] << 24) | (parts[1] << 16);
  169. break;
  170. case 4: /* a.b.c.d -- 8.8.8.8 bits */
  171. if (val > 0xff)
  172. return (0);
  173. val |= (parts[0] << 24) | (parts[1] << 16) | (parts[2] << 8);
  174. break;
  175. }
  176. if (addr != NULL)
  177. addr->s_addr = htonl(val);
  178. return (1);
  179. }