package skill import ( "ai-agent/workflow/consts/public" skillDto "ai-agent/workflow/model/dto/skill" "ai-agent/workflow/model/entity" "context" "gitea.redpowerfuture.com/red-future/common/db/gfdb" "github.com/gogf/gf/v2/frame/g" "github.com/gogf/gf/v2/util/gconv" ) var SkillTemplateDao = &skillTemplateDao{} type skillTemplateDao struct{} func (d *skillTemplateDao) Insert(ctx context.Context, req *skillDto.CreateSkillTemplateReq) (id int64, err error) { skillTemplate := new(entity.SkillTemplate) err = gconv.Struct(req, &skillTemplate) r, err := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillTemplate).Insert(&skillTemplate) if err != nil { return } return r.LastInsertId() } func (d *skillTemplateDao) Update(ctx context.Context, req *skillDto.UpdateSkillTemplateReq) (rows int64, err error) { r, err := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillTemplate).OmitEmpty().Data(&req).Where(entity.SkillTemplateCol.Id, req.Id).Update() if err != nil { return } return r.RowsAffected() } func (d *skillTemplateDao) Delete(ctx context.Context, req *skillDto.DeleteSkillTemplateReq) (rows int64, err error) { r, err := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillTemplate).Where(entity.SkillTemplateCol.Id, req.Id).Delete() if err != nil { return } return r.RowsAffected() } func (d *skillTemplateDao) Count(ctx context.Context, req *skillDto.GetSkillTemplateReq) (count int, err error) { count, err = gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillTemplate).NoTenantId(ctx).OmitEmpty(). WhereNot(entity.SkillTemplateCol.Id, req.NotInId). Where(entity.SkillTemplateCol.Name, req.Name). Where(entity.SkillTemplateCol.Id, req.Id).Count() return } func (d *skillTemplateDao) Get(ctx context.Context, req *skillDto.GetSkillTemplateReq, fields ...string) (res *entity.SkillTemplate, err error) { r, err := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillTemplate).NoTenantId(ctx).OmitEmpty(). Where(entity.SkillTemplateCol.Id, req.Id). Where(entity.SkillTemplateCol.Name, req.Name). Fields(fields).One() if err != nil { return } err = r.Struct(&res) return } func (d *skillTemplateDao) List(ctx context.Context, req *skillDto.ListSkillTemplateReq, fields ...string) (res []*entity.SkillTemplate, total int, err error) { model := gfdb.DB(ctx, public.DbNameBlackDeacon).Model(ctx, public.TableNameSkillTemplate).NoTenantId(ctx).Fields(fields).OmitEmpty() if !g.IsEmpty(req.Keyword) { model.WhereLike(entity.SkillTemplateCol.Name, "%"+req.Keyword+"%") } model.OrderDesc(entity.SkillTemplateCol.CreatedAt) if req.Page != nil { model.Page(int(req.Page.PageNum), int(req.Page.PageSize)) } r, total, err := model.AllAndCount(false) if err != nil { return } err = r.Structs(&res) return }