yaml
This commit is contained in:
		
							
								
								
									
										3
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								go.mod
									
									
									
									
									
								
							@@ -15,5 +15,8 @@ require github.com/mattn/go-sqlite3 v1.14.16 // indirect
 | 
				
			|||||||
require (
 | 
					require (
 | 
				
			||||||
	github.com/jinzhu/inflection v1.0.0 // indirect
 | 
						github.com/jinzhu/inflection v1.0.0 // indirect
 | 
				
			||||||
	github.com/jinzhu/now v1.1.5 // 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
 | 
						gorm.io/driver/sqlite v1.5.0
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										7
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								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/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 h1:KqfZb0pUVN2lYqZUYRddxF4OR8ZMURnJIG5Y3VRLtww=
 | 
				
			||||||
github.com/russross/blackfriday v1.6.0/go.mod h1:ti0ldHuxg49ri4ksnFxlkCfN+hvslNlmVHqNRXXJNAY=
 | 
					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 h1:zKYbzRCpBrT1bNijRnxLDJWPjVfImGEn0lSnUY5gZ+c=
 | 
				
			||||||
gorm.io/driver/sqlite v1.5.0/go.mod h1:kDMDfntV9u/vuMmz8APHtHF0b4nyBB7sfCieC6G8k8I=
 | 
					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=
 | 
					gorm.io/gorm v1.24.7-0.20230306060331-85eaf9eeda11/go.mod h1:L4uxeKpfBml98NYqVqwAdmV1a2nBtAec/cf3fpucW/k=
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,9 +3,18 @@ package models
 | 
				
			|||||||
import (
 | 
					import (
 | 
				
			||||||
	"encoding/json"
 | 
						"encoding/json"
 | 
				
			||||||
	"fmt"
 | 
						"fmt"
 | 
				
			||||||
 | 
						"io/ioutil"
 | 
				
			||||||
 | 
						"log"
 | 
				
			||||||
	"main/configs"
 | 
						"main/configs"
 | 
				
			||||||
	"net/http"
 | 
						"net/http"
 | 
				
			||||||
	"time"
 | 
						"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 {
 | 
					type Server struct {
 | 
				
			||||||
@@ -22,6 +31,55 @@ type Server struct {
 | 
				
			|||||||
	UpdatedAt time.Time                `json:"updated_at" gorm:"autoUpdateTime"`
 | 
						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 {
 | 
					func (server *Server) CheckStatus() error {
 | 
				
			||||||
	switch server.Type {
 | 
						switch server.Type {
 | 
				
			||||||
	case "訓練":
 | 
						case "訓練":
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user