diff --git a/go.mod b/go.mod index 25b5b65..cf2d832 100644 --- a/go.mod +++ b/go.mod @@ -15,5 +15,8 @@ require github.com/mattn/go-sqlite3 v1.14.16 // indirect require ( github.com/jinzhu/inflection v1.0.0 // indirect github.com/jinzhu/now v1.1.5 // indirect + github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.669 + github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cvm v1.0.669 + gopkg.in/yaml.v2 v2.4.0 gorm.io/driver/sqlite v1.5.0 ) diff --git a/go.sum b/go.sum index 183c292..3ffa613 100644 --- a/go.sum +++ b/go.sum @@ -13,6 +13,13 @@ github.com/mattn/go-sqlite3 v1.14.16 h1:yOQRA0RpS5PFz/oikGwBEqvAWhWg5ufRz4ETLjwp github.com/mattn/go-sqlite3 v1.14.16/go.mod h1:2eHXhiwb8IkHr+BDWZGa96P6+rkvnG63S2DGjv9HUNg= github.com/russross/blackfriday v1.6.0 h1:KqfZb0pUVN2lYqZUYRddxF4OR8ZMURnJIG5Y3VRLtww= github.com/russross/blackfriday v1.6.0/go.mod h1:ti0ldHuxg49ri4ksnFxlkCfN+hvslNlmVHqNRXXJNAY= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.669 h1:5KKJBcemqKONBFxMdMyLMvk+TrqXaEPhqe9TrZqB3r0= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common v1.0.669/go.mod h1:7sCQWVkxcsR38nffDW057DRGk8mUjK1Ing/EFOK8s8Y= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cvm v1.0.669 h1:gc1bPO/YVfuXEIs+HbQ/gFlFjdkJjOsjm8xWqF7hPww= +github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cvm v1.0.669/go.mod h1:hhy13j6NKKxt/g62JZEDekJNQx3EAevnHopmwlt2tRc= +gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= +gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= gorm.io/driver/sqlite v1.5.0 h1:zKYbzRCpBrT1bNijRnxLDJWPjVfImGEn0lSnUY5gZ+c= gorm.io/driver/sqlite v1.5.0/go.mod h1:kDMDfntV9u/vuMmz8APHtHF0b4nyBB7sfCieC6G8k8I= gorm.io/gorm v1.24.7-0.20230306060331-85eaf9eeda11/go.mod h1:L4uxeKpfBml98NYqVqwAdmV1a2nBtAec/cf3fpucW/k= diff --git a/models/Server.go b/models/Server.go index b9df918..c64e407 100644 --- a/models/Server.go +++ b/models/Server.go @@ -3,9 +3,18 @@ package models import ( "encoding/json" "fmt" + "io/ioutil" + "log" "main/configs" "net/http" "time" + + "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common" + "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/errors" + "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/common/profile" + cvm "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cvm/v20170312" + + "gopkg.in/yaml.v2" ) type Server struct { @@ -22,6 +31,55 @@ type Server struct { UpdatedAt time.Time `json:"updated_at" gorm:"autoUpdateTime"` } +type Config struct { + TencentCloud struct { + SecretId string `yaml:"SecretId"` + SecretKey string `yaml:"SecretKey"` + } `yaml:"TencentCloud"` +} + +func CreateServerByTencentCloud() { + // 從 data/config.yaml 中獲取配置 + configFile, err := ioutil.ReadFile("data/config.yaml") + if err != nil { + log.Fatalf("Failed to read config file: %v", err) + } + + var config Config + err = yaml.Unmarshal(configFile, &config) + if err != nil { + log.Fatalf("Failed to unmarshal config file: %v", err) + } + + fmt.Println(config.TencentCloud.SecretId) + fmt.Println(config.TencentCloud.SecretKey) + + // 实例化一个认证对象,入参需要传入腾讯云账户 SecretId 和 SecretKey,此处还需注意密钥对的保密 + // 代码泄露可能会导致 SecretId 和 SecretKey 泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考,建议采用更安全的方式来使用密钥,请参见:https://cloud.tencent.com/document/product/1278/85305 + // 密钥可前往官网控制台 https://console.cloud.tencent.com/cam/capi 进行获取 + // 实例化一个client选项,可选的,没有特殊需求可以跳过 + // 实例化要请求产品的client对象,clientProfile是可选的 + credential := common.NewCredential(config.TencentCloud.SecretId, config.TencentCloud.SecretKey) + cpf := profile.NewClientProfile() + cpf.HttpProfile.Endpoint = "cvm.tencentcloudapi.com" + client, _ := cvm.NewClient(credential, "", cpf) + + // 实例化一个请求对象,每个接口都会对应一个request对象 + request := cvm.NewRunInstancesRequest() + + // 返回的resp是一个RunInstancesResponse的实例,与请求对象对应 + response, err := client.RunInstances(request) + if _, ok := err.(*errors.TencentCloudSDKError); ok { + fmt.Printf("An API error has returned: %s", err) + return + } + if err != nil { + panic(err) + } + // 输出json格式的字符串回包 + fmt.Printf("%s", response.ToJsonString()) +} + func (server *Server) CheckStatus() error { switch server.Type { case "訓練":