123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- /* tld.h --- Declarations for TLD restriction checking.
- Copyright (C) 2004-2024 Simon Josefsson.
- Copyright (C) 2003-2024 Free Software Foundation, Inc.
- Author: Thomas Jacob, Internet24.de
- This file is part of GNU Libidn.
- GNU Libidn is free software: you can redistribute it and/or
- modify it under the terms of either:
- * 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.
- or
- * the GNU General Public License as published by the Free
- Software Foundation; either version 2 of the License, or (at
- your option) any later version.
- or both in parallel, as here.
- GNU Libidn 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
- General Public License for more details.
- You should have received copies of the GNU General Public License and
- the GNU Lesser General Public License along with this program. If
- not, see <https://www.gnu.org/licenses/>. */
- #ifndef TLD_H
- # define TLD_H
- /**
- * SECTION:tld
- * @title: tld.h
- * @short_description: TLD-related functions
- *
- * TLD-related functions.
- */
- # ifndef IDNAPI
- # define IDNAPI
- # endif
- # ifdef __cplusplus
- extern "C"
- {
- # endif
- /* Get size_t. */
- # include <stdlib.h>
- /* Get uint32_t. */
- # include <idn-int.h>
- /* *INDENT-OFF* */
- /* Why INDENT-OFF? See stringprep.h */
- /**
- * Tld_table_element:
- * @start: Start of range.
- * @end: End of range, end == start if single.
- *
- * Interval of valid code points in the TLD.
- */
- struct Tld_table_element
- {
- uint32_t start;
- uint32_t end;
- };
- typedef struct Tld_table_element Tld_table_element;
- /**
- * Tld_table:
- * @name: TLD name, e.g., "no".
- * @version: Version string from TLD file.
- * @nvalid: Number of entries in data.
- * @valid: Sorted array (of size @nvalid) of valid code points.
- *
- * List valid code points in a TLD.
- */
- struct Tld_table
- {
- const char *name;
- const char *version;
- size_t nvalid;
- const Tld_table_element *valid;
- };
- typedef struct Tld_table Tld_table;
- /* *INDENT-ON* */
- /* Error codes. */
- typedef enum
- {
- TLD_SUCCESS = 0,
- TLD_INVALID = 1, /* Invalid character found. */
- TLD_NODATA = 2, /* Char, domain or inlen = 0. */
- TLD_MALLOC_ERROR = 3,
- TLD_ICONV_ERROR = 4,
- TLD_NO_TLD = 5,
- /* Workaround typo in earlier versions. */
- TLD_NOTLD = TLD_NO_TLD
- } Tld_rc;
- extern IDNAPI const char *tld_strerror (Tld_rc rc);
- /* Extract TLD, as ASCII string, of UCS4 domain name into "out". */
- extern IDNAPI int tld_get_4 (const uint32_t * in, size_t inlen, char **out);
- extern IDNAPI int tld_get_4z (const uint32_t * in, char **out);
- extern IDNAPI int tld_get_z (const char *in, char **out);
- /* Return structure corresponding to the named TLD from specified
- * list of TLD tables, or return NULL if no matching TLD can be
- * found. */
- extern IDNAPI const Tld_table *tld_get_table (const char *tld,
- const Tld_table ** tables);
- /* Return structure corresponding to the named TLD, first looking
- * thru overrides then thru built-in list, or return NULL if no
- * matching TLD can be found. */
- extern IDNAPI const Tld_table *tld_default_table (const char *tld,
- const Tld_table **
- overrides);
- /* Check NAMEPREPPED domain name for valid characters as defined by
- * the relevant registering body (plus [a-z0-9.-]). If error is
- * TLD_INVALID, set errpos to position of offending character. */
- extern IDNAPI int tld_check_4t (const uint32_t * in, size_t inlen,
- size_t *errpos, const Tld_table * tld);
- extern IDNAPI int tld_check_4tz (const uint32_t * in, size_t *errpos,
- const Tld_table * tld);
- /* Utility interfaces that uses tld_get_4* to find TLD of string,
- then tld_default_table (with overrides) to find proper TLD table
- for the string, and then hands over to tld_check_4t*. */
- extern IDNAPI int tld_check_4 (const uint32_t * in, size_t inlen,
- size_t *errpos,
- const Tld_table ** overrides);
- extern IDNAPI int tld_check_4z (const uint32_t * in, size_t *errpos,
- const Tld_table ** overrides);
- extern IDNAPI int tld_check_8z (const char *in, size_t *errpos,
- const Tld_table ** overrides);
- extern IDNAPI int tld_check_lz (const char *in, size_t *errpos,
- const Tld_table ** overrides);
- # ifdef __cplusplus
- }
- # endif
- #endif /* TLD_H */
|