X-Git-Url: https://git.exim.org/exim.git/blobdiff_plain/7c41bb87ff1d49572cb18d4f9a1eb109b9ea0a85..1d28cc061677bd07d9bed48dd84bd5c590247043:/src/src/spf.h diff --git a/src/src/spf.h b/src/src/spf.h index 4338fd8e6..76c7522bd 100644 --- a/src/src/spf.h +++ b/src/src/spf.h @@ -1,45 +1,39 @@ -/* $Cambridge: exim/src/src/spf.h,v 1.5 2005/06/24 08:36:48 tom Exp $ */ - /************************************************* * Exim - an Internet mail transport agent * *************************************************/ /* Experimental SPF support. + Copyright (c) The Exim Maintainers 2016 - 2022 Copyright (c) Tom Kistner 2004 - License: GPL */ + License: GPL + SPDX-License-Identifier: GPL-2.0-or-later +*/ -#ifdef EXPERIMENTAL_SPF +#ifdef SUPPORT_SPF /* Yes, we do have ns_type. spf.h redefines it if we don't set this. Doh */ -#define HAVE_NS_TYPE +#if !defined(HAVE_NS_TYPE) && defined(NS_INADDRSZ) +# define HAVE_NS_TYPE +#endif #include - #include #include - typedef struct spf_result_id { uschar *name; int value; } spf_result_id; -/* must be kept in numeric order */ -static spf_result_id spf_result_id_list[] = { - { US"invalid", 0}, - { US"neutral", 1 }, - { US"pass", 2 }, - { US"fail", 3 }, - { US"softfail", 4 }, - { US"none", 5 }, - { US"err_temp", 6 }, - { US"err_perm", 7 } -}; - -static int spf_result_id_list_size = sizeof(spf_result_id_list)/sizeof(spf_result_id); - /* prototypes */ -int spf_init(uschar *,uschar *); -int spf_process(uschar **, uschar *); +gstring * spf_lib_version_report(gstring *); +BOOL spf_init(void); +BOOL spf_conn_init(uschar *, uschar *); +int spf_process(const uschar **, uschar *, int); +void spf_response_debug(SPF_response_t *); + +#define SPF_PROCESS_NORMAL 0 +#define SPF_PROCESS_GUESS 1 +#define SPF_PROCESS_FALLBACK 2 #endif