dnl Build options for dkim-milter package dnl ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ dnl Any options you set here are applied to all subdirectories of this dnl build. Also, you may override or augment the defaults of any of the dnl values described in devtools/README by setting your preferred values dnl in this file. dnl Debug binary dnl dnl If you are encountering coredumps and want to be able to analyze them dnl using something like "gdb", enable this next line by deleting the "dnl" dnl at the front of it. dnl define(`confOPTIMIZE', `-g') dnl Shared library for libdkim dnl dnl If you want libdkim to be built as a shared object library in addition dnl to a static library, enable this next line by deleting the "dnl" at the dnl front of it. dnl define(`bld_LIBDKIM_SHARED', `true') dnl Faster strtoul()/strtoull() implementations dnl dnl Some vendor implementations of strtoul() and strtoull() are slow. dnl A version has been contributed which optimizes away the slow bits. dnl If you'd like to use it, enable this next line by deleting the "dnl" dnl at the front of it. dnl APPENDDEF(`confENVDEF', `-DNEED_FAST_STRTOUL') dnl libar -- asynchronous resolver library dnl dnl If you want to use the asynchronous resolver library, enable this dnl next line by deleting the "dnl" at the front of it. dnl define(`bld_USE_ARLIB', `true') dnl dnl libar normally uses res_init() or res_ninit() to load the contents dnl of resolv.conf for its use. If neither of these work on your system dnl in multi-threaded programs (e.g. OpenBSD 3.7 and later), then you dnl may need to enable code that parses that file manually. This will dnl also be required if you've got any IPv6 addresses in /etc/resolv.conf. dnl In that case, enable this next line by deleting the "dnl" at the front dnl of it. dnl APPENDDEF(`conf_libar_ENVDEF', `-DAR_RES_MANUAL') dnl POPAUTH -- POP-before-SMTP authentication dnl dnl If you use any POP-before-SMTP authentication, dkim-filter can dnl query that database to see if a client sending a message for signing dnl is legitimate, enable this next line by deleting the "dnl" at the dnl front of it. Also see the section below called "BerkeleyDB". dnl APPENDDEF(`conf_dkim_filter_ENVDEF', `-DPOPAUTH ') dnl QUERY_CACHE -- Query caching dnl dnl If you would like libdkim to maintain a cache of key and policy records dnl it has seen, rather than relying on the DNS server to provide caching, dnl enable this next line by deleting the "dnl" at the front of it. Also dnl see the section below called "BerkeleyDB". dnl APPENDDEF(`confENVDEF', `-DQUERY_CACHE ') dnl BerkeleyDB -- Berkeley DB ("Sleepycat") database dnl dnl Several optional features in this package need the Berkeley DB library. dnl These include: POPAUTH, QUERY_CACHE, _FFR_STATS dnl dnl Sometimes this is built into your libc, but perhaps not, or perhaps dnl you have a newer version that you want to use. If that's the case, dnl edit the following lines as needed and enable the ones that apply dnl by deleting "dnl" from the front of them: dnl APPENDDEF(`confINCDIRS', `-I/usr/local/BerkeleyDB/include ') dnl APPENDDEF(`confLIBDIRS', `-L/usr/local/BerkeleyDB/lib ') dnl APPENDDEF(`confLIBS', `-ldb ') dnl OpenSSL -- cryptography library dnl dnl DKIM requires several algorithms provided by this library. You must dnl have v0.9.8 or later for SHA256 support. If necessary, enable these dnl lines by deleting "dnl" from the front of them and edit paths as needed. dnl APPENDDEF(`confINCDIRS', `-I/usr/local/ssl/include ') dnl APPENDDEF(`confLIBDIRS', `-L/usr/local/ssl/lib ') dnl TRE -- Approximate regular expression matching dnl dnl If you want to use the dkim_diffheaders() function, you also need dnl to have the "tre" library and its header files installed. If necessary, dnl enable these lines by deleting "dnl" from the front of them and edit dnl paths as needed. dnl APPENDDEF(`confINCDIRS', `-I/usr/local/include/tre ') dnl APPENDDEF(`confLIBDIRS', `-L/usr/local/lib/tre ') dnl APPENDDEF(`confLIBS', `-ltre ') dnl Code For Future Release (FFRs): dnl dnl See the FEATURES file for descriptions of the features available dnl as options. Many of these are untested and/or undocumented, so use dnl at your own risk. To enable one, delete "dnl" from the front of its dnl line. dnl dnl APPENDDEF(`confENVDEF', `-D_FFR_ANTICIPATE_SENDMAIL_MUNGE ') dnl APPENDDEF(`confENVDEF', `-D_FFR_CAPTURE_UNKNOWN_ERRORS ') dnl APPENDDEF(`confENVDEF', `-D_FFR_DNS_UPGRADE ') dnl APPENDDEF(`confENVDEF', `-D_FFR_DIFFHEADERS ') dnl APPENDDEF(`confENVDEF', `-D_FFR_PARSE_TIME ') dnl APPENDDEF(`confENVDEF', `-D_FFR_REPLACE_RULES ') dnl APPENDDEF(`confENVDEF', `-D_FFR_REQUIRED_HEADERS ') dnl APPENDDEF(`confENVDEF', `-D_FFR_SELECT_CANONICALIZATION ') dnl APPENDDEF(`confENVDEF', `-D_FFR_SELECTOR_HEADER ') dnl APPENDDEF(`confENVDEF', `-D_FFR_STATS ') dnl APPENDDEF(`confENVDEF', `-D_FFR_VBR ') dnl APPENDDEF(`confENVDEF', `-D_FFR_ZTAGS ') dnl DomainKeys -- Yahoo DomainKeys verification support dnl dnl If you also want to verify messages signed with DomainKeys, enable this dnl line by deleting "dnl" from the front of it. See also the README as it dnl requires an additional library not included in this package. dnl define(`bld_VERIFY_DOMAINKEYS', `true') dnl libmilter -- Sendmail's milter library dnl dnl This must be in the search rules for your compile. If necessary, dnl adjust the paths below and enable the lines by deleting "dnl" from the dnl front of them. dnl APPENDDEF(`bld_dkim_filter_INCDIRS', `-I/usr/local/sendmail/include') dnl APPENDDEF(`bld_dkim_filter_LIBDIRS', `-L/usr/local/sendmail/lib') dnl smfi_addheader() -- older versions of libmilter dnl dnl If you run a version of libmilter too old to have the smfi_insheader() dnl primitive, you can enable this to have dkim-filter use smfi_addheader() dnl instead. It will still work, but it breaks the DKIM specification. dnl To enable this, remove the "dnl" from the front of the line. dnl APPENDDEF(`conf_dkim_filter_ENVDEF', `-DNO_SMFI_INSHEADER ')