53 lines
1.4 KiB
Go
53 lines
1.4 KiB
Go
|
package model
|
||
|
|
||
|
import (
|
||
|
_ "gorm.io/driver/sqlite"
|
||
|
)
|
||
|
|
||
|
type Token struct {
|
||
|
Id int `json:"id"`
|
||
|
UserId int `json:"user_id"`
|
||
|
Key string `json:"key"`
|
||
|
Status int `json:"status" gorm:"default:1"`
|
||
|
Name string `json:"name" gorm:"unique;index"`
|
||
|
CreatedTime int64 `json:"created_time" gorm:"bigint"`
|
||
|
AccessedTime int64 `json:"accessed_time" gorm:"bigint"`
|
||
|
}
|
||
|
|
||
|
func GetAllUserTokens(userId int, startIdx int, num int) ([]*Token, error) {
|
||
|
var tokens []*Token
|
||
|
var err error
|
||
|
err = DB.Where("userId = ?", userId).Order("id desc").Limit(num).Offset(startIdx).Omit("key").Find(&tokens).Error
|
||
|
return tokens, err
|
||
|
}
|
||
|
|
||
|
func SearchUserTokens(userId int, keyword string) (tokens []*Token, err error) {
|
||
|
err = DB.Where("userId = ?", userId).Omit("key").Where("id = ? or name LIKE ?", keyword, keyword+"%").Find(&tokens).Error
|
||
|
return tokens, err
|
||
|
}
|
||
|
|
||
|
func GetTokenById(id int) (*Token, error) {
|
||
|
token := Token{Id: id}
|
||
|
var err error = nil
|
||
|
err = DB.Omit("key").Select([]string{"id", "type"}).First(&token, "id = ?", id).Error
|
||
|
return &token, err
|
||
|
}
|
||
|
|
||
|
func (token *Token) Insert() error {
|
||
|
var err error
|
||
|
err = DB.Create(token).Error
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
func (token *Token) Update() error {
|
||
|
var err error
|
||
|
err = DB.Model(token).Updates(token).Error
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
func (token *Token) Delete() error {
|
||
|
var err error
|
||
|
err = DB.Delete(token).Error
|
||
|
return err
|
||
|
}
|