like images

This commit is contained in:
2023-07-06 08:38:16 +08:00
parent f50735412b
commit 581da1b294
3 changed files with 38 additions and 0 deletions

View File

@@ -38,6 +38,7 @@ type Image struct {
Public bool `json:"public"` // 是否公开 Public bool `json:"public"` // 是否公开
UserID int `json:"user_id"` // 用户ID UserID int `json:"user_id"` // 用户ID
ModelID int `json:"model_id"` // 模型ID ModelID int `json:"model_id"` // 模型ID
Preview string `json:"preview" gorm:"-"` // 实时预览 base64
CreatedAt time.Time `json:"created_at" gorm:"autoCreateTime"` CreatedAt time.Time `json:"created_at" gorm:"autoCreateTime"`
UpdatedAt time.Time `json:"updated_at" gorm:"autoUpdateTime"` UpdatedAt time.Time `json:"updated_at" gorm:"autoUpdateTime"`
} }

View File

@@ -176,11 +176,14 @@ func (model *Model) Inference(image_list []Image, callback func(Image)) {
image_list[index].Format = "webp" image_list[index].Format = "webp"
image_list[index].Status = "success" image_list[index].Status = "success"
image_list[index].Progress = 100 image_list[index].Progress = 100
//image_list[index].Preview = img
callback(image_list[index]) callback(image_list[index])
} }
log.Println("推理完成:", model.ID, model.Name) log.Println("推理完成:", model.ID, model.Name)
} }
// 加入推理任务
// 将base64编码的图片保存到本地webp // 将base64编码的图片保存到本地webp
func SaveBase64Image(base64Str string, filename string) error { func SaveBase64Image(base64Str string, filename string) error {
// 解码base64图片 // 解码base64图片

View File

@@ -87,6 +87,35 @@ func ImagesGet(w http.ResponseWriter, r *http.Request) {
var image_list []models.Image var image_list []models.Image
db := configs.ORMDB() db := configs.ORMDB()
if r.URL.Query().Get("task") != "" {
db = db.Where("task = ?", r.URL.Query().Get("task"))
}
if r.URL.Query().Get("user_id") != "" {
db = db.Where("user_id = ?", r.URL.Query().Get("user_id"))
}
if r.URL.Query().Get("status") != "" {
db = db.Where("status = ?", r.URL.Query().Get("status"))
}
if r.URL.Query().Get("from_image") != "" {
db = db.Where("from_image = ?", r.URL.Query().Get("from_image"))
}
if r.URL.Query().Get("prompt") != "" {
db = db.Where("prompt LIKE ?", "%"+r.URL.Query().Get("prompt")+"%")
}
if r.URL.Query().Get("negative_prompt") != "" {
db = db.Where("negative_prompt LIKE ?", "%"+r.URL.Query().Get("negative_prompt")+"%")
}
// 获取指定用户喜欢的图片
if r.URL.Query().Get("like") != "" {
list, err := models.LikeImage.GetA(r.URL.Query().Get("like"))
if err != nil {
log.Println(err)
return
}
db = db.Where("id IN (?)", list)
}
db.Offset((listview.Page - 1) * listview.PageSize).Limit(listview.PageSize).Find(&image_list) db.Offset((listview.Page - 1) * listview.PageSize).Limit(listview.PageSize).Find(&image_list)
for _, image := range image_list { for _, image := range image_list {
listview.List = append(listview.List, image) listview.List = append(listview.List, image)
@@ -286,12 +315,17 @@ func ImagesItemPatch(w http.ResponseWriter, r *http.Request) {
w.Write(utils.ToJSON(image)) w.Write(utils.ToJSON(image))
} }
// 删除一条图片
func ImagesItemDelete(w http.ResponseWriter, r *http.Request) { func ImagesItemDelete(w http.ResponseWriter, r *http.Request) {
image := models.Image{ID: utils.ParamInt(mux.Vars(r)["id"], 0)} image := models.Image{ID: utils.ParamInt(mux.Vars(r)["id"], 0)}
if err := configs.ORMDB().Delete(&image).Error; err != nil { if err := configs.ORMDB().Delete(&image).Error; err != nil {
log.Println(err) log.Println(err)
return return
} }
// TODO: 删除本地文件
// 删除所有喜欢此图片的记录(双向解绑, A是user, B是image)
models.LikeImage.RemoveB(strconv.Itoa(image.ID))
w.Header().Set("Content-Type", "application/json; charset=utf-8") w.Header().Set("Content-Type", "application/json; charset=utf-8")
w.Write(utils.ToJSON(image)) w.Write(utils.ToJSON(image))
} }