| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451 |
- package entity
- import (
- "git.sxidc.com/go-framework/baize/convenient/binding"
- "git.sxidc.com/go-framework/baize/convenient/binding/request"
- "git.sxidc.com/go-framework/baize/convenient/binding/response"
- "git.sxidc.com/go-framework/baize/framwork/api"
- "git.sxidc.com/go-framework/baize/framwork/domain"
- "git.sxidc.com/go-framework/baize/framwork/infrastructure"
- "git.sxidc.com/go-framework/baize/framwork/infrastructure/database"
- "git.sxidc.com/go-framework/baize/framwork/infrastructure/database/sql"
- "git.sxidc.com/go-framework/baize/framwork/tag/sql/sql_mapping"
- "git.sxidc.com/go-tools/utils/reflectutils"
- "git.sxidc.com/service-supports/fserr"
- "reflect"
- )
- func Create(tableName string, callbacks *Callbacks[string]) binding.ServiceFunc[string] {
- return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (string, error) {
- object := objects[0]
- if object == nil {
- return "", fserr.New("领域实体为空")
- }
- dbExecutor := i.DBExecutor()
- e, ok := objects[0].(domain.Entity)
- if !ok {
- return "", fserr.New("需要传递领域对象应该为实体")
- }
- err := e.GenerateID()
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, "")
- }
- err = e.ForCreate()
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, "")
- }
- err = callbackBeforeDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, "")
- }
- err = database.InsertEntity(dbExecutor, tableName, e)
- if err != nil {
- if database.IsErrorDBRecordHasExist(err) {
- err = fserr.New(e.DomainCNName() + "已存在")
- }
- return callbackOnErrorReturn(callbacks, e, err, i, "")
- }
- err = callbackAfterDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, "")
- }
- return callbackOnSuccessReturn(callbacks, e, i, e.GetID())
- }
- }
- func Delete(tableName string, callbacks *Callbacks[any]) binding.ServiceFunc[any] {
- return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (any, error) {
- object := objects[0]
- if object == nil {
- return nil, fserr.New("领域实体为空")
- }
- dbExecutor := i.DBExecutor()
- e, ok := objects[0].(domain.Entity)
- if !ok {
- return nil, fserr.New("需要传递领域对象应该为实体")
- }
- err := e.CheckFieldID(e.DomainCNName())
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- err = callbackBeforeDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- err = database.DeleteEntity(dbExecutor, tableName, e)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- err = callbackAfterDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- return callbackOnSuccessReturn(callbacks, e, i, nil)
- }
- }
- func Update(tableName string, callbacks *Callbacks[any]) binding.ServiceFunc[any] {
- return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (any, error) {
- object := objects[0]
- if object == nil {
- return nil, fserr.New("领域实体为空")
- }
- dbExecutor := i.DBExecutor()
- e, ok := objects[0].(domain.Entity)
- if !ok {
- return nil, fserr.New("需要传递领域对象应该为实体")
- }
- err := e.ForUpdate()
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- exist, err := database.CheckExist(dbExecutor, &sql.CheckExistExecuteParams{
- TableName: tableName,
- Conditions: sql.NewConditions().Equal(domain.ColumnID, e.GetID()),
- })
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- if !exist {
- err := fserr.New(e.DomainCNName() + "不存在")
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- err = callbackBeforeDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- err = database.UpdateEntity(dbExecutor, tableName, e)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- err = callbackAfterDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- return callbackOnSuccessReturn(callbacks, e, i, nil)
- }
- }
- type ConditionFieldCallback func(conditions *sql.Conditions, fieldName string, columnName string, value any) (hasDeal bool)
- func Query[O any](tableName string, callbacks *Callbacks[response.InfosData[O]], conditionFieldCallback ConditionFieldCallback) binding.ServiceFunc[response.InfosData[O]] {
- return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (response.InfosData[O], error) {
- errResponse := response.InfosData[O]{
- Infos: make([]O, 0),
- }
- if params == nil {
- return errResponse, fserr.New("请求参数为空")
- }
- object := objects[0]
- if object == nil {
- return errResponse, fserr.New("领域实体为空")
- }
- dbExecutor := i.DBExecutor()
- queryParams, ok := params.(request.Query)
- if !ok {
- return errResponse, fserr.New("请求参数不是Query接口")
- }
- e, ok := objects[0].(domain.Entity)
- if !ok {
- return errResponse, fserr.New("需要传递领域对象应该为实体")
- }
- conditions := sql.NewConditions()
- fields, err := sql_mapping.DefaultUsage(e)
- if err != nil {
- return errResponse, err
- }
- for _, field := range fields {
- hasDeal := false
- if conditionFieldCallback != nil {
- hasDeal = conditionFieldCallback(conditions, field.FieldName, field.ColumnName, field.Value)
- }
- if !hasDeal {
- fieldValue := reflect.ValueOf(field.Value)
- if !fieldValue.IsZero() {
- conditions.Equal(field.ColumnName, field.Value)
- }
- }
- }
- err = callbackBeforeDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, errResponse)
- }
- results, totalCount, err := database.Query(dbExecutor, &sql.QueryExecuteParams{
- TableName: tableName,
- Conditions: conditions,
- PageNo: queryParams.GetPageNo(),
- PageSize: queryParams.GetPageSize(),
- })
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, errResponse)
- }
- err = callbackAfterDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, errResponse)
- }
- infos := make([]O, 0)
- err = sql.ParseSqlResult(results, &infos)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, errResponse)
- }
- output := response.InfosData[O]{
- Infos: infos,
- TotalCount: totalCount,
- PageNo: queryParams.GetPageNo(),
- }
- return callbackOnSuccessReturn(callbacks, e, i, output)
- }
- }
- func GetByID[O any](tableName string, callbacks *Callbacks[O]) binding.ServiceFunc[O] {
- return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (O, error) {
- outputZero := reflectutils.Zero[O]()
- object := objects[0]
- if object == nil {
- return outputZero, fserr.New("领域实体为空")
- }
- dbExecutor := i.DBExecutor()
- e, ok := objects[0].(domain.Entity)
- if !ok {
- return outputZero, fserr.New("需要传递领域对象应该为实体")
- }
- err := e.CheckFieldID(e.DomainCNName())
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, outputZero)
- }
- err = callbackBeforeDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, outputZero)
- }
- result, err := database.QueryOne(dbExecutor, &sql.QueryOneExecuteParams{
- TableName: tableName,
- Conditions: sql.NewConditions().Equal(domain.ColumnID, e.GetID()),
- })
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, outputZero)
- }
- err = callbackAfterDBOperate(callbacks, e, i, dbExecutor)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, outputZero)
- }
- info := reflectutils.Zero[O]()
- var infoPointer any
- infoPointer = &info
- if reflect.TypeOf(info).Kind() == reflect.Pointer {
- infoPointer = info
- }
- err = sql.ParseSqlResult(result, infoPointer)
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, outputZero)
- }
- return callbackOnSuccessReturn(callbacks, e, i, info)
- }
- }
- func CreateTx(tableName string, callbacks *Callbacks[string]) binding.ServiceFunc[string] {
- return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (string, error) {
- object := objects[0]
- if object == nil {
- return "", fserr.New("领域实体为空")
- }
- dbExecutor := i.DBExecutor()
- e, ok := objects[0].(domain.Entity)
- if !ok {
- return "", fserr.New("需要传递领域对象应该为实体")
- }
- err := e.GenerateID()
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, "")
- }
- err = e.ForCreate()
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, "")
- }
- err = database.Transaction(dbExecutor, func(tx database.Executor) error {
- err = callbackBeforeDBOperate(callbacks, e, i, tx)
- if err != nil {
- return err
- }
- err = database.InsertEntity(tx, tableName, e)
- if err != nil {
- if database.IsErrorDBRecordHasExist(err) {
- err = fserr.New(e.DomainCNName() + "已存在")
- }
- return err
- }
- err = callbackAfterDBOperate(callbacks, e, i, tx)
- if err != nil {
- return err
- }
- return nil
- })
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, "")
- }
- return callbackOnSuccessReturn(callbacks, e, i, e.GetID())
- }
- }
- func DeleteTx(tableName string, callbacks *Callbacks[any]) binding.ServiceFunc[any] {
- return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (any, error) {
- object := objects[0]
- if object == nil {
- return nil, fserr.New("领域实体为空")
- }
- dbExecutor := i.DBExecutor()
- e, ok := objects[0].(domain.Entity)
- if !ok {
- return nil, fserr.New("需要传递领域对象应该为实体")
- }
- err := e.CheckFieldID(e.DomainCNName())
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- err = database.Transaction(dbExecutor, func(tx database.Executor) error {
- err = callbackBeforeDBOperate(callbacks, e, i, tx)
- if err != nil {
- return err
- }
- err = database.DeleteEntity(tx, tableName, e)
- if err != nil {
- return err
- }
- err = callbackAfterDBOperate(callbacks, e, i, tx)
- if err != nil {
- return err
- }
- return nil
- })
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- return callbackOnSuccessReturn(callbacks, e, i, nil)
- }
- }
- func UpdateTx(tableName string, callbacks *Callbacks[any]) binding.ServiceFunc[any] {
- return func(c *api.Context, params request.Params, objects []domain.Object, i *infrastructure.Infrastructure) (any, error) {
- object := objects[0]
- if object == nil {
- return nil, fserr.New("领域实体为空")
- }
- dbExecutor := i.DBExecutor()
- e, ok := objects[0].(domain.Entity)
- if !ok {
- return nil, fserr.New("需要传递领域对象应该为实体")
- }
- err := e.CheckFieldID(e.DomainCNName())
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- exist, err := database.CheckExist(dbExecutor, &sql.CheckExistExecuteParams{
- TableName: tableName,
- Conditions: sql.NewConditions().Equal(domain.ColumnID, e.GetID()),
- })
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- if !exist {
- err := fserr.New(e.DomainCNName() + "不存在")
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- err = database.Transaction(dbExecutor, func(tx database.Executor) error {
- err = callbackBeforeDBOperate(callbacks, e, i, tx)
- if err != nil {
- return err
- }
- err = database.UpdateEntity(tx, tableName, e)
- if err != nil {
- return err
- }
- err = callbackAfterDBOperate(callbacks, e, i, tx)
- if err != nil {
- return err
- }
- return nil
- })
- if err != nil {
- return callbackOnErrorReturn(callbacks, e, err, i, nil)
- }
- return callbackOnSuccessReturn(callbacks, e, i, nil)
- }
- }
|