Blame include/libpsl.h.in

Packit 0af36a
/*
Packit 0af36a
 * Copyright(c) 2014-2018 Tim Ruehsen
Packit 0af36a
 *
Packit 0af36a
 * Permission is hereby granted, free of charge, to any person obtaining a
Packit 0af36a
 * copy of this software and associated documentation files (the "Software"),
Packit 0af36a
 * to deal in the Software without restriction, including without limitation
Packit 0af36a
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
Packit 0af36a
 * and/or sell copies of the Software, and to permit persons to whom the
Packit 0af36a
 * Software is furnished to do so, subject to the following conditions:
Packit 0af36a
 *
Packit 0af36a
 * The above copyright notice and this permission notice shall be included in
Packit 0af36a
 * all copies or substantial portions of the Software.
Packit 0af36a
 *
Packit 0af36a
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Packit 0af36a
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Packit 0af36a
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
Packit 0af36a
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
Packit 0af36a
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
Packit 0af36a
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
Packit 0af36a
 * DEALINGS IN THE SOFTWARE.
Packit 0af36a
 *
Packit 0af36a
 * This file is part of libpsl.
Packit 0af36a
 *
Packit 0af36a
 * Header file for libpsl library routines
Packit 0af36a
 *
Packit 0af36a
 * Changelog
Packit 0af36a
 * 20.03.2014  Tim Ruehsen  created
Packit 0af36a
 *
Packit 0af36a
 */
Packit 0af36a
Packit 0af36a
#ifndef LIBPSL_LIBPSL_H
Packit 0af36a
#define LIBPSL_LIBPSL_H
Packit 0af36a
Packit 0af36a
#include <stdio.h>
Packit 0af36a
#include <time.h>
Packit 0af36a
Packit 0af36a
#define PSL_VERSION "@LIBPSL_VERSION@"
Packit 0af36a
#define PSL_VERSION_MAJOR @LIBPSL_VERSION_MAJOR@
Packit 0af36a
#define PSL_VERSION_MINOR @LIBPSL_VERSION_MINOR@
Packit 0af36a
#define PSL_VERSION_PATCH @LIBPSL_VERSION_PATCH@
Packit 0af36a
#define PSL_VERSION_NUMBER @LIBPSL_VERSION_NUMBER@
Packit 0af36a
Packit 0af36a
#ifndef PSL_API
Packit 0af36a
#if defined BUILDING_PSL && HAVE_VISIBILITY
Packit 0af36a
#  define PSL_API __attribute__ ((__visibility__("default")))
Packit 0af36a
#elif defined BUILDING_PSL && defined _MSC_VER && !defined PSL_STATIC
Packit 0af36a
#  define PSL_API __declspec(dllexport)
Packit 0af36a
#elif defined _MSC_VER && !defined PSL_STATIC
Packit 0af36a
#  define PSL_API __declspec(dllimport)
Packit 0af36a
#else
Packit 0af36a
#  define PSL_API
Packit 0af36a
#endif
Packit 0af36a
#endif
Packit 0af36a
Packit 0af36a
#ifdef  __cplusplus
Packit 0af36a
extern "C" {
Packit 0af36a
#endif
Packit 0af36a
Packit 0af36a
/* types for psl_is_public_suffix2() */
Packit 0af36a
#define PSL_TYPE_ICANN        (1<<0)
Packit 0af36a
#define PSL_TYPE_PRIVATE      (1<<1)
Packit 0af36a
#define PSL_TYPE_NO_STAR_RULE (1<<2)
Packit 0af36a
#define PSL_TYPE_ANY          (PSL_TYPE_ICANN | PSL_TYPE_PRIVATE)
Packit 0af36a
Packit 0af36a
/**
Packit 0af36a
 * psl_error_t:
Packit 0af36a
 * @PSL_SUCCESS: Successful return.
Packit 0af36a
 * @PSL_ERR_INVALID_ARG: Invalid argument.
Packit 0af36a
 * @PSL_ERR_CONVERTER: Failed to open libicu utf-16 converter.
Packit 0af36a
 * @PSL_ERR_TO_UTF16: Failed to convert to utf-16.
Packit 0af36a
 * @PSL_ERR_TO_LOWER: Failed to convert utf-16 to lowercase.
Packit 0af36a
 * @PSL_ERR_TO_UTF8: Failed to convert utf-16 to utf-8.
Packit 0af36a
 * @PSL_ERR_NO_MEM: Failed to allocate memory.
Packit 0af36a
 *
Packit 0af36a
 * Return codes for PSL functions.
Packit 0af36a
 * Negative return codes mean failure.
Packit 0af36a
 * Positive values are reserved for non-error return codes.
Packit 0af36a
 */
Packit 0af36a
typedef enum {
Packit 0af36a
	PSL_SUCCESS = 0,
Packit 0af36a
	PSL_ERR_INVALID_ARG = -1,
Packit 0af36a
	PSL_ERR_CONVERTER = -2, /* failed to open libicu utf-16 converter */
Packit 0af36a
	PSL_ERR_TO_UTF16 = -3,  /* failed to convert to utf-16 */
Packit 0af36a
	PSL_ERR_TO_LOWER = -4,  /* failed to convert utf-16 to lowercase */
Packit 0af36a
	PSL_ERR_TO_UTF8 = -5,   /* failed to convert utf-16 to utf-8 */
Packit 0af36a
	PSL_ERR_NO_MEM = -6    /* failed to allocate memory */
Packit 0af36a
} psl_error_t;
Packit 0af36a
Packit 0af36a
typedef struct _psl_ctx_st psl_ctx_t;
Packit 0af36a
Packit 0af36a
/* frees PSL context */
Packit 0af36a
PSL_API
Packit 0af36a
void
Packit 0af36a
	psl_free(psl_ctx_t *psl);
Packit 0af36a
Packit 0af36a
/* frees memory allocated by libpsl routines */
Packit 0af36a
PSL_API
Packit 0af36a
void
Packit 0af36a
	psl_free_string(char *str);
Packit 0af36a
Packit 0af36a
/* loads PSL data from file */
Packit 0af36a
PSL_API
Packit 0af36a
psl_ctx_t *
Packit 0af36a
	psl_load_file(const char *fname);
Packit 0af36a
Packit 0af36a
/* loads PSL data from FILE pointer */
Packit 0af36a
PSL_API
Packit 0af36a
psl_ctx_t *
Packit 0af36a
	psl_load_fp(FILE *fp);
Packit 0af36a
Packit 0af36a
/* retrieves builtin PSL data */
Packit 0af36a
PSL_API
Packit 0af36a
const psl_ctx_t *
Packit 0af36a
	psl_builtin(void);
Packit 0af36a
Packit 0af36a
/* retrieves most recent PSL data */
Packit 0af36a
PSL_API
Packit 0af36a
psl_ctx_t *
Packit 0af36a
	psl_latest(const char *fname);
Packit 0af36a
Packit 0af36a
/* checks whether domain is a public suffix or not */
Packit 0af36a
PSL_API
Packit 0af36a
int
Packit 0af36a
	psl_is_public_suffix(const psl_ctx_t *psl, const char *domain);
Packit 0af36a
Packit 0af36a
/* checks whether domain is a public suffix regarding the type or not */
Packit 0af36a
PSL_API
Packit 0af36a
int
Packit 0af36a
	psl_is_public_suffix2(const psl_ctx_t *psl, const char *domain, int type);
Packit 0af36a
Packit 0af36a
/* checks whether cookie_domain is acceptable for domain or not */
Packit 0af36a
PSL_API
Packit 0af36a
int
Packit 0af36a
	psl_is_cookie_domain_acceptable(const psl_ctx_t *psl, const char *hostname, const char *cookie_domain);
Packit 0af36a
Packit 0af36a
/* returns the longest not registrable domain within 'domain' or NULL if none found */
Packit 0af36a
PSL_API
Packit 0af36a
const char *
Packit 0af36a
	psl_unregistrable_domain(const psl_ctx_t *psl, const char *domain);
Packit 0af36a
Packit 0af36a
/* returns the shortest possible registrable domain part or NULL if domain is not registrable at all */
Packit 0af36a
PSL_API
Packit 0af36a
const char *
Packit 0af36a
	psl_registrable_domain(const psl_ctx_t *psl, const char *domain);
Packit 0af36a
Packit 0af36a
/* convert a string into lowercase UTF-8 */
Packit 0af36a
PSL_API
Packit 0af36a
psl_error_t
Packit 0af36a
	psl_str_to_utf8lower(const char *str, const char *encoding, const char *locale, char **lower);
Packit 0af36a
Packit 0af36a
/* does not include exceptions */
Packit 0af36a
PSL_API
Packit 0af36a
int
Packit 0af36a
	psl_suffix_count(const psl_ctx_t *psl);
Packit 0af36a
Packit 0af36a
/* just counts exceptions */
Packit 0af36a
PSL_API
Packit 0af36a
int
Packit 0af36a
	psl_suffix_exception_count(const psl_ctx_t *psl);
Packit 0af36a
Packit 0af36a
/* just counts wildcards */
Packit 0af36a
PSL_API
Packit 0af36a
int
Packit 0af36a
	psl_suffix_wildcard_count(const psl_ctx_t *psl);
Packit 0af36a
Packit 0af36a
/* returns mtime of PSL source file */
Packit 0af36a
PSL_API
Packit 0af36a
time_t
Packit 0af36a
	psl_builtin_file_time(void);
Packit 0af36a
Packit 0af36a
/* returns SHA1 checksum (hex-encoded, lowercase) of PSL source file */
Packit 0af36a
PSL_API
Packit 0af36a
const char *
Packit 0af36a
	psl_builtin_sha1sum(void);
Packit 0af36a
Packit 0af36a
/* returns file name of PSL source file */
Packit 0af36a
PSL_API
Packit 0af36a
const char *
Packit 0af36a
	psl_builtin_filename(void);
Packit 0af36a
Packit 0af36a
/* returns name of distribution PSL data file */
Packit 0af36a
PSL_API
Packit 0af36a
const char *
Packit 0af36a
	psl_dist_filename(void);
Packit 0af36a
Packit 0af36a
/* returns library version string */
Packit 0af36a
PSL_API
Packit 0af36a
const char *
Packit 0af36a
	psl_get_version(void);
Packit 0af36a
Packit 0af36a
/* checks library version number */
Packit 0af36a
PSL_API
Packit 0af36a
int
Packit 0af36a
	psl_check_version_number(int version);
Packit 0af36a
Packit 0af36a
/* returns whether the built-in data is outdated or not */
Packit 0af36a
PSL_API
Packit 0af36a
int
Packit 0af36a
	psl_builtin_outdated(void);
Packit 0af36a
Packit 0af36a
#ifdef  __cplusplus
Packit 0af36a
}
Packit 0af36a
#endif
Packit 0af36a
Packit 0af36a
#endif /* LIBPSL_LIBPSL_H */