|
@@ -1,5 +1,5 @@
|
|
// mautrix-whatsapp - A Matrix-WhatsApp puppeting bridge.
|
|
// mautrix-whatsapp - A Matrix-WhatsApp puppeting bridge.
|
|
-// Copyright (C) 2021 Tulir Asokan
|
|
|
|
|
|
+// Copyright (C) 2022 Tulir Asokan
|
|
//
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
@@ -44,7 +44,7 @@ func (uq *UserQuery) New() *User {
|
|
}
|
|
}
|
|
|
|
|
|
func (uq *UserQuery) GetAll() (users []*User) {
|
|
func (uq *UserQuery) GetAll() (users []*User) {
|
|
- rows, err := uq.db.Query(`SELECT mxid, username, agent, device, management_room, space_room, phone_last_seen FROM "user"`)
|
|
|
|
|
|
+ rows, err := uq.db.Query(`SELECT mxid, username, agent, device, management_room, space_room, phone_last_seen, phone_last_pinged FROM "user"`)
|
|
if err != nil || rows == nil {
|
|
if err != nil || rows == nil {
|
|
return nil
|
|
return nil
|
|
}
|
|
}
|
|
@@ -56,7 +56,7 @@ func (uq *UserQuery) GetAll() (users []*User) {
|
|
}
|
|
}
|
|
|
|
|
|
func (uq *UserQuery) GetByMXID(userID id.UserID) *User {
|
|
func (uq *UserQuery) GetByMXID(userID id.UserID) *User {
|
|
- row := uq.db.QueryRow(`SELECT mxid, username, agent, device, management_room, space_room, phone_last_seen FROM "user" WHERE mxid=$1`, userID)
|
|
|
|
|
|
+ row := uq.db.QueryRow(`SELECT mxid, username, agent, device, management_room, space_room, phone_last_seen, phone_last_pinged FROM "user" WHERE mxid=$1`, userID)
|
|
if row == nil {
|
|
if row == nil {
|
|
return nil
|
|
return nil
|
|
}
|
|
}
|
|
@@ -64,7 +64,7 @@ func (uq *UserQuery) GetByMXID(userID id.UserID) *User {
|
|
}
|
|
}
|
|
|
|
|
|
func (uq *UserQuery) GetByUsername(username string) *User {
|
|
func (uq *UserQuery) GetByUsername(username string) *User {
|
|
- row := uq.db.QueryRow(`SELECT mxid, username, agent, device, management_room, space_room, phone_last_seen FROM "user" WHERE username=$1`, username)
|
|
|
|
|
|
+ row := uq.db.QueryRow(`SELECT mxid, username, agent, device, management_room, space_room, phone_last_seen, phone_last_pinged FROM "user" WHERE username=$1`, username)
|
|
if row == nil {
|
|
if row == nil {
|
|
return nil
|
|
return nil
|
|
}
|
|
}
|
|
@@ -75,11 +75,12 @@ type User struct {
|
|
db *Database
|
|
db *Database
|
|
log log.Logger
|
|
log log.Logger
|
|
|
|
|
|
- MXID id.UserID
|
|
|
|
- JID types.JID
|
|
|
|
- ManagementRoom id.RoomID
|
|
|
|
- SpaceRoom id.RoomID
|
|
|
|
- PhoneLastSeen time.Time
|
|
|
|
|
|
+ MXID id.UserID
|
|
|
|
+ JID types.JID
|
|
|
|
+ ManagementRoom id.RoomID
|
|
|
|
+ SpaceRoom id.RoomID
|
|
|
|
+ PhoneLastSeen time.Time
|
|
|
|
+ PhoneLastPinged time.Time
|
|
|
|
|
|
lastReadCache map[PortalKey]time.Time
|
|
lastReadCache map[PortalKey]time.Time
|
|
lastReadCacheLock sync.Mutex
|
|
lastReadCacheLock sync.Mutex
|
|
@@ -90,8 +91,8 @@ type User struct {
|
|
func (user *User) Scan(row Scannable) *User {
|
|
func (user *User) Scan(row Scannable) *User {
|
|
var username sql.NullString
|
|
var username sql.NullString
|
|
var device, agent sql.NullByte
|
|
var device, agent sql.NullByte
|
|
- var phoneLastSeen sql.NullInt64
|
|
|
|
- err := row.Scan(&user.MXID, &username, &agent, &device, &user.ManagementRoom, &user.SpaceRoom, &phoneLastSeen)
|
|
|
|
|
|
+ var phoneLastSeen, phoneLastPinged sql.NullInt64
|
|
|
|
+ err := row.Scan(&user.MXID, &username, &agent, &device, &user.ManagementRoom, &user.SpaceRoom, &phoneLastSeen, &phoneLastPinged)
|
|
if err != nil {
|
|
if err != nil {
|
|
if err != sql.ErrNoRows {
|
|
if err != sql.ErrNoRows {
|
|
user.log.Errorln("Database scan failed:", err)
|
|
user.log.Errorln("Database scan failed:", err)
|
|
@@ -104,6 +105,9 @@ func (user *User) Scan(row Scannable) *User {
|
|
if phoneLastSeen.Valid {
|
|
if phoneLastSeen.Valid {
|
|
user.PhoneLastSeen = time.Unix(phoneLastSeen.Int64, 0)
|
|
user.PhoneLastSeen = time.Unix(phoneLastSeen.Int64, 0)
|
|
}
|
|
}
|
|
|
|
+ if phoneLastPinged.Valid {
|
|
|
|
+ user.PhoneLastPinged = time.Unix(phoneLastPinged.Int64, 0)
|
|
|
|
+ }
|
|
return user
|
|
return user
|
|
}
|
|
}
|
|
|
|
|
|
@@ -136,17 +140,25 @@ func (user *User) phoneLastSeenPtr() *int64 {
|
|
return &ts
|
|
return &ts
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+func (user *User) phoneLastPingedPtr() *int64 {
|
|
|
|
+ if user.PhoneLastPinged.IsZero() {
|
|
|
|
+ return nil
|
|
|
|
+ }
|
|
|
|
+ ts := user.PhoneLastPinged.Unix()
|
|
|
|
+ return &ts
|
|
|
|
+}
|
|
|
|
+
|
|
func (user *User) Insert() {
|
|
func (user *User) Insert() {
|
|
- _, err := user.db.Exec(`INSERT INTO "user" (mxid, username, agent, device, management_room, space_room, phone_last_seen) VALUES ($1, $2, $3, $4, $5, $6, $7)`,
|
|
|
|
- user.MXID, user.usernamePtr(), user.agentPtr(), user.devicePtr(), user.ManagementRoom, user.SpaceRoom, user.phoneLastSeenPtr())
|
|
|
|
|
|
+ _, err := user.db.Exec(`INSERT INTO "user" (mxid, username, agent, device, management_room, space_room, phone_last_seen, phone_last_pinged) VALUES ($1, $2, $3, $4, $5, $6, $7, $8)`,
|
|
|
|
+ user.MXID, user.usernamePtr(), user.agentPtr(), user.devicePtr(), user.ManagementRoom, user.SpaceRoom, user.phoneLastSeenPtr(), user.phoneLastPingedPtr())
|
|
if err != nil {
|
|
if err != nil {
|
|
user.log.Warnfln("Failed to insert %s: %v", user.MXID, err)
|
|
user.log.Warnfln("Failed to insert %s: %v", user.MXID, err)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
func (user *User) Update() {
|
|
func (user *User) Update() {
|
|
- _, err := user.db.Exec(`UPDATE "user" SET username=$1, agent=$2, device=$3, management_room=$4, space_room=$5, phone_last_seen=$6 WHERE mxid=$7`,
|
|
|
|
- user.usernamePtr(), user.agentPtr(), user.devicePtr(), user.ManagementRoom, user.SpaceRoom, user.phoneLastSeenPtr(), user.MXID)
|
|
|
|
|
|
+ _, err := user.db.Exec(`UPDATE "user" SET username=$1, agent=$2, device=$3, management_room=$4, space_room=$5, phone_last_seen=$6, phone_last_pinged=$7 WHERE mxid=$8`,
|
|
|
|
+ user.usernamePtr(), user.agentPtr(), user.devicePtr(), user.ManagementRoom, user.SpaceRoom, user.phoneLastSeenPtr(), user.phoneLastPingedPtr(), user.MXID)
|
|
if err != nil {
|
|
if err != nil {
|
|
user.log.Warnfln("Failed to update %s: %v", user.MXID, err)
|
|
user.log.Warnfln("Failed to update %s: %v", user.MXID, err)
|
|
}
|
|
}
|