diff options
author | Jukka Rissanen <jukka.rissanen@linux.intel.com> | 2013-05-14 11:10:41 +0300 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2013-05-16 00:09:48 +0300 |
commit | 7c41d839f9a00a10c763a8f6c3c349b61da3fd21 (patch) | |
tree | 2dcc94fd6138761c346ece7ec1660fe375ac34a2 /meta/recipes-connectivity/connman | |
parent | ca64333d0bc2666eae18dbaa90cebb090cd43a45 (diff) | |
download | poky-7c41d839f9a00a10c763a8f6c3c349b61da3fd21.tar.gz |
connman: Add VPN support
One needs to add following statement into local.conf or distro config
PACKAGECONFIG_append_pn-connman = " openvpn vpnc l2tp pptp"
in order to activate support for these VPN technogies in ConnMan.
(From OE-Core rev: 92da847ed6cea6342bdc86de121534259332a2c3)
Signed-off-by: Jukka Rissanen <jukka.rissanen@linux.intel.com>
Signed-off-by: Saul Wold <sgw@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-connectivity/connman')
-rw-r--r-- | meta/recipes-connectivity/connman/connman.inc | 52 |
1 files changed, 42 insertions, 10 deletions
diff --git a/meta/recipes-connectivity/connman/connman.inc b/meta/recipes-connectivity/connman/connman.inc index afc361ccc7..137deedb30 100644 --- a/meta/recipes-connectivity/connman/connman.inc +++ b/meta/recipes-connectivity/connman/connman.inc | |||
@@ -38,6 +38,10 @@ PACKAGECONFIG ??= "\ | |||
38 | ${@base_contains('DISTRO_FEATURES', '3g','3g', '', d)} \ | 38 | ${@base_contains('DISTRO_FEATURES', '3g','3g', '', d)} \ |
39 | " | 39 | " |
40 | 40 | ||
41 | # If you want ConnMan to support VPN, add following statement into | ||
42 | # local.conf or distro config | ||
43 | # PACKAGECONFIG_append_pn-connman = " openvpn vpnc l2tp pptp" | ||
44 | |||
41 | PACKAGECONFIG[wifi] = "--enable-wifi, --disable-wifi, wpa-supplicant" | 45 | PACKAGECONFIG[wifi] = "--enable-wifi, --disable-wifi, wpa-supplicant" |
42 | PACKAGECONFIG[bluetooth] = "--enable-bluetooth, --disable-bluetooth, bluez4" | 46 | PACKAGECONFIG[bluetooth] = "--enable-bluetooth, --disable-bluetooth, bluez4" |
43 | PACKAGECONFIG[3g] = "--enable-ofono, --disable-ofono, ofono" | 47 | PACKAGECONFIG[3g] = "--enable-ofono, --disable-ofono, ofono" |
@@ -47,6 +51,7 @@ INITSCRIPT_NAME = "connman" | |||
47 | INITSCRIPT_PARAMS = "start 05 5 2 3 . stop 22 0 1 6 ." | 51 | INITSCRIPT_PARAMS = "start 05 5 2 3 . stop 22 0 1 6 ." |
48 | 52 | ||
49 | SYSTEMD_SERVICE_${PN} = "connman.service" | 53 | SYSTEMD_SERVICE_${PN} = "connman.service" |
54 | SYSTEMD_SERVICE_${PN}-vpn = "connman-vpn.service" | ||
50 | SYSTEMD_WIRED_SETUP = "ExecStartPre=-/usr/lib/connman/wired-setup" | 55 | SYSTEMD_WIRED_SETUP = "ExecStartPre=-/usr/lib/connman/wired-setup" |
51 | 56 | ||
52 | # IMPORTANT: because xuser is shared with rootless X, please make sure the | 57 | # IMPORTANT: because xuser is shared with rootless X, please make sure the |
@@ -67,6 +72,7 @@ do_configure_append () { | |||
67 | # both this and the xuser patch can be dropped. | 72 | # both this and the xuser patch can be dropped. |
68 | do_compile_append() { | 73 | do_compile_append() { |
69 | sed -i -e s:deny:allow:g src/connman-dbus.conf | 74 | sed -i -e s:deny:allow:g src/connman-dbus.conf |
75 | sed -i -e s:deny:allow:g vpn/vpn-dbus.conf | ||
70 | } | 76 | } |
71 | 77 | ||
72 | do_install_append() { | 78 | do_install_append() { |
@@ -81,7 +87,7 @@ do_install_append() { | |||
81 | install -m 0755 ${B}/client/connmanctl ${D}${bindir} | 87 | install -m 0755 ${B}/client/connmanctl ${D}${bindir} |
82 | 88 | ||
83 | # We don't need to package an empty directory | 89 | # We don't need to package an empty directory |
84 | rmdir ${D}${libdir}/connman/scripts | 90 | rmdir --ignore-fail-on-non-empty ${D}${libdir}/connman/scripts |
85 | 91 | ||
86 | # Automake 1.12 won't install empty directories, but we need the | 92 | # Automake 1.12 won't install empty directories, but we need the |
87 | # plugins directory to be present for ownership | 93 | # plugins directory to be present for ownership |
@@ -106,20 +112,32 @@ RDEPENDS_${PN} = "\ | |||
106 | 112 | ||
107 | PACKAGES_DYNAMIC += "^${PN}-plugin-.*" | 113 | PACKAGES_DYNAMIC += "^${PN}-plugin-.*" |
108 | 114 | ||
115 | def add_rdepends(bb, d, file, pkg, depmap, multilib_prefix, add_insane_skip): | ||
116 | plugintype = pkg.split( '-' )[-1] | ||
117 | if plugintype in depmap: | ||
118 | rdepends = map(lambda x: multilib_prefix + x, \ | ||
119 | depmap[plugintype].split()) | ||
120 | d.setVar("RDEPENDS_%s" % pkg, " ".join(rdepends)) | ||
121 | if add_insane_skip: | ||
122 | d.appendVar("INSANE_SKIP_%s" % pkg, "dev-so") | ||
123 | |||
109 | python populate_packages_prepend() { | 124 | python populate_packages_prepend() { |
110 | depmap = dict(pppd="ppp") | 125 | depmap = dict(pppd="ppp") |
111 | packages = [] | ||
112 | multilib_prefix = (d.getVar("MLPREFIX", True) or "") | 126 | multilib_prefix = (d.getVar("MLPREFIX", True) or "") |
113 | hook = lambda file,pkg,b,c,d:packages.append((file,pkg)) | 127 | |
128 | hook = lambda file,pkg,x,y,z: \ | ||
129 | add_rdepends(bb, d, file, pkg, depmap, multilib_prefix, False) | ||
114 | plugin_dir = d.expand('${libdir}/connman/plugins/') | 130 | plugin_dir = d.expand('${libdir}/connman/plugins/') |
115 | plugin_name = d.expand('${PN}-plugin-%s') | 131 | plugin_name = d.expand('${PN}-plugin-%s') |
116 | do_split_packages(d, plugin_dir, '^(.*).so$', plugin_name, '${PN} plugin for %s', extra_depends='', hook=hook, prepend=True ) | 132 | do_split_packages(d, plugin_dir, '^(.*).so$', plugin_name, \ |
117 | for (file, package) in packages: | 133 | '${PN} plugin for %s', extra_depends='', hook=hook, prepend=True ) |
118 | plugintype = package.split( '-' )[-1] | 134 | |
119 | if plugintype in depmap: | 135 | hook = lambda file,pkg,x,y,z: \ |
120 | rdepends = map(lambda x: multilib_prefix + x, depmap[plugintype].split()) | 136 | add_rdepends(bb, d, file, pkg, depmap, multilib_prefix, True) |
121 | bb.note( "Adding rdependency on %s to %s" % ( rdepends, package ) ) | 137 | plugin_dir = d.expand('${libdir}/connman/plugins-vpn/') |
122 | d.setVar("RDEPENDS_%s" % package, " ".join(rdepends)) | 138 | plugin_name = d.expand('${PN}-plugin-vpn-%s') |
139 | do_split_packages(d, plugin_dir, '^(.*).so$', plugin_name, \ | ||
140 | '${PN} VPN plugin for %s', extra_depends='', hook=hook, prepend=True ) | ||
123 | } | 141 | } |
124 | 142 | ||
125 | PACKAGES =+ "${PN}-tools ${PN}-tests ${PN}-client" | 143 | PACKAGES =+ "${PN}-tools ${PN}-tests ${PN}-client" |
@@ -140,3 +158,17 @@ FILES_${PN} = "${bindir}/* ${sbindir}/* ${libexecdir}/* ${libdir}/lib*.so.* \ | |||
140 | FILES_${PN}-dbg += "${libdir}/connman/*/.debug" | 158 | FILES_${PN}-dbg += "${libdir}/connman/*/.debug" |
141 | 159 | ||
142 | FILES_${PN}-dev += "${libdir}/connman/*/*.la" | 160 | FILES_${PN}-dev += "${libdir}/connman/*/*.la" |
161 | |||
162 | PACKAGES =+ "${PN}-vpn" | ||
163 | |||
164 | SUMMARY_${PN}-vpn = "A daemon for managing VPN connections within embedded devices" | ||
165 | DESCRIPTION_${PN}-vpn = "The ConnMan VPN provides a daemon for \ | ||
166 | managing VPN connections within embedded devices running the Linux \ | ||
167 | operating system. The connman-vpnd handles all the VPN connections \ | ||
168 | and starts/stops VPN client processes when necessary. The connman-vpnd \ | ||
169 | provides a DBus API for managing VPN connections. All the different \ | ||
170 | VPN technogies are implemented using plug-ins." | ||
171 | FILES_${PN}-vpn += "${sbindir}/connman-vpnd \ | ||
172 | ${sysconfdir}/dbus-1/system.d/connman-vpn-dbus.conf \ | ||
173 | ${datadir}/dbus-1/system-services/net.connman.vpn.service \ | ||
174 | ${systemd_unitdir}/system/connman-vpn.service" | ||