2021-04-20 21:31:37 +00:00
|
|
|
package entrypoint
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"syscall"
|
|
|
|
)
|
|
|
|
|
|
|
|
var subCmdGarageMC = subCmd{
|
|
|
|
name: "mc",
|
|
|
|
descr: "Runs the mc (minio-client) binary. The cryptic-net garage can be accessed under the `garage` alias",
|
|
|
|
checkLock: true,
|
|
|
|
do: func(subCmdCtx subCmdCtx) error {
|
|
|
|
|
|
|
|
flags := subCmdCtx.flagSet(true)
|
|
|
|
|
|
|
|
keyID := flags.StringP(
|
|
|
|
"key-id", "i", "",
|
|
|
|
"Optional key ID to use, defaults to that of the shared cryptic-net-global key",
|
|
|
|
)
|
|
|
|
|
|
|
|
keySecret := flags.StringP(
|
|
|
|
"key-secret", "s", "",
|
|
|
|
"Optional key secret to use, defaults to that of the shared cryptic-net-global key",
|
|
|
|
)
|
|
|
|
|
|
|
|
if err := flags.Parse(subCmdCtx.args); err != nil {
|
|
|
|
return fmt.Errorf("parsing flags: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
env := subCmdCtx.env
|
|
|
|
|
2022-10-16 13:38:15 +00:00
|
|
|
s3APIAddr := env.Bootstrap.ChooseGaragePeer().S3APIAddr()
|
2021-04-20 21:31:37 +00:00
|
|
|
|
|
|
|
if *keyID == "" || *keySecret == "" {
|
|
|
|
|
|
|
|
if *keyID == "" {
|
2022-10-15 14:28:03 +00:00
|
|
|
*keyID = env.Bootstrap.GarageGlobalBucketS3APICredentials.ID
|
2021-04-20 21:31:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if *keySecret == "" {
|
2022-10-15 14:28:03 +00:00
|
|
|
*keyID = env.Bootstrap.GarageGlobalBucketS3APICredentials.Secret
|
2021-04-20 21:31:37 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
args := flags.Args()
|
|
|
|
|
|
|
|
if i := flags.ArgsLenAtDash(); i >= 0 {
|
|
|
|
args = args[i:]
|
|
|
|
}
|
|
|
|
|
|
|
|
args = append([]string{"mc"}, args...)
|
|
|
|
|
|
|
|
var (
|
|
|
|
binPath = env.BinPath("mc")
|
|
|
|
cliEnv = append(
|
|
|
|
os.Environ(),
|
|
|
|
fmt.Sprintf(
|
|
|
|
"MC_HOST_garage=http://%s:%s@%s",
|
2022-10-15 14:28:03 +00:00
|
|
|
*keyID, *keySecret, s3APIAddr,
|
2021-04-20 21:31:37 +00:00
|
|
|
),
|
|
|
|
|
|
|
|
// The garage docs say this is necessary, though nothing bad
|
|
|
|
// seems to happen if we leave it out *shrug*
|
|
|
|
"MC_REGION=garage",
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
if err := syscall.Exec(binPath, args, cliEnv); err != nil {
|
|
|
|
return fmt.Errorf(
|
|
|
|
"calling exec(%q, %#v, %#v): %w",
|
|
|
|
binPath, args, cliEnv, err,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
var subCmdGarageCLI = subCmd{
|
|
|
|
name: "cli",
|
|
|
|
descr: "Runs the garage binary, automatically configured to point to the garage sub-process of a running cryptic-net daemon",
|
|
|
|
checkLock: true,
|
|
|
|
do: func(subCmdCtx subCmdCtx) error {
|
|
|
|
|
|
|
|
env := subCmdCtx.env
|
|
|
|
|
|
|
|
var (
|
|
|
|
binPath = env.BinPath("garage")
|
|
|
|
args = append([]string{"garage"}, subCmdCtx.args...)
|
|
|
|
cliEnv = append(
|
|
|
|
os.Environ(),
|
2022-10-16 13:38:15 +00:00
|
|
|
"GARAGE_RPC_HOST="+env.Bootstrap.ChooseGaragePeer().RPCAddr(),
|
2022-10-15 14:28:03 +00:00
|
|
|
"GARAGE_RPC_SECRET="+env.Bootstrap.GarageRPCSecret,
|
2021-04-20 21:31:37 +00:00
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
if err := syscall.Exec(binPath, args, cliEnv); err != nil {
|
|
|
|
return fmt.Errorf(
|
|
|
|
"calling exec(%q, %#v, %#v): %w",
|
|
|
|
binPath, args, cliEnv, err,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
var subCmdGarage = subCmd{
|
|
|
|
name: "garage",
|
|
|
|
descr: "Runs the garage binary, automatically configured to point to the garage sub-process of a running cryptic-net daemon",
|
|
|
|
do: func(subCmdCtx subCmdCtx) error {
|
|
|
|
return subCmdCtx.doSubCmd(
|
|
|
|
subCmdGarageCLI,
|
|
|
|
subCmdGarageMC,
|
|
|
|
)
|
|
|
|
},
|
|
|
|
}
|