commit | ceeba4f9684be6b705568718d9a1afd5886989cd | [log] [tgz] |
---|---|---|
author | Ed Tanous <edtanous@google.com> | Mon May 16 14:59:33 2022 -0700 |
committer | Ed Tanous <ed@tanous.net> | Thu Jun 23 21:55:53 2022 +0000 |
tree | 1187315e5af9ae82c5d87405e521a11aed49d79a | |
parent | f1eac5775ed6593fe7148118304bdecec08af1ef [diff] |
Start to document maintainer responsibilities In the past, a number of contributors have inquired about what bmcweb maintainers do, and how they can become one. As bmcweb grows in popularity and scope, it's important that we be able to spread out the load amongst more maintainers, and make sure that we're including community members, while still keeping the core principles that made bmcweb attract so many users intact. To that end, I've attempted to document, in the OWNERS file, the basic responsibilities that are required to be a maintainer within bmcweb. I very much expect that this list evolves over time, but this is expected to be a starting point, and a place to point people that are interested in becoming a maintainer of bmcweb. As a pattern, I would like to see this kind of "how to be a maintainer of this component" called out in more repositories, as I believe it opens up the community to more people, common solutions, and better results. Signed-off-by: Ed Tanous <edtanous@google.com> Change-Id: Id156edd7e340df9432bf5a8a73e8a117b5d4099a
This component attempts to be a "do everything" embedded webserver for openbmc.
At this time, the webserver implements a few interfaces:
BMCWeb is configured by setting -D
flags that correspond to options in bmcweb/meson_options.txt
and then compiling. For example, meson <builddir> -Dkvm=disabled ...
followed by ninja
in build directory. The option names become C++ preprocessor symbols that control which code is compiled into the program.
meson builddir ninja -C builddir
meson builddir -Dbuildtype=minsize -Db_lto=true -Dtests=disabled ninja -C buildir
If any of the dependencies are not found on the host system during configuration, meson automatically gets them via its wrap dependencies mentioned in bmcweb/subprojects
.
meson builddir -Dwrap_mode=nofallback ninja -C builddir
meson builddir -Dbuildtype=debug ninja -C builddir
meson builddir -Db_coverage=true -Dtests=enabled ninja -C builddir test ninja -C builddir coverage
When BMCWeb starts running, it reads persistent configuration data (such as UUID and session data) from a local file. If this is not usable, it generates a new configuration.
When BMCWeb SSL support is enabled and a usable certificate is not found, it will generate a self-sign a certificate before launching the server. The keys are generated by the secp384r1
algorithm. The certificate
C=US, O=OpenBMC, CN=testhost
,SHA-256
algorithm.