/* GNU Mailutils -- a suite of utilities for electronic mail Copyright (C) 2011-2021 Free Software Foundation, Inc. This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library. If not, see . */ #ifdef HAVE_CONFIG_H # include #endif #include #include #include int mu_str_is_ipv4 (const char *addr) { int dot_count = 0; int digit_count = 0; for (; *addr; addr++) { if (!mu_isascii (*addr)) return 0; if (*addr == '.') { if (++dot_count > 3) break; digit_count = 0; } else if (!(mu_isdigit (*addr) && ++digit_count <= 3)) return 0; } return (dot_count == 3); } int mu_str_is_ipv6 (const char *addr) { int col_count = 0; /* Number of colons */ int dcol = 0; /* Did we encounter a double-colon? */ int dig_count = 0; /* Number of digits in the last group */ for (; *addr; addr++) { if (!mu_isascii (*addr)) return 0; else if (mu_isxdigit (*addr)) { if (++dig_count > 4) return 0; } else if (*addr == ':') { if (col_count && dig_count == 0 && ++dcol > 1) return 0; if (++col_count > 7) return 0; dig_count = 0; } else return 0; } return (col_count == 7 || dcol); } int mu_str_is_ipaddr (const char *addr) { if (strchr (addr, '.')) return mu_str_is_ipv4(addr); else if (strchr (addr, ':')) return mu_str_is_ipv6(addr); return 0; }