package utils

import (
	"github.com/dgrijalva/jwt-go"
	"time"
)

type UserTokenClaims struct {
	UserId    int64  `json:"userId"`
	CompanyId int64  `json:"companyId"`
	AdminType int    `json:"adminType"` //用户类型 1:合伙人 2:高管
	Phone     string `json:"phone"`
	jwt.StandardClaims
}

var jwtSecret = []byte("123456")

//解析 UserTokenClaims
func ParseJWTToken(token string) (*UserTokenClaims, error) {
	tokenClaims, err := jwt.ParseWithClaims(token, &UserTokenClaims{}, func(token *jwt.Token) (interface{}, error) {
		return jwtSecret, nil
	})
	if err != nil {
		return nil, err
	}
	if tokenClaims != nil {
		if claim, ok := tokenClaims.Claims.(*UserTokenClaims); ok && tokenClaims.Valid {
			// TODO:版本兼容
			//if claim.CompanyId==0{
			//	claim.CompanyId = 1
			//	claim.AdminType = 1
			//}
			return claim, nil
		}
	}
	return nil, err
}

//生成token
//@uid 用户变化
//@password 密码
//@expire 过期时长
func GenerateToken(uid int64, phone string, expire time.Duration) (string, error) {
	now := time.Now()
	expireTime := now.Add(expire)
	claims := UserTokenClaims{
		UserId: uid,
		Phone:  phone,
		StandardClaims: jwt.StandardClaims{
			ExpiresAt: expireTime.Unix(),
			Issuer:    "jwt",
		},
	}

	tokenClaims := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
	token, err := tokenClaims.SignedString(jwtSecret)
	return token, err
}

func GenerateTokenWithAdminType(uid int64, phone string, adminType int, expire time.Duration) (string, error) {
	now := time.Now()
	expireTime := now.Add(expire)
	claims := UserTokenClaims{
		UserId:    uid,
		Phone:     phone,
		AdminType: adminType,
		StandardClaims: jwt.StandardClaims{
			ExpiresAt: expireTime.Unix(),
			Issuer:    "jwt",
		},
	}

	tokenClaims := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
	token, err := tokenClaims.SignedString(jwtSecret)
	return token, err
}

func GenerateTokenWithClaim(claim UserTokenClaims, expire time.Duration) (string, error) {
	now := time.Now()
	expireTime := now.Add(expire)
	claims := UserTokenClaims{
		UserId:    claim.UserId,
		Phone:     claim.Phone,
		CompanyId: claim.CompanyId,
		AdminType: claim.AdminType,
		StandardClaims: jwt.StandardClaims{
			ExpiresAt: expireTime.Unix(),
			Issuer:    "jwt",
		},
	}

	tokenClaims := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
	token, err := tokenClaims.SignedString(jwtSecret)
	return token, err
}