channel.go 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. package model
  2. import (
  3. _ "gorm.io/driver/sqlite"
  4. )
  5. type Channel struct {
  6. Id int `json:"id"`
  7. Type int `json:"type" gorm:"default:0"`
  8. Key string `json:"key"`
  9. Status int `json:"status" gorm:"default:1"`
  10. Name string `json:"name" gorm:"unique;index"`
  11. Weight int `json:"weight"`
  12. CreatedTime int64 `json:"created_time" gorm:"bigint"`
  13. AccessedTime int64 `json:"accessed_time" gorm:"bigint"`
  14. }
  15. func GetAllChannels(startIdx int, num int) ([]*Channel, error) {
  16. var channels []*Channel
  17. var err error
  18. err = DB.Order("id desc").Limit(num).Offset(startIdx).Omit("key").Find(&channels).Error
  19. return channels, err
  20. }
  21. func SearchChannels(keyword string) (channels []*Channel, err error) {
  22. err = DB.Omit("key").Where("id = ? or name LIKE ?", keyword, keyword+"%").Find(&channels).Error
  23. return channels, err
  24. }
  25. func GetChannelById(id int) (*Channel, error) {
  26. channel := Channel{Id: id}
  27. var err error = nil
  28. err = DB.Omit("key").First(&channel, "id = ?", id).Error
  29. return &channel, err
  30. }
  31. func (channel *Channel) Insert() error {
  32. var err error
  33. err = DB.Create(channel).Error
  34. return err
  35. }
  36. func (channel *Channel) Update() error {
  37. var err error
  38. err = DB.Model(channel).Updates(channel).Error
  39. return err
  40. }
  41. func (channel *Channel) Delete() error {
  42. var err error
  43. err = DB.Delete(channel).Error
  44. return err
  45. }