kcrypt/main.go

98 lines
2.2 KiB
Go
Raw Normal View History

2022-10-03 09:03:48 +00:00
package main
import (
"fmt"
"os"
"github.com/kairos-io/kcrypt/pkg/lib"
2022-10-03 09:03:48 +00:00
"github.com/urfave/cli"
)
var Version = "v0.0.0-dev"
2022-10-03 09:03:48 +00:00
func main() {
app := &cli.App{
Name: "kairos-kcrypt",
Version: Version,
2022-10-05 21:09:04 +00:00
Author: "Ettore Di Giacinto",
Usage: "kairos escrow key agent component",
2022-10-03 09:03:48 +00:00
Description: ``,
2022-10-05 21:09:04 +00:00
UsageText: ``,
Copyright: "Ettore Di Giacinto",
2022-10-03 09:03:48 +00:00
Commands: []cli.Command{
{
Name: "encrypt",
Description: "Encrypts a partition",
Usage: "Encrypts a partition",
ArgsUsage: "kcrypt [--version VERSION] [--tpm] LABEL",
Flags: []cli.Flag{
&cli.StringFlag{
Name: "version",
Value: "luks1",
Usage: "luks version to use",
},
&cli.BoolFlag{
Name: "tpm",
Usage: "Use TPM to lock the partition",
},
},
2022-10-03 09:03:48 +00:00
Action: func(c *cli.Context) error {
if c.NArg() != 1 {
return fmt.Errorf("requires 1 arg, the partition label")
}
out, err := lib.Luksify(c.Args().First(), c.String("version"), c.Bool("tpm"))
if err != nil {
return err
}
fmt.Println(out)
return nil
2022-10-03 09:03:48 +00:00
},
},
{
Name: "unlock-all",
UsageText: "unlock-all",
Usage: "Try to unlock all LUKS partitions",
Description: "Typically run during initrd to unlock all the LUKS partitions found",
ArgsUsage: "kcrypt [--tpm] unlock-all",
Flags: []cli.Flag{
&cli.BoolFlag{
Name: "tpm",
Usage: "Use TPM to unlock the partition",
},
},
2022-10-03 09:03:48 +00:00
Action: func(c *cli.Context) error {
return lib.UnlockAll(c.Bool("tpm"))
2022-10-03 09:03:48 +00:00
},
},
{
Name: "extract-initrd",
Hidden: true,
Action: func(c *cli.Context) error {
if c.NArg() != 2 {
return fmt.Errorf("requires 3 args. initrd,, dst")
}
return lib.ExtractInitrd(c.Args()[0], c.Args()[1])
},
},
{
Name: "inject-initrd",
Hidden: true,
Action: func(c *cli.Context) error {
if c.NArg() != 3 {
return fmt.Errorf("requires 3 args. initrd, srcfile, dst")
}
return lib.InjectInitrd(c.Args()[0], c.Args()[1], c.Args()[2])
},
},
2022-10-03 09:03:48 +00:00
},
}
if err := app.Run(os.Args); err != nil {
fmt.Println(err.Error())
os.Exit(1)
}
}