1.. SPDX-License-Identifier: CC-BY-SA-2.0-UK 2 3Working with Packages 4********************* 5 6This section describes a few tasks that involve packages: 7 8- :ref:`dev-manual/packages:excluding packages from an image` 9 10- :ref:`dev-manual/packages:incrementing a package version` 11 12- :ref:`dev-manual/packages:handling optional module packaging` 13 14- :ref:`dev-manual/packages:using runtime package management` 15 16- :ref:`dev-manual/packages:generating and using signed packages` 17 18- :ref:`Setting up and running package test 19 (ptest) <test-manual/ptest:testing packages with ptest>` 20 21- :ref:`dev-manual/packages:creating node package manager (npm) packages` 22 23- :ref:`dev-manual/packages:adding custom metadata to packages` 24 25Excluding Packages from an Image 26================================ 27 28You might find it necessary to prevent specific packages from being 29installed into an image. If so, you can use several variables to direct 30the build system to essentially ignore installing recommended packages 31or to not install a package at all. 32 33The following list introduces variables you can use to prevent packages 34from being installed into your image. Each of these variables only works 35with IPK and RPM package types, not for Debian packages. 36Also, you can use these variables from your ``local.conf`` file 37or attach them to a specific image recipe by using a recipe name 38override. For more detail on the variables, see the descriptions in the 39Yocto Project Reference Manual's glossary chapter. 40 41- :term:`BAD_RECOMMENDATIONS`: 42 Use this variable to specify "recommended-only" packages that you do 43 not want installed. 44 45- :term:`NO_RECOMMENDATIONS`: 46 Use this variable to prevent all "recommended-only" packages from 47 being installed. 48 49- :term:`PACKAGE_EXCLUDE`: 50 Use this variable to prevent specific packages from being installed 51 regardless of whether they are "recommended-only" or not. You need to 52 realize that the build process could fail with an error when you 53 prevent the installation of a package whose presence is required by 54 an installed package. 55 56Incrementing a Package Version 57============================== 58 59This section provides some background on how binary package versioning 60is accomplished and presents some of the services, variables, and 61terminology involved. 62 63In order to understand binary package versioning, you need to consider 64the following: 65 66- Binary Package: The binary package that is eventually built and 67 installed into an image. 68 69- Binary Package Version: The binary package version is composed of two 70 components --- a version and a revision. 71 72 .. note:: 73 74 Technically, a third component, the "epoch" (i.e. :term:`PE`) is involved 75 but this discussion for the most part ignores :term:`PE`. 76 77 The version and revision are taken from the 78 :term:`PV` and 79 :term:`PR` variables, respectively. 80 81- :term:`PV`: The recipe version. :term:`PV` represents the version of the 82 software being packaged. Do not confuse :term:`PV` with the binary 83 package version. 84 85- :term:`PR`: The recipe revision. 86 87- :yocto_wiki:`PR Service </PR_Service>`: A 88 network-based service that helps automate keeping package feeds 89 compatible with existing package manager applications such as RPM, 90 APT, and OPKG. 91 92Whenever the binary package content changes, the binary package version 93must change. Changing the binary package version is accomplished by 94changing or "bumping" the :term:`PR` and/or :term:`PV` values. Increasing these 95values occurs one of two ways: 96 97- Automatically using a Package Revision Service (PR Service). 98 99- Manually incrementing the :term:`PR` and/or :term:`PV` variables. 100 101Given a primary challenge of any build system and its users is how to 102maintain a package feed that is compatible with existing package manager 103applications such as RPM, APT, and OPKG, using an automated system is 104much preferred over a manual system. In either system, the main 105requirement is that binary package version numbering increases in a 106linear fashion and that there is a number of version components that 107support that linear progression. For information on how to ensure 108package revisioning remains linear, see the 109":ref:`dev-manual/packages:automatically incrementing a package version number`" 110section. 111 112The following three sections provide related information on the PR 113Service, the manual method for "bumping" :term:`PR` and/or :term:`PV`, and on 114how to ensure binary package revisioning remains linear. 115 116Working With a PR Service 117------------------------- 118 119As mentioned, attempting to maintain revision numbers in the 120:term:`Metadata` is error prone, inaccurate, 121and causes problems for people submitting recipes. Conversely, the PR 122Service automatically generates increasing numbers, particularly the 123revision field, which removes the human element. 124 125.. note:: 126 127 For additional information on using a PR Service, you can see the 128 :yocto_wiki:`PR Service </PR_Service>` wiki page. 129 130The Yocto Project uses variables in order of decreasing priority to 131facilitate revision numbering (i.e. 132:term:`PE`, 133:term:`PV`, and 134:term:`PR` for epoch, version, and 135revision, respectively). The values are highly dependent on the policies 136and procedures of a given distribution and package feed. 137 138Because the OpenEmbedded build system uses 139":ref:`signatures <overview-manual/concepts:checksums (signatures)>`", which are 140unique to a given build, the build system knows when to rebuild 141packages. All the inputs into a given task are represented by a 142signature, which can trigger a rebuild when different. Thus, the build 143system itself does not rely on the :term:`PR`, :term:`PV`, and :term:`PE` numbers to 144trigger a rebuild. The signatures, however, can be used to generate 145these values. 146 147The PR Service works with both ``OEBasic`` and ``OEBasicHash`` 148generators. The value of :term:`PR` bumps when the checksum changes and the 149different generator mechanisms change signatures under different 150circumstances. 151 152As implemented, the build system includes values from the PR Service 153into the :term:`PR` field as an addition using the form "``.x``" so ``r0`` 154becomes ``r0.1``, ``r0.2`` and so forth. This scheme allows existing 155:term:`PR` values to be used for whatever reasons, which include manual 156:term:`PR` bumps, should it be necessary. 157 158By default, the PR Service is not enabled or running. Thus, the packages 159generated are just "self consistent". The build system adds and removes 160packages and there are no guarantees about upgrade paths but images will 161be consistent and correct with the latest changes. 162 163The simplest form for a PR Service is for a single host development system 164that builds the package feed (building system). For this scenario, you can 165enable a local PR Service by setting :term:`PRSERV_HOST` in your 166``local.conf`` file in the :term:`Build Directory`:: 167 168 PRSERV_HOST = "localhost:0" 169 170Once the service is started, packages will automatically 171get increasing :term:`PR` values and BitBake takes care of starting and 172stopping the server. 173 174If you have a more complex setup where multiple host development systems 175work against a common, shared package feed, you have a single PR Service 176running and it is connected to each building system. For this scenario, 177you need to start the PR Service using the ``bitbake-prserv`` command:: 178 179 bitbake-prserv --host ip --port port --start 180 181In addition to 182hand-starting the service, you need to update the ``local.conf`` file of 183each building system as described earlier so each system points to the 184server and port. 185 186It is also recommended you use build history, which adds some sanity 187checks to binary package versions, in conjunction with the server that 188is running the PR Service. To enable build history, add the following to 189each building system's ``local.conf`` file:: 190 191 # It is recommended to activate "buildhistory" for testing the PR service 192 INHERIT += "buildhistory" 193 BUILDHISTORY_COMMIT = "1" 194 195For information on build 196history, see the 197":ref:`dev-manual/build-quality:maintaining build output quality`" section. 198 199.. note:: 200 201 The OpenEmbedded build system does not maintain :term:`PR` information as 202 part of the shared state (sstate) packages. If you maintain an sstate 203 feed, it's expected that either all your building systems that 204 contribute to the sstate feed use a shared PR service, or you do not 205 run a PR service on any of your building systems. 206 207 That's because if you had multiple machines sharing a PR service but 208 not their sstate feed, you could end up with "diverging" hashes for 209 the same output artefacts. When presented to the share PR service, 210 each would be considered as new and would increase the revision 211 number, causing many unnecessary package upgrades. 212 213 For more information on shared state, see the 214 ":ref:`overview-manual/concepts:shared state cache`" 215 section in the Yocto Project Overview and Concepts Manual. 216 217Manually Bumping PR 218------------------- 219 220The alternative to setting up a PR Service is to manually "bump" the 221:term:`PR` variable. 222 223If a committed change results in changing the package output, then the 224value of the :term:`PR` variable needs to be increased (or "bumped") as part of 225that commit. For new recipes you should add the :term:`PR` variable and set 226its initial value equal to "r0", which is the default. Even though the 227default value is "r0", the practice of adding it to a new recipe makes 228it harder to forget to bump the variable when you make changes to the 229recipe in future. 230 231Usually, version increases occur only to binary packages. However, if 232for some reason :term:`PV` changes but does not increase, you can increase 233the :term:`PE` variable (Package Epoch). The :term:`PE` variable defaults to 234"0". 235 236Binary package version numbering strives to follow the `Debian Version 237Field Policy 238Guidelines <https://www.debian.org/doc/debian-policy/ch-controlfields.html>`__. 239These guidelines define how versions are compared and what "increasing" 240a version means. 241 242Automatically Incrementing a Package Version Number 243--------------------------------------------------- 244 245When fetching a repository, BitBake uses the 246:term:`SRCREV` variable to determine 247the specific source code revision from which to build. You set the 248:term:`SRCREV` variable to 249:term:`AUTOREV` to cause the 250OpenEmbedded build system to automatically use the latest revision of 251the software:: 252 253 SRCREV = "${AUTOREV}" 254 255Furthermore, you need to include a ``+`` sign in :term:`PV` in order to 256automatically update the version whenever the revision of the source 257code changes. Here is an example:: 258 259 PV = "1.0+git" 260 261The OpenEmbedded build system will automatically add the source control 262information to the end of the variable :term:`PKGV`, in this format:: 263 264 AUTOINC+source_code_revision 265 266The build system replaces the ``AUTOINC`` 267with a number. The number used depends on the state of the PR Service: 268 269- If PR Service is enabled, the build system increments the number, 270 which is similar to the behavior of 271 :term:`PR`. This behavior results in 272 linearly increasing package versions, which is desirable. Here is an 273 example: 274 275 .. code-block:: none 276 277 hello-world-git_0.0+git0+b6558dd387-r0.0_armv7a-neon.ipk 278 hello-world-git_0.0+git1+dd2f5c3565-r0.0_armv7a-neon.ipk 279 280- If PR Service is not enabled, the build system replaces the 281 ``AUTOINC`` placeholder with zero (i.e. "0"). This results in 282 changing the package version since the source revision is included. 283 However, package versions are not increased linearly. Here is an 284 example: 285 286 .. code-block:: none 287 288 hello-world-git_0.0+git0+b6558dd387-r0.0_armv7a-neon.ipk 289 hello-world-git_0.0+git0+dd2f5c3565-r0.0_armv7a-neon.ipk 290 291In summary, the OpenEmbedded build system does not track the history of 292binary package versions for this purpose. ``AUTOINC``, in this case, is 293comparable to :term:`PR`. If PR server is not enabled, ``AUTOINC`` in the 294package version is simply replaced by "0". If PR server is enabled, the 295build system keeps track of the package versions and bumps the number 296when the package revision changes. 297 298Handling Optional Module Packaging 299================================== 300 301Many pieces of software split functionality into optional modules (or 302plugins) and the plugins that are built might depend on configuration 303options. To avoid having to duplicate the logic that determines what 304modules are available in your recipe or to avoid having to package each 305module by hand, the OpenEmbedded build system provides functionality to 306handle module packaging dynamically. 307 308To handle optional module packaging, you need to do two things: 309 310- Ensure the module packaging is actually done. 311 312- Ensure that any dependencies on optional modules from other recipes 313 are satisfied by your recipe. 314 315Making Sure the Packaging is Done 316--------------------------------- 317 318To ensure the module packaging actually gets done, you use the 319``do_split_packages`` function within the ``populate_packages`` Python 320function in your recipe. The ``do_split_packages`` function searches for 321a pattern of files or directories under a specified path and creates a 322package for each one it finds by appending to the 323:term:`PACKAGES` variable and 324setting the appropriate values for ``FILES:packagename``, 325``RDEPENDS:packagename``, ``DESCRIPTION:packagename``, and so forth. 326Here is an example from the ``lighttpd`` recipe:: 327 328 python populate_packages:prepend () { 329 lighttpd_libdir = d.expand('${libdir}') 330 do_split_packages(d, lighttpd_libdir, '^mod_(.*).so$', 331 'lighttpd-module-%s', 'Lighttpd module for %s', 332 extra_depends='') 333 } 334 335The previous example specifies a number of things in the call to 336``do_split_packages``. 337 338- A directory within the files installed by your recipe through 339 :ref:`ref-tasks-install` in which to search. 340 341- A regular expression used to match module files in that directory. In 342 the example, note the parentheses () that mark the part of the 343 expression from which the module name should be derived. 344 345- A pattern to use for the package names. 346 347- A description for each package. 348 349- An empty string for ``extra_depends``, which disables the default 350 dependency on the main ``lighttpd`` package. Thus, if a file in 351 ``${libdir}`` called ``mod_alias.so`` is found, a package called 352 ``lighttpd-module-alias`` is created for it and the 353 :term:`DESCRIPTION` is set to 354 "Lighttpd module for alias". 355 356Often, packaging modules is as simple as the previous example. However, 357there are more advanced options that you can use within 358``do_split_packages`` to modify its behavior. And, if you need to, you 359can add more logic by specifying a hook function that is called for each 360package. It is also perfectly acceptable to call ``do_split_packages`` 361multiple times if you have more than one set of modules to package. 362 363For more examples that show how to use ``do_split_packages``, see the 364``connman.inc`` file in the ``meta/recipes-connectivity/connman/`` 365directory of the ``poky`` :ref:`source repository <overview-manual/development-environment:yocto project source repositories>`. You can 366also find examples in ``meta/classes-recipe/kernel.bbclass``. 367 368Here is a reference that shows ``do_split_packages`` mandatory and 369optional arguments:: 370 371 Mandatory arguments 372 373 root 374 The path in which to search 375 file_regex 376 Regular expression to match searched files. 377 Use parentheses () to mark the part of this 378 expression that should be used to derive the 379 module name (to be substituted where %s is 380 used in other function arguments as noted below) 381 output_pattern 382 Pattern to use for the package names. Must 383 include %s. 384 description 385 Description to set for each package. Must 386 include %s. 387 388 Optional arguments 389 390 postinst 391 Postinstall script to use for all packages 392 (as a string) 393 recursive 394 True to perform a recursive search --- default 395 False 396 hook 397 A hook function to be called for every match. 398 The function will be called with the following 399 arguments (in the order listed): 400 401 f 402 Full path to the file/directory match 403 pkg 404 The package name 405 file_regex 406 As above 407 output_pattern 408 As above 409 modulename 410 The module name derived using file_regex 411 extra_depends 412 Extra runtime dependencies (RDEPENDS) to be 413 set for all packages. The default value of None 414 causes a dependency on the main package 415 (${PN}) --- if you do not want this, pass empty 416 string '' for this parameter. 417 aux_files_pattern 418 Extra item(s) to be added to FILES for each 419 package. Can be a single string item or a list 420 of strings for multiple items. Must include %s. 421 postrm 422 postrm script to use for all packages (as a 423 string) 424 allow_dirs 425 True to allow directories to be matched - 426 default False 427 prepend 428 If True, prepend created packages to PACKAGES 429 instead of the default False which appends them 430 match_path 431 match file_regex on the whole relative path to 432 the root rather than just the filename 433 aux_files_pattern_verbatim 434 Extra item(s) to be added to FILES for each 435 package, using the actual derived module name 436 rather than converting it to something legal 437 for a package name. Can be a single string item 438 or a list of strings for multiple items. Must 439 include %s. 440 allow_links 441 True to allow symlinks to be matched --- default 442 False 443 summary 444 Summary to set for each package. Must include %s; 445 defaults to description if not set. 446 447 448 449Satisfying Dependencies 450----------------------- 451 452The second part for handling optional module packaging is to ensure that 453any dependencies on optional modules from other recipes are satisfied by 454your recipe. You can be sure these dependencies are satisfied by using 455the :term:`PACKAGES_DYNAMIC` 456variable. Here is an example that continues with the ``lighttpd`` recipe 457shown earlier:: 458 459 PACKAGES_DYNAMIC = "lighttpd-module-.*" 460 461The name 462specified in the regular expression can of course be anything. In this 463example, it is ``lighttpd-module-`` and is specified as the prefix to 464ensure that any :term:`RDEPENDS` and 465:term:`RRECOMMENDS` on a package 466name starting with the prefix are satisfied during build time. If you 467are using ``do_split_packages`` as described in the previous section, 468the value you put in :term:`PACKAGES_DYNAMIC` should correspond to the name 469pattern specified in the call to ``do_split_packages``. 470 471Using Runtime Package Management 472================================ 473 474During a build, BitBake always transforms a recipe into one or more 475packages. For example, BitBake takes the ``bash`` recipe and produces a 476number of packages (e.g. ``bash``, ``bash-bashbug``, 477``bash-completion``, ``bash-completion-dbg``, ``bash-completion-dev``, 478``bash-completion-extra``, ``bash-dbg``, and so forth). Not all 479generated packages are included in an image. 480 481In several situations, you might need to update, add, remove, or query 482the packages on a target device at runtime (i.e. without having to 483generate a new image). Examples of such situations include: 484 485- You want to provide in-the-field updates to deployed devices (e.g. 486 security updates). 487 488- You want to have a fast turn-around development cycle for one or more 489 applications that run on your device. 490 491- You want to temporarily install the "debug" packages of various 492 applications on your device so that debugging can be greatly improved 493 by allowing access to symbols and source debugging. 494 495- You want to deploy a more minimal package selection of your device 496 but allow in-the-field updates to add a larger selection for 497 customization. 498 499In all these situations, you have something similar to a more 500traditional Linux distribution in that in-field devices are able to 501receive pre-compiled packages from a server for installation or update. 502Being able to install these packages on a running, in-field device is 503what is termed "runtime package management". 504 505In order to use runtime package management, you need a host or server 506machine that serves up the pre-compiled packages plus the required 507metadata. You also need package manipulation tools on the target. The 508build machine is a likely candidate to act as the server. However, that 509machine does not necessarily have to be the package server. The build 510machine could push its artifacts to another machine that acts as the 511server (e.g. Internet-facing). In fact, doing so is advantageous for a 512production environment as getting the packages away from the development 513system's :term:`Build Directory` prevents accidental overwrites. 514 515A simple build that targets just one device produces more than one 516package database. In other words, the packages produced by a build are 517separated out into a couple of different package groupings based on 518criteria such as the target's CPU architecture, the target board, or the 519C library used on the target. For example, a build targeting the 520``qemux86`` device produces the following three package databases: 521``noarch``, ``i586``, and ``qemux86``. If you wanted your ``qemux86`` 522device to be aware of all the packages that were available to it, you 523would need to point it to each of these databases individually. In a 524similar way, a traditional Linux distribution usually is configured to 525be aware of a number of software repositories from which it retrieves 526packages. 527 528Using runtime package management is completely optional and not required 529for a successful build or deployment in any way. But if you want to make 530use of runtime package management, you need to do a couple things above 531and beyond the basics. The remainder of this section describes what you 532need to do. 533 534Build Considerations 535-------------------- 536 537This section describes build considerations of which you need to be 538aware in order to provide support for runtime package management. 539 540When BitBake generates packages, it needs to know what format or formats 541to use. In your configuration, you use the 542:term:`PACKAGE_CLASSES` 543variable to specify the format: 544 545#. Open the ``local.conf`` file inside your :term:`Build Directory` (e.g. 546 ``poky/build/conf/local.conf``). 547 548#. Select the desired package format as follows:: 549 550 PACKAGE_CLASSES ?= "package_packageformat" 551 552 where packageformat can be "ipk", "rpm", 553 "deb", or "tar" which are the supported package formats. 554 555 .. note:: 556 557 Because the Yocto Project supports four different package formats, 558 you can set the variable with more than one argument. However, the 559 OpenEmbedded build system only uses the first argument when 560 creating an image or Software Development Kit (SDK). 561 562If you would like your image to start off with a basic package database 563containing the packages in your current build as well as to have the 564relevant tools available on the target for runtime package management, 565you can include "package-management" in the 566:term:`IMAGE_FEATURES` 567variable. Including "package-management" in this configuration variable 568ensures that when the image is assembled for your target, the image 569includes the currently-known package databases as well as the 570target-specific tools required for runtime package management to be 571performed on the target. However, this is not strictly necessary. You 572could start your image off without any databases but only include the 573required on-target package tool(s). As an example, you could include 574"opkg" in your 575:term:`IMAGE_INSTALL` variable 576if you are using the IPK package format. You can then initialize your 577target's package database(s) later once your image is up and running. 578 579Whenever you perform any sort of build step that can potentially 580generate a package or modify existing package, it is always a good idea 581to re-generate the package index after the build by using the following 582command:: 583 584 $ bitbake package-index 585 586It might be tempting to build the 587package and the package index at the same time with a command such as 588the following:: 589 590 $ bitbake some-package package-index 591 592Do not do this as 593BitBake does not schedule the package index for after the completion of 594the package you are building. Consequently, you cannot be sure of the 595package index including information for the package you just built. 596Thus, be sure to run the package update step separately after building 597any packages. 598 599You can use the 600:term:`PACKAGE_FEED_ARCHS`, 601:term:`PACKAGE_FEED_BASE_PATHS`, 602and 603:term:`PACKAGE_FEED_URIS` 604variables to pre-configure target images to use a package feed. If you 605do not define these variables, then manual steps as described in the 606subsequent sections are necessary to configure the target. You should 607set these variables before building the image in order to produce a 608correctly configured image. 609 610.. note:: 611 612 Your image will need enough free storage space to run package upgrades, 613 especially if many of them need to be downloaded at the same time. 614 You should make sure images are created with enough free space 615 by setting the :term:`IMAGE_ROOTFS_EXTRA_SPACE` variable. 616 617When your build is complete, your packages reside in the 618``${TMPDIR}/deploy/packageformat`` directory. For example, if 619``${``\ :term:`TMPDIR`\ ``}`` is 620``tmp`` and your selected package type is RPM, then your RPM packages 621are available in ``tmp/deploy/rpm``. 622 623Host or Server Machine Setup 624---------------------------- 625 626Although other protocols are possible, a server using HTTP typically 627serves packages. If you want to use HTTP, then set up and configure a 628web server such as Apache 2, lighttpd, or Python web server on the 629machine serving the packages. 630 631To keep things simple, this section describes how to set up a 632Python web server to share package feeds from the developer's 633machine. Although this server might not be the best for a production 634environment, the setup is simple and straight forward. Should you want 635to use a different server more suited for production (e.g. Apache 2, 636Lighttpd, or Nginx), take the appropriate steps to do so. 637 638From within the :term:`Build Directory` where you have built an image based on 639your packaging choice (i.e. the :term:`PACKAGE_CLASSES` setting), simply start 640the server. The following example assumes a :term:`Build Directory` of ``poky/build`` 641and a :term:`PACKAGE_CLASSES` setting of ":ref:`ref-classes-package_rpm`":: 642 643 $ cd poky/build/tmp/deploy/rpm 644 $ python3 -m http.server 645 646Target Setup 647------------ 648 649Setting up the target differs depending on the package management 650system. This section provides information for RPM, IPK, and DEB. 651 652Using RPM 653~~~~~~~~~ 654 655The :wikipedia:`Dandified Packaging <DNF_(software)>` (DNF) performs 656runtime package management of RPM packages. In order to use DNF for 657runtime package management, you must perform an initial setup on the 658target machine for cases where the ``PACKAGE_FEED_*`` variables were not 659set as part of the image that is running on the target. This means if 660you built your image and did not use these variables as part of the 661build and your image is now running on the target, you need to perform 662the steps in this section if you want to use runtime package management. 663 664.. note:: 665 666 For information on the ``PACKAGE_FEED_*`` variables, see 667 :term:`PACKAGE_FEED_ARCHS`, :term:`PACKAGE_FEED_BASE_PATHS`, and 668 :term:`PACKAGE_FEED_URIS` in the Yocto Project Reference Manual variables 669 glossary. 670 671On the target, you must inform DNF that package databases are available. 672You do this by creating a file named 673``/etc/yum.repos.d/oe-packages.repo`` and defining the ``oe-packages``. 674 675As an example, assume the target is able to use the following package 676databases: ``all``, ``i586``, and ``qemux86`` from a server named 677``my.server``. The specifics for setting up the web server are up to 678you. The critical requirement is that the URIs in the target repository 679configuration point to the correct remote location for the feeds. 680 681.. note:: 682 683 For development purposes, you can point the web server to the build 684 system's ``deploy`` directory. However, for production use, it is better to 685 copy the package directories to a location outside of the build area and use 686 that location. Doing so avoids situations where the build system 687 overwrites or changes the ``deploy`` directory. 688 689When telling DNF where to look for the package databases, you must 690declare individual locations per architecture or a single location used 691for all architectures. You cannot do both: 692 693- *Create an Explicit List of Architectures:* Define individual base 694 URLs to identify where each package database is located: 695 696 .. code-block:: none 697 698 [oe-packages] 699 baseurl=http://my.server/rpm/i586 http://my.server/rpm/qemux86 http://my.server/rpm/all 700 701 This example 702 informs DNF about individual package databases for all three 703 architectures. 704 705- *Create a Single (Full) Package Index:* Define a single base URL that 706 identifies where a full package database is located:: 707 708 [oe-packages] 709 baseurl=http://my.server/rpm 710 711 This example informs DNF about a single 712 package database that contains all the package index information for 713 all supported architectures. 714 715Once you have informed DNF where to find the package databases, you need 716to fetch them: 717 718.. code-block:: none 719 720 # dnf makecache 721 722DNF is now able to find, install, and 723upgrade packages from the specified repository or repositories. 724 725.. note:: 726 727 See the `DNF documentation <https://dnf.readthedocs.io/en/latest/>`__ for 728 additional information. 729 730Using IPK 731~~~~~~~~~ 732 733The ``opkg`` application performs runtime package management of IPK 734packages. You must perform an initial setup for ``opkg`` on the target 735machine if the 736:term:`PACKAGE_FEED_ARCHS`, 737:term:`PACKAGE_FEED_BASE_PATHS`, 738and 739:term:`PACKAGE_FEED_URIS` 740variables have not been set or the target image was built before the 741variables were set. 742 743The ``opkg`` application uses configuration files to find available 744package databases. Thus, you need to create a configuration file inside 745the ``/etc/opkg/`` directory, which informs ``opkg`` of any repository 746you want to use. 747 748As an example, suppose you are serving packages from a ``ipk/`` 749directory containing the ``i586``, ``all``, and ``qemux86`` databases 750through an HTTP server named ``my.server``. On the target, create a 751configuration file (e.g. ``my_repo.conf``) inside the ``/etc/opkg/`` 752directory containing the following: 753 754.. code-block:: none 755 756 src/gz all http://my.server/ipk/all 757 src/gz i586 http://my.server/ipk/i586 758 src/gz qemux86 http://my.server/ipk/qemux86 759 760Next, instruct ``opkg`` to fetch the 761repository information: 762 763.. code-block:: none 764 765 # opkg update 766 767The ``opkg`` application is now able to find, install, and upgrade packages 768from the specified repository. 769 770Using DEB 771~~~~~~~~~ 772 773The ``apt`` application performs runtime package management of DEB 774packages. This application uses a source list file to find available 775package databases. You must perform an initial setup for ``apt`` on the 776target machine if the 777:term:`PACKAGE_FEED_ARCHS`, 778:term:`PACKAGE_FEED_BASE_PATHS`, 779and 780:term:`PACKAGE_FEED_URIS` 781variables have not been set or the target image was built before the 782variables were set. 783 784To inform ``apt`` of the repository you want to use, you might create a 785list file (e.g. ``my_repo.list``) inside the 786``/etc/apt/sources.list.d/`` directory. As an example, suppose you are 787serving packages from a ``deb/`` directory containing the ``i586``, 788``all``, and ``qemux86`` databases through an HTTP server named 789``my.server``. The list file should contain: 790 791.. code-block:: none 792 793 deb http://my.server/deb/all ./ 794 deb http://my.server/deb/i586 ./ 795 deb http://my.server/deb/qemux86 ./ 796 797Next, instruct the ``apt`` application 798to fetch the repository information: 799 800.. code-block:: none 801 802 $ sudo apt update 803 804After this step, 805``apt`` is able to find, install, and upgrade packages from the 806specified repository. 807 808Generating and Using Signed Packages 809==================================== 810 811In order to add security to RPM packages used during a build, you can 812take steps to securely sign them. Once a signature is verified, the 813OpenEmbedded build system can use the package in the build. If security 814fails for a signed package, the build system stops the build. 815 816This section describes how to sign RPM packages during a build and how 817to use signed package feeds (repositories) when doing a build. 818 819Signing RPM Packages 820-------------------- 821 822To enable signing RPM packages, you must set up the following 823configurations in either your ``local.config`` or ``distro.config`` 824file:: 825 826 # Inherit sign_rpm.bbclass to enable signing functionality 827 INHERIT += " sign_rpm" 828 # Define the GPG key that will be used for signing. 829 RPM_GPG_NAME = "key_name" 830 # Provide passphrase for the key 831 RPM_GPG_PASSPHRASE = "passphrase" 832 833.. note:: 834 835 Be sure to supply appropriate values for both `key_name` and 836 `passphrase`. 837 838Aside from the ``RPM_GPG_NAME`` and ``RPM_GPG_PASSPHRASE`` variables in 839the previous example, two optional variables related to signing are available: 840 841- *GPG_BIN:* Specifies a ``gpg`` binary/wrapper that is executed 842 when the package is signed. 843 844- *GPG_PATH:* Specifies the ``gpg`` home directory used when the 845 package is signed. 846 847Processing Package Feeds 848------------------------ 849 850In addition to being able to sign RPM packages, you can also enable 851signed package feeds for IPK and RPM packages. 852 853The steps you need to take to enable signed package feed use are similar 854to the steps used to sign RPM packages. You must define the following in 855your ``local.config`` or ``distro.config`` file:: 856 857 INHERIT += "sign_package_feed" 858 PACKAGE_FEED_GPG_NAME = "key_name" 859 PACKAGE_FEED_GPG_PASSPHRASE_FILE = "path_to_file_containing_passphrase" 860 861For signed package feeds, the passphrase must be specified in a separate file, 862which is pointed to by the ``PACKAGE_FEED_GPG_PASSPHRASE_FILE`` 863variable. Regarding security, keeping a plain text passphrase out of the 864configuration is more secure. 865 866Aside from the ``PACKAGE_FEED_GPG_NAME`` and 867``PACKAGE_FEED_GPG_PASSPHRASE_FILE`` variables, three optional variables 868related to signed package feeds are available: 869 870- *GPG_BIN* Specifies a ``gpg`` binary/wrapper that is executed 871 when the package is signed. 872 873- *GPG_PATH:* Specifies the ``gpg`` home directory used when the 874 package is signed. 875 876- *PACKAGE_FEED_GPG_SIGNATURE_TYPE:* Specifies the type of ``gpg`` 877 signature. This variable applies only to RPM and IPK package feeds. 878 Allowable values for the ``PACKAGE_FEED_GPG_SIGNATURE_TYPE`` are 879 "ASC", which is the default and specifies ascii armored, and "BIN", 880 which specifies binary. 881 882Testing Packages With ptest 883=========================== 884 885See the :ref:`test-manual/ptest:Testing Packages With ptest` section of the 886Yocto Project Test Environment Manual. 887 888Creating Node Package Manager (NPM) Packages 889============================================ 890 891:wikipedia:`NPM <Npm_(software)>` is a package manager for the JavaScript 892programming language. The Yocto Project supports the NPM 893:ref:`fetcher <bitbake-user-manual/bitbake-user-manual-fetching:fetchers>`. 894You can use this fetcher in combination with 895:doc:`devtool </ref-manual/devtool-reference>` to create recipes that produce 896NPM packages. 897 898There are two workflows that allow you to create NPM packages using 899``devtool``: the NPM registry modules method and the NPM project code 900method. 901 902.. note:: 903 904 While it is possible to create NPM recipes manually, using 905 ``devtool`` is far simpler. 906 907Additionally, some requirements and caveats exist. 908 909Requirements and Caveats 910------------------------ 911 912You need to be aware of the following before using ``devtool`` to create 913NPM packages: 914 915- Of the two methods that you can use ``devtool`` to create NPM 916 packages, the registry approach is slightly simpler. However, you 917 might consider the project approach because you do not have to 918 publish your module in the `NPM registry <https://docs.npmjs.com/misc/registry>`__, 919 which is NPM's public registry. 920 921- Be familiar with 922 :doc:`devtool </ref-manual/devtool-reference>`. 923 924- The NPM host tools need the native ``nodejs-npm`` package, which is 925 part of the OpenEmbedded environment. You need to get the package by 926 cloning the :oe_git:`meta-openembedded </meta-openembedded>` 927 repository. Be sure to add the path to your local copy 928 to your ``bblayers.conf`` file. 929 930- ``devtool`` cannot detect native libraries in module dependencies. 931 Consequently, you must manually add packages to your recipe. 932 933- While deploying NPM packages, ``devtool`` cannot determine which 934 dependent packages are missing on the target (e.g. the node runtime 935 ``nodejs``). Consequently, you need to find out what files are 936 missing and be sure they are on the target. 937 938- Although you might not need NPM to run your node package, it is 939 useful to have NPM on your target. The NPM package name is 940 ``nodejs-npm``. 941 942Using the Registry Modules Method 943--------------------------------- 944 945This section presents an example that uses the ``cute-files`` module, 946which is a file browser web application. 947 948.. note:: 949 950 You must know the ``cute-files`` module version. 951 952The first thing you need to do is use ``devtool`` and the NPM fetcher to 953create the recipe:: 954 955 $ devtool add "npm://registry.npmjs.org;package=cute-files;version=1.0.2" 956 957The 958``devtool add`` command runs ``recipetool create`` and uses the same 959fetch URI to download each dependency and capture license details where 960possible. The result is a generated recipe. 961 962After running for quite a long time, in particular building the 963``nodejs-native`` package, the command should end as follows:: 964 965 INFO: Recipe /home/.../build/workspace/recipes/cute-files/cute-files_1.0.2.bb has been automatically created; further editing may be required to make it fully functional 966 967The recipe file is fairly simple and contains every license that 968``recipetool`` finds and includes the licenses in the recipe's 969:term:`LIC_FILES_CHKSUM` 970variables. You need to examine the variables and look for those with 971"unknown" in the :term:`LICENSE` 972field. You need to track down the license information for "unknown" 973modules and manually add the information to the recipe. 974 975``recipetool`` creates a "shrinkwrap" file for your recipe. Shrinkwrap 976files capture the version of all dependent modules. Many packages do not 977provide shrinkwrap files but ``recipetool`` will create a shrinkwrap file as it 978runs. 979 980.. note:: 981 982 A package is created for each sub-module. This policy is the only 983 practical way to have the licenses for all of the dependencies 984 represented in the license manifest of the image. 985 986The ``devtool edit-recipe`` command lets you take a look at the recipe:: 987 988 $ devtool edit-recipe cute-files 989 # Recipe created by recipetool 990 # This is the basis of a recipe and may need further editing in order to be fully functional. 991 # (Feel free to remove these comments when editing.) 992 993 SUMMARY = "Turn any folder on your computer into a cute file browser, available on the local network." 994 # WARNING: the following LICENSE and LIC_FILES_CHKSUM values are best guesses - it is 995 # your responsibility to verify that the values are complete and correct. 996 # 997 # NOTE: multiple licenses have been detected; they have been separated with & 998 # in the LICENSE value for now since it is a reasonable assumption that all 999 # of the licenses apply. If instead there is a choice between the multiple 1000 # licenses then you should change the value to separate the licenses with | 1001 # instead of &. If there is any doubt, check the accompanying documentation 1002 # to determine which situation is applicable. 1003 1004 SUMMARY = "Turn any folder on your computer into a cute file browser, available on the local network." 1005 LICENSE = "BSD-3-Clause & ISC & MIT" 1006 LIC_FILES_CHKSUM = "file://LICENSE;md5=71d98c0a1db42956787b1909c74a86ca \ 1007 file://node_modules/accepts/LICENSE;md5=bf1f9ad1e2e1d507aef4883fff7103de \ 1008 file://node_modules/array-flatten/LICENSE;md5=44088ba57cb871a58add36ce51b8de08 \ 1009 ... 1010 file://node_modules/cookie-signature/Readme.md;md5=57ae8b42de3dd0c1f22d5f4cf191e15a" 1011 1012 SRC_URI = " \ 1013 npm://registry.npmjs.org/;package=cute-files;version=${PV} \ 1014 npmsw://${THISDIR}/${BPN}/npm-shrinkwrap.json \ 1015 " 1016 1017 S = "${WORKDIR}/npm" 1018 1019 inherit npm 1020 1021 LICENSE:${PN} = "MIT" 1022 LICENSE:${PN}-accepts = "MIT" 1023 LICENSE:${PN}-array-flatten = "MIT" 1024 ... 1025 LICENSE:${PN}-vary = "MIT" 1026 1027Three key points in the previous example are: 1028 1029- :term:`SRC_URI` uses the NPM 1030 scheme so that the NPM fetcher is used. 1031 1032- ``recipetool`` collects all the license information. If a 1033 sub-module's license is unavailable, the sub-module's name appears in 1034 the comments. 1035 1036- The ``inherit npm`` statement causes the :ref:`ref-classes-npm` class to 1037 package up all the modules. 1038 1039You can run the following command to build the ``cute-files`` package:: 1040 1041 $ devtool build cute-files 1042 1043Remember that ``nodejs`` must be installed on 1044the target before your package. 1045 1046Assuming 192.168.7.2 for the target's IP address, use the following 1047command to deploy your package:: 1048 1049 $ devtool deploy-target -s cute-files root@192.168.7.2 1050 1051Once the package is installed on the target, you can 1052test the application to show the contents of any directory:: 1053 1054 $ cd /usr/lib/node_modules/cute-files 1055 $ cute-files 1056 1057On a browser, 1058go to ``http://192.168.7.2:3000`` and you see the following: 1059 1060.. image:: figures/cute-files-npm-example.png 1061 :width: 100% 1062 1063You can find the recipe in ``workspace/recipes/cute-files``. You can use 1064the recipe in any layer you choose. 1065 1066Using the NPM Projects Code Method 1067---------------------------------- 1068 1069Although it is useful to package modules already in the NPM registry, 1070adding ``node.js`` projects under development is a more common developer 1071use case. 1072 1073This section covers the NPM projects code method, which is very similar 1074to the "registry" approach described in the previous section. In the NPM 1075projects method, you provide ``devtool`` with an URL that points to the 1076source files. 1077 1078Replicating the same example, (i.e. ``cute-files``) use the following 1079command:: 1080 1081 $ devtool add https://github.com/martinaglv/cute-files.git 1082 1083The recipe this command generates is very similar to the recipe created in 1084the previous section. However, the :term:`SRC_URI` looks like the following:: 1085 1086 SRC_URI = " \ 1087 git://github.com/martinaglv/cute-files.git;protocol=https;branch=master \ 1088 npmsw://${THISDIR}/${BPN}/npm-shrinkwrap.json \ 1089 " 1090 1091In this example, 1092the main module is taken from the Git repository and dependencies are 1093taken from the NPM registry. Other than those differences, the recipe is 1094basically the same between the two methods. You can build and deploy the 1095package exactly as described in the previous section that uses the 1096registry modules method. 1097 1098Adding custom metadata to packages 1099================================== 1100 1101The variable 1102:term:`PACKAGE_ADD_METADATA` 1103can be used to add additional metadata to packages. This is reflected in 1104the package control/spec file. To take the ipk format for example, the 1105CONTROL file stored inside would contain the additional metadata as 1106additional lines. 1107 1108The variable can be used in multiple ways, including using suffixes to 1109set it for a specific package type and/or package. Note that the order 1110of precedence is the same as this list: 1111 1112- ``PACKAGE_ADD_METADATA_<PKGTYPE>:<PN>`` 1113 1114- ``PACKAGE_ADD_METADATA_<PKGTYPE>`` 1115 1116- ``PACKAGE_ADD_METADATA:<PN>`` 1117 1118- :term:`PACKAGE_ADD_METADATA` 1119 1120`<PKGTYPE>` is a parameter and expected to be a distinct name of specific 1121package type: 1122 1123- IPK for .ipk packages 1124 1125- DEB for .deb packages 1126 1127- RPM for .rpm packages 1128 1129`<PN>` is a parameter and expected to be a package name. 1130 1131The variable can contain multiple [one-line] metadata fields separated 1132by the literal sequence '\\n'. The separator can be redefined using the 1133variable flag ``separator``. 1134 1135Here is an example that adds two custom fields for ipk 1136packages:: 1137 1138 PACKAGE_ADD_METADATA_IPK = "Vendor: CustomIpk\nGroup:Applications/Spreadsheets" 1139 1140