swupdate.inc 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. SUMMARY="Image updater for Yocto projects"
  2. DESCRIPTION = "Application for automatic software update from USB Pen"
  3. SECTION="swupdate"
  4. DEPENDS += "libconfig"
  5. # SWUpdate licensing is described in the following pages:
  6. # https://sbabic.github.io/swupdate/licensing.html
  7. # rst form: file://doc/source/licensing.rst
  8. LICENSE = "GPLv2+ & LGPLv2+ & MIT"
  9. LICENSE_${PN}-lua = "LGPLv2+"
  10. LICENSE_${PN}-www = "MIT"
  11. LIC_FILES_CHKSUM = "file://COPYING;md5=0636e73ff0215e8d672dc4c32c317bb3 \
  12. file://Licenses/lgpl-2.1.txt;md5=4fbd65380cdd255951079008b364516c \
  13. file://Licenses/mit.txt;md5=838c366f69b72c5df05c96dff79b35f2 \
  14. file://Licenses/Exceptions;md5=5f205fe7a7f2b056b4fa42603fe2d63a"
  15. inherit cml1 update-rc.d systemd pkgconfig
  16. SRC_URI = "git://github.com/sbabic/swupdate.git;protocol=https \
  17. file://defconfig \
  18. file://swupdate \
  19. file://swupdate.sh \
  20. file://swupdate.service \
  21. file://swupdate.socket.tmpl \
  22. file://swupdate-usb.rules \
  23. file://swupdate-usb@.service \
  24. file://swupdate-progress.service \
  25. file://tmpfiles-swupdate.conf \
  26. file://10-mongoose-args \
  27. file://90-start-progress \
  28. "
  29. LTOEXTRA += "-flto-partition=none"
  30. PACKAGES =+ " \
  31. ${PN}-client \
  32. ${PN}-lua \
  33. ${PN}-progress \
  34. ${PN}-tools \
  35. ${PN}-tools-hawkbit \
  36. ${PN}-usb \
  37. ${PN}-www \
  38. "
  39. # tools is now an empty meta package for backward compatibility
  40. ALLOW_EMPTY_${PN}-tools = "1"
  41. FILES_${PN}-client = "${bindir}/swupdate-client"
  42. FILES_${PN}-lua += "${libdir}/lua/"
  43. FILES_${PN}-progress = " \
  44. ${bindir}/swupdate-progress \
  45. ${systemd_system_unitdir}/swupdate-progress.service \
  46. ${libdir}/swupdate/conf.d/90-start-progress \
  47. "
  48. FILES_${PN}-usb = " \
  49. ${sysconfdir}/udev/rules.d/swupdate-usb.rules \
  50. ${systemd_system_unitdir}/swupdate-usb@.service \
  51. "
  52. FILES_${PN}-tools-hawkbit = " \
  53. ${bindir}/swupdate-hawkbitcfg \
  54. ${bindir}/swupdate-sendtohawkbit \
  55. "
  56. FILES_${PN} += " \
  57. ${libdir}/tmpfiles.d \
  58. ${libdir}/swupdate/* \
  59. ${systemd_system_unitdir}/swupdate.socket \
  60. ${systemd_system_unitdir}/swupdate.service \
  61. ${sysconfdir}/init.d/* \
  62. "
  63. FILES_${PN}-www = " \
  64. ${libdir}/swupdate/conf.d/*mongoose* \
  65. /www/* \
  66. "
  67. RDEPENDS_${PN}-usb += "${PN}-client"
  68. # The tools package is deprecated, it is an empty meta package for backward compatibility
  69. RDEPENDS_${PN}-tools += "${PN}-client ${PN}-progress ${PN}-tools-hawkbit \
  70. ${@bb.utils.contains('DISTRO_FEATURES','systemd','${PN}-usb','',d)} \
  71. "
  72. S = "${WORKDIR}/git"
  73. B = "${WORKDIR}/build"
  74. EXTRA_OEMAKE += " O=${B} HOSTCC="${BUILD_CC}" HOSTCXX="${BUILD_CXX}" LD="${CC}" DESTDIR="${D}" LIBDIR="${libdir}" V=1 ARCH=${TARGET_ARCH} CROSS_COMPILE=${TARGET_PREFIX} SKIP_STRIP=y"
  75. DEPENDS += "kern-tools-native"
  76. python () {
  77. import re
  78. try:
  79. defconfig = bb.fetch2.localpath('file://defconfig', d)
  80. except bb.fetch2.FetchError:
  81. return
  82. try:
  83. configfile = open(defconfig)
  84. except IOError:
  85. return
  86. features = configfile.read()
  87. configfile.close()
  88. for current_fragment in find_cfgs(d):
  89. try:
  90. fragment_fd = open(current_fragment)
  91. except IOError:
  92. continue
  93. fragment = fragment_fd.read()
  94. fragment_fd.close()
  95. fragment_search = re.findall('^(?:# )?(CONFIG_[a-zA-Z0-9_]*)[= ].*\n?', fragment, re.MULTILINE)
  96. for feature in fragment_search:
  97. features = re.sub("^(?:# )?" + feature + "[= ].*\n?", "", features, flags=re.MULTILINE)
  98. features = features + fragment
  99. features = features.splitlines(True)
  100. depends = d.getVar('DEPENDS', False)
  101. if 'CONFIG_REMOTE_HANDLER=y\n' in features:
  102. depends += ' zeromq'
  103. if 'CONFIG_SSL_IMPL_OPENSSL=y\n' in features:
  104. depends += ' openssl'
  105. elif 'CONFIG_SSL_IMPL_MBEDTLS=y\n' in features:
  106. depends += ' mbedtls'
  107. elif 'CONFIG_SSL_IMPL_WOLFSSL=y\n' in features:
  108. depends += ' wolfssl'
  109. if 'CONFIG_JSON=y\n' in features:
  110. depends += ' json-c'
  111. if 'CONFIG_SYSTEMD=y\n' in features:
  112. depends += ' systemd'
  113. if 'CONFIG_ARCHIVE=y\n' in features:
  114. depends += ' libarchive'
  115. if 'CONFIG_LUA=y\n' in features:
  116. depends += ' lua'
  117. if 'CONFIG_UBOOT=y\n' in features:
  118. depends += ' libubootenv'
  119. if 'CONFIG_DOWNLOAD=y\n' in features or 'CONFIG_SURICATTA=y\n' in features:
  120. depends += ' curl'
  121. if 'CONFIG_MTD=y\n' in features or 'CONFIG_CFI=y\n' in features or 'CONFIG_UBIVOL=y\n' in features:
  122. depends += ' mtd-utils'
  123. if 'CONFIG_UCFWHANDLER=y\n' in features:
  124. depends += ' libgpiod'
  125. if 'CONFIG_SWUFORWARDER_HANDLER=y\n' in features:
  126. depends += ' curl libwebsockets uriparser'
  127. if 'CONFIG_RDIFFHANDLER=y\n' in features:
  128. depends += ' librsync'
  129. if 'CONFIG_BOOTLOADER_EBG=y\n' in features:
  130. depends += ' efibootguard'
  131. if 'CONFIG_ZSTD=y\n' in features:
  132. depends += ' zstd'
  133. if 'CONFIG_DISKPART=y\n' in features:
  134. depends += ' util-linux'
  135. d.setVar('DEPENDS', depends)
  136. if 'CONFIG_MONGOOSE=y\n' in features:
  137. d.setVar('SWUPDATE_MONGOOSE', 'true')
  138. else:
  139. d.setVar('SWUPDATE_MONGOOSE', 'false')
  140. if 'CONFIG_MONGOOSE_WEB_API_V2=y\n' in features:
  141. d.setVar('SWUPDATE_WWW', 'webapp')
  142. # Values not used here might be used in a bbappend
  143. d.setVar('SWUPDATE_SOCKET_CTRL_PATH', '/tmp/sockinstctrl')
  144. d.setVar('SWUPDATE_SOCKET_PROGRESS_PATH', '/tmp/swupdateprog')
  145. d.setVar('SWUPDATE_HW_COMPATIBILITY_FILE', '/etc/hwrevision')
  146. d.setVar('SWUPDATE_SW_VERSIONS_FILE', '/etc/sw-versions')
  147. for feature in features:
  148. if feature.startswith('CONFIG_SOCKET_CTRL_PATH='):
  149. ctrl_path = feature.split('=')[1].strip()
  150. d.setVar('SWUPDATE_SOCKET_CTRL_PATH', ctrl_path)
  151. elif feature.startswith('CONFIG_SOCKET_PROGRESS_PATH='):
  152. prog_path = feature.split('=')[1].strip()
  153. d.setVar('SWUPDATE_SOCKET_PROGRESS_PATH', prog_path)
  154. elif feature.startswith('CONFIG_HW_COMPATIBILITY_FILE='):
  155. hwrev_file = feature.split('=')[1].strip()
  156. d.setVar('SWUPDATE_HW_COMPATIBILITY_FILE', hwrev_file)
  157. elif feature.startswith('CONFIG_SW_VERSIONS_FILE='):
  158. swver_file = feature.split('=')[1].strip()
  159. d.setVar('SWUPDATE_SW_VERSIONS_FILE', swver_file)
  160. }
  161. do_configure () {
  162. cat > ${WORKDIR}/.config <<HEREDOC
  163. CONFIG_EXTRA_CFLAGS="${CFLAGS}"
  164. CONFIG_EXTRA_LDFLAGS="${LDFLAGS}"
  165. HEREDOC
  166. cat ${WORKDIR}/defconfig >> ${WORKDIR}/.config
  167. merge_config.sh -O ${B} -m ${WORKDIR}/.config ${@" ".join(find_cfgs(d))}
  168. (cd ${S} && cml1_do_configure)
  169. }
  170. do_compile() {
  171. unset LDFLAGS
  172. (cd ${S} && oe_runmake)
  173. }
  174. do_install () {
  175. (cd ${S} && oe_runmake install)
  176. install -m 0755 -d ${D}/www
  177. if [ -d ${S}/web-app ];then
  178. cp -R --no-dereference --preserve=mode,links -v ${S}/examples/www/v2/* ${D}/www
  179. else
  180. install -m 0755 ${S}/www/* ${D}/www
  181. fi
  182. install -d ${D}${sysconfdir}/init.d
  183. install -m 755 ${WORKDIR}/swupdate ${D}${sysconfdir}/init.d
  184. # shell based configuration loader allows to place code snippets into this folder
  185. install -d ${D}${libdir}/swupdate/conf.d
  186. install -m 755 ${WORKDIR}/swupdate.sh ${D}${libdir}/swupdate
  187. sed -i 's#@LIBDIR@#${libdir}#g' ${D}${libdir}/swupdate/swupdate.sh
  188. if ${SWUPDATE_MONGOOSE}; then
  189. install -m 644 ${WORKDIR}/10-mongoose-args ${D}${libdir}/swupdate/conf.d/
  190. fi
  191. install -d ${D}${systemd_unitdir}/system
  192. install -m 644 ${WORKDIR}/swupdate.service ${D}${systemd_system_unitdir}
  193. sed -i 's#@LIBDIR@#${libdir}#' ${D}${systemd_system_unitdir}/swupdate.service
  194. install -m 644 ${WORKDIR}/swupdate.socket.tmpl ${D}${systemd_system_unitdir}/swupdate.socket
  195. sed -e "s,@@SWUPDATE_SOCKET_CTRL_PATH@@,${SWUPDATE_SOCKET_CTRL_PATH},g" \
  196. -e "s,@@SWUPDATE_SOCKET_PROGRESS_PATH@@,${SWUPDATE_SOCKET_PROGRESS_PATH},g" \
  197. -i ${D}${systemd_system_unitdir}/swupdate.socket
  198. install -m 644 ${WORKDIR}/swupdate-usb@.service ${D}${systemd_system_unitdir}
  199. install -m 644 ${WORKDIR}/swupdate-progress.service ${D}${systemd_system_unitdir}
  200. if ${@bb.utils.contains('DISTRO_FEATURES','systemd','true','false',d)}; then
  201. install -d ${D}${libdir}/tmpfiles.d
  202. install -m 0644 ${WORKDIR}/tmpfiles-swupdate.conf ${D}${libdir}/tmpfiles.d/swupdate.conf
  203. install -d ${D}${sysconfdir}/udev/rules.d
  204. install -m 0644 ${WORKDIR}/swupdate-usb.rules ${D}${sysconfdir}/udev/rules.d/
  205. else
  206. # in case of systemd there is a service file, for sysv init we need to start it as well
  207. install -m 0644 ${WORKDIR}/90-start-progress ${D}${libdir}/swupdate/conf.d/
  208. fi
  209. }
  210. INITSCRIPT_NAME = "swupdate"
  211. INITSCRIPT_PARAMS = "defaults 70"
  212. SYSTEMD_PACKAGES = "${PN} ${PN}-progress ${PN}-usb"
  213. SYSTEMD_SERVICE_${PN} = "swupdate.service swupdate.socket"
  214. SYSTEMD_SERVICE_${PN}-progress = "swupdate-progress.service"
  215. SYSTEMD_SERVICE_${PN}-usb = "swupdate-usb@.service"