Ai
2 Star 1 Fork 3

NanhuLab/tcas-cli

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
token.go 1.54 KB
一键复制 编辑 原始数据 按行查看 历史
chase 提交于 2024-09-13 11:46 +08:00 . [auth] support authentication
package attest
import (
"fmt"
"gitee.com/nanhu-lab/tcas-cli/cmd/initconfig"
"gitee.com/nanhu-lab/tcas-cli/manager"
"gitee.com/nanhu-lab/tcas-cli/tees"
"github.com/sirupsen/logrus"
"github.com/spf13/cobra"
)
var tokenCmd = &cobra.Command{
Use: "token",
Short: "attest for getting token",
Long: "",
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")
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.AttestForToken(tee, userdata, devices, policies)
if err != nil {
logrus.Errorf("do attest for token failed, error: %s", err)
return
}
fmt.Println(res.Token)
},
}
func init() {
Cmd.AddCommand(tokenCmd)
//set parameter for getting token
tokenCmd.Flags().StringP("url", "u", "https://api.trustcluster.cc", "optional, tcas's api url")
tokenCmd.Flags().StringP("tee", "t", "", "must, tee type")
tokenCmd.MarkFlagRequired("tee")
tokenCmd.Flags().StringP("devices", "v", "", "optional, the trust devices")
tokenCmd.Flags().StringP("userdata", "d", "", "optional, the base64 encoded userdata")
tokenCmd.Flags().StringP("policies", "p", "", "optional, the ids of the policy needed matching")
}
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

搜索帮助