Ai
2 Star 1 Fork 3

NanhuLab/tcas-cli

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
secret.go 2.68 KB
一键复制 编辑 原始数据 按行查看 历史
chase 提交于 2024-09-13 11:46 +08:00 . [auth] support authentication
package attest
import (
"encoding/json"
"fmt"
"gitee.com/nanhu-lab/tcas-cli/cmd/initconfig"
consts "gitee.com/nanhu-lab/tcas-cli/constants"
"gitee.com/nanhu-lab/tcas-cli/manager"
"gitee.com/nanhu-lab/tcas-cli/tees"
"gitee.com/nanhu-lab/tcas-cli/utils/file"
"gitee.com/nanhu-lab/tcas-cli/utils/tools"
"os"
"path/filepath"
"github.com/sirupsen/logrus"
"github.com/spf13/cobra"
)
var secretCmd = &cobra.Command{
Use: "secret",
Short: "attest for getting secret ",
Long: `attest for getting secret `,
Run: func(cmd *cobra.Command, args []string) {
url, _ := cmd.Flags().GetString("url")
tee, _ := cmd.Flags().GetString("tee")
devices, _ := cmd.Flags().GetString("devices")
userdata, _ := cmd.Flags().GetString("userdata")
policies, _ := cmd.Flags().GetString("policies")
secretID, _ := cmd.Flags().GetString("secretId")
tcasConfig, err := initconfig.ReadTCASInfoFromConfig(url)
if err != nil {
logrus.Errorf("get tcasConfig failed, please run <tcascli init> first")
return
}
m, err := manager.New(tcasConfig, tees.GetCollectors())
if err != nil {
return
}
res, err := m.AttestForSecret(tee, userdata, devices, policies, secretID)
if err != nil {
logrus.Errorf(err.Error())
return
}
jsonData, err := json.MarshalIndent(res.Secret, "", " ")
if err != nil {
logrus.Errorf("Error marshaling JSON:", err)
return
}
jsonData = append(jsonData, '\n')
outputPath, _ := cmd.Flags().GetString("output")
err = file.EnsureDirExists(outputPath)
if err != nil {
logrus.Errorf("Error ensuring directory exists: %v", err)
return
}
fileName := tools.GenerateName("secret") + ".json"
resultPath := filepath.Join(outputPath, fileName)
err = os.WriteFile(resultPath, jsonData, 0644)
if err != nil {
logrus.Errorf("Error writing secret json file: %v", err)
return
}
fmt.Println(consts.ColorGreen + "The secert successfully saved in: " + resultPath + consts.OutReset)
},
}
func init() {
Cmd.AddCommand(secretCmd)
//set parameter for getting secret
secretCmd.Flags().StringP("url", "u", "https://api.trustcluster.cc", "optional, tcas's api url")
secretCmd.Flags().StringP("tee", "t", "", "must, tee type")
secretCmd.Flags().StringP("devices", "v", "", "optional, the trust devices")
secretCmd.Flags().StringP("policies", "p", "", "optional, the ids of the policy needed matching")
secretCmd.Flags().StringP("userdata", "d", "", "optional, the base64 encoded userdata")
secretCmd.Flags().StringP("secretId", "s", "", "must,the secret ID that needs to be obtained")
secretCmd.Flags().StringP("output", "o", "./tcas-secret", "optional, the output dir of the secret")
secretCmd.MarkFlagRequired("tee")
secretCmd.MarkFlagRequired("secretId")
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/nanhu-lab/tcas-cli.git
git@gitee.com:nanhu-lab/tcas-cli.git
nanhu-lab
tcas-cli
tcas-cli
v0.0.2

搜索帮助