|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- package device
-
- import (
- "egg-im/internal/business/domain/user/model"
- "egg-im/pkg/db"
- "egg-im/pkg/gerrors"
- "time"
-
- "github.com/jinzhu/gorm"
- )
-
- type deviceDao struct{}
-
- var DeviceDao = new(deviceDao)
-
- // Save 插入一条设备信息
- func (*deviceDao) Save(device *Device) error {
- device.CreateTime = time.Now()
- device.UpdateTime = time.Now()
- err := db.DB.Save(&device).Error
- if err != nil {
- return gerrors.WrapError(err)
- }
- return nil
- }
-
- // Get 获取设备
- func (*deviceDao) Get(deviceId int64) (*Device, error) {
- var device = Device{Id: deviceId}
- err := db.DB.First(&device).Error
- if err != nil && err != gorm.ErrRecordNotFound {
- return nil, gerrors.WrapError(err)
- }
- if err == gorm.ErrRecordNotFound {
- return nil, nil
- }
- return &device, nil
- }
-
- // ListOnlineByUserId 查询用户所有的在线设备
- func (*deviceDao) ListOnlineByUserId(userId int64) ([]Device, error) {
- var devices []Device
- err := db.DB.Find(&devices, "user_id = ? and status = ?", userId, DeviceOnLine).Error
- if err != nil {
- return nil, gerrors.WrapError(err)
- }
- return devices, nil
- }
-
- // ListOffLineByUserId 查询用户所有的离线设备
- func (*deviceDao) ListOffLineByUserId(userId int64) ([]Device, error) {
- var devices []Device
- err := db.DB.Find(&devices, "user_id = ? and status = ?", userId, DeviceOnLine).Error
- if err != nil {
- return nil, gerrors.WrapError(err)
- }
- return devices, nil
- }
-
- // ListOnlineByConnAddr 查询用户所有的在线设备
- func (*deviceDao) ListOnlineByConnAddr(connAddr string) ([]Device, error) {
- var devices []Device
- err := db.DB.Find(&devices, "conn_addr = ? and status = ?", connAddr, DeviceOnLine).Error
- if err != nil {
- return nil, gerrors.WrapError(err)
- }
- return devices, nil
- }
-
- // UpdateStatus 更新在线状态
- func (*deviceDao) UpdateStatus(deviceId int64, connAddr string, status int) (int64, error) {
- db := db.DB.Model(&model.Device{}).Where("id = ? and conn_addr = ?", deviceId, connAddr).
- Update("status", status)
- if db.Error != nil {
- return 0, gerrors.WrapError(db.Error)
- }
- return db.RowsAffected, nil
- }
|