[OE-core] [PATCH] connman: Simplify and fix packaging of VPN plug-ins

Andreas Oberritter obi at opendreambox.org
Tue May 9 09:19:24 UTC 2017


Ping.

I know conflicts may have appeared in the meantime. I've got a rebased
version in my tree. Some feedback would be nice however, before I'm going
to send it again.

Regards,
Andreas

On Mon, 30 Jan 2017 23:19:30 +0100
Andreas Oberritter <obi at opendreambox.org> wrote:

> Ping.
> 
> On Mon,  5 Dec 2016 23:41:53 +0100
> Andreas Oberritter <obi at opendreambox.org> wrote:
> 
> > - Use simple static packaging.
> > - Move VPN runtime dependencies from connman to the individual plug-ins.
> > - Create a connmann-ppp package containing libppp-plugin.so, which is
> >   a shared library needed by l2tp and pptp plug-ins.
> > - Let connman suggest VPN packages instead of recommending them, so they
> >   don't get installed by default.
> > - Remove unknown configure options (--with-pptp --with-l2tp)
> > 
> > Signed-off-by: Andreas Oberritter <obi at opendreambox.org>
> > ---
> >  v2: Made dependencies from meta-networking conditional. Now the reported
> >      errors should appear only if meta-network is not available and a
> >      packageconfig option related to VPN was enabled.
> > 
> >  Note: I can't build-test it right now, because python3-native has weird
> >        conflicts populating sysroot. But this patch doesn't cause parse
> >        errors, so I guess syntax is fine.
> > 
> >  meta/recipes-connectivity/connman/connman.inc | 95 +++++++++------------------
> >  1 file changed, 32 insertions(+), 63 deletions(-)
> > 
> > diff --git a/meta/recipes-connectivity/connman/connman.inc b/meta/recipes-connectivity/connman/connman.inc
> > index 35a7eed..671d533 100644
> > --- a/meta/recipes-connectivity/connman/connman.inc
> > +++ b/meta/recipes-connectivity/connman/connman.inc
> > @@ -46,24 +46,17 @@ PACKAGECONFIG[wifi] = "--enable-wifi, --disable-wifi, wpa-supplicant, wpa-suppli
> >  PACKAGECONFIG[bluez] = "--enable-bluetooth, --disable-bluetooth, ${BLUEZ}, ${BLUEZ}"
> >  PACKAGECONFIG[3g] = "--enable-ofono, --disable-ofono, ofono, ofono"
> >  PACKAGECONFIG[tist] = "--enable-tist,--disable-tist,"
> > -PACKAGECONFIG[openvpn] = "--enable-openvpn --with-openvpn=${sbindir}/openvpn,--disable-openvpn,,openvpn"
> > -PACKAGECONFIG[vpnc] = "--enable-vpnc --with-vpnc=${sbindir}/vpnc,--disable-vpnc,,vpnc"
> > -PACKAGECONFIG[l2tp] = "--enable-l2tp --with-l2tp=${sbindir}/xl2tpd,--disable-l2tp,,xl2tpd"
> > -PACKAGECONFIG[pptp] = "--enable-pptp --with-pptp=${sbindir}/pptp,--disable-pptp,,pptp-linux"
> > +PACKAGECONFIG[openvpn] = "--enable-openvpn --with-openvpn=${sbindir}/openvpn,--disable-openvpn"
> > +PACKAGECONFIG[vpnc] = "--enable-vpnc --with-vpnc=${sbindir}/vpnc,--disable-vpnc"
> > +PACKAGECONFIG[l2tp] = "--enable-l2tp,--disable-l2tp"
> > +PACKAGECONFIG[pptp] = "--enable-pptp,--disable-pptp"
> >  # WISPr support for logging into hotspots, requires TLS
> >  PACKAGECONFIG[wispr] = "--enable-wispr,--disable-wispr,gnutls,"
> >  
> >  INITSCRIPT_NAME = "connman"
> >  INITSCRIPT_PARAMS = "start 05 5 2 3 . stop 22 0 1 6 ."
> >  
> > -python __anonymous () {
> > -    systemd_packages = "${PN}"
> > -    pkgconfig = d.getVar('PACKAGECONFIG', True)
> > -    if ('openvpn' or 'vpnc' or 'l2tp' or 'pptp') in pkgconfig.split():
> > -        systemd_packages += " ${PN}-vpn"
> > -    d.setVar('SYSTEMD_PACKAGES', systemd_packages)
> > -}
> > -
> > +SYSTEMD_PACKAGES = "${PN} ${PN}-vpn"
> >  SYSTEMD_SERVICE_${PN} = "connman.service"
> >  SYSTEMD_SERVICE_${PN}-vpn = "connman-vpn.service"
> >  SYSTEMD_SERVICE_${PN}-wait-online = "connman-wait-online.service"
> > @@ -103,36 +96,6 @@ RDEPENDS_${PN} = "\
> >  	dbus \
> >  	"
> >  
> > -PACKAGES_DYNAMIC += "^${PN}-plugin-.*"
> > -
> > -def add_rdepends(bb, d, file, pkg, depmap, multilib_prefix, add_insane_skip):
> > -    plugintype = pkg.split( '-' )[-1]
> > -    if plugintype in depmap:
> > -        rdepends = map(lambda x: multilib_prefix + x, \
> > -                       depmap[plugintype].split())
> > -        d.setVar("RDEPENDS_%s" % pkg, " ".join(rdepends))
> > -    if add_insane_skip:
> > -        d.appendVar("INSANE_SKIP_%s" % pkg, "dev-so")
> > -
> > -python populate_packages_prepend() {
> > -    depmap = dict(pppd="ppp")
> > -    multilib_prefix = (d.getVar("MLPREFIX", True) or "")
> > -
> > -    hook = lambda file,pkg,x,y,z: \
> > -        add_rdepends(bb, d, file, pkg, depmap, multilib_prefix, False)
> > -    plugin_dir = d.expand('${libdir}/connman/plugins/')
> > -    plugin_name = d.expand('${PN}-plugin-%s')
> > -    do_split_packages(d, plugin_dir, '^(.*).so$', plugin_name, \
> > -        '${PN} plugin for %s', extra_depends='', hook=hook, prepend=True )
> > -
> > -    hook = lambda file,pkg,x,y,z: \
> > -        add_rdepends(bb, d, file, pkg, depmap, multilib_prefix, True)
> > -    plugin_dir = d.expand('${libdir}/connman/plugins-vpn/')
> > -    plugin_name = d.expand('${PN}-plugin-vpn-%s')
> > -    do_split_packages(d, plugin_dir, '^(.*).so$', plugin_name, \
> > -        '${PN} VPN plugin for %s', extra_depends='', hook=hook, prepend=True )
> > -}
> > -
> >  PACKAGES =+ "${PN}-tools ${PN}-tests ${PN}-client"
> >  
> >  FILES_${PN}-tools = "${bindir}/wispr"
> > @@ -152,7 +115,12 @@ FILES_${PN} = "${bindir}/* ${sbindir}/* ${libexecdir}/* ${libdir}/lib*.so.* \
> >  
> >  FILES_${PN}-dev += "${libdir}/connman/*/*.la"
> >  
> > -PACKAGES =+ "${PN}-vpn ${PN}-wait-online"
> > +PACKAGES =+ "${PN}-vpn ${PN}-wait-online \
> > +             ${PN}-ppp \
> > +             ${PN}-plugin-vpn-l2tp \
> > +             ${PN}-plugin-vpn-openvpn \
> > +             ${PN}-plugin-vpn-pptp \
> > +             ${PN}-plugin-vpn-vpnc"
> >  
> >  SUMMARY_${PN}-vpn = "A daemon for managing VPN connections within embedded devices"
> >  DESCRIPTION_${PN}-vpn = "The ConnMan VPN provides a daemon for \
> > @@ -161,10 +129,10 @@ operating system.  The connman-vpnd handles all the VPN connections \
> >  and starts/stops VPN client processes when necessary. The connman-vpnd \
> >  provides a DBus API for managing VPN connections. All the different \
> >  VPN technogies are implemented using plug-ins."
> > -FILES_${PN}-vpn += "${sbindir}/connman-vpnd \
> > -                    ${sysconfdir}/dbus-1/system.d/connman-vpn-dbus.conf \
> > -                    ${datadir}/dbus-1/system-services/net.connman.vpn.service \
> > -                    ${systemd_unitdir}/system/connman-vpn.service"
> > +FILES_${PN}-vpn = "${sbindir}/connman-vpnd \
> > +                   ${sysconfdir}/dbus-1/system.d/connman-vpn-dbus.conf \
> > +                   ${datadir}/dbus-1/system-services/net.connman.vpn.service \
> > +                   ${systemd_unitdir}/system/connman-vpn.service"
> >  
> >  SUMMARY_${PN}-wait-online = "A program that will return once ConnMan has connected to a network"
> >  DESCRIPTION_${PN}-wait-online = "A service that can be enabled so that \
> > @@ -175,31 +143,32 @@ FILES_${PN}-wait-online += "${sbindir}/connmand-wait-online \
> >  SUMMARY_${PN}-plugin-vpn-openvpn = "An OpenVPN plugin for ConnMan VPN"
> >  DESCRIPTION_${PN}-plugin-vpn-openvpn = "The ConnMan OpenVPN plugin uses openvpn client \
> >  to create a VPN connection to OpenVPN server."
> > -FILES_${PN}-plugin-vpn-openvpn += "${libdir}/connman/scripts/openvpn-script \
> > -                                   ${libdir}/connman/plugins-vpn/openvpn.so"
> > -RDEPENDS_${PN}-plugin-vpn-openvpn += "${PN}-vpn"
> > -RRECOMMENDS_${PN} += "${@bb.utils.contains('PACKAGECONFIG','openvpn','${PN}-plugin-vpn-openvpn', '', d)}"
> > +FILES_${PN}-plugin-vpn-openvpn = "${libdir}/connman/scripts/openvpn-script \
> > +                                  ${libdir}/connman/plugins-vpn/openvpn.so"
> > +RDEPENDS_${PN}-plugin-vpn-openvpn = "${PN}-vpn ${@bb.utils.contains('PACKAGECONFIG', 'openvpn', 'openvpn', '', d)}"
> > +RSUGGESTS_${PN} += "${@bb.utils.contains('PACKAGECONFIG','openvpn','${PN}-plugin-vpn-openvpn', '', d)}"
> >  
> >  SUMMARY_${PN}-plugin-vpn-vpnc = "A vpnc plugin for ConnMan VPN"
> >  DESCRIPTION_${PN}-plugin-vpn-vpnc = "The ConnMan vpnc plugin uses vpnc client \
> >  to create a VPN connection to Cisco3000 VPN Concentrator."
> > -FILES_${PN}-plugin-vpn-vpnc += "${libdir}/connman/scripts/openconnect-script \
> > -                                ${libdir}/connman/plugins-vpn/vpnc.so"
> > -RDEPENDS_${PN}-plugin-vpn-vpnc += "${PN}-vpn"
> > -RRECOMMENDS_${PN} += "${@bb.utils.contains('PACKAGECONFIG','vpnc','${PN}-plugin-vpn-vpnc', '', d)}"
> > +FILES_${PN}-plugin-vpn-vpnc = "${libdir}/connman/scripts/openconnect-script \
> > +                               ${libdir}/connman/plugins-vpn/vpnc.so"
> > +RDEPENDS_${PN}-plugin-vpn-vpnc = "${PN}-vpn ${@bb.utils.contains('PACKAGECONFIG', 'vpnc', 'vpnc', '', d)}"
> > +RSUGGESTS_${PN} += "${@bb.utils.contains('PACKAGECONFIG','vpnc','${PN}-plugin-vpn-vpnc', '', d)}"
> >  
> >  SUMMARY_${PN}-plugin-vpn-l2tp = "A L2TP plugin for ConnMan VPN"
> >  DESCRIPTION_${PN}-plugin-vpn-l2tp = "The ConnMan L2TP plugin uses xl2tpd daemon \
> >  to create a VPN connection to L2TP server."
> > -FILES_${PN}-plugin-vpn-l2tp += "${libdir}/connman/scripts/libppp-plugin.so* \
> > -                                ${libdir}/connman/plugins-vpn/l2tp.so"
> > -RDEPENDS_${PN}-plugin-vpn-l2tp += "${PN}-vpn"
> > -RRECOMMENDS_${PN} += "${@bb.utils.contains('PACKAGECONFIG','l2tp','${PN}-plugin-vpn-l2tp', '', d)}"
> > +FILES_${PN}-plugin-vpn-l2tp = "${libdir}/connman/plugins-vpn/l2tp.so"
> > +RDEPENDS_${PN}-plugin-vpn-l2tp = "${PN}-vpn ${PN}-ppp ${@bb.utils.contains('PACKAGECONFIG', 'l2tp', 'xl2tpd', '', d)}"
> > +RSUGGESTS_${PN} += "${@bb.utils.contains('PACKAGECONFIG','l2tp','${PN}-plugin-vpn-l2tp', '', d)}"
> >  
> >  SUMMARY_${PN}-plugin-vpn-pptp = "A PPTP plugin for ConnMan VPN"
> >  DESCRIPTION_${PN}-plugin-vpn-pptp = "The ConnMan PPTP plugin uses pptp-linux client \
> >  to create a VPN connection to PPTP server."
> > -FILES_${PN}-plugin-vpn-pptp += "${libdir}/connman/scripts/libppp-plugin.so* \
> > -                                ${libdir}/connman/plugins-vpn/pptp.so"
> > -RDEPENDS_${PN}-plugin-vpn-pptp += "${PN}-vpn"
> > -RRECOMMENDS_${PN} += "${@bb.utils.contains('PACKAGECONFIG','pptp','${PN}-plugin-vpn-pptp', '', d)}"
> > +FILES_${PN}-plugin-vpn-pptp = "${libdir}/connman/plugins-vpn/pptp.so"
> > +RDEPENDS_${PN}-plugin-vpn-pptp = "${PN}-vpn ${PN}-ppp ${@bb.utils.contains('PACKAGECONFIG', 'pptp', 'pptp-linux', '', d)}"
> > +RSUGGESTS_${PN} += "${@bb.utils.contains('PACKAGECONFIG','pptp','${PN}-plugin-vpn-pptp', '', d)}"
> > +
> > +FILES_${PN}-ppp = "${libdir}/connman/scripts/libppp-plugin.so"
> > +RDEPENDS_${PN}-ppp = "ppp"  
> 




More information about the Openembedded-core mailing list