You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This is a discussion that covers improving the user experience of external projects depending on aktualizr, including aktualizr-lite
Description
The proposal is to export an API from the aktualizr project so that it can be included from dependant projects, see the step 11 of the cmake tutorial for more information.
In short this would be enabling the dependent projects of using find_package(aktualizr REQUIRED) instead of including it as a git submodule, which would have the following advantages:
Help system builders control the versioning and patching of each of these projects independently
Force the aktualizr project to export a fixed API with a proper semantic versioning scheme, which would in turn propagate to all it's dependents, and give them a view of breaking API changes in a versioned manner
Add the missing install calls, which would help the developers install a version of aktualizr on their machines and base multiple projects on the same version of aktualizr, instead of having this version as a transitive dependency for the projects including it as submodule
Push the project into adapting the modern cmake format and modernize the project
Proposed implementation
Updating target references to solve transitive dependencies
In order to be able to export the cmake targets to an external project, these targets have to be setup correctly with the appropriate TAGET_PROPERTIES attached to them. Appropriate in the world of modern cmake means replacing the usage of cmake variables attached to a target (e.g. ${OPENSSL_INCLUDE_DIR} and ${OPENSSL_LIBRARIES}) with the corresponding target exported from the find_package'd package (like OpenSSL::SSL). This is important as it solves build time problems where the building environment of aktualizr and it's dependent project (e.g. aktualizr-lite) are different.
For example, let's consider both projects (aktualizr-lite depending on aktualizr) are built with yocto, each with a different recipe. yocto generates a sysroot per recipe when building, and openssl on the aktualizr sysroot would point to ${aktualizr_sysroot}/usr/lib/openssl.so. If ${OPENSSL_LIBRARIES} is attached as a cmake property to the aktualizr_lib target, exporting this target from the project would propagate the ${OPENSSL_LIBRARIES} entry within it's properties to the parent project (aktualizr-lite). Now the upstream project would be trying to find ${aktualizr_sysroot}/usr/lib/openssl.so when being built, however this induces a race condition since the ${aktualizr_sysroot} is safe to be deleted in the yocto context whenever the build process of aktualize finished.
An alternative to this behavior would be using OpenSSL::SSL as a publicly linked library to the aktualizr_lib, this way the target will be re-resolved in the parent project when stumbled upon. To help with the resolution of such a target, a find_dependency(OpenSSL) call should be added to the end of the aktualizrConfig.cmake file exported by this project. This line would be executed when find_package(aktualizr REQUIRED) is called from the parent project, and in turns define the OpenSSL::SSL target
Adaptating the FindModules.cmake scripts defined in the project, and exporting them for transitive dependencies
Ideally, each project should export it's own Config.cmake scripts, but for projects not built with cmake, or old styled cmake projects, these scripts are not exported. This requires parent projects that are in need for such libraries to define their own FindModules.cmake scripts like in ./cmake-modules. However, if these find scripts do not define targets, the same problem mentioned in point 1 would appear, and therefore updating the modules is required to be able to export the project. That can be easily applied with the following declarations in these scripts
Also, these scripts are helpful for parent projects, so they can be also exported with the config.cmake file, and referenced from it, so that each project depending on aktualizr would have them available.
Distinction between public and private headers
headers are used to reduce duplicate declarations in source files, but these headers may or may not be exported by the active project so that parent projects can include and use them. When deciding to install aktualizr (whether on the system or in a local test directory), a decision should be made about which headers are, and which are not exported by the project. A common pattern would be placing the private headers in the src/ directory of the project, and public headers in the include directory of the project. Then on installation time the include folder can be directly installed as is to the target location. The main issue is propagated from aktualizr-lite which should expose it's offline/client.h to give the users the ability to control offline updates, but that headers includes the following headers
In addition to that, these headers should be pushed to a directory matching the name of project, not to conflict with other headers from different installations or different projects. Therefore changes to the references of these headers should be made in the source code to push this namespace
All these changes are already performed in the following patch
I believe the suggested modification has potential benefits across various contexts and is not limited to Foundries/aktualizr-lite alone. Consequently, I recommend submitting the issue or a pull request directly to the original/upstream project repository based on this patch.
The main issue is propagated from aktualizr-lite which should expose it's offline/client.h to >give the users the ability to control offline updates, but that headers includes the following >headers
The offline/client.h file serves as an internal interface and is never intended to be exposed as a public interface. Presently, we are actively integrating offline update support into our public API.
I recommend transitioning to the usage of the public interface once we post it. Utilizing the internal interface may potentially result in subtle issues.
Sorry for the misleading comment there, I meant that the aktualizr project should expose the offline/client.h to it's public API because it's used (among other headers) here for example.
I will update the comment on the upstream project issue
This is a discussion that covers improving the user experience of external projects depending on aktualizr, including aktualizr-lite
Description
The proposal is to export an API from the aktualizr project so that it can be included from dependant projects, see the step 11 of the cmake tutorial for more information.
In short this would be enabling the dependent projects of using
find_package(aktualizr REQUIRED)
instead of including it as a git submodule, which would have the following advantages:Proposed implementation
In order to be able to export the cmake targets to an external project, these targets have to be setup correctly with the appropriate TAGET_PROPERTIES attached to them. Appropriate in the world of modern cmake means replacing the usage of cmake variables attached to a target (e.g.
${OPENSSL_INCLUDE_DIR}
and${OPENSSL_LIBRARIES}
) with the corresponding target exported from thefind_package
'd package (likeOpenSSL::SSL
). This is important as it solves build time problems where the building environment of aktualizr and it's dependent project (e.g. aktualizr-lite) are different.For example, let's consider both projects (aktualizr-lite depending on aktualizr) are built with yocto, each with a different recipe. yocto generates a sysroot per recipe when building, and openssl on the aktualizr sysroot would point to ${aktualizr_sysroot}/usr/lib/openssl.so. If ${OPENSSL_LIBRARIES} is attached as a cmake property to the
aktualizr_lib
target, exporting this target from the project would propagate the ${OPENSSL_LIBRARIES} entry within it's properties to the parent project (aktualizr-lite). Now the upstream project would be trying to find ${aktualizr_sysroot}/usr/lib/openssl.so when being built, however this induces a race condition since the ${aktualizr_sysroot} is safe to be deleted in the yocto context whenever the build process of aktualize finished.An alternative to this behavior would be using
OpenSSL::SSL
as a publicly linked library to theaktualizr_lib
, this way the target will be re-resolved in the parent project when stumbled upon. To help with the resolution of such a target, a find_dependency(OpenSSL) call should be added to the end of the aktualizrConfig.cmake file exported by this project. This line would be executed whenfind_package(aktualizr REQUIRED)
is called from the parent project, and in turns define theOpenSSL::SSL
targetIdeally, each project should export it's own Config.cmake scripts, but for projects not built with cmake, or old styled cmake projects, these scripts are not exported. This requires parent projects that are in need for such libraries to define their own FindModules.cmake scripts like in
./cmake-modules
. However, if these find scripts do not define targets, the same problem mentioned in point 1 would appear, and therefore updating the modules is required to be able to export the project. That can be easily applied with the following declarations in these scriptsAlso, these scripts are helpful for parent projects, so they can be also exported with the config.cmake file, and referenced from it, so that each project depending on aktualizr would have them available.
headers are used to reduce duplicate declarations in source files, but these headers may or may not be exported by the active project so that parent projects can include and use them. When deciding to install aktualizr (whether on the system or in a local test directory), a decision should be made about which headers are, and which are not exported by the project. A common pattern would be placing the private headers in the
src/
directory of the project, and public headers in theinclude
directory of the project. Then on installation time theinclude
folder can be directly installed as is to the target location. The main issue is propagated fromaktualizr-lite
which should expose it'soffline/client.h
to give the users the ability to control offline updates, but that headers includes the following headersWhich forces aktualizr project to export them and force all the following headers to be exported as well
In addition to that, these headers should be pushed to a directory matching the name of project, not to conflict with other headers from different installations or different projects. Therefore changes to the references of these headers should be made in the source code to push this namespace
All these changes are already performed in the following patch
0000-updates.patch
The text was updated successfully, but these errors were encountered: