doc: Start writing some in-tree documentation
[petitboot] / doc / dev / design.rst
1 Design Topics
2 =============
3
4 When considering new functionality or other changes to Petitboot there are a few guidelines we do our best to adhere to:
5
6 Be Generic
7 ----------
8
9 Avoid adding code that ties Petitboot to a particular platform or functionality by default. Avoid making assumptions about the system that Petitboot may be running on. Platform specific functionality should as much as possible be confined to `platform-` files. Especially when thinking about dependencies on outside utilities or tools consider using the pb-plugin interface instead.
10
11 Don't Surprise The User
12 -----------------------
13
14 Communicate clearly to the user what is happening. What the UI says is happening should be what actually happens.
15 A particular example of this is the kernel command line: there are a few problems that would be easier to solve if we could modify the command line of the kernel to be booted, but this would be something that interferes with the users expectations and depending on their scenario could cause them problems.
16
17 Avoid Dependencies On The Target Operating System
18 -------------------------------------------------
19
20 Supporting multiple configuration formats means that Petitboot can be dropped in as the bootloader for most existing systems without any change in the target operating system or its bootloader configuration. Avoid any changes that would require a corresponding update in the target operating system or dependencies on any particular version of Petitboot.
21
22 Maintain Server-Client Separation
23 ---------------------------------
24
25 As much as possible the server should perform any actions, and the clients should only makes requests to the server. This is particularly true with the introduction of Petitboot "users" and password restrictions.
26 An exception to this is the running of Petitboot plugins since these need to be run in the visible shell; however these are still subject to user permissions if enabled.
27
28 Abstract Dependencies
29 ---------------------
30
31 Avoid direct dependencies on certain utilities or versions of utilities. If there are several versions or interfaces to a utility that Petitboot might access, abstract these differences where possible. (See handling of different utilities such as tftp, udhcpc, etc).