AC_HEADER_STDC
+AH_TEMPLATE(HAVE_XATTR, [define to compile support for filesystem extended attributes])
+AC_ARG_WITH(xattr, [ --with-xattr Enable XATTR support])
+HAS_XATTR=""
+if test "$with_xattr" = no; then HAS_XATTR=no; fi
+if test -z "$HAS_XATTR"; then
+ AC_CHECK_LIB(attr, getxattr, [:], [HAS_XATTR=no])
+fi
+if test -z "$HAS_XATTR"; then
+ AC_CHECK_HEADER(attr/xattr.h, [], [HAS_XATTR=no])
+fi
+if test "$HAS_XATTR" != no; then HAS_XATTR=yes; fi
+if test "$with_xattr" = yes -a "$HAS_XATTR" = no; then
+ AC_MSG_ERROR([*** cannot find xattr support on this system])
+fi
+if test "$HAS_XATTR" = yes; then
+ XATTR_LIBS=-lattr
+ AC_DEFINE(HAVE_XATTR)
+fi
+AC_SUBST(XATTR_LIBS)
+
AC_OUTPUT([
Makefile
src/Makefile
LDADD = $(top_srcdir)/lib/libht.a
AM_CPPFLAGS = -I$(top_srcdir)/lib
-sendfile_LDADD = $(LDADD) -lmagic
+sendfile_LDADD = $(LDADD) -lmagic @XATTR_LIBS@
#include <log.h>
#include <resp.h>
+#ifdef HAVE_XATTR
+#include <attr/xattr.h>
+#endif
+
static magic_t cookie = NULL;
static void passdata(int in, int out)
return(strcmp(str + strlen(str) - strlen(end), end));
}
+static char *attrmimetype(char *file)
+{
+#ifdef HAVE_XATTR
+ static char buf[1024];
+ int i;
+ ssize_t sz;
+
+ if((sz = getxattr(file, "user.ash-mime-type", buf, sizeof(buf) - 1)) > 0)
+ goto found;
+ if((sz = getxattr(file, "user.mime-type", buf, sizeof(buf) - 1)) > 0)
+ goto found;
+ if((sz = getxattr(file, "user.mime_type", buf, sizeof(buf) - 1)) > 0)
+ goto found;
+ if((sz = getxattr(file, "user.Content-Type", buf, sizeof(buf) - 1)) > 0)
+ goto found;
+ return(NULL);
+found:
+ for(i = 0; i < sz; i++) {
+ if((buf[sz] < 32) || (buf[sz] >= 128))
+ return(NULL);
+ }
+ buf[sz] = 0;
+ return(buf);
+#else
+ return(NULL);
+#endif
+}
+
static const char *getmimetype(char *file, struct stat *sb)
{
const char *ret;
+ if((ret = attrmimetype(file)) != NULL)
+ return(ret);
if(cookie == NULL) {
cookie = magic_open(MAGIC_MIME_TYPE);
magic_load(cookie, NULL);