hi-server/internal/logic/public/iap/apple/getStatusLogic.go
shanshanzhong 130fb702ab
All checks were successful
Build docker and publish / build (20.15.1) (push) Successful in 7m42s
fix: IAP 支付流程优化与关键 bug 修复
- getStatusLogic 类型断言修复(*user.User)
- restoreLogic 事务拆分为单条处理 + appAccountToken 解析
- attachTransactionLogic 提取 ParseProductIdDuration 共享函数
- 新增 config_helper.go 统一 Apple API 配置加载
- reconcileLogic 补充 BundleID 配置读取
- activateOrderLogic 邀请赠送天数逻辑完善

Co-Authored-By: claude-flow <ruv@ruv.net>
2026-03-09 00:27:16 -07:00

69 lines
1.8 KiB
Go
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

package apple
import (
"context"
"strings"
"time"
"github.com/perfect-panel/server/internal/model/user"
"github.com/perfect-panel/server/internal/svc"
"github.com/perfect-panel/server/internal/types"
"github.com/perfect-panel/server/pkg/constant"
"github.com/perfect-panel/server/pkg/logger"
"github.com/perfect-panel/server/pkg/xerr"
"github.com/pkg/errors"
)
type GetStatusLogic struct {
logger.Logger
ctx context.Context
svcCtx *svc.ServiceContext
}
func NewGetStatusLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetStatusLogic {
return &GetStatusLogic{
Logger: logger.WithContext(ctx),
ctx: ctx,
svcCtx: svcCtx,
}
}
func (l *GetStatusLogic) GetStatus() (*types.GetAppleStatusResponse, error) {
u, ok := l.ctx.Value(constant.CtxKeyUser).(*user.User)
if !ok || u == nil {
return nil, errors.Wrapf(xerr.NewErrCode(xerr.InvalidAccess), "invalid access")
}
// 查该用户所有状态的订阅,找 IAP 相关的token 以 iap: 开头)
subs, err := l.svcCtx.UserModel.QueryUserSubscribe(l.ctx, u.Id, 1)
if err != nil {
return &types.GetAppleStatusResponse{Active: false, ExpiresAt: 0, Tier: ""}, nil
}
now := time.Now()
var bestExpire time.Time
var bestTier string
for _, sub := range subs {
if sub == nil {
continue
}
// 仅处理 IAP 创建的订阅token 以 "iap:" 开头)
if !strings.HasPrefix(sub.Token, "iap:") {
continue
}
if sub.ExpireTime.After(bestExpire) {
bestExpire = sub.ExpireTime
if sub.Subscribe != nil {
bestTier = sub.Subscribe.Name
}
}
}
if bestExpire.IsZero() {
return &types.GetAppleStatusResponse{Active: false, ExpiresAt: 0, Tier: ""}, nil
}
active := bestExpire.After(now)
return &types.GetAppleStatusResponse{
Active: active,
ExpiresAt: bestExpire.Unix(),
Tier: bestTier,
}, nil
}