xref: /openbmc/openbmc/poky/documentation/dev-manual/packages.rst (revision 96e4b4e121e0e2da1535d7d537d6a982a6ff5bc0)
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