从 demo 引用

This commit is contained in:
2023-11-20 23:25:18 +08:00
parent e43fde4116
commit 9186827b51
4 changed files with 154 additions and 122 deletions

213
api/graphql.go Normal file
View File

@@ -0,0 +1,213 @@
package api
import (
"fmt"
"log"
"strings"
"git.satori.love/gameui/webp/models"
"github.com/graphql-go/graphql"
"github.com/graphql-go/graphql/language/ast"
"github.com/jmoiron/sqlx"
)
var connection *sqlx.DB
func init() {
var err error
user := models.Viper.Get("mysql.user").(string)
password := models.Viper.Get("mysql.password").(string)
host := models.Viper.Get("mysql.host").(string)
port := models.Viper.Get("mysql.port").(int)
database := models.Viper.Get("mysql.database").(string)
connection, err = sqlx.Connect("mysql", fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=utf8mb4&parseTime=True&loc=Local", user, password, host, port, database))
if err != nil {
log.Fatalln("连接数据库失败", err)
}
}
func NewSchema() (graphql.Schema, error) {
user := graphql.NewObject(graphql.ObjectConfig{
Name: "User",
Fields: graphql.Fields{
"id": &graphql.Field{Type: graphql.Int},
"user_name": &graphql.Field{Type: graphql.String},
"avatar": &graphql.Field{Type: graphql.String},
"rank": &graphql.Field{Type: graphql.String},
"price": &graphql.Field{Type: graphql.Float},
"create_time": &graphql.Field{Type: graphql.DateTime},
"update_time": &graphql.Field{Type: graphql.DateTime},
},
})
users := &graphql.Field{
Type: graphql.NewList(user),
Args: graphql.FieldConfigArgument{
"id": &graphql.ArgumentConfig{Type: graphql.Int},
"user_name": &graphql.ArgumentConfig{Type: graphql.String},
"avatar": &graphql.ArgumentConfig{Type: graphql.String},
"rank": &graphql.ArgumentConfig{Type: graphql.String},
"create_time": &graphql.ArgumentConfig{Type: graphql.DateTime},
"update_time": &graphql.ArgumentConfig{Type: graphql.DateTime},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
var fields []string
requestedFields := p.Info.FieldASTs[0].SelectionSet.Selections
for _, field := range requestedFields {
fieldAST, ok := field.(*ast.Field)
if ok {
fields = append(fields, fieldAST.Name.Value)
}
}
fields_str := strings.Join(fields, ",")
var where []string
if p.Args["id"] != nil {
where = append(where, fmt.Sprintf("id=%d", p.Args["id"]))
}
if p.Args["user_name"] != nil {
where = append(where, fmt.Sprintf("user_name='%s'", p.Args["user_name"]))
}
// 筛选条件
where_str := strings.Join(where, " AND ")
fmt.Println(where_str)
var query strings.Builder
query.WriteString(fmt.Sprintf("SELECT %s FROM web_member WHERE %s LIMIT %s", fields_str, where_str, "10"))
fmt.Println(query.String())
var users []User
if err := connection.Select(&users, query.String()); err != nil {
fmt.Println("获取用户列表失败", err)
return nil, err
}
fmt.Println(users)
return users, nil
},
}
image := graphql.NewObject(graphql.ObjectConfig{
Name: "Image",
Fields: graphql.Fields{
"id": &graphql.Field{Type: graphql.Int},
"width": &graphql.Field{Type: graphql.Int},
"height": &graphql.Field{Type: graphql.Int},
"content": &graphql.Field{Type: graphql.String},
"article_category_top_id": &graphql.Field{Type: graphql.Int},
"praise_count": &graphql.Field{Type: graphql.Int},
"collect_count": &graphql.Field{Type: graphql.Int},
"create_time": &graphql.Field{Type: graphql.DateTime},
"update_time": &graphql.Field{Type: graphql.DateTime},
"user": &graphql.Field{
Type: user,
},
},
})
images := &graphql.Field{
Type: graphql.NewList(image),
Args: graphql.FieldConfigArgument{
"id": &graphql.ArgumentConfig{
Type: graphql.Int,
},
"width": &graphql.ArgumentConfig{
Type: graphql.Int,
},
"height": &graphql.ArgumentConfig{
Type: graphql.Int,
},
"content": &graphql.ArgumentConfig{
Type: graphql.String,
},
},
Resolve: func(p graphql.ResolveParams) (interface{}, error) {
var fields []string
requestedFields := p.Info.FieldASTs[0].SelectionSet.Selections
for _, field := range requestedFields {
fieldAST, ok := field.(*ast.Field)
if ok {
fields = append(fields, fieldAST.Name.Value)
}
}
fields_str := strings.Join(fields, ",")
var where []string
if p.Args["id"] != nil {
where = append(where, fmt.Sprintf("id=%d", p.Args["id"]))
}
if p.Args["width"] != nil {
where = append(where, fmt.Sprintf("width='%s'", p.Args["width"]))
}
if p.Args["height"] != nil {
where = append(where, fmt.Sprintf("height='%s'", p.Args["height"]))
}
if p.Args["content"] != nil {
where = append(where, fmt.Sprintf("content='%s'", p.Args["content"]))
}
// 筛选条件
where_str := strings.Join(where, " AND ")
fmt.Println(where_str)
var query strings.Builder
query.WriteString(fmt.Sprintf("SELECT %s FROM web_images WHERE %s LIMIT %s", fields_str, where_str, "10"))
fmt.Println(query.String())
var images []Image
if err := connection.Select(&images, query.String()); err != nil {
fmt.Println("获取图像列表失败", err)
return nil, err
}
fmt.Println(images)
return images, nil
//return []interface{}{
// map[string]interface{}{
// "id": 1,
// "width": 100,
// "height": 100,
// "content": "content",
// "article_category_top_id": 1,
// "praise_count": 1,
// "collect_count": 1,
// "create_time": "2018-01-01 00:00:00",
// "update_time": "2018-01-01 00:00:00",
// "user": map[string]interface{}{
// "id": 1,
// "name": "user1",
// "age": 10,
// "info": "info",
// "price": 1.1,
// "avatar": "",
// },
// },
// map[string]interface{}{
// "id": 2,
// "width": 100,
// "height": 100,
// "content": "content",
// "article_category_top_id": 1,
// "praise_count": 1,
// "collect_count": 1,
// "create_time": "2018-01-01 00:00:00",
// "update_time": "2018-01-01 00:00:00",
// "user": map[string]interface{}{
// "id": 2,
// "name": "user2",
// "age": 20,
// "info": "info",
// "price": 2.2,
// "avatar": "",
// },
// },
//}, nil
},
}
rootQuery := graphql.ObjectConfig{Name: "RootQuery", Fields: graphql.Fields{
"users": users,
"images": images,
}}
schemaConfig := graphql.SchemaConfig{Query: graphql.NewObject(rootQuery)}
schema, err := graphql.NewSchema(schemaConfig)
if err != nil {
return schema, err
}
return schema, nil
}

31
api/struct.go Normal file
View File

@@ -0,0 +1,31 @@
package api
import (
"time"
"git.satori.love/gameui/webp/models"
)
type Image struct {
Id int `json:"id" db:"id"`
Width int `json:"width" db:"width"`
Height int `json:"height" db:"height"`
Content string `json:"content" db:"content"`
ArticleCategoryTopId int `json:"article_category_top_id" db:"article_category_top_id"`
PraiseCount int `json:"praise_count" db:"praise_count"`
CollectCount int `json:"collect_count" db:"collect_count"`
UserID int `json:"user_id" db:"user_id"`
User models.User `json:"user" db:"user"`
Article models.Article `json:"article" db:"article"`
CreateTime time.Time `json:"createTime" db:"createTime"`
UpdateTime time.Time `json:"updateTime" db:"updateTime"`
}
type User struct {
ID int `json:"id" db:"id"`
UserName string `json:"user_name" db:"user_name"`
Avatar string `json:"avatar" db:"avatar"`
Rank string `json:"rank" db:"rank"`
CreateTime time.Time `json:"create_time" db:"create_time"`
UpdateTime time.Time `json:"update_time" db:"update_time"`
}