portal.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. // mautrix-whatsapp - A Matrix-WhatsApp puppeting bridge.
  2. // Copyright (C) 2018 Tulir Asokan
  3. //
  4. // This program is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Affero General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // This program is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Affero General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Affero General Public License
  15. // along with this program. If not, see <https://www.gnu.org/licenses/>.
  16. package database
  17. import (
  18. log "maunium.net/go/maulogger"
  19. )
  20. type PortalQuery struct {
  21. db *Database
  22. log log.Logger
  23. }
  24. func (pq *PortalQuery) CreateTable() error {
  25. _, err := pq.db.Exec(`CREATE TABLE IF NOT EXISTS portal (
  26. jid VARCHAR(255),
  27. owner VARCHAR(255),
  28. mxid VARCHAR(255) NOT NULL UNIQUE,
  29. PRIMARY KEY (jid, owner),
  30. FOREIGN KEY owner REFERENCES user(mxid)
  31. )`)
  32. return err
  33. }
  34. func (pq *PortalQuery) New() *Portal {
  35. return &Portal{
  36. db: pq.db,
  37. log: pq.log,
  38. }
  39. }
  40. func (pq *PortalQuery) GetAll(owner string) (portals []*Portal) {
  41. rows, err := pq.db.Query("SELECT * FROM portal WHERE owner=?", owner)
  42. if err != nil || rows == nil {
  43. return nil
  44. }
  45. defer rows.Close()
  46. for rows.Next() {
  47. portals = append(portals, pq.New().Scan(rows))
  48. }
  49. return
  50. }
  51. func (pq *PortalQuery) GetByJID(owner, jid string) *Portal {
  52. return pq.get("SELECT * FROM portal WHERE jid=? AND owner=?", jid, owner)
  53. }
  54. func (pq *PortalQuery) GetByMXID(mxid string) *Portal {
  55. return pq.get("SELECT * FROM portal WHERE mxid=?", mxid)
  56. }
  57. func (pq *PortalQuery) get(query string, args ...interface{}) *Portal {
  58. row := pq.db.QueryRow(query, args...)
  59. if row == nil {
  60. return nil
  61. }
  62. return pq.New().Scan(row)
  63. }
  64. type Portal struct {
  65. db *Database
  66. log log.Logger
  67. JID string
  68. MXID string
  69. Owner string
  70. }
  71. func (portal *Portal) Scan(row Scannable) *Portal {
  72. err := row.Scan(&portal.JID, &portal.MXID, &portal.Owner)
  73. if err != nil {
  74. portal.log.Fatalln("Database scan failed:", err)
  75. }
  76. return portal
  77. }
  78. func (portal *Portal) Insert() error {
  79. _, err := portal.db.Exec("INSERT INTO portal VALUES (?, ?, ?)", portal.JID, portal.Owner, portal.MXID)
  80. return err
  81. }
  82. func (portal *Portal) Update() error {
  83. _, err := portal.db.Exec("UPDATE portal SET mxid=? WHERE jid=? AND owner=?", portal.MXID, portal.JID, portal.Owner)
  84. return err
  85. }