# # Copyright (C) 2010 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. # include $(TOPDIR)/rules.mk PKG_NAME:=strongswan PKG_VERSION:=4.3.6 PKG_RELEASE:=1 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.bz2 PKG_SOURCE_URL:=http://download.strongswan.org/ PKG_MD5SUM:=e071f46b6c463ce76900758734e6143e PKG_MOD_AVAILABLE:= \ aes \ agent \ attr \ attr-sql \ blowfish \ curl \ des \ dnskey \ eap-md5 \ eap-mschapv2 \ eap-radius \ fips-prf \ gcrypt \ gmp \ hmac \ kernel-klips \ kernel-netlink \ kernel-pfkey \ ldap \ load-tester \ md5 \ medcli \ medsrv \ mysql \ padlock \ pem \ pgp \ pkcs1 \ pubkey \ random \ resolve \ sha1 \ sha2 \ smp \ sql \ sqlite \ stroke \ uci \ updown \ x509 \ xcbc \ PKG_BUILD_DEPENDS:= \ clearsilver \ fcgi \ PKG_CONFIG_DEPENDS:= \ CONFIG_STRONGSWAN4_ENABLE_CISCO_QUIRKS \ CONFIG_STRONGSWAN4_ENABLE_NAT_TRANSPORT \ CONFIG_STRONGSWAN4_DEVICE_RANDOM \ CONFIG_STRONGSWAN4_DEVICE_URANDOM \ CONFIG_STRONGSWAN4_ROUTING_TABLE \ CONFIG_STRONGSWAN4_ROUTING_TABLE_PRIO \ $(patsubst %,CONFIG_PACKAGE_strongswan4-mod-%,$(PKG_MOD_AVAILABLE)) \ PKG_FIXUP:=libtool PKG_INSTALL:=1 include $(INCLUDE_DIR)/package.mk define Package/strongswan4/Default SECTION:=net CATEGORY:=Network TITLE:=StrongSwan URL:=http://www.strongswan.org/ endef define Package/strongswan4/description/Default StrongSwan is an OpenSource IPsec implementation for the Linux operating system. endef define Package/strongswan4 $(call Package/strongswan4/Default) DEPENDS:= +libpthread +ip \ +kmod-ipsec +kmod-ipsec4 \ +kmod-ipt-ipsec +iptables-mod-ipsec MENU:=1 endef define Package/strongswan4/config source "$(SOURCE)/Config.in" endef define Package/strongswan4/description $(call Package/strongswan4/description/Default) . This package contains shared libraries and scripts. endef define Package/strongswan4-full $(call Package/strongswan4/Default) TITLE+= (full) DEPENDS:= strongswan4 \ +strongswan4-app-charon \ +strongswan4-app-pluto \ +strongswan4-mod-aes \ +strongswan4-mod-agent \ +strongswan4-mod-attr \ +strongswan4-mod-attr-sql \ +strongswan4-mod-blowfish \ +strongswan4-mod-curl \ +strongswan4-mod-des \ +strongswan4-mod-dnskey \ +strongswan4-mod-eap-md5 \ +strongswan4-mod-eap-mschapv2 \ +strongswan4-mod-eap-radius \ +strongswan4-mod-fips-prf \ +strongswan4-mod-gcrypt \ +strongswan4-mod-gmp \ +strongswan4-mod-hmac \ +strongswan4-mod-kernel-klips \ +strongswan4-mod-kernel-netlink \ +strongswan4-mod-kernel-pfkey \ +strongswan4-mod-ldap \ +strongswan4-mod-load-tester \ +strongswan4-mod-md5 \ +strongswan4-mod-medcli \ +strongswan4-mod-medsrv \ +strongswan4-mod-mysql \ +strongswan4-mod-padlock \ +strongswan4-mod-pem \ +strongswan4-mod-pgp \ +strongswan4-mod-pkcs1 \ +strongswan4-mod-pubkey \ +strongswan4-mod-random \ +strongswan4-mod-resolve \ +strongswan4-mod-sha1 \ +strongswan4-mod-sha2 \ +strongswan4-mod-smp \ +strongswan4-mod-sql \ +strongswan4-mod-sqlite \ +strongswan4-mod-stroke \ +strongswan4-mod-uci \ +strongswan4-mod-updown \ +strongswan4-mod-x509 \ +strongswan4-mod-xcbc \ +strongswan4-utils endef define Package/strongswan4-full/description $(call Package/strongswan4/description/Default) . This meta-package contains only dependencies for a complete setup. endef define Package/strongswan4-minimal $(call Package/strongswan4/Default) TITLE+= (minimal) DEPENDS:= strongswan4 \ +strongswan4-app-charon \ +strongswan4-mod-aes \ +strongswan4-mod-gmp \ +strongswan4-mod-hmac \ +strongswan4-mod-pubkey \ +strongswan4-mod-random \ +strongswan4-mod-sha1 \ +strongswan4-mod-stroke \ +strongswan4-mod-updown \ +strongswan4-mod-x509 \ +strongswan4-mod-xcbc endef define Package/strongswan4-minimal/description $(call Package/strongswan4/description/Default) . This meta-package contains only dependencies for a minimal setup. endef define Package/strongswan4-app-charon $(call Package/strongswan4/Default) TITLE+= IKEv2 keying daemon DEPENDS:= strongswan4 endef define Package/strongswan4-app-charon/description $(call Package/strongswan4/description/Default) . This package contains charon, an IKEv2 keying daemon. endef define Package/strongswan4-app-pluto $(call Package/strongswan4/Default) TITLE+= IKEv1 keying daemon DEPENDS:= strongswan4 endef define Package/strongswan4-app-pluto/description $(call Package/strongswan4/description/Default) . This package contains pluto, an IKEv1 keying daemon. endef define Package/strongswan4-utils $(call Package/strongswan4/Default) TITLE+= utilities DEPENDS:= strongswan4 endef define Package/strongswan4-utils/description $(call Package/strongswan4/description/Default) . This package contains the openac, pki & scepclient utilities. endef # 1. Name # 2. Title # 3. Depends define BuildPlugin define Package/strongswan4-mod-$(1) $$(call Package/strongswan4/Default) TITLE:= StronSwan $(2) plugin DEPENDS:= strongswan4 $(3) endef define Package/strongswan4-mod-$(1)/install $(INSTALL_DIR) $$(1)/usr/lib/ipsec/plugins $(CP) \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/plugins/libstrongswan-$(1).so \ $$(1)/usr/lib/ipsec/plugins/ ; $(call Plugin/$(1)/install,$$(1)) endef $$(eval $$(call BuildPackage,strongswan4-mod-$(1))) endef CONFIGURE_ARGS+= \ $(if $(CONFIG_STRONGSWAN4_ENABLE_CISCO_QUIRKS),--enable-cisco-quirks,--disable-cisco-quirks) \ $(if $(CONFIG_STRONGSWAN4_ENABLE_NAT_TRANSPORT),--enable-nat-transport,--disable-nat-transport) \ --disable-scripts \ --disable-static \ $(if $(CONFIG_PACKAGE_strongswan4-utils),--enable-tools,--disable-tools) \ --with-random-device="$(call qstrip,$(CONFIG_STRONGSWAN4_DEVICE_RANDOM))" \ --with-urandom-device="$(call qstrip,$(CONFIG_STRONGSWAN4_DEVICE_RANDOM))" \ --with-routing-table="$(call qstrip,$(CONFIG_STRONGSWAN4_ROUTING_TABLE))" \ --with-routing-table-prio="$(call qstrip,$(CONFIG_STRONGSWAN4_ROUTING_TABLE_PRIO))" \ $(foreach m,$(PKG_MOD_AVAILABLE), \ $(if $(CONFIG_PACKAGE_strongswan4-mod-$(m)),--enable-$(m),--disable-$(m)) \ ) \ EXTRA_CPPFLAGS+= -I$(STAGING_DIR)/usr/include/ClearSilver EXTRA_LDFLAGS+= -Wl,-rpath-link,$(STAGING_DIR)/usr/lib define Package/strongswan4/conffiles /etc/ipsec.conf /etc/ipsec.secrets /etc/strongswan.conf endef define Package/strongswan4/install $(INSTALL_DIR) $(1)/etc $(CP) -R $(PKG_INSTALL_DIR)/etc/ipsec.d $(1)/etc/ $(INSTALL_DIR) $(1)/usr/lib $(CP) $(PKG_INSTALL_DIR)/usr/lib/libstrongswan.so.* $(1)/usr/lib/ $(INSTALL_DIR) $(1)/usr/sbin $(CP) $(PKG_INSTALL_DIR)/usr/sbin/ipsec $(1)/usr/sbin/ $(INSTALL_DIR) $(1)/usr/lib/ipsec $(CP) \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/_copyright \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/starter \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/whack \ $(1)/usr/lib/ipsec/ $(INSTALL_CONF) \ ./files/ipsec.conf \ ./files/ipsec.secrets \ ./files/strongswan.conf \ $(1)/etc/ endef define Package/strongswan4-full/install true endef define Package/strongswan4-minimal/install true endef define Package/strongswan4-app-charon/install $(INSTALL_DIR) $(1)/usr/lib/ipsec $(CP) \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/charon \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/stroke \ $(1)/usr/lib/ipsec/ endef define Package/strongswan4-app-pluto/install $(INSTALL_DIR) $(1)/usr/lib/ipsec $(CP) \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/pluto \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/_pluto_adns \ $(1)/usr/lib/ipsec/ endef define Package/strongswan4-utils/install $(INSTALL_DIR) $(1)/usr/lib/ipsec $(CP) \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/openac \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/pki \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/scepclient \ $(1)/usr/lib/ipsec/ endef define Plugin/attr-sql/install $(INSTALL_DIR) $(1)/usr/lib/ipsec $(CP) \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/pool \ $(1)/usr/lib/ipsec/ endef define Plugin/updown/install $(INSTALL_DIR) $(1)/usr/lib/ipsec $(CP) \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/_updown \ $(PKG_INSTALL_DIR)/usr/lib/ipsec/_updown_espmark \ $(1)/usr/lib/ipsec/ endef $(eval $(call BuildPackage,strongswan4)) $(eval $(call BuildPackage,strongswan4-full)) $(eval $(call BuildPackage,strongswan4-minimal)) $(eval $(call BuildPackage,strongswan4-app-charon)) $(eval $(call BuildPackage,strongswan4-app-pluto)) $(eval $(call BuildPackage,strongswan4-utils)) $(eval $(call BuildPlugin,aes,AES crypto,)) $(eval $(call BuildPlugin,agent,SSH agent signing,)) $(eval $(call BuildPlugin,attr,File-based config attr,)) $(eval $(call BuildPlugin,attr-sql,SQL-based config attrib,+strongswan4-mod-sql)) $(eval $(call BuildPlugin,blowfish,Blowfish crypto,)) $(eval $(call BuildPlugin,curl,cURL,+libcurl)) $(eval $(call BuildPlugin,des,DES crypto,)) $(eval $(call BuildPlugin,dnskey,DNS RR key decoding,)) $(eval $(call BuildPlugin,eap-md5,MD5 EAP (CHAP) auth,)) $(eval $(call BuildPlugin,eap-mschapv2,MS-CHAPv2 EAP auth,)) $(eval $(call BuildPlugin,eap-radius,RADIUS proxy auth,)) $(eval $(call BuildPlugin,fips-prf,FIPS PRF crypto,)) $(eval $(call BuildPlugin,gcrypt,libgcrypt,+libgcrypt)) $(eval $(call BuildPlugin,gmp,libgmp,+libgmp)) $(eval $(call BuildPlugin,hmac,HMAC crypto,)) $(eval $(call BuildPlugin,kernel-klips,KLIPS kernel interface,)) $(eval $(call BuildPlugin,kernel-netlink,netlink kernel interface,)) $(eval $(call BuildPlugin,kernel-pfkey,PK_KEY kernel interface,)) $(eval $(call BuildPlugin,ldap,LDAP,+libopenldap)) $(eval $(call BuildPlugin,load-tester,load testing,)) $(eval $(call BuildPlugin,md5,MD5 crypto,)) $(eval $(call BuildPlugin,medcli,mediation client configuration database,)) $(eval $(call BuildPlugin,medsrv,mediation server configuration database,)) $(eval $(call BuildPlugin,mysql,MySQL database interface,+strongswan4-mod-sql +libmysqlclient)) $(eval $(call BuildPlugin,padlock,VIA PadLock crypto,)) $(eval $(call BuildPlugin,pem,PEM decoding,)) $(eval $(call BuildPlugin,pgp,PGP key decoding,)) $(eval $(call BuildPlugin,pkcs1,PKCS1 key decoding,)) $(eval $(call BuildPlugin,pubkey,raw public key,)) $(eval $(call BuildPlugin,random,RNG,)) $(eval $(call BuildPlugin,resolve,DNS resolver,)) $(eval $(call BuildPlugin,sha1,SHA1 crypto,)) $(eval $(call BuildPlugin,sha2,SHA2 crypto,)) $(eval $(call BuildPlugin,smp,SMP configuration and control interface,+libxml2)) $(eval $(call BuildPlugin,sql,SQL database interface,)) $(eval $(call BuildPlugin,sqlite,SQLite database interface,+strongswan4-mod-sql +libsqlite3)) $(eval $(call BuildPlugin,stroke,Stroke,)) $(eval $(call BuildPlugin,uci,UCI config interface,+libuci)) $(eval $(call BuildPlugin,updown,updown firewall,)) $(eval $(call BuildPlugin,x509,x509 certificate,)) $(eval $(call BuildPlugin,xcbc,xcbc crypto,))