-#
-# Copyright (C) 2006 OpenWrt.org
+#
+# Copyright (C) 2006-2009 OpenWrt.org
#
# This is free software, licensed under the GNU General Public License v2.
# See /LICENSE for more information.
#
-# $Id$
include $(TOPDIR)/rules.mk
PKG_NAME:=lighttpd
-PKG_VERSION:=1.4.13
-PKG_RELEASE:=1
+PKG_VERSION:=1.4.22
+PKG_RELEASE:=2
-PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_VERSION)
-PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz
+PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.bz2
PKG_SOURCE_URL:=http://www.lighttpd.net/download/
-PKG_MD5SUM:=d775d6478391b95d841a1018c8db0b95
-PKG_CAT:=zcat
+PKG_MD5SUM:=ed4ca3897eadf419c893b03fee53c982
-PKG_INSTALL_DIR:=$(PKG_BUILD_DIR)/ipkg-install
+PKG_FIXUP:=libtool
include $(INCLUDE_DIR)/package.mk
-define Package/lighttpd
- MENU:=1
+define Package/lighttpd/Default
+ SUBMENU:=Web
SECTION:=net
CATEGORY:=Network
- DEPENDS:=+libopenssl +libpcre +libpthread +libsqlite3 +libxml2
- TITLE:=A flexible and lightweight web server
URL:=http://www.lighttpd.net/
endef
-define Package/lighttpd/conffiles
-/etc/lighttpd.conf
-/etc/default/lighttpd
-/etc/init.d/lighttpd
+define Package/lighttpd
+ $(call Package/lighttpd/Default)
+ MENU:=1
+ DEPENDS:=+libopenssl +libpcre +libpthread
+ TITLE:=A flexible and lightweight web server
+endef
+
+define Package/lighttpd-mod-access
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd
+ TITLE:=Access restrictions module
endef
define Package/lighttpd-mod-accesslog
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=Access logging module
endef
define Package/lighttpd-mod-alias
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=Directory alias module
endef
define Package/lighttpd-mod-auth
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=Authentication module
endef
define Package/lighttpd-mod-cgi
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=CGI module
endef
+define Package/lighttpd-mod-cml
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd
+ TITLE:=Cache Meta Language module
+endef
+
+define Package/lighttpd-mod-compress
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd +zlib
+ TITLE:=Compress output module
+endef
+
define Package/lighttpd-mod-evasive
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=Evasive module
endef
define Package/lighttpd-mod-expire
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=Expire module
endef
+define Package/lighttpd-mod-extforward
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd
+ TITLE:=Extract client IP module
+endef
+
define Package/lighttpd-mod-fastcgi
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=FastCGI module
endef
+define Package/lighttpd-mod-flv-streaming
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd
+ TITLE:=flv streaming module
+endef
+
+define Package/lighttpd-mod-magnet
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd
+ TITLE:=magnet module
+endef
+
+define Package/lighttpd-mod-mysql-vhost
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd +libmysqlclient
+ TITLE:=Mysql virtual hosting module
+endef
+
define Package/lighttpd-mod-proxy
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=Proxy module
endef
define Package/lighttpd-mod-redirect
- $(call Package/lighttpd)
- DEPENDS:=lighttpd
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd +libpcre
TITLE:=URL redirection module
endef
define Package/lighttpd-mod-rewrite
- $(call Package/lighttpd)
- DEPENDS:=lighttpd
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd +libpcre
TITLE:=URL rewriting module
endef
+define Package/lighttpd-mod-rrdtool
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd
+ TITLE:=rrdtool module
+endef
+
+define Package/lighttpd-mod-scgi
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd
+ TITLE:=SCGI module
+endef
+
+define Package/lighttpd-mod-secdownload
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd
+ TITLE:=Secure and fast download module
+endef
+
define Package/lighttpd-mod-setenv
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=Environment variable setting module
endef
define Package/lighttpd-mod-simple-vhost
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=Simple virtual hosting module
endef
define Package/lighttpd-mod-ssi
- $(call Package/lighttpd)
- DEPENDS:=lighttpd
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd +libpcre
TITLE:=SSI module
endef
define Package/lighttpd-mod-status
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=Server status display module
endef
+define Package/lighttpd-mod-trigger-b4-dl
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd +libpcre
+ TITLE:=Trigger before download module
+endef
+
+define Package/lighttpd-mod-userdir
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd
+ TITLE:=User directory module
+endef
+
define Package/lighttpd-mod-usertrack
- $(call Package/lighttpd)
+ $(call Package/lighttpd/Default)
DEPENDS:=lighttpd
TITLE:=User tracking module
endef
define Package/lighttpd-mod-webdav
- $(call Package/lighttpd)
- DEPENDS:=lighttpd
+ $(call Package/lighttpd/Default)
+ DEPENDS:=lighttpd +libsqlite3 +libuuid +libxml2
TITLE:=WebDAV module
endef
+CONFIGURE_ARGS+= \
+ --libdir=/usr/lib/lighttpd \
+ --sysconfdir=/etc/lighttpd \
+ --enable-shared \
+ --enable-static \
+ --disable-rpath \
+ --without-attr \
+ --without-bzip2 \
+ --without-fam \
+ --without-gdbm \
+ --without-ldap \
+ --without-lua \
+ --without-memcache \
+ --without-mysql \
+ --with-openssl="$(STAGING_DIR)/usr" \
+ --with-pcre \
+ --without-valgrind \
+
+CONFIGURE_VARS+= \
+ PCRE_LIB="-lpcre" \
+
+ifneq ($(CONFIG_LARGEFILE),y)
+ CONFIGURE_ARGS+= \
+ --disable-lfs
+endif
+
+ifneq ($(SDK)$(CONFIG_PACKAGE_lighttpd-mod-webdav),)
+ CONFIGURE_ARGS+= \
+ --with-webdav-locks \
+ --with-webdav-props
+ # XXX: needed by sqlite3 to prevent segfaults in mod_webdav.so
+ CONFIGURE_VARS+= \
+ LIBS="-lpthread"
+else
+ CONFIGURE_ARGS+= \
+ --without-webdav-locks \
+ --without-webdav-props
+endif
+
define Build/Configure
- (cd $(PKG_BUILD_DIR); rm -f config.cache; \
- $(TARGET_CONFIGURE_OPTS) \
- CFLAGS="$(TARGET_CFLAGS)" \
- CPPFLAGS="-I$(STAGING_DIR)/usr/include/libxml2 -I$(STAGING_DIR)/usr/include -I$(STAGING_DIR)/include" \
- LDFLAGS="-L$(STAGING_DIR)/usr/lib -L$(STAGING_DIR)/lib" \
- PCRE_LIB="-lpcre" \
- PKG_CONFIG_PATH="$(STAGING_DIR)/usr/lib/pkgconfig" \
- ./configure \
- --target=$(GNU_TARGET_NAME) \
- --host=$(GNU_TARGET_NAME) \
- --build=$(GNU_HOST_NAME) \
- --program-prefix="" \
- --program-suffix="" \
- --prefix=/usr \
- --exec-prefix=/usr \
- --bindir=/usr/bin \
- --datadir=/usr/share \
- --includedir=/usr/include \
- --infodir=/usr/share/info \
- --libdir=/usr/lib/lighttpd \
- --libexecdir=/usr/lib \
- --localstatedir=/var \
- --mandir=/usr/share/man \
- --sbindir=/usr/sbin \
- --sysconfdir=/etc/lighttpd \
- $(DISABLE_LARGEFILE) \
- $(DISABLE_NLS) \
- --enable-shared \
- --enable-static \
- --disable-rpath \
- --without-attr \
- --without-bzip2 \
- --without-fam \
- --without-gdbm \
- --without-ldap \
- --without-lua \
- --without-memcache \
- --without-mysql \
- --with-openssl="$(STAGING_DIR)/usr" \
- --with-pcre \
- --without-valgrind \
- --with-webdav-props \
- );
+$(call Build/Configure/Default)
+ # XXX: override pcre (mis)detection by ./configure when cross-compiling
+ echo "#define HAVE_LIBPCRE 1" >>$(PKG_BUILD_DIR)/config.h
+ echo "#define HAVE_PCRE_H 1" >>$(PKG_BUILD_DIR)/config.h
endef
define Build/Compile
- rm -rf $(PKG_INSTALL_DIR)
- mkdir -p $(PKG_INSTALL_DIR)
- $(MAKE) -C $(PKG_BUILD_DIR) \
- DESTDIR="$(PKG_INSTALL_DIR)" \
- all install
+ $(MAKE) -C $(PKG_BUILD_DIR) DESTDIR="$(PKG_INSTALL_DIR)" all install
+endef
+
+define Package/lighttpd/conffiles
+/etc/lighttpd/lighttpd.conf
+/etc/default/lighttpd
endef
define Package/lighttpd/install
- $(INSTALL_DIR) $(1)/etc
- $(INSTALL_DATA) ./files/lighttpd.conf $(1)/etc/
+ $(INSTALL_DIR) $(1)/etc/lighttpd
+ $(INSTALL_DATA) ./files/lighttpd.conf $(1)/etc/lighttpd/
$(INSTALL_DIR) $(1)/etc/default
$(INSTALL_DATA) ./files/lighttpd.default $(1)/etc/default/lighttpd
$(INSTALL_DIR) $(1)/etc/init.d
$(CP) $(PKG_INSTALL_DIR)/usr/lib/lighttpd/mod_$$$${m}.so $(1)/usr/lib/lighttpd/ ; \
done
$(INSTALL_DIR) $(1)/usr/sbin
- $(CP) $(PKG_INSTALL_DIR)/usr/sbin/lighttpd $(1)/usr/sbin/
+ $(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/sbin/lighttpd $(1)/usr/sbin/
endef
define BuildPlugin
endef
$(eval $(call BuildPackage,lighttpd))
+$(eval $(call BuildPlugin,lighttpd-mod-access,access))
$(eval $(call BuildPlugin,lighttpd-mod-accesslog,accesslog))
$(eval $(call BuildPlugin,lighttpd-mod-alias,alias))
$(eval $(call BuildPlugin,lighttpd-mod-auth,auth))
$(eval $(call BuildPlugin,lighttpd-mod-cgi,cgi))
+$(eval $(call BuildPlugin,lighttpd-mod-cml,cml))
+$(eval $(call BuildPlugin,lighttpd-mod-compress,compress))
$(eval $(call BuildPlugin,lighttpd-mod-evasive,evasive))
$(eval $(call BuildPlugin,lighttpd-mod-expire, expire))
+$(eval $(call BuildPlugin,lighttpd-mod-extforward, extforward))
$(eval $(call BuildPlugin,lighttpd-mod-fastcgi,fastcgi))
+$(eval $(call BuildPlugin,lighttpd-mod-flv-streaming,flv_streaming))
$(eval $(call BuildPlugin,lighttpd-mod-proxy,proxy))
$(eval $(call BuildPlugin,lighttpd-mod-redirect,redirect))
$(eval $(call BuildPlugin,lighttpd-mod-rewrite,rewrite))
+$(eval $(call BuildPlugin,lighttpd-mod-rrdtool,rrdtool))
+$(eval $(call BuildPlugin,lighttpd-mod-scgi,scgi))
+$(eval $(call BuildPlugin,lighttpd-mod-secdownload,secdownload))
$(eval $(call BuildPlugin,lighttpd-mod-setenv,setenv))
$(eval $(call BuildPlugin,lighttpd-mod-simple-vhost,simple_vhost))
$(eval $(call BuildPlugin,lighttpd-mod-ssi,ssi))
$(eval $(call BuildPlugin,lighttpd-mod-status,status))
+$(eval $(call BuildPlugin,lighttpd-mod-trigger-b4-dl,trigger_b4_dl))
+$(eval $(call BuildPlugin,lighttpd-mod-userdir,userdir))
$(eval $(call BuildPlugin,lighttpd-mod-usertrack,usertrack))
$(eval $(call BuildPlugin,lighttpd-mod-webdav,webdav))