forked from security/hakurei
This is the initial effort of splitting up host and container side of finalisation for params to shim. The new layout also enables much finer grained unit testing of each step, as well as partition access to per-app state for each step. Signed-off-by: Ophestra <cat@gensokyo.uk>
30 lines
643 B
Go
30 lines
643 B
Go
// Package app implements high-level hakurei container behaviour.
|
|
package app
|
|
|
|
import (
|
|
"context"
|
|
"log"
|
|
"os"
|
|
|
|
"hakurei.app/container"
|
|
"hakurei.app/hst"
|
|
"hakurei.app/internal/app/state"
|
|
)
|
|
|
|
// Main runs an app according to [hst.Config] and terminates. Main does not return.
|
|
func Main(ctx context.Context, msg container.Msg, config *hst.Config) {
|
|
var id state.ID
|
|
if err := state.NewAppID(&id); err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
seal := outcome{syscallDispatcher: direct{}}
|
|
if err := seal.finalise(ctx, msg, &id, config); err != nil {
|
|
printMessageError("cannot seal app:", err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
seal.main(msg)
|
|
panic("unreachable")
|
|
}
|