74 lines
1.7 KiB
Go
74 lines
1.7 KiB
Go
package database
|
|
|
|
import (
|
|
"github.com/karmanyaahm/matrix-groupme-go/types"
|
|
log "maunium.net/go/maulogger/v2"
|
|
"maunium.net/go/mautrix/id"
|
|
)
|
|
|
|
type ReactionQuery struct {
|
|
db *Database
|
|
log log.Logger
|
|
}
|
|
|
|
func (mq *ReactionQuery) New() *Reaction {
|
|
return &Reaction{
|
|
db: mq.db,
|
|
log: mq.log,
|
|
}
|
|
}
|
|
|
|
func (mq *ReactionQuery) GetByJID(jid types.GroupMeID) (reactions []*Reaction) {
|
|
ans := mq.db.Model(&Reaction{}).
|
|
Joins("Users"). // TODO: Do this in seperate function?
|
|
Where("message_jid = ?", jid).
|
|
Limit(1).Find(&reactions)
|
|
|
|
if ans.Error != nil || ans.RowsAffected == 0 {
|
|
return nil
|
|
}
|
|
|
|
for _, reaction := range reactions {
|
|
reaction.db = mq.db
|
|
reaction.log = mq.log
|
|
}
|
|
|
|
return
|
|
}
|
|
|
|
// ans := mq.db.Model(&Reaction{}).
|
|
// Joins("INNER JOIN users on users.mxid = reactions.user_mxid").
|
|
// Where("reactions.message_jid = ? AND users.jid = ?", jid, uid).
|
|
// Limit(1).Find(&reactions)
|
|
|
|
type Reaction struct {
|
|
db *Database
|
|
log log.Logger
|
|
|
|
MXID id.EventID `gorm:"primaryKey"`
|
|
|
|
//Message
|
|
MessageJID types.GroupMeID `gorm:"notNull"`
|
|
MessageMXID id.EventID `gorm:"notNull"`
|
|
|
|
Message Message `gorm:"foreignKey:MessageMXID,MessageJID;references:MXID,JID;"`
|
|
|
|
//User
|
|
UserMXID id.UserID `gorm:"notNull"`
|
|
User User `gorm:"foreignKey:UserMXID;references:MXID;"`
|
|
}
|
|
|
|
func (reaction *Reaction) Insert() {
|
|
ans := reaction.db.Create(&reaction)
|
|
if ans.Error != nil {
|
|
reaction.log.Warnfln("Failed to insert %s@%s: %v", reaction.MXID, reaction.MessageJID, ans.Error)
|
|
}
|
|
}
|
|
|
|
func (reaction *Reaction) Delete() {
|
|
ans := reaction.db.Delete(&reaction)
|
|
if ans.Error != nil {
|
|
reaction.log.Warnfln("Failed to insert %s@%s: %v", reaction.MXID, reaction.MessageJID, ans.Error)
|
|
}
|
|
}
|