]> git.ozlabs.org Git - petitboot/blobdiff - lib/types/types.h
lib: Add AUTH_MSG_DECRYPT
[petitboot] / lib / types / types.h
index 5c5f6ed80110e8e341bc2f3380add6b63f2affa8..433a37b2578d9a58d03074761c447b684d474dd1 100644 (file)
@@ -11,6 +11,7 @@ enum device_type {
        DEVICE_TYPE_USB,
        DEVICE_TYPE_OPTICAL,
        DEVICE_TYPE_ANY,
+       DEVICE_TYPE_LUKS,
        DEVICE_TYPE_UNKNOWN,
 };
 
@@ -52,11 +53,33 @@ struct boot_option {
        char            *initrd_file;
        char            *dtb_file;
        char            *boot_args;
+       char            *args_sig_file;
        bool            is_default;
+       bool            is_autoboot_default;
 
        struct list_item        list;
 
        void            *ui_info;
+
+       enum {
+               DISCOVER_BOOT_OPTION,
+               DISCOVER_PLUGIN_OPTION,
+       } type;
+};
+
+struct plugin_option {
+       char            *id;
+       char            *name;
+       char            *vendor;
+       char            *vendor_id;
+       char            *version;
+       char            *date;
+       char            *plugin_file;
+
+       unsigned int    n_executables;
+       char            **executables;
+
+       void            *ui_info;
 };
 
 struct boot_command {
@@ -65,17 +88,23 @@ struct boot_command {
        char *initrd_file;
        char *dtb_file;
        char *boot_args;
-       char *tty;
+       char *args_sig_file;
+       char *console;
 };
 
-struct boot_status {
-       enum {
-               BOOT_STATUS_INFO,
-               BOOT_STATUS_ERROR,
+struct status {
+       enum status_type {
+               STATUS_INFO,
+               STATUS_ERROR,
        } type;
        char    *message;
-       char    *detail;
-       int     progress;
+       bool    backlog;
+       bool    boot_active;
+};
+
+struct statuslog_entry {
+       struct status           *status;
+       struct list_item        list;
 };
 
 struct interface_info {
@@ -83,6 +112,8 @@ struct interface_info {
        uint8_t         *hwaddr;
        char            *name;
        bool            link;
+       char            *address;
+       char            *address_v6;
 };
 
 struct blockdev_info {
@@ -127,6 +158,7 @@ struct interface_config {
                        char *url;
                } static_config;
        };
+       bool    override;
 };
 
 struct network_config {
@@ -157,18 +189,25 @@ struct config {
 
        unsigned int            ipmi_bootdev;
        bool                    ipmi_bootdev_persistent;
+       bool                    ipmi_bootdev_mailbox;
+
+       char                    *http_proxy;
+       char                    *https_proxy;
 
        bool                    allow_writes;
 
-       char                    *boot_tty;
+       char                    *boot_console;
+       bool                    manual_console;
        char                    *lang;
 
        /* not user-settable */
-       unsigned int            n_tty;
-       char                    **tty_list;
+       unsigned int            n_consoles;
+       char                    **consoles;
        bool                    disable_snapshots;
        bool                    safe_mode;
        bool                    debug;
 };
 
+bool config_autoboot_active(const struct config *config);
+
 #endif /* _TYPES_H */