PKG_RELEASE:=1
ifeq ($(USELOCAL),1)
- PKG_VERSION:=0.9+svn
+ PKG_VERSION:=0.10+svn
else
PKG_SOURCE_URL:=http://svn.luci.subsignal.org/luci/$(PKG_BRANCH)
ifeq ($(DUMP),)
- PKG_REV:=$(shell LC_ALL=C svn info ${PKG_SOURCE_URL} | sed -ne's/^Last Changed Rev: //p')
- PKG_VERSION:=0.9+svn$(PKG_REV)
+ PKG_REV:=$(shell LC_ALL=C svn info $(CURDIR) | sed -ne's/^Revision: //p')
+ PKG_VERSION:=0.10+svn$(PKG_REV)
endif
PKG_SOURCE_SUBDIR:=$(PKG_NAME)-$(PKG_VERSION)
PKG_SOURCE:=$(PKG_SOURCE_SUBDIR).tar.gz
PKG_SOURCE_VERSION:=$(PKG_REV)
endif
+PKG_BUILD_DEPENDS:=$(if $(STAGING_DIR_ROOT),lua/host)
PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_VERSION)
PKG_INSTALL_DIR:=$(PKG_BUILD_DIR)/ipkg-install
-PKG_BUILD_DEPENDS:=libnotimpl
LUA_TARGET:=source
-PKG_SELECTED_MODULES:=
+LUCI_CFLAGS:=
+LUCI_BUILD_PACKAGES:=
+LUCI_SELECTED_MODULES:=
+
+ifeq ($(BOARD),brcm-2.4)
+ MAKE_FLAGS += CRAP="1"
+endif
include $(INCLUDE_DIR)/package.mk
define Build/Configure
endef
-### Templates ###
-
-define Package/luci/libtemplate
- SECTION:=admin
- CATEGORY:=Administration
- TITLE:=LuCI - Lua Configuration Interface
- URL:=http://luci.freifunk-halle.net/
- MAINTAINER:=Steven Barth <steven-at-midlink-dot-org>
- SUBMENU:=LuCI Libraries
- DEPENDS:=+luci-core
-endef
-
-define Package/luci/fftemplate
- $(call Package/luci/libtemplate)
- SUBMENU:=LuCI Freifunk Support
- DEPENDS:=+luci-mod-freifunk
-endef
-
-define Package/luci/httpdtemplate
- $(call Package/luci/libtemplate)
- SUBMENU:=LuCIttpd
- DEPENDS:=+luci-httpd
-endef
-
-define Package/luci/i18ntemplate
- $(call Package/luci/libtemplate)
- SUBMENU:=LuCI Translations
- DEPENDS:=+luci-web
-endef
-
-define Package/luci/thtemplate
- $(call Package/luci/libtemplate)
- SUBMENU:=LuCI Themes
- DEPENDS:=+luci-web
-endef
-
-define Package/luci/webtemplate
- $(call Package/luci/libtemplate)
- SUBMENU:=LuCI Components
-endef
+MAKE_FLAGS += \
+ MODULES="$(LUCI_SELECTED_MODULES)" \
+ LUA_TARGET="$(LUA_TARGET)" \
+ LUA_SHLIBS="-llua -lm -ldl -lcrypt" \
+ CFLAGS="$(TARGET_CFLAGS) $(LUCI_CFLAGS) -I$(STAGING_DIR)/usr/include" \
+ LDFLAGS="$(TARGET_LDFLAGS) -L$(STAGING_DIR)/usr/lib" \
+ NIXIO_TLS="$(NIXIO_TLS)" OS="Linux"
+### Templates ###
define Package/luci/install/template
$(CP) -a $(PKG_BUILD_DIR)/$(2)/dist/* $(1)/ -R
$(CP) -a $(PKG_BUILD_DIR)/$(2)/ipkg/* $(1)/CONTROL/ 2>/dev/null || true
endef
-
### Core package ###
-
-define Package/luci-core
- $(call Package/luci/libtemplate)
+define Package/luci-lib-core
+ SECTION:=luci
+ CATEGORY:=LuCI
+ TITLE:=LuCI - Lua Configuration Interface
+ URL:=http://luci.subsignal.org/
+ MAINTAINER:=LuCI Development Team <luci@lists.subsignal.org>
+ SUBMENU:=Libraries
DEPENDS:=+lua
TITLE:=LuCI core libraries
endef
-define Package/luci-core/install
+define Package/luci-lib-core/install
$(call Package/luci/install/template,$(1),libs/core)
$(PKG_BUILD_DIR)/build/mkversion.sh $(1)/usr/lib/lua/luci/version.lua \
"OpenWrt Firmware" \
"$(PKG_VERSION)"
endef
-define Package/luci-core/config
+define Package/luci-lib-core/config
choice
prompt "Build Target"
- default PACKAGE_luci-core_source
+ default PACKAGE_luci-lib-core_source
- config PACKAGE_luci-core_compile
+ config PACKAGE_luci-lib-core_compile
bool "Precompiled"
- config PACKAGE_luci-core_stripped
+ config PACKAGE_luci-lib-core_stripped
bool "Stripped"
- config PACKAGE_luci-core_source
+ config PACKAGE_luci-lib-core_source
bool "Full Source"
endchoice
endef
-ifneq ($(CONFIG_PACKAGE_luci-core_compile),)
+ifneq ($(CONFIG_PACKAGE_luci-lib-core_compile),)
LUA_TARGET:=compile
endif
-ifneq ($(CONFIG_PACKAGE_luci-core_stripped),)
+ifneq ($(CONFIG_PACKAGE_luci-lib-core_stripped),)
LUA_TARGET:=strip
endif
+ifneq ($(CONFIG_PACKAGE_luci-lib-core_zipped),)
+ LUA_TARGET:=gzip
+endif
-### Libraries ###
-define Package/luci-cbi
- $(call Package/luci/libtemplate)
- DEPENDS+=+luci-web +luci-uvl +luci-uci
- TITLE:=Configuration Binding Interface
-endef
-
-define Package/luci-cbi/install
- $(call Package/luci/install/template,$(1),libs/cbi)
-endef
-
-
-define Package/luci-uci
- $(call Package/luci/libtemplate)
- DEPENDS+=+libuci-lua
- TITLE:=High-Level UCI API
-endef
-
-define Package/luci-uci/install
- $(call Package/luci/install/template,$(1),libs/uci)
-endef
-
-
-define Package/luci-fastindex
- $(call Package/luci/libtemplate)
- TITLE:=Fastindex indexing module
-endef
-
-define Package/luci-fastindex/install
- $(call Package/luci/install/template,$(1),libs/fastindex)
-endef
-
-
-define Package/luci-http
- $(call Package/luci/libtemplate)
- TITLE:=HTTP Protocol implementation
-endef
-
-define Package/luci-http/install
- $(call Package/luci/install/template,$(1),libs/http)
-endef
+ifneq ($(CONFIG_PACKAGE_luci-lib-core),)
+ LUCI_SELECTED_MODULES+=libs/core
+endif
+LUCI_BUILD_PACKAGES += luci-lib-core
-define Package/luci-ipkg
- $(call Package/luci/libtemplate)
- TITLE:=LuCI IPKG/OPKG call abstraction library
-endef
-define Package/luci-ipkg/install
- $(call Package/luci/install/template,$(1),libs/ipkg)
-endef
+### Libraries ###
+define library
+ define Package/luci-lib-$(1)
+ SECTION:=luci
+ CATEGORY:=LuCI
+ TITLE:=LuCI - Lua Configuration Interface
+ URL:=http://luci.subsignal.org/
+ MAINTAINER:=LuCI Development Team <luci@lists.subsignal.org>
+ SUBMENU:=Libraries
+ TITLE:=$(if $(2),$(2),LuCI $(1) library)
+ $(if $(3),DEPENDS:=+luci-lib-core $(3))
+ endef
+ define Package/luci-lib-$(1)/install
+ $(call Package/luci/install/template,$$(1),libs/$(1))
+ $(call Package/luci-lib-$(1)/extra-install)
+ endef
-define Package/luci-json
- $(call Package/luci/libtemplate)
- TITLE:=LuCI JSON Library
-endef
+ ifneq ($(CONFIG_PACKAGE_luci-lib-$(1)),)
+ LUCI_SELECTED_MODULES+=libs/$(1)
+ endif
-define Package/luci-json/install
- $(call Package/luci/install/template,$(1),libs/json)
+ LUCI_BUILD_PACKAGES += luci-lib-$(1)
endef
-
-define Package/luci-sys
- $(call Package/luci/libtemplate)
- TITLE:=LuCI Linux/POSIX system library
+define Package/luci-lib-lucid/extra-install
+ $(call Package/luci/install/template,$(1),libs/lucid-http)
endef
-define Package/luci-sys/install
- $(call Package/luci/install/template,$(1),libs/sys)
+define Package/luci-lib-web/conffiles
+/etc/config/luci
endef
+define Package/luci-lib-nixio/config
+ choice
+ prompt "TLS Provider"
+ default PACKAGE_luci-lib-nixio_notls
-define Package/luci-web
- $(call Package/luci/libtemplate)
- DEPENDS+=+luci-http +luci-sys +luci-uci +luci-sgi-cgi
- TITLE:=MVC Webframework
- $(call Config,luci.main.lang,string,en,Default Language)
-endef
+ config PACKAGE_luci-lib-nixio_notls
+ bool "Disabled"
-define Package/luci-web/conffiles
-/etc/config/luci
-endef
+ config PACKAGE_luci-lib-nixio_axtls
+ bool "Builtin (axTLS)"
-define Package/luci-web/install
- $(call Package/luci/install/template,$(1),libs/web)
-endef
+ config PACKAGE_luci-lib-nixio_cyassl
+ bool "CyaSSL"
+ select PACKAGE_libcyassl
-
-define Package/luci-uvl
- $(call Package/luci/libtemplate)
- DEPENDS+=+luci-sys +luci-uci +luci-core
- TITLE:=UVL - UCI Validation Layer
+ config PACKAGE_luci-lib-nixio_openssl
+ bool "OpenSSL"
+ select PACKAGE_libopenssl
+ endchoice
endef
-define Package/luci-uvl/install
- $(call Package/luci/install/template,$(1),libs/uvl)
-endef
+NIXIO_TLS:=
+ifneq ($(CONFIG_PACKAGE_luci-lib-nixio_axtls),)
+ NIXIO_TLS:=axtls
+endif
-### HTTPD ###
+ifneq ($(CONFIG_PACKAGE_luci-lib-nixio_openssl),)
+ NIXIO_TLS:=openssl
+endif
-define Package/luci-httpd
- $(call Package/luci/httpdtemplate)
- DEPENDS:=+luci-http +libuci
- TITLE:=Server Core
-endef
+ifneq ($(CONFIG_PACKAGE_luci-lib-nixio_cyassl),)
+ NIXIO_TLS:=cyassl
+ LUCI_CFLAGS+=-I$(STAGING_DIR)/usr/include/cyassl
+endif
-define Package/luci-httpd/install
- $(call Package/luci/install/template,$(1),libs/lucittpd)
-endef
+$(eval $(call library,fastindex,Fastindex indexing module))
+$(eval $(call library,httpclient,HTTP(S) client library,+luci-lib-web +luci-lib-nixio))
+$(eval $(call library,ipkg,LuCI IPKG/OPKG call abstraction library))
+$(eval $(call library,json,LuCI JSON library))
+$(eval $(call library,lmo,LuCI LMO I18N library))
+$(eval $(call library,luanet,LuCI luanet library,+libiw))
+$(eval $(call library,lucid,LuCId Full-Stack Webserver,+luci-lib-nixio +luci-lib-web +luci-lib-px5g))
+$(eval $(call library,nixio,NIXIO POSIX library,+PACKAGE_luci-lib-nixio_openssl:libopenssl +PACKAGE_luci-lib-nixio_cyassl:libcyassl))
+$(eval $(call library,px5g,RSA/X.509 Key Generator (required for LuCId SSL support),+luci-lib-nixio))
+$(eval $(call library,sys,LuCI Linux/POSIX system library,+libiwinfo))
+$(eval $(call library,web,MVC Webframework,+luci-lib-sys +luci-lib-nixio +luci-lib-core +luci-sgi-cgi +luci-lib-lmo))
+$(eval $(call library,uvl,UVL - UCI Validation Layer,+luci-lib-sys +luci-lib-core))
### Community Packages ###
-
-define Package/luci-freifunk-community
- $(call Package/luci/fftemplate)
+define Package/luci-mod-freifunk-community
+ SECTION:=luci
+ CATEGORY:=LuCI
+ TITLE:=LuCI - Lua Configuration Interface
+ URL:=http://luci.subsignal.org/
+ MAINTAINER:=LuCI Development Team <luci@lists.subsignal.org>
+ SUBMENU:=Freifunk
+ TITLE:=Freifunk Community Meta-Package
DEPENDS+= \
- +luci-sgi-cgi +luci-app-splash \
+ +luci-lib-web +luci-app-splash \
+luci-app-ffwizard-leipzig \
- +luci-theme-fledermaus \
+luci-i18n-german \
- +PACKAGE_luci-freifunk-community:olsrd-luci +PACKAGE_luci-freifunk-community:olsrd-luci-mod-dyn-gw-plain \
- +PACKAGE_luci-freifunk-community:olsrd-luci-mod-txtinfo +PACKAGE_luci-freifunk-community:olsrd-luci-mod-nameservice \
- +PACKAGE_luci-freifunk-community:kmod-tun +PACKAGE_luci-freifunk-community:ip \
- +luci-app-olsr
- TITLE:=Freifunk Community Meta-Package
+ +PACKAGE_luci-mod-freifunk-community:olsrd-luci +PACKAGE_luci-mod-freifunk-community:olsrd-luci-mod-dyn-gw-plain \
+ +PACKAGE_luci-mod-freifunk-community:olsrd-luci-mod-txtinfo +PACKAGE_luci-mod-freifunk-community:olsrd-luci-mod-nameservice \
+ +PACKAGE_luci-mod-freifunk-community:olsrd-luci-mod-watchdog +PACKAGE_luci-mod-freifunk-community:kmod-tun \
+ +PACKAGE_luci-mod-freifunk-community:ip +PACKAGE_luci-mod-freifunk-community:freifunk-watchdog +luci-app-olsr
endef
-define Package/luci-freifunk-community/install
+define Package/luci-mod-freifunk-community/install
$(call Package/luci/install/template,$(1),applications/freifunk-community)
endef
-### Modules ###
-
-define Package/luci-admin-core
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-web +luci-cbi +luci-theme-openwrt +luci-i18n-english
- TITLE:=Web UI Core Module
-endef
-
-define Package/luci-admin-core/conffiles
-/etc/config/luci_hosts
-/etc/config/luci_ethers
-endef
-
-define Package/luci-admin-core/install
- $(call Package/luci/install/template,$(1),modules/admin-core)
- touch $(1)/etc/init.d/luci_fixtime || true
-endef
-
-
-define Package/luci-admin-mini
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-core
- TITLE:=LuCI Essentials - stripped down and user-friendly
-endef
-
-define Package/luci-admin-mini/install
- $(call Package/luci/install/template,$(1),modules/admin-mini)
-endef
+ifneq ($(CONFIG_PACKAGE_luci-mod-freifunk-community),)
+ LUCI_SELECTED_MODULES+=applications/freifunk-community
+endif
+LUCI_BUILD_PACKAGES += luci-mod-freifunk-community
-define Package/luci-admin-full
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-core +luci-ipkg
- TITLE:=LuCI Administration - full-featured for full control
-endef
-define Package/luci-admin-full/install
- $(call Package/luci/install/template,$(1),modules/admin-full)
-endef
+### Modules ###
+define module
+ define Package/luci-mod-$(1)
+ SECTION:=luci
+ CATEGORY:=LuCI
+ TITLE:=LuCI - Lua Configuration Interface
+ URL:=http://luci.subsignal.org/
+ MAINTAINER:=LuCI Development Team <luci@lists.subsignal.org>
+ SUBMENU:=Modules
+ TITLE:=$(if $(2),$(2),LuCI $(1) module)
+ $(if $(3),DEPENDS+=$(3))
+ endef
+ define Package/luci-mod-$(1)/install
+ $(call Package/luci/install/template,$$(1),modules/$(1))
+ $(call Package/luci-mod-$(1)/extra-install)
+ endef
-define Package/luci-admin-rpc
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-json
- TITLE:=LuCI RPC - JSON-RPC API
-endef
+ ifneq ($(CONFIG_PACKAGE_luci-mod-$(1)),)
+ LUCI_SELECTED_MODULES+=modules/$(1)
+ endif
-define Package/luci-admin-rpc/install
- $(call Package/luci/install/template,$(1),modules/rpc)
+ LUCI_BUILD_PACKAGES += luci-mod-$(1)
endef
-define Package/luci-mod-freifunk
- $(call Package/luci/fftemplate)
- DEPENDS:=+luci-admin-full +luci-json
- TITLE:=LuCI Freifunk module
+define Package/luci-mod-admin-core/extra-install
+ touch $(1)/etc/init.d/luci_fixtime || true
endef
define Package/luci-mod-freifunk/conffiles
/etc/config/freifunk
endef
-define Package/luci-mod-freifunk/install
- $(call Package/luci/install/template,$(1),modules/freifunk)
-endef
-
+$(eval $(call module,admin-core,Web UI Core module,+luci-lib-web +luci-i18n-english))
+$(eval $(call module,admin-mini,LuCI Essentials - stripped down and user-friendly,+luci-mod-admin-core))
+$(eval $(call module,admin-full,LuCI Administration - full-featured for full control,+luci-mod-admin-core +luci-lib-ipkg))
+$(eval $(call module,rpc,LuCI RPC - JSON-RPC API,+luci-lib-json))
+$(eval $(call module,freifunk,LuCI Freifunk module,+luci-mod-admin-full +luci-lib-json +PACKAGE_luci-mod-freifunk:freifunk-firewall))
+$(eval $(call module,niu,NIU - Next Generation Interface,+luci-mod-admin-core @BROKEN))
### Applications ###
+define application
+ define Package/luci-app-$(1)
+ SECTION:=luci
+ CATEGORY:=LuCI
+ TITLE:=LuCI - Lua Configuration Interface
+ URL:=http://luci.subsignal.org/
+ MAINTAINER:=LuCI Development Team <luci@lists.subsignal.org>
+ SUBMENU:=Applications
+ TITLE:=$(if $(2),$(2),LuCI $(1) application)
+ DEPENDS:=+luci-mod-admin-core $(3)
+ endef
-define Package/luci-app-ffwizard-leipzig
- $(call Package/luci/fftemplate)
- TITLE:=Freifunk Leipzig configuration wizard
-endef
-
-define Package/luci-app-ffwizard-leipzig/install
- $(call Package/luci/install/template,$(1),applications/luci-ffwizard-leipzig)
-endef
-
-
-define Package/luci-app-siitwizard
- $(call Package/luci/fftemplate)
- TITLE:=SIIT IPv4-over-IPv6 configuration wizard
- DEPENDS:=+luci-admin-core +PACKAGE_luci-app-siitwizard:kmod-siit
-endef
-
-define Package/luci-app-siitwizard/install
- $(call Package/luci/install/template,$(1),applications/luci-siitwizard)
-endef
-
-
-define Package/luci-app-firewall
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-core +PACKAGE_luci-app-firewall:firewall
- TITLE:=Firewall and Portforwarding application
-endef
-
-define Package/luci-app-firewall/install
- $(call Package/luci/install/template,$(1),applications/luci-fw)
-endef
-
-
-define Package/luci-app-olsr
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full +PACKAGE_luci-app-olsr:olsrd-luci +PACKAGE_luci-app-olsr:olsrd-luci-mod-txtinfo
- TITLE:=OLSR configuration and status module
-endef
-
-define Package/luci-app-olsr/install
- $(call Package/luci/install/template,$(1),applications/luci-olsr)
-endef
-
-
-define Package/luci-app-qos
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-core +PACKAGE_luci-app-qos:qos-scripts
- TITLE:=Quality of Service configuration module
-endef
-
-define Package/luci-app-qos/install
- $(call Package/luci/install/template,$(1),applications/luci-qos)
-endef
+ define Package/luci-app-$(1)/install
+ $(call Package/luci/install/template,$$(1),applications/luci-$(1))
+ endef
+ ifneq ($(CONFIG_PACKAGE_luci-app-$(1)),)
+ LUCI_SELECTED_MODULES+=applications/luci-$(1)
+ endif
-define Package/luci-app-splash
- $(call Package/luci/fftemplate)
- DEPENDS+=+PACKAGE_luci-app-splash:luasocket
- TITLE:=Freifunk DHCP-Splash application
+ LUCI_BUILD_PACKAGES += luci-app-$(1)
endef
define Package/luci-app-splash/conffiles
/etc/config/luci_splash
endef
-define Package/luci-app-splash/install
- $(call Package/luci/install/template,$(1),applications/luci-splash)
-endef
-
-
-define Package/luci-app-statistics
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full +PACKAGE_luci-app-statistics:collectd \
- +PACKAGE_luci-app-statistics:collectd-mod-rrdtool1 +PACKAGE_luci-app-statistics:rrdtool1
- TITLE:=LuCI Statistics Application
-endef
-
define Package/luci-app-statistics/conffiles
/etc/config/luci_statistics
endef
-define Package/luci-app-statistics/install
- $(call Package/luci/install/template,$(1),applications/luci-statistics)
+define Package/luci-app-diag-devinfo/conffiles
+/etc/config/luci_devinfo
endef
-define Package/luci-app-upnp
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-core +PACKAGE_luci-app-upnp:miniupnpd
- TITLE:=Universal Plug & Play configuration module
-endef
+$(eval $(call application,ffwizard-leipzig,Freifunk Leipzig configuration wizard))
-define Package/luci-app-upnp/install
- $(call Package/luci/install/template,$(1),applications/luci-upnp)
-endef
+$(eval $(call application,siitwizard,SIIT IPv4-over-IPv6 configuration wizard,\
+ +PACKAGE_luci-app-siitwizard:kmod-siit))
+$(eval $(call application,firewall,Firmware and Portforwarding application,\
+ +PACKAGE_luci-app-firewall:firewall))
-define Package/luci-app-ntpc
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-core +PACKAGE_luci-app-ntpc:ntpclient
- TITLE:=NTP time synchronisation client configuration module
-endef
-
-define Package/luci-app-ntpc/install
- $(call Package/luci/install/template,$(1),applications/luci-ntpc)
-endef
+$(eval $(call application,olsr,OLSR configuration and status module,\
+ +luci-mod-admin-full +PACKAGE_luci-app-olsr:olsrd-luci +PACKAGE_luci-app-olsr:olsrd-luci-mod-txtinfo))
+$(eval $(call application,qos,Quality of Service configuration module,\
+ +PACKAGE_luci-app-qos:qos-scripts))
-define Package/luci-app-ddns
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-core +PACKAGE_luci-app-ddns:ddns-scripts
- TITLE:=Dynamic DNS configuration module
-endef
+$(eval $(call application,splash,Freifunk DHCP-Splash application,\
+ +luci-lib-nixio +PACKAGE_luci-app-splash:tc \
+ +PACKAGE_luci-app-splash:kmod-sched +PACKAGE_luci-app-splash:iptables-mod-nat-extra \
+ +PACKAGE_luci-app-splash:iptables-mod-ipopt))
-define Package/luci-app-ddns/install
- $(call Package/luci/install/template,$(1),applications/luci-ddns)
-endef
-
-
-define Package/luci-app-samba
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full +PACKAGE_luci-app-samba:samba3
- TITLE:=Network Shares - Samba SMB/CIFS module
-endef
-
-define Package/luci-app-samba/install
- $(call Package/luci/install/template,$(1),applications/luci-samba)
-endef
-
-
-define Package/luci-app-uvc_streamer
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full +PACKAGE_luci-app-uvc_streamer:uvc-streamer
- TITLE:=Webcam Streaming - UVC-Streamer module
-endef
+$(eval $(call application,statistics,LuCI Statistics Application,\
+ +luci-mod-admin-full +PACKAGE_luci-app-statistics:collectd \
+ +PACKAGE_luci-app-statistics:rrdtool1 \
+ +PACKAGE_luci-app-statistics:collectd-mod-rrdtool \
+ +PACKAGE_luci-app-statistics:collectd-mod-wireless \
+ +PACKAGE_luci-app-statistics:collectd-mod-interface \
+ +PACKAGE_luci-app-statistics:collectd-mod-load))
-define Package/luci-app-uvc_streamer/install
- $(call Package/luci/install/template,$(1),applications/luci-uvc_streamer)
-endef
+$(eval $(call application,diag-core,LuCI Diagnostics Tools (Core)))
-define Package/luci-app-mmc_over_gpio
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full +PACKAGE_luci-app-mmc_over_gpio:kmod-mmc-over-gpio
- TITLE:=mmc_over_gpio
-endef
+$(eval $(call application,diag-devinfo,LuCI Diagnostics Tools (Device Info),\
+ +luci-app-diag-core \
+ +PACKAGE_luci-app-diag-devinfo:smap \
+ +PACKAGE_luci-app-diag-devinfo:netdiscover \
+ +PACKAGE_luci-app-diag-devinfo:mac-to-devinfo \
+ +PACKAGE_luci-app-diag-devinfo:httping \
+ +PACKAGE_luci-app-diag-devinfo:smap-to-devinfo \
+ +PACKAGE_luci-app-diag-devinfo:netdiscover-to-devinfo))
-define Package/luci-app-mmc_over_gpio/install
- $(call Package/luci/install/template,$(1),applications/luci-mmc_over_gpio)
-endef
+$(eval $(call application,voice-core,LuCI Voice Software (Core)))
+$(eval $(call application,voide-diag,LuCI Voice Software (Diagnostics),\
+ +luci-app-voice-core +luci-app-diag-devinfo))
-define Package/luci-app-p910nd
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full +PACKAGE_luci-app-p910nd:p910nd
- TITLE:=p910nd - Printer server module
-endef
-define Package/luci-app-p910nd/install
- $(call Package/luci/install/template,$(1),applications/luci-p910nd)
-endef
+$(eval $(call application,upnp,Universal Plug & Play configuration module,\
+ +PACKAGE_luci-app-upnp:miniupnpd))
+$(eval $(call application,ntpc,NTP time synchronisation configuration module,\
+ +PACKAGE_luci-app-ntpc:ntpclient))
-define Package/luci-app-ushare
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full +PACKAGE_luci-app-ushare:ushare
- TITLE:=ushare - UPnP A/V & DLNA Media Server
-endef
+$(eval $(call application,ddns,Dynamic DNS configuration module,\
+ +PACKAGE_luci-app-ddns:ddns-scripts))
-define Package/luci-app-ushare/install
- $(call Package/luci/install/template,$(1),applications/luci-ushare)
-endef
+$(eval $(call application,samba,Network Shares - Samba SMB/CIFS module,\
+ +luci-mod-admin-full +PACKAGE_luci-app-samba:samba3))
-define Package/luci-app-hd_idle
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full +PACKAGE_luci-app-hd_idle:hd-idle
- TITLE:=hd-idle
-endef
+$(eval $(call application,mmc-over-gpio,MMC-over-GPIO configuration module,\
+ +luci-mod-admin-full +PACKAGE_luci-app-mmc-over-gpio:kmod-mmc-over-gpio))
-define Package/luci-app-hd_idle/install
- $(call Package/luci/install/template,$(1),applications/luci-hd_idle)
-endef
+$(eval $(call application,p910nd,p910nd - Printer server module,\
+ +luci-mod-admin-full +PACKAGE_luci-app-p910nd:p910nd))
-define Package/luci-app-tinyproxy
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full +PACKAGE_luci-app-tinyproxy:tinyproxy
- TITLE:=Tinyproxy - HTTP(S)-Proxy
-endef
+$(eval $(call application,ushare,uShare - UPnP A/V & DLNA Media Server,\
+ +luci-mod-admin-full +PACKAGE_luci-app-ushare:ushare))
-define Package/luci-app-tinyproxy/install
- $(call Package/luci/install/template,$(1),applications/luci-tinyproxy)
-endef
+$(eval $(call application,hd-idle,Hard Disk Idle Spin-Down module,\
+ +luci-mod-admin-full +PACKAGE_luci-app-hd-idle:hd-idle))
-define Package/luci-app-initmgr
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-full
- TITLE:=LuCI Initscript Management
-endef
+$(eval $(call application,tinyproxy,Tinyproxy - HTTP(S)-Proxy configuration,\
+ +luci-mod-admin-full +PACKAGE_luci-app-tinyproxy:tinyproxy))
-define Package/luci-app-initmgr/install
- $(call Package/luci/install/template,$(1),applications/luci-initmgr)
-endef
+$(eval $(call application,initmgr,LuCI Initscript Management,\
+ +luci-mod-admin-full))
-define Package/luci-app-livestats
- $(call Package/luci/webtemplate)
- DEPENDS+=+luci-admin-core +luci-admin-rpc
- TITLE:=LuCI Realtime Statistics
-endef
+$(eval $(call application,livestats,LuCI Realtime Statistics,\
+ +luci-mod-rpc))
-define Package/luci-app-livestats/install
- $(call Package/luci/install/template,$(1),applications/luci-livestats)
-endef
+$(eval $(call application,asterisk,LuCI Support for Asterisk PBX,\
+ @BROKEN +PACKAGE_luci-app-asterisk:asterisk14-xip-core))
-define Package/luci-app-asterisk
- $(call Package/luci/webtemplate)
- TITLE:=LuCI Support for Asterisk PBX
- DEPENDS+=@BROKEN +luci-admin-core +PACKAGE_luci-app-asterisk:asterisk14-xip-core
-endef
+$(eval $(call application,polipo,LuCI Support for the Polipo Proxy,\
+ +PACKAGE_luci-app-polipo:polipo))
-define Package/luci-app-asterisk/install
- $(call Package/luci/install/template,$(1),applications/luci-asterisk)
-endef
+$(eval $(call application,openvpn,LuCI Support for OpenVPN,\
+ +PACKAGE_luci-app-openvpn:openvpn))
-define Package/luci-app-polipo
- $(call Package/luci/webtemplate)
- TITLE:=LuCI Support for the Polipo Proxy
- DEPENDS+=+luci-admin-core +PACKAGE_luci-app-polipo:polipo
-endef
+$(eval $(call application,p2pblock,LuCI Support for the Freifunk P2P-Block addon,\
+ +luci-app-firewall +PACKAGE_luci-app-p2pblock:freifunk-p2pblock))
-define Package/luci-app-polipo/install
- $(call Package/luci/install/template,$(1),applications/luci-polipo)
-endef
+$(eval $(call application,multiwan,LuCI Support for the OpenWrt MultiWAN agent,\
+ +luci-app-firewall +PACKAGE_luci-app-multiwan:multiwan))
-define Package/luci-app-openvpn
- $(call Package/luci/webtemplate)
- TITLE:=LuCI Support for OpenVPN
- DEPENDS+=@BROKEN +luci-admin-core +PACKAGE_luci-app-openvpn:openvpn
-endef
+$(eval $(call application,wol,LuCI Support for Wake-on-LAN,\
+ +PACKAGE_luci-app-wol:etherwake))
-define Package/luci-app-openvpn/install
- $(call Package/luci/install/template,$(1),applications/luci-openvpn)
-endef
+$(eval $(call application,vnstat,LuCI Support for VnStat,\
+ +PACKAGE_luci-app-vnstat:vnstat \
+ +PACKAGE_luci-app-vnstat:vnstati))
### Server Gateway Interfaces ###
+define sgi
+ define Package/luci-sgi-$(1)
+ SECTION:=luci
+ CATEGORY:=LuCI
+ TITLE:=LuCI - Lua Configuration Interface
+ URL:=http://luci.subsignal.org/
+ MAINTAINER:=LuCI Development Team <luci@lists.subsignal.org>
+ SUBMENU:=Server Interfaces
+ TITLE:=$(if $(2),$(2),LuCI $(1) server gateway interface)
+ $(if $(3),DEPENDS:=$(3))
+ endef
-define Package/luci-sgi-cgi
- $(call Package/luci/libtemplate)
- TITLE:=SGI for CGI
-endef
-
-define Package/luci-sgi-cgi/install
- $(call Package/luci/install/template,$(1),libs/sgi-cgi)
-endef
+ define Package/luci-sgi-$(1)/install
+ $(call Package/luci/install/template,$$(1),libs/sgi-$(1))
+ endef
-define Package/luci-sgi-luci
- $(call Package/luci/libtemplate)
- DEPENDS+=+luci-httpd
- TITLE:=SGI for LuCIttpd
-endef
+ ifneq ($(CONFIG_PACKAGE_luci-sgi-$(1)),)
+ LUCI_SELECTED_MODULES+=libs/sgi-$(1)
+ endif
-define Package/luci-sgi-luci/install
- $(call Package/luci/install/template,$(1),libs/sgi-luci)
+ LUCI_BUILD_PACKAGES += luci-sgi-$(1)
endef
-define Package/luci-sgi-webuci
- $(call Package/luci/libtemplate)
- TITLE:=SGI for Webuci
-endef
+$(eval $(call sgi,cgi,CGI Gateway behind existing Webserver))
+$(eval $(call sgi,uhttpd,Binding for the uHTTPd server,+uhttpd +uhttpd-mod-lua))
-define Package/luci-sgi-webuci/install
- $(call Package/luci/install/template,$(1),libs/sgi-webuci)
-endef
### Themes ###
-define Package/luci-theme-base
- $(call Package/luci/thtemplate)
- DEPENDS:=+luci-web
- TITLE:=Common base for all themes
-endef
-
-define Package/luci-theme-base/install
- $(call Package/luci/install/template,$(1),themes/base)
-endef
-
-define Package/luci-theme-fledermaus
- $(call Package/luci/fftemplate)
- DEPENDS:=+luci-web
- TITLE:=Fledermaus Theme
-endef
-
-define Package/luci-theme-fledermaus/install
- $(call Package/luci/install/template,$(1),themes/fledermaus)
-endef
-
-define Package/luci-theme-freifunk
- $(call Package/luci/fftemplate)
- DEPENDS:=+luci-web
- MAINTAINER:=Stefan Pirwitz <stefan-at-freifunk-bno-dot-de>
- TITLE:=alternative Freifunk Theme
-endef
+define theme
+ define Package/luci-theme-$(1)
+ SECTION:=luci
+ CATEGORY:=LuCI
+ TITLE:=LuCI - Lua Configuration Interface
+ URL:=http://luci.subsignal.org/
+ SUBMENU:=Themes
+ TITLE:=$(if $(2),$(2),LuCI $(1) theme)
+ MAINTAINER:=$(if $(3),$(3),LuCI Development Team <luci@lists.subsignal.org>)
+ DEPENDS:=$(ifneq $(1),base,+luci-theme-base) $(4)
+ $(if $(5),DEFAULT:=y if PACKAGE_luci-lib-core)
+ endef
-define Package/luci-theme-freifunk/install
- $(call Package/luci/install/template,$(1),themes/freifunk)
-endef
+ define Package/luci-theme-$(1)/install
+ $(call Package/luci/install/template,$$(1),themes/$(1))
+ endef
-define Package/luci-theme-freifunk-bno
- $(call Package/luci/fftemplate)
- DEPENDS:=+luci-web
- MAINTAINER:=Stefan Pirwitz <stefan-at-freifunk-bno-dot-de>
- TITLE:=Freifunk Berlin Nordost Theme
-endef
+ ifneq ($(CONFIG_PACKAGE_luci-theme-$(1)),)
+ LUCI_SELECTED_MODULES+=themes/$(1)
+ endif
-define Package/luci-theme-freifunk-bno/install
- $(call Package/luci/install/template,$(1),themes/freifunk-bno)
+ LUCI_BUILD_PACKAGES += luci-theme-$(1)
endef
-define Package/luci-theme-openwrt
- $(call Package/luci/thtemplate)
- TITLE:=OpenWrt.org (default)
- DEPENDS:=+luci-theme-base
-endef
+$(eval $(call theme,base,Common base for all themes,,+luci-lib-web))
+$(eval $(call theme,openwrt,OpenWrt.org (default),,,1))
+$(eval $(call theme,openwrt-light,OpenWrt.org - light variant without images))
+$(eval $(call theme,fledermaus,Fledermaus Theme))
-define Package/luci-theme-openwrt/install
- $(call Package/luci/install/template,$(1),themes/openwrt.org)
-endef
+$(eval $(call theme,freifunk,alternative Freifunk Theme,\
+ Stefan Pirwitz <stefan-at-freifunk-bno-dot-de>))
-define Package/luci-theme-openwrtlight
- $(call Package/luci/thtemplate)
- TITLE:=OpenWrt.org - light variant without images
- DEPENDS:=+luci-theme-base
-endef
+$(eval $(call theme,freifunk-bno,Freifunk Berlin Nordost Theme,\
+ Stefan Pirwitz <stefan-at-freifunk-bno-dot-de>))
-define Package/luci-theme-openwrtlight/install
- $(call Package/luci/install/template,$(1),themes/openwrt-light)
-endef
+$(eval $(call theme,freifunk-hannover,Freifunk Hannover Theme,\
+ Mikolas Bingemer <mickey-at-freifunk-hannover-dot-de>))
### Translations ###
-define Package/luci-i18n-german
- $(call Package/luci/i18ntemplate)
- TITLE:=German
-endef
-
-define Package/luci-i18n-german/install
- $(call Package/luci/install/template,$(1),i18n/german)
-endef
-
-
-define Package/luci-i18n-english
- $(call Package/luci/i18ntemplate)
- TITLE:=English
-endef
-
-define Package/luci-i18n-english/install
- $(call Package/luci/install/template,$(1),i18n/english)
-endef
-
+define translation
+ define Package/luci-i18n-$(1)
+ SECTION:=luci
+ CATEGORY:=LuCI
+ TITLE:=LuCI - Lua Configuration Interface
+ URL:=http://luci.subsignal.org/
+ MAINTAINER:=LuCI Development Team <luci@lists.subsignal.org>
+ SUBMENU:=Translations
+ TITLE:=$(if $(2),$(2),$(1))
+ endef
-define Package/luci-i18n-french
- $(call Package/luci/i18ntemplate)
- TITLE:=French (by Florian Fainelli)
-endef
+ define Package/luci-i18n-$(1)/install
+ $(call Package/luci/install/template,$$(1),i18n/$(1))
+ endef
-define Package/luci-i18n-french/install
- $(call Package/luci/install/template,$(1),i18n/french)
-endef
+ ifneq ($(CONFIG_PACKAGE_luci-i18n-$(1)),)
+ LUCI_SELECTED_MODULES+=i18n/$(1)
+ endif
+ LUCI_BUILD_PACKAGES += luci-i18n-$(1)
+endef
+
+$(eval $(call translation,german,German))
+$(eval $(call translation,english,English))
+$(eval $(call translation,french,French (by Florian Fainelli)))
+$(eval $(call translation,italian,Italian (by Matteo Croce)))
+$(eval $(call translation,russian,Russian (by Skryabin Dmitry)))
+$(eval $(call translation,portuguese_brazilian,Portuguese (Brazilian) (by Carlos Cesario)))
+$(eval $(call translation,japanese,Japanese (by Tsukasa Hamano)))
+$(eval $(call translation,greek,Greek (by Vasilis Tsiligiannis)))
+$(eval $(call translation,catalan,Catalan (by Eduard Duran)))
+$(eval $(call translation,portuguese,Portuguese (by Jose Monteiro)))
+$(eval $(call translation,spanish,Spanish (by Guillermo Javier Nardoni)))
+$(eval $(call translation,vietnamese,Vietnamese (by Hong Phuc Dang)))
+$(eval $(call translation,malay,Malay (by Teow Wai Chet)))
+$(eval $(call translation,norwegian,Norwegian (by Lars Hardy)))
+
+
+### Collections ###
+define collection
+ define Package/luci$(if $(1),-$(1))
+ SECTION:=luci
+ CATEGORY:=LuCI
+ TITLE:=LuCI - Lua Configuration Interface
+ URL:=http://luci.subsignal.org/
+ MAINTAINER:=LuCI Development Team <luci@lists.subsignal.org>
+ SUBMENU:=Collections
+ TITLE:=$(if $(2),$(2),LuCI $(if $(1),$(1),general) collection)
+ $(if $(3),DEPENDS:=$(3))
+ endef
-define Package/luci-i18n-italian
- $(call Package/luci/i18ntemplate)
- TITLE:=Italian (by Matteo Croce)
-endef
+ define Package/luci$(if $(1),-$(1))/install
+ true
+ endef
-define Package/luci-i18n-italian/install
- $(call Package/luci/install/template,$(1),i18n/italian)
+ LUCI_BUILD_PACKAGES += luci$(if $(1),-$(1))
endef
+$(eval $(call collection,,\
+ Standard OpenWrt set including full and mini admin and the standard theme,\
+ +uhttpd +luci-mod-admin-full +luci-mod-admin-mini +luci-theme-openwrt \
+ +luci-app-firewall +luci-app-initmgr))
-define Package/luci-i18n-russian
- $(call Package/luci/i18ntemplate)
- TITLE:=Russian (by Skryabin Dmitry)
-endef
-
-define Package/luci-i18n-russian/install
- $(call Package/luci/install/template,$(1),i18n/russian)
-endef
+$(eval $(call collection,ssl,\
+ Standard OpenWrt set with HTTPS support,\
+ +uhttpd +uhttpd-mod-tls +px5g +luci-mod-admin-full +luci-mod-admin-mini \
+ +luci-theme-openwrt +luci-app-firewall +luci-app-initmgr))
+$(eval $(call collection,medium,\
+ Medium package set using only admin full and a theme without graphics,\
+ +uhttpd +luci-mod-admin-full +luci-theme-openwrt-light))
-define Package/luci-i18n-portuguese_brazilian
- $(call Package/luci/i18ntemplate)
- TITLE:=Portuguese (Brazilian) (by Carlos Cesario)
-endef
-
-define Package/luci-i18n-portuguese_brazilian/install
- $(call Package/luci/install/template,$(1),i18n/portuguese_brazilian)
-endef
+$(eval $(call collection,light,\
+ Minimum package set using only admin mini and a theme without graphics,\
+ +uhttpd +luci-mod-admin-mini +luci-theme-openwrt-light))
### Compile ###
-ifneq ($(CONFIG_PACKAGE_luci-core),)
- PKG_SELECTED_MODULES+=libs/core
-endif
-ifneq ($(CONFIG_PACKAGE_luci-cbi),)
- PKG_SELECTED_MODULES+=libs/cbi
-endif
-ifneq ($(CONFIG_PACKAGE_luci-fastindex),)
- PKG_SELECTED_MODULES+=libs/fastindex
-endif
-ifneq ($(CONFIG_PACKAGE_luci-http),)
- PKG_SELECTED_MODULES+=libs/http
-endif
-ifneq ($(CONFIG_PACKAGE_luci-ipkg),)
- PKG_SELECTED_MODULES+=libs/ipkg
-endif
-ifneq ($(CONFIG_PACKAGE_luci-json),)
- PKG_SELECTED_MODULES+=libs/json
-endif
-ifneq ($(CONFIG_PACKAGE_luci-uci),)
- PKG_SELECTED_MODULES+=libs/uci
-endif
-ifneq ($(CONFIG_PACKAGE_luci-sys),)
- PKG_SELECTED_MODULES+=libs/sys
-endif
-ifneq ($(CONFIG_PACKAGE_luci-web),)
- PKG_SELECTED_MODULES+=libs/web
-endif
-ifneq ($(CONFIG_PACKAGE_luci-uvl),)
- PKG_SELECTED_MODULES+=libs/uvl
-endif
-
-ifneq ($(CONFIG_PACKAGE_luci-httpd),)
- PKG_SELECTED_MODULES+=libs/lucittpd
-endif
-
-ifneq ($(CONFIG_PACKAGE_luci-admin-core),)
- PKG_SELECTED_MODULES+=modules/admin-core
-endif
-ifneq ($(CONFIG_PACKAGE_luci-admin-mini),)
- PKG_SELECTED_MODULES+=modules/admin-mini
-endif
-ifneq ($(CONFIG_PACKAGE_luci-admin-full),)
- PKG_SELECTED_MODULES+=modules/admin-full
-endif
-ifneq ($(CONFIG_PACKAGE_luci-admin-rpc),)
- PKG_SELECTED_MODULES+=modules/rpc
-endif
-ifneq ($(CONFIG_PACKAGE_luci-mod-freifunk),)
- PKG_SELECTED_MODULES+=modules/freifunk
-endif
-
-ifneq ($(CONFIG_PACKAGE_luci-freifunk-community),)
- PKG_SELECTED_MODULES+=applications/freifunk-community
-endif
-
-ifneq ($(CONFIG_PACKAGE_luci-app-ffwizard-leipzig),)
- PKG_SELECTED_MODULES+=applications/luci-ffwizard-leipzig
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-siitwizard),)
- PKG_SELECTED_MODULES+=applications/luci-siitwizard
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-firewall),)
- PKG_SELECTED_MODULES+=applications/luci-fw
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-olsr),)
- PKG_SELECTED_MODULES+=applications/luci-olsr
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-qos),)
- PKG_SELECTED_MODULES+=applications/luci-qos
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-splash),)
- PKG_SELECTED_MODULES+=applications/luci-splash
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-statistics),)
- PKG_SELECTED_MODULES+=applications/luci-statistics
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-upnp),)
- PKG_SELECTED_MODULES+=applications/luci-upnp
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-ntpc),)
- PKG_SELECTED_MODULES+=applications/luci-ntpc
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-ddns),)
- PKG_SELECTED_MODULES+=applications/luci-ddns
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-samba),)
- PKG_SELECTED_MODULES+=applications/luci-samba
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-uvc_streamer),)
- PKG_SELECTED_MODULES+=applications/luci-uvc_streamer
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-mmc_over_gpio),)
- PKG_SELECTED_MODULES+=applications/luci-mmc_over_gpio
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-p910nd),)
- PKG_SELECTED_MODULES+=applications/luci-p910nd
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-ushare),)
- PKG_SELECTED_MODULES+=applications/luci-ushare
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-hd_idle),)
- PKG_SELECTED_MODULES+=applications/luci-hd_idle
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-tinyproxy),)
- PKG_SELECTED_MODULES+=applications/luci-tinyproxy
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-initmgr),)
- PKG_SELECTED_MODULES+=applications/luci-initmgr
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-livestats),)
- PKG_SELECTED_MODULES+=applications/luci-livestats
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-asterisk),)
- PKG_SELECTED_MODULES+=applications/luci-asterisk
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-polipo),)
- PKG_SELECTED_MODULES+=applications/luci-polipo
-endif
-ifneq ($(CONFIG_PACKAGE_luci-app-openvpn),)
- PKG_SELECTED_MODULES+=applications/luci-openvpn
-endif
-
-
-ifneq ($(CONFIG_PACKAGE_luci-sgi-cgi),)
- PKG_SELECTED_MODULES+=libs/sgi-cgi
-endif
-ifneq ($(CONFIG_PACKAGE_luci-sgi-luci),)
- PKG_SELECTED_MODULES+=libs/sgi-luci
-endif
-ifneq ($(CONFIG_PACKAGE_luci-sgi-webuci),)
- PKG_SELECTED_MODULES+=libs/sgi-webuci
-endif
-
-ifneq ($(CONFIG_PACKAGE_luci-theme-base),)
- PKG_SELECTED_MODULES+=themes/base
-endif
-ifneq ($(CONFIG_PACKAGE_luci-theme-fledermaus),)
- PKG_SELECTED_MODULES+=themes/fledermaus
-endif
-ifneq ($(CONFIG_PACKAGE_luci-theme-freifunk-bno),)
- PKG_SELECTED_MODULES+=themes/freifunk-bno
-endif
-ifneq ($(CONFIG_PACKAGE_luci-theme-freifunk),)
- PKG_SELECTED_MODULES+=themes/freifunk
-endif
-ifneq ($(CONFIG_PACKAGE_luci-theme-openwrt),)
- PKG_SELECTED_MODULES+=themes/openwrt.org
-endif
-ifneq ($(CONFIG_PACKAGE_luci-theme-openwrtlight),)
- PKG_SELECTED_MODULES+=themes/openwrt-light
-endif
-
-ifneq ($(CONFIG_PACKAGE_luci-i18n-german),)
- PKG_SELECTED_MODULES+=i18n/german
-endif
-ifneq ($(CONFIG_PACKAGE_luci-i18n-english),)
- PKG_SELECTED_MODULES+=i18n/english
-endif
-ifneq ($(CONFIG_PACKAGE_luci-i18n-french),)
- PKG_SELECTED_MODULES+=i18n/french
-endif
-ifneq ($(CONFIG_PACKAGE_luci-i18n-italian),)
- PKG_SELECTED_MODULES+=i18n/italian
-endif
-ifneq ($(CONFIG_PACKAGE_luci-i18n-russian),)
- PKG_SELECTED_MODULES+=i18n/russian
-endif
-ifneq ($(CONFIG_PACKAGE_luci-i18n-portuguese_brazilian),)
- PKG_SELECTED_MODULES+=i18n/portuguese_brazilian
-endif
-
-
-MAKE_FLAGS += \
- MODULES="$(PKG_SELECTED_MODULES)" \
- LUA_TARGET="$(LUA_TARGET)" \
- LUA_SHLIBS="-llua -lm -ldl -lcrypt" \
- CFLAGS="$(TARGET_CFLAGS) -I$(STAGING_DIR)/usr/include" \
- LDFLAGS="$(TARGET_LDFLAGS) -L$(STAGING_DIR)/usr/lib" \
- OS="Linux"
-
-
-$(eval $(call BuildPackage,luci-core))
-$(eval $(call BuildPackage,luci-cbi))
-$(eval $(call BuildPackage,luci-fastindex))
-$(eval $(call BuildPackage,luci-http))
-$(eval $(call BuildPackage,luci-ipkg))
-$(eval $(call BuildPackage,luci-json))
-$(eval $(call BuildPackage,luci-uci))
-$(eval $(call BuildPackage,luci-sys))
-$(eval $(call BuildPackage,luci-web))
-$(eval $(call BuildPackage,luci-uvl))
-
-$(eval $(call BuildPackage,luci-httpd))
-
-$(eval $(call BuildPackage,luci-admin-core))
-$(eval $(call BuildPackage,luci-admin-mini))
-$(eval $(call BuildPackage,luci-admin-full))
-$(eval $(call BuildPackage,luci-admin-rpc))
-$(eval $(call BuildPackage,luci-mod-freifunk))
-
-$(eval $(call BuildPackage,luci-freifunk-community))
-
-$(eval $(call BuildPackage,luci-app-ffwizard-leipzig))
-$(eval $(call BuildPackage,luci-app-siitwizard))
-$(eval $(call BuildPackage,luci-app-firewall))
-$(eval $(call BuildPackage,luci-app-olsr))
-$(eval $(call BuildPackage,luci-app-qos))
-$(eval $(call BuildPackage,luci-app-splash))
-$(eval $(call BuildPackage,luci-app-statistics))
-$(eval $(call BuildPackage,luci-app-upnp))
-$(eval $(call BuildPackage,luci-app-ntpc))
-$(eval $(call BuildPackage,luci-app-ddns))
-$(eval $(call BuildPackage,luci-app-samba))
-$(eval $(call BuildPackage,luci-app-uvc_streamer))
-$(eval $(call BuildPackage,luci-app-mmc_over_gpio))
-$(eval $(call BuildPackage,luci-app-p910nd))
-$(eval $(call BuildPackage,luci-app-ushare))
-$(eval $(call BuildPackage,luci-app-hd_idle))
-$(eval $(call BuildPackage,luci-app-tinyproxy))
-$(eval $(call BuildPackage,luci-app-initmgr))
-$(eval $(call BuildPackage,luci-app-livestats))
-$(eval $(call BuildPackage,luci-app-asterisk))
-$(eval $(call BuildPackage,luci-app-polipo))
-$(eval $(call BuildPackage,luci-app-openvpn))
-
-$(eval $(call BuildPackage,luci-sgi-cgi))
-$(eval $(call BuildPackage,luci-sgi-luci))
-$(eval $(call BuildPackage,luci-sgi-webuci))
-
-$(eval $(call BuildPackage,luci-theme-base))
-$(eval $(call BuildPackage,luci-theme-fledermaus))
-$(eval $(call BuildPackage,luci-theme-freifunk))
-$(eval $(call BuildPackage,luci-theme-freifunk-bno))
-$(eval $(call BuildPackage,luci-theme-openwrt))
-$(eval $(call BuildPackage,luci-theme-openwrtlight))
-
-$(eval $(call BuildPackage,luci-i18n-german))
-$(eval $(call BuildPackage,luci-i18n-english))
-$(eval $(call BuildPackage,luci-i18n-french))
-$(eval $(call BuildPackage,luci-i18n-italian))
-$(eval $(call BuildPackage,luci-i18n-russian))
-$(eval $(call BuildPackage,luci-i18n-portuguese_brazilian))
+PKG_CONFIG_DEPENDS := $(patsubst %,CONFIG_PACKAGE_%,$(LUCI_BUILD_PACKAGES))
+$(foreach b,$(LUCI_BUILD_PACKAGES),$(eval $(call BuildPackage,$(b))))