v1.0.0
This commit is contained in:
		| @@ -65,14 +65,23 @@ func (l *PaymentLogic) Payment(req *types.PaymentReq) (resp *types.PaymentResp, | |||||||
| 	} | 	} | ||||||
| 	var prepayID string | 	var prepayID string | ||||||
| 	var outTradeNo string | 	var outTradeNo string | ||||||
|  | 	var amount float64 | ||||||
|  | 	user, err := l.svcCtx.UserModel.FindOne(l.ctx, userID) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "生成订单, 获取用户信息失败: %+v", err) | ||||||
|  | 	} | ||||||
|  | 	if user.Inside == 1 { | ||||||
|  | 		amount = 0.01 | ||||||
|  | 	} else { | ||||||
|  | 		amount = product.SellPrice | ||||||
|  | 	} | ||||||
| 	var createOrderErr error | 	var createOrderErr error | ||||||
| 	if req.PayMethod == "wechatpay" { | 	if req.PayMethod == "wechatpay" { | ||||||
| 		outTradeNo = l.svcCtx.WechatPayService.GenerateOutTradeNo() | 		outTradeNo = l.svcCtx.WechatPayService.GenerateOutTradeNo() | ||||||
| 		prepayID, createOrderErr = l.svcCtx.WechatPayService.CreateWechatOrder(l.ctx, product.SellPrice, product.Description, outTradeNo) | 		prepayID, createOrderErr = l.svcCtx.WechatPayService.CreateWechatOrder(l.ctx, amount, product.Description, outTradeNo) | ||||||
| 	} else if req.PayMethod == "alipay" { | 	} else if req.PayMethod == "alipay" { | ||||||
| 		outTradeNo = l.svcCtx.AlipayService.GenerateOutTradeNo() | 		outTradeNo = l.svcCtx.AlipayService.GenerateOutTradeNo() | ||||||
| 		prepayID, createOrderErr = l.svcCtx.AlipayService.CreateAlipayOrder(l.ctx, product.SellPrice, product.Description, outTradeNo) | 		prepayID, createOrderErr = l.svcCtx.AlipayService.CreateAlipayOrder(l.ctx, amount, product.Description, outTradeNo) | ||||||
| 	} else if req.PayMethod == "appleiap" { | 	} else if req.PayMethod == "appleiap" { | ||||||
| 		outTradeNo = l.svcCtx.ApplePayService.GenerateOutTradeNo() | 		outTradeNo = l.svcCtx.ApplePayService.GenerateOutTradeNo() | ||||||
| 		prepayID = l.svcCtx.ApplePayService.GetIappayAppID(product.ProductEn) | 		prepayID = l.svcCtx.ApplePayService.GetIappayAppID(product.ProductEn) | ||||||
| @@ -88,7 +97,7 @@ func (l *PaymentLogic) Payment(req *types.PaymentReq) (resp *types.PaymentResp, | |||||||
| 			ProductId:       product.Id, | 			ProductId:       product.Id, | ||||||
| 			PaymentPlatform: req.PayMethod, | 			PaymentPlatform: req.PayMethod, | ||||||
| 			PaymentScene:    "app", | 			PaymentScene:    "app", | ||||||
| 			Amount:          product.SellPrice, | 			Amount:          amount, | ||||||
| 			Status:          "pending", | 			Status:          "pending", | ||||||
| 		} | 		} | ||||||
| 		orderInsertResult, insertOrderErr := l.svcCtx.OrderModel.Insert(ctx, session, &order) | 		orderInsertResult, insertOrderErr := l.svcCtx.OrderModel.Insert(ctx, session, &order) | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import ( | |||||||
| 	"context" | 	"context" | ||||||
| 	"database/sql" | 	"database/sql" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"qnc-server/deploy/script/model" | 	model2 "qnc-server/deploy/script/model" | ||||||
| 	"strings" | 	"strings" | ||||||
|  |  | ||||||
| 	"time" | 	"time" | ||||||
| @@ -67,6 +67,7 @@ type ( | |||||||
| 		Password   sql.NullString `db:"password"` | 		Password   sql.NullString `db:"password"` | ||||||
| 		Nickname   string         `db:"nickname"` | 		Nickname   string         `db:"nickname"` | ||||||
| 		Info       string         `db:"info"` | 		Info       string         `db:"info"` | ||||||
|  | 		Inside     int64          `db:"inside"` | ||||||
| 	} | 	} | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -82,11 +83,11 @@ func (m *defaultUserModel) Insert(ctx context.Context, session sqlx.Session, dat | |||||||
| 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, data.Id) | 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, data.Id) | ||||||
| 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, data.Mobile) | 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, data.Mobile) | ||||||
| 	return m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (result sql.Result, err error) { | 	return m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (result sql.Result, err error) { | ||||||
| 		query := fmt.Sprintf("INSERT INTO %s (%s) VALUES (?, ?, ?, ?, ?, ?, ?)", m.table, userRowsExpectAutoSet) | 		query := fmt.Sprintf("insert into %s (%s) values (?, ?, ?, ?, ?, ?, ?, ?)", m.table, userRowsExpectAutoSet) | ||||||
| 		if session != nil { | 		if session != nil { | ||||||
| 			return session.ExecCtx(ctx, query, data.DeleteTime, data.DelState, data.Version, data.Mobile, data.Password, data.Nickname, data.Info) | 			return session.ExecCtx(ctx, query, data.DeleteTime, data.DelState, data.Version, data.Mobile, data.Password, data.Nickname, data.Info, data.Inside) | ||||||
| 		} | 		} | ||||||
| 		return conn.ExecCtx(ctx, query, data.DeleteTime, data.DelState, data.Version, data.Mobile, data.Password, data.Nickname, data.Info) | 		return conn.ExecCtx(ctx, query, data.DeleteTime, data.DelState, data.Version, data.Mobile, data.Password, data.Nickname, data.Info, data.Inside) | ||||||
| 	}, qncUserIdKey, qncUserMobileKey) | 	}, qncUserIdKey, qncUserMobileKey) | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -94,14 +95,14 @@ func (m *defaultUserModel) FindOne(ctx context.Context, id int64) (*User, error) | |||||||
| 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, id) | 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, id) | ||||||
| 	var resp User | 	var resp User | ||||||
| 	err := m.QueryRowCtx(ctx, &resp, qncUserIdKey, func(ctx context.Context, conn sqlx.SqlConn, v interface{}) error { | 	err := m.QueryRowCtx(ctx, &resp, qncUserIdKey, func(ctx context.Context, conn sqlx.SqlConn, v interface{}) error { | ||||||
| 		query := fmt.Sprintf("SELECT %s FROM %s WHERE `id` = ? AND del_state = ? limit 1", userRows, m.table) | 		query := fmt.Sprintf("select %s from %s where `id` = ? and del_state = ? limit 1", userRows, m.table) | ||||||
| 		return conn.QueryRowCtx(ctx, v, query, id, globalkey.DelStateNo) | 		return conn.QueryRowCtx(ctx, v, query, id, globalkey.DelStateNo) | ||||||
| 	}) | 	}) | ||||||
| 	switch err { | 	switch err { | ||||||
| 	case nil: | 	case nil: | ||||||
| 		return &resp, nil | 		return &resp, nil | ||||||
| 	case sqlc.ErrNotFound: | 	case sqlc.ErrNotFound: | ||||||
| 		return nil, model.ErrNotFound | 		return nil, model2.ErrNotFound | ||||||
| 	default: | 	default: | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -111,7 +112,7 @@ func (m *defaultUserModel) FindOneByMobile(ctx context.Context, mobile string) ( | |||||||
| 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, mobile) | 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, mobile) | ||||||
| 	var resp User | 	var resp User | ||||||
| 	err := m.QueryRowIndexCtx(ctx, &resp, qncUserMobileKey, m.formatPrimary, func(ctx context.Context, conn sqlx.SqlConn, v interface{}) (i interface{}, e error) { | 	err := m.QueryRowIndexCtx(ctx, &resp, qncUserMobileKey, m.formatPrimary, func(ctx context.Context, conn sqlx.SqlConn, v interface{}) (i interface{}, e error) { | ||||||
| 		query := fmt.Sprintf("SELECT %s FROM %s WHERE `mobile` = ? AND del_state = ? limit 1", userRows, m.table) | 		query := fmt.Sprintf("select %s from %s where `mobile` = ? and del_state = ? limit 1", userRows, m.table) | ||||||
| 		if err := conn.QueryRowCtx(ctx, &resp, query, mobile, globalkey.DelStateNo); err != nil { | 		if err := conn.QueryRowCtx(ctx, &resp, query, mobile, globalkey.DelStateNo); err != nil { | ||||||
| 			return nil, err | 			return nil, err | ||||||
| 		} | 		} | ||||||
| @@ -121,7 +122,7 @@ func (m *defaultUserModel) FindOneByMobile(ctx context.Context, mobile string) ( | |||||||
| 	case nil: | 	case nil: | ||||||
| 		return &resp, nil | 		return &resp, nil | ||||||
| 	case sqlc.ErrNotFound: | 	case sqlc.ErrNotFound: | ||||||
| 		return nil, model.ErrNotFound | 		return nil, model2.ErrNotFound | ||||||
| 	default: | 	default: | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| @@ -135,11 +136,11 @@ func (m *defaultUserModel) Update(ctx context.Context, session sqlx.Session, new | |||||||
| 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, data.Id) | 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, data.Id) | ||||||
| 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, data.Mobile) | 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, data.Mobile) | ||||||
| 	return m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (result sql.Result, err error) { | 	return m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (result sql.Result, err error) { | ||||||
| 		query := fmt.Sprintf("UPDATE %s SET %s WHERE `id` = ?", m.table, userRowsWithPlaceHolder) | 		query := fmt.Sprintf("update %s set %s where `id` = ?", m.table, userRowsWithPlaceHolder) | ||||||
| 		if session != nil { | 		if session != nil { | ||||||
| 			return session.ExecCtx(ctx, query, newData.DeleteTime, newData.DelState, newData.Version, newData.Mobile, newData.Password, newData.Nickname, newData.Info, newData.Id) | 			return session.ExecCtx(ctx, query, newData.DeleteTime, newData.DelState, newData.Version, newData.Mobile, newData.Password, newData.Nickname, newData.Info, newData.Inside, newData.Id) | ||||||
| 		} | 		} | ||||||
| 		return conn.ExecCtx(ctx, query, newData.DeleteTime, newData.DelState, newData.Version, newData.Mobile, newData.Password, newData.Nickname, newData.Info, newData.Id) | 		return conn.ExecCtx(ctx, query, newData.DeleteTime, newData.DelState, newData.Version, newData.Mobile, newData.Password, newData.Nickname, newData.Info, newData.Inside, newData.Id) | ||||||
| 	}, qncUserIdKey, qncUserMobileKey) | 	}, qncUserIdKey, qncUserMobileKey) | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -158,11 +159,11 @@ func (m *defaultUserModel) UpdateWithVersion(ctx context.Context, session sqlx.S | |||||||
| 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, data.Id) | 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, data.Id) | ||||||
| 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, data.Mobile) | 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, data.Mobile) | ||||||
| 	sqlResult, err = m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (result sql.Result, err error) { | 	sqlResult, err = m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (result sql.Result, err error) { | ||||||
| 		query := fmt.Sprintf("UPDATE %s SET %s WHERE `id` = ? AND version = ? ", m.table, userRowsWithPlaceHolder) | 		query := fmt.Sprintf("update %s set %s where `id` = ? and version = ? ", m.table, userRowsWithPlaceHolder) | ||||||
| 		if session != nil { | 		if session != nil { | ||||||
| 			return session.ExecCtx(ctx, query, newData.DeleteTime, newData.DelState, newData.Version, newData.Mobile, newData.Password, newData.Nickname, newData.Info, newData.Id, oldVersion) | 			return session.ExecCtx(ctx, query, newData.DeleteTime, newData.DelState, newData.Version, newData.Mobile, newData.Password, newData.Nickname, newData.Info, newData.Inside, newData.Id, oldVersion) | ||||||
| 		} | 		} | ||||||
| 		return conn.ExecCtx(ctx, query, newData.DeleteTime, newData.DelState, newData.Version, newData.Mobile, newData.Password, newData.Nickname, newData.Info, newData.Id, oldVersion) | 		return conn.ExecCtx(ctx, query, newData.DeleteTime, newData.DelState, newData.Version, newData.Mobile, newData.Password, newData.Nickname, newData.Info, newData.Inside, newData.Id, oldVersion) | ||||||
| 	}, qncUserIdKey, qncUserMobileKey) | 	}, qncUserIdKey, qncUserMobileKey) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| @@ -172,7 +173,7 @@ func (m *defaultUserModel) UpdateWithVersion(ctx context.Context, session sqlx.S | |||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	if updateCount == 0 { | 	if updateCount == 0 { | ||||||
| 		return model.ErrNoRowsUpdate | 		return model2.ErrNoRowsUpdate | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return nil | 	return nil | ||||||
| @@ -389,7 +390,7 @@ func (m *defaultUserModel) Delete(ctx context.Context, session sqlx.Session, id | |||||||
| 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, id) | 	qncUserIdKey := fmt.Sprintf("%s%v", cacheQncUserIdPrefix, id) | ||||||
| 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, data.Mobile) | 	qncUserMobileKey := fmt.Sprintf("%s%v", cacheQncUserMobilePrefix, data.Mobile) | ||||||
| 	_, err = m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (result sql.Result, err error) { | 	_, err = m.ExecCtx(ctx, func(ctx context.Context, conn sqlx.SqlConn) (result sql.Result, err error) { | ||||||
| 		query := fmt.Sprintf("DELETE FROM %s WHERE `id` = ?", m.table) | 		query := fmt.Sprintf("delete from %s where `id` = ?", m.table) | ||||||
| 		if session != nil { | 		if session != nil { | ||||||
| 			return session.ExecCtx(ctx, query, id) | 			return session.ExecCtx(ctx, query, id) | ||||||
| 		} | 		} | ||||||
| @@ -401,7 +402,7 @@ func (m *defaultUserModel) formatPrimary(primary interface{}) string { | |||||||
| 	return fmt.Sprintf("%s%v", cacheQncUserIdPrefix, primary) | 	return fmt.Sprintf("%s%v", cacheQncUserIdPrefix, primary) | ||||||
| } | } | ||||||
| func (m *defaultUserModel) queryPrimary(ctx context.Context, conn sqlx.SqlConn, v, primary interface{}) error { | func (m *defaultUserModel) queryPrimary(ctx context.Context, conn sqlx.SqlConn, v, primary interface{}) error { | ||||||
| 	query := fmt.Sprintf("SELECT %s FROM %s WHERE `id` = ? AND del_state = ? limit 1", userRows, m.table) | 	query := fmt.Sprintf("select %s from %s where `id` = ? and del_state = ? limit 1", userRows, m.table) | ||||||
| 	return conn.QueryRowCtx(ctx, v, query, primary, globalkey.DelStateNo) | 	return conn.QueryRowCtx(ctx, v, query, primary, globalkey.DelStateNo) | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,6 +16,7 @@ CREATE TABLE `user` ( | |||||||
|   `password` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL, |   `password` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL, | ||||||
|   `nickname` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '', |   `nickname` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '', | ||||||
|   `info` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '', |   `info` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL DEFAULT '', | ||||||
|  |   `inside` tinyint NOT NULL DEFAULT '0', | ||||||
|   PRIMARY KEY (`id`), |   PRIMARY KEY (`id`), | ||||||
|   UNIQUE KEY `unique_mobile` (`mobile`) |   UNIQUE KEY `unique_mobile` (`mobile`) | ||||||
| ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='用户表'; | ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='用户表'; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user