2022-09-28 09:01:17 +02:00
|
|
|
package query
|
|
|
|
|
|
|
|
import (
|
2022-10-03 22:59:29 +02:00
|
|
|
"fmt"
|
|
|
|
"strings"
|
2022-09-28 09:01:17 +02:00
|
|
|
|
|
|
|
"github.com/photoprism/photoprism/internal/entity"
|
2022-10-03 22:59:29 +02:00
|
|
|
"github.com/photoprism/photoprism/pkg/rnd"
|
2024-01-29 13:54:50 +01:00
|
|
|
"github.com/photoprism/photoprism/pkg/unix"
|
2022-09-28 09:01:17 +02:00
|
|
|
)
|
|
|
|
|
2022-10-03 22:59:29 +02:00
|
|
|
// Session finds an existing session by its id.
|
|
|
|
func Session(id string) (result entity.Session, err error) {
|
|
|
|
if l := len(id); l < 6 && l > 2048 {
|
|
|
|
return result, fmt.Errorf("invalid session id")
|
|
|
|
} else if rnd.IsRefID(id) {
|
|
|
|
err = Db().Where("ref_id = ?", id).First(&result).Error
|
2024-01-06 17:35:19 +01:00
|
|
|
} else if rnd.IsSessionID(id) {
|
2022-10-03 22:59:29 +02:00
|
|
|
err = Db().Where("id LIKE ?", id).First(&result).Error
|
2024-01-06 17:35:19 +01:00
|
|
|
} else {
|
|
|
|
err = Db().Where("id LIKE ?", rnd.SessionID(id)).First(&result).Error
|
2022-10-03 22:59:29 +02:00
|
|
|
}
|
2022-09-28 09:01:17 +02:00
|
|
|
|
|
|
|
return result, err
|
|
|
|
}
|
|
|
|
|
2022-10-03 22:59:29 +02:00
|
|
|
// Sessions finds user sessions and returns them.
|
|
|
|
func Sessions(limit, offset int, sortOrder, search string) (result entity.Sessions, err error) {
|
|
|
|
result = entity.Sessions{}
|
|
|
|
stmt := Db()
|
|
|
|
|
|
|
|
search = strings.TrimSpace(search)
|
|
|
|
|
|
|
|
if search == "expired" {
|
2024-01-29 13:54:50 +01:00
|
|
|
stmt = stmt.Where("sess_expires > 0 AND sess_expires < ?", unix.Time())
|
2022-10-03 22:59:29 +02:00
|
|
|
} else if rnd.IsSessionID(search) {
|
|
|
|
stmt = stmt.Where("id = ?", search)
|
2024-01-06 17:35:19 +01:00
|
|
|
} else if rnd.IsAuthToken(search) {
|
|
|
|
stmt = stmt.Where("id = ?", rnd.SessionID(search))
|
2022-10-03 22:59:29 +02:00
|
|
|
} else if rnd.IsUID(search, entity.UserUID) {
|
|
|
|
stmt = stmt.Where("user_uid = ?", search)
|
|
|
|
} else if search != "" {
|
2023-03-09 18:45:04 +01:00
|
|
|
stmt = stmt.Where("user_name LIKE ? OR auth_provider LIKE ?", search+"%", search+"%")
|
2022-10-03 22:59:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if sortOrder == "" {
|
2024-01-29 17:32:53 +01:00
|
|
|
sortOrder = "last_active DESC, created_at DESC, user_name"
|
2022-10-03 22:59:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if limit > 0 {
|
|
|
|
stmt = stmt.Limit(limit)
|
|
|
|
|
|
|
|
if offset > 0 {
|
|
|
|
stmt = stmt.Offset(offset)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
err = stmt.Order(sortOrder).Find(&result).Error
|
2022-09-28 09:01:17 +02:00
|
|
|
|
|
|
|
return result, err
|
|
|
|
}
|