This commit is contained in:
Alex 2020-02-17 19:02:26 +01:00
parent 531b59bf95
commit a4dd3b310d
9 changed files with 142 additions and 144 deletions

View file

@ -10,10 +10,10 @@ import (
) )
type Account struct { type Account struct {
MatrixUser string MatrixUser string
AccountName string AccountName string
Protocol string Protocol string
Conn Connector Conn Connector
JoinedRooms map[RoomID]bool JoinedRooms map[RoomID]bool
} }
@ -240,4 +240,3 @@ func (a *Account) eventInternal(event *Event) error {
return mxSendMessageAs(mx_room_id, typ, event.Text, mx_user_id) return mxSendMessageAs(mx_room_id, typ, event.Text, mx_user_id)
} }
} }

View file

@ -3,14 +3,14 @@ package appservice
import ( import (
"fmt" "fmt"
log "github.com/sirupsen/logrus"
"github.com/jinzhu/gorm" "github.com/jinzhu/gorm"
_ "github.com/jinzhu/gorm/dialects/mysql" _ "github.com/jinzhu/gorm/dialects/mysql"
_ "github.com/jinzhu/gorm/dialects/postgres" _ "github.com/jinzhu/gorm/dialects/postgres"
_ "github.com/jinzhu/gorm/dialects/sqlite" _ "github.com/jinzhu/gorm/dialects/sqlite"
log "github.com/sirupsen/logrus"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/mxlib"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/connector" "git.deuxfleurs.fr/Deuxfleurs/easybridge/connector"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/mxlib"
) )
var db *gorm.DB var db *gorm.DB
@ -40,7 +40,7 @@ type DbUserMap struct {
gorm.Model gorm.Model
Protocol string Protocol string
UserID connector.UserID UserID connector.UserID
MxUserID string `gorm:"index:mxuserid"` MxUserID string `gorm:"index:mxuserid"`
} }
@ -63,8 +63,8 @@ type DbPmRoomMap struct {
gorm.Model gorm.Model
// User id and account name of the local end viewed on Matrix // User id and account name of the local end viewed on Matrix
MxUserID string MxUserID string
Protocol string Protocol string
AccountName string AccountName string
// User id to reach them // User id to reach them
@ -83,7 +83,7 @@ func dbGetMxRoom(protocol string, roomId connector.RoomID) (string, error) {
// If not create it // If not create it
must_create := db.First(&room, DbRoomMap{ must_create := db.First(&room, DbRoomMap{
Protocol: protocol, Protocol: protocol,
RoomID: roomId, RoomID: roomId,
}).RecordNotFound() }).RecordNotFound()
if must_create { if must_create {
alias := roomAlias(protocol, roomId) alias := roomAlias(protocol, roomId)
@ -103,7 +103,7 @@ func dbGetMxRoom(protocol string, roomId connector.RoomID) (string, error) {
room = DbRoomMap{ room = DbRoomMap{
Protocol: protocol, Protocol: protocol,
RoomID: roomId, RoomID: roomId,
MxRoomID: mx_room_id, MxRoomID: mx_room_id,
} }
db.Create(&room) db.Create(&room)
@ -117,10 +117,10 @@ func dbGetMxPmRoom(protocol string, them connector.UserID, themMxId string, usMx
var room DbPmRoomMap var room DbPmRoomMap
must_create := db.First(&room, DbPmRoomMap{ must_create := db.First(&room, DbPmRoomMap{
MxUserID: usMxId, MxUserID: usMxId,
Protocol: protocol, Protocol: protocol,
AccountName: usAccount, AccountName: usAccount,
UserID: them, UserID: them,
}).RecordNotFound() }).RecordNotFound()
if must_create { if must_create {
name := fmt.Sprintf("%s (%s)", them, protocol) name := fmt.Sprintf("%s (%s)", them, protocol)
@ -138,11 +138,11 @@ func dbGetMxPmRoom(protocol string, them connector.UserID, themMxId string, usMx
} }
room = DbPmRoomMap{ room = DbPmRoomMap{
MxUserID: usMxId, MxUserID: usMxId,
Protocol: protocol, Protocol: protocol,
AccountName: usAccount, AccountName: usAccount,
UserID: them, UserID: them,
MxRoomID: mx_room_id, MxRoomID: mx_room_id,
} }
db.Create(&room) db.Create(&room)
} }
@ -156,7 +156,7 @@ func dbGetMxUser(protocol string, userId connector.UserID) (string, error) {
must_create := db.First(&user, DbUserMap{ must_create := db.First(&user, DbUserMap{
Protocol: protocol, Protocol: protocol,
UserID: userId, UserID: userId,
}).RecordNotFound() }).RecordNotFound()
if must_create { if must_create {
username := userMxId(protocol, userId) username := userMxId(protocol, userId)
@ -174,7 +174,7 @@ func dbGetMxUser(protocol string, userId connector.UserID) (string, error) {
user = DbUserMap{ user = DbUserMap{
Protocol: protocol, Protocol: protocol,
UserID: userId, UserID: userId,
MxUserID: mxid, MxUserID: mxid,
} }
db.Create(&user) db.Create(&user)

View file

@ -1,12 +1,12 @@
package appservice package appservice
import ( import (
"fmt"
"net/url"
"net/http"
"time"
"bytes" "bytes"
"encoding/json" "encoding/json"
"fmt"
"net/http"
"net/url"
"time"
log "github.com/sirupsen/logrus" log "github.com/sirupsen/logrus"
@ -33,7 +33,7 @@ func init() {
func mxGetApiCall(endpoint string, response interface{}) error { func mxGetApiCall(endpoint string, response interface{}) error {
log.Debugf("Matrix GET request: %s\n", endpoint) log.Debugf("Matrix GET request: %s\n", endpoint)
req, err := http.NewRequest("GET", config.Server + endpoint, nil) req, err := http.NewRequest("GET", config.Server+endpoint, nil)
if err != nil { if err != nil {
return err return err
} }
@ -49,7 +49,7 @@ func mxPutApiCall(endpoint string, data interface{}, response interface{}) error
log.Debugf("Matrix PUT request: %s %s\n", endpoint, string(body)) log.Debugf("Matrix PUT request: %s %s\n", endpoint, string(body))
req, err := http.NewRequest("PUT", config.Server + endpoint, bytes.NewBuffer(body)) req, err := http.NewRequest("PUT", config.Server+endpoint, bytes.NewBuffer(body))
if err != nil { if err != nil {
return err return err
} }
@ -66,7 +66,7 @@ func mxPostApiCall(endpoint string, data interface{}, response interface{}) erro
log.Debugf("Matrix POST request: %s %s\n", endpoint, string(body)) log.Debugf("Matrix POST request: %s %s\n", endpoint, string(body))
req, err := http.NewRequest("POST", config.Server + endpoint, bytes.NewBuffer(body)) req, err := http.NewRequest("POST", config.Server+endpoint, bytes.NewBuffer(body))
if err != nil { if err != nil {
return err return err
} }
@ -76,7 +76,7 @@ func mxPostApiCall(endpoint string, data interface{}, response interface{}) erro
} }
func mxDoAndParse(req *http.Request, response interface{}) error { func mxDoAndParse(req *http.Request, response interface{}) error {
req.Header.Add("Authorization", "Bearer " + registration.AsToken) req.Header.Add("Authorization", "Bearer "+registration.AsToken)
resp, err := httpClient.Do(req) resp, err := httpClient.Do(req)
if err != nil { if err != nil {
@ -125,7 +125,7 @@ func mxProfileDisplayname(userid string, displayname string) error {
func mxDirectoryRoom(alias string) (string, error) { func mxDirectoryRoom(alias string) (string, error) {
var rep DirectoryRoomResponse var rep DirectoryRoomResponse
err := mxGetApiCall("/_matrix/client/r0/directory/room/" + url.QueryEscape(alias), &rep) err := mxGetApiCall("/_matrix/client/r0/directory/room/"+url.QueryEscape(alias), &rep)
if err != nil { if err != nil {
return "", err return "", err
} }
@ -134,18 +134,18 @@ func mxDirectoryRoom(alias string) (string, error) {
func mxCreateRoom(name string, alias string, invite []string) (string, error) { func mxCreateRoom(name string, alias string, invite []string) (string, error) {
rq := CreateRoomRequest{ rq := CreateRoomRequest{
Preset: "private_chat", Preset: "private_chat",
RoomAliasName: alias, RoomAliasName: alias,
Name: name, Name: name,
Topic: "", Topic: "",
Invite: invite, Invite: invite,
CreationContent: map[string]interface{} { CreationContent: map[string]interface{}{
"m.federate": false, "m.federate": false,
}, },
PowerLevels: map[string]interface{} { PowerLevels: map[string]interface{}{
"invite": 100, "invite": 100,
"events": map[string]interface{} { "events": map[string]interface{}{
"m.room.topic": 0, "m.room.topic": 0,
"m.room.avatar": 0, "m.room.avatar": 0,
}, },
}, },
@ -161,19 +161,19 @@ func mxCreateRoom(name string, alias string, invite []string) (string, error) {
func mxCreateDirectRoomAs(name string, invite []string, as_user string) (string, error) { func mxCreateDirectRoomAs(name string, invite []string, as_user string) (string, error) {
rq := CreateRoomNoAliasRequest{ rq := CreateRoomNoAliasRequest{
Preset: "private_chat", Preset: "private_chat",
Name: name, Name: name,
Topic: "", Topic: "",
Invite: invite, Invite: invite,
CreationContent: map[string]interface{} { CreationContent: map[string]interface{}{
"m.federate": false, "m.federate": false,
}, },
PowerLevels: map[string]interface{} { PowerLevels: map[string]interface{}{
"invite": 100, "invite": 100,
}, },
IsDirect: true, IsDirect: true,
} }
var rep CreateRoomResponse var rep CreateRoomResponse
err := mxPostApiCall("/_matrix/client/r0/createRoom?user_id=" + url.QueryEscape(as_user), &rq, &rep) err := mxPostApiCall("/_matrix/client/r0/createRoom?user_id="+url.QueryEscape(as_user), &rq, &rep)
if err != nil { if err != nil {
return "", err return "", err
} }
@ -185,7 +185,7 @@ func mxRoomInvite(room string, user string) error {
UserId: user, UserId: user,
} }
var rep struct{} var rep struct{}
err := mxPostApiCall("/_matrix/client/r0/rooms/" + url.QueryEscape(room) + "/invite", &rq, &rep) err := mxPostApiCall("/_matrix/client/r0/rooms/"+url.QueryEscape(room)+"/invite", &rq, &rep)
return err return err
} }
@ -195,21 +195,21 @@ func mxRoomKick(room string, user string, reason string) error {
Reason: reason, Reason: reason,
} }
var rep struct{} var rep struct{}
err := mxPostApiCall("/_matrix/client/r0/rooms/" + url.QueryEscape(room) + "/kick", &rq, &rep) err := mxPostApiCall("/_matrix/client/r0/rooms/"+url.QueryEscape(room)+"/kick", &rq, &rep)
return err return err
} }
func mxRoomJoinAs(room string, user string) error { func mxRoomJoinAs(room string, user string) error {
rq := struct{}{} rq := struct{}{}
var rep RoomJoinResponse var rep RoomJoinResponse
err := mxPostApiCall("/_matrix/client/r0/rooms/" + url.QueryEscape(room) + "/join?user_id=" + url.QueryEscape(user), &rq, &rep) err := mxPostApiCall("/_matrix/client/r0/rooms/"+url.QueryEscape(room)+"/join?user_id="+url.QueryEscape(user), &rq, &rep)
return err return err
} }
func mxRoomLeaveAs(room string, user string) error { func mxRoomLeaveAs(room string, user string) error {
rq := struct{}{} rq := struct{}{}
var rep struct{} var rep struct{}
err := mxPostApiCall("/_matrix/client/r0/rooms/" + url.QueryEscape(room) + "/leave?user_id=" + url.QueryEscape(user), &rq, &rep) err := mxPostApiCall("/_matrix/client/r0/rooms/"+url.QueryEscape(room)+"/leave?user_id="+url.QueryEscape(user), &rq, &rep)
return err return err
} }
@ -224,9 +224,9 @@ func mxSendAs(room string, event_type string, content map[string]interface{}, us
} }
func mxSendMessageAs(room string, typ string, body string, user string) error { func mxSendMessageAs(room string, typ string, body string, user string) error {
content := map[string]interface{} { content := map[string]interface{}{
"msgtype": typ, "msgtype": typ,
"body": body, "body": body,
} }
return mxSendAs(room, "m.room.message", content, user) return mxSendAs(room, "m.room.message", content, user)
} }
@ -241,14 +241,14 @@ func mxPutStateAs(room string, event_type string, key string, content map[string
} }
func mxRoomNameAs(room string, name string, as_user string) error { func mxRoomNameAs(room string, name string, as_user string) error {
content := map[string]interface{} { content := map[string]interface{}{
"name": name, "name": name,
} }
return mxPutStateAs(room, "m.room.name", "", content, as_user) return mxPutStateAs(room, "m.room.name", "", content, as_user)
} }
func mxRoomTopicAs(room string, topic string, as_user string) error { func mxRoomTopicAs(room string, topic string, as_user string) error {
content := map[string]interface{} { content := map[string]interface{}{
"topic": topic, "topic": topic,
} }
return mxPutStateAs(room, "m.room.topic", "", content, as_user) return mxPutStateAs(room, "m.room.topic", "", content, as_user)

View file

@ -3,25 +3,24 @@ package appservice
import ( import (
"encoding/json" "encoding/json"
"fmt" "fmt"
"strings"
"net/http" "net/http"
"strings"
"github.com/gorilla/mux" "github.com/gorilla/mux"
log "github.com/sirupsen/logrus" log "github.com/sirupsen/logrus"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/mxlib"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/connector" "git.deuxfleurs.fr/Deuxfleurs/easybridge/connector"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/mxlib"
) )
type Config struct { type Config struct {
HttpBindAddr string HttpBindAddr string
Server string Server string
DbType string DbType string
DbPath string DbPath string
MatrixDomain string MatrixDomain string
} }
var registration *mxlib.Registration var registration *mxlib.Registration
var config *Config var config *Config

View file

@ -8,11 +8,11 @@ package connector
- A connector represents a connection to an outgoing service (IRC, XMPP, etc) - A connector represents a connection to an outgoing service (IRC, XMPP, etc)
It satisfies a generic interface representing the actions that can be called It satisfies a generic interface representing the actions that can be called
(send messages, join room, etc) (send messages, join room, etc)
- A handler represents a consumer of events happening on a connection - A handler represents a consumer of events happening on a connection
It satisfies a generic interface representing the events that can happend It satisfies a generic interface representing the events that can happend
(message received, rooms autojoined, etc) (message received, rooms autojoined, etc)
- A connector implements a given protocol that has an identifier - A connector implements a given protocol that has an identifier
Each protocol identifier determines a namespace for user identifiers Each protocol identifier determines a namespace for user identifiers
and room identifiers which are globally unique for all connections using and room identifiers which are globally unique for all connections using
@ -82,6 +82,7 @@ type Handler interface {
} }
type EventType int type EventType int
const ( const (
EVENT_JOIN EventType = iota EVENT_JOIN EventType = iota
EVENT_LEAVE EVENT_LEAVE
@ -114,12 +115,12 @@ type Event struct {
type UserInfo struct { type UserInfo struct {
DisplayName string DisplayName string
Avatar MediaObject Avatar MediaObject
} }
type RoomInfo struct { type RoomInfo struct {
Name string Name string
Topic string Topic string
Picture MediaObject Picture MediaObject
} }

View file

@ -1,10 +1,10 @@
package irc package irc
import ( import (
"time" "fmt"
_ "os" _ "os"
"strings" "strings"
"fmt" "time"
"github.com/lrstanley/girc" "github.com/lrstanley/girc"
@ -19,19 +19,19 @@ type IRC struct {
handler Handler handler Handler
connected bool connected bool
timeout int timeout int
nick string nick string
name string name string
server string server string
conn *girc.Client conn *girc.Client
} }
func (irc *IRC) SetHandler(h Handler) { func (irc *IRC) SetHandler(h Handler) {
irc.handler = h irc.handler = h
} }
func(irc *IRC) Protocol() string { func (irc *IRC) Protocol() string {
return "irc" return "irc"
} }
@ -64,9 +64,9 @@ func (irc *IRC) Configure(c Configuration) error {
client := girc.New(girc.Config{ client := girc.New(girc.Config{
Server: irc.server, Server: irc.server,
Port: port, Port: port,
Nick: irc.nick, Nick: irc.nick,
User: irc.nick, User: irc.nick,
//Out: os.Stderr, //Out: os.Stderr,
SSL: ssl, SSL: ssl,
}) })
@ -85,7 +85,7 @@ func (irc *IRC) Configure(c Configuration) error {
go irc.connectLoop(client) go irc.connectLoop(client)
for i := 0; i < 42; i++ { for i := 0; i < 42; i++ {
time.Sleep(time.Duration(1)*time.Second) time.Sleep(time.Duration(1) * time.Second)
if irc.conn != client { if irc.conn != client {
break break
} }
@ -245,9 +245,9 @@ func (irc *IRC) ircConnected(c *girc.Client, e girc.Event) {
func (irc *IRC) ircPrivmsg(c *girc.Client, e girc.Event) { func (irc *IRC) ircPrivmsg(c *girc.Client, e girc.Event) {
ev := &Event{ ev := &Event{
Type: EVENT_MESSAGE, Type: EVENT_MESSAGE,
Author: UserID(e.Source.Name + "@" + irc.server), Author: UserID(e.Source.Name + "@" + irc.server),
Text: e.Last(), Text: e.Last(),
} }
if e.IsFromChannel() { if e.IsFromChannel() {
ev.Room = RoomID(e.Params[0] + "@" + irc.server) ev.Room = RoomID(e.Params[0] + "@" + irc.server)
@ -265,9 +265,9 @@ func (irc *IRC) ircJoin(c *girc.Client, e girc.Event) {
} else { } else {
user := UserID(e.Source.Name + "@" + irc.server) user := UserID(e.Source.Name + "@" + irc.server)
ev := &Event{ ev := &Event{
Type: EVENT_JOIN, Type: EVENT_JOIN,
Author: user, Author: user,
Room: room, Room: room,
} }
irc.handler.Event(ev) irc.handler.Event(ev)
irc.handler.UserInfoUpdated(user, &UserInfo{ irc.handler.UserInfoUpdated(user, &UserInfo{
@ -283,9 +283,9 @@ func (irc *IRC) ircPart(c *girc.Client, e girc.Event) {
} else { } else {
user := UserID(e.Source.Name + "@" + irc.server) user := UserID(e.Source.Name + "@" + irc.server)
ev := &Event{ ev := &Event{
Type: EVENT_LEAVE, Type: EVENT_LEAVE,
Author: user, Author: user,
Room: room, Room: room,
} }
irc.handler.Event(ev) irc.handler.Event(ev)
irc.handler.UserInfoUpdated(user, &UserInfo{ irc.handler.UserInfoUpdated(user, &UserInfo{
@ -304,9 +304,9 @@ func (irc *IRC) ircNamreply(c *girc.Client, e girc.Event) {
src := girc.ParseSource(name) src := girc.ParseSource(name)
if src.Name != irc.nick { if src.Name != irc.nick {
irc.handler.Event(&Event{ irc.handler.Event(&Event{
Type: EVENT_JOIN, Type: EVENT_JOIN,
Author: UserID(src.Name + "@" + irc.server), Author: UserID(src.Name + "@" + irc.server),
Room: room, Room: room,
}) })
} }
} }

62
main.go
View file

@ -1,41 +1,41 @@
package main package main
import ( import (
"fmt"
"crypto/rand" "crypto/rand"
"encoding/hex" "encoding/hex"
"encoding/json"
"flag" "flag"
"fmt"
_ "fmt"
"io/ioutil" "io/ioutil"
"os" "os"
_"strings" _ "strings"
_ "time" _ "time"
_ "fmt"
"encoding/json"
log "github.com/sirupsen/logrus" log "github.com/sirupsen/logrus"
"gopkg.in/yaml.v2" "gopkg.in/yaml.v2"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/mxlib"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/appservice" "git.deuxfleurs.fr/Deuxfleurs/easybridge/appservice"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/connector" "git.deuxfleurs.fr/Deuxfleurs/easybridge/connector"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/connector/irc" "git.deuxfleurs.fr/Deuxfleurs/easybridge/connector/irc"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/connector/xmpp" "git.deuxfleurs.fr/Deuxfleurs/easybridge/connector/xmpp"
"git.deuxfleurs.fr/Deuxfleurs/easybridge/mxlib"
) )
type ConfigAccount struct { type ConfigAccount struct {
Protocol string `json:"protocol"` Protocol string `json:"protocol"`
Rooms []string `json:"rooms"` Rooms []string `json:"rooms"`
Config map[string]string `json:"config"` Config map[string]string `json:"config"`
} }
type ConfigFile struct { type ConfigFile struct {
HttpBindAddr string`json:"http_bind_addr"` HttpBindAddr string `json:"http_bind_addr"`
Registration string `json:"registration"` Registration string `json:"registration"`
Server string `json:"homeserver_url"` Server string `json:"homeserver_url"`
DbType string `json:"db_type"` DbType string `json:"db_type"`
DbPath string `json:"db_path"` DbPath string `json:"db_path"`
MatrixDomain string `json:"matrix_domain"` MatrixDomain string `json:"matrix_domain"`
Accounts map[string]map[string]ConfigAccount `json:"accounts"` Accounts map[string]map[string]ConfigAccount `json:"accounts"`
} }
var configFlag = flag.String("config", "./config.json", "Configuration file path") var configFlag = flag.String("config", "./config.json", "Configuration file path")
@ -47,10 +47,10 @@ func readConfig() ConfigFile {
config_file := ConfigFile{ config_file := ConfigFile{
HttpBindAddr: "0.0.0.0:8321", HttpBindAddr: "0.0.0.0:8321",
Registration: "./registration.yaml", Registration: "./registration.yaml",
Server: "http://localhost:8008", Server: "http://localhost:8008",
DbType: "sqlite3", DbType: "sqlite3",
DbPath: "easybridge.db", DbPath: "easybridge.db",
Accounts: map[string]map[string]ConfigAccount{}, Accounts: map[string]map[string]ConfigAccount{},
} }
_, err := os.Stat(*configFlag) _, err := os.Stat(*configFlag)
@ -96,22 +96,22 @@ func readRegistration(file string) mxlib.Registration {
} }
reg := mxlib.Registration{ reg := mxlib.Registration{
Id: "Easybridge", Id: "Easybridge",
Url: "http://localhost:8321", Url: "http://localhost:8321",
AsToken: hex.EncodeToString(rnd[:32]), AsToken: hex.EncodeToString(rnd[:32]),
HsToken: hex.EncodeToString(rnd[32:]), HsToken: hex.EncodeToString(rnd[32:]),
SenderLocalpart: "_ezbr_", SenderLocalpart: "_ezbr_",
Namespaces: mxlib.RegistrationNamespaceSet{ Namespaces: mxlib.RegistrationNamespaceSet{
Users: []mxlib.RegistrationNamespace{ Users: []mxlib.RegistrationNamespace{
mxlib.RegistrationNamespace{ mxlib.RegistrationNamespace{
Exclusive: true, Exclusive: true,
Regex: "@_ezbr_.*", Regex: "@_ezbr_.*",
}, },
}, },
Aliases: []mxlib.RegistrationNamespace{ Aliases: []mxlib.RegistrationNamespace{
mxlib.RegistrationNamespace{ mxlib.RegistrationNamespace{
Exclusive: true, Exclusive: true,
Regex: "#_ezbr_.*", Regex: "#_ezbr_.*",
}, },
}, },
Rooms: []mxlib.RegistrationNamespace{}, Rooms: []mxlib.RegistrationNamespace{},
@ -166,9 +166,9 @@ func main() {
as_config := &appservice.Config{ as_config := &appservice.Config{
HttpBindAddr: config.HttpBindAddr, HttpBindAddr: config.HttpBindAddr,
Server: config.Server, Server: config.Server,
DbType: config.DbType, DbType: config.DbType,
DbPath: config.DbPath, DbPath: config.DbPath,
MatrixDomain: config.MatrixDomain, MatrixDomain: config.MatrixDomain,
} }
@ -189,10 +189,10 @@ func main() {
log.Fatalf("Invalid protocol %s", params.Protocol) log.Fatalf("Invalid protocol %s", params.Protocol)
} }
account := &appservice.Account{ account := &appservice.Account{
MatrixUser: fmt.Sprintf("@%s:%s", user, config.MatrixDomain), MatrixUser: fmt.Sprintf("@%s:%s", user, config.MatrixDomain),
AccountName: name, AccountName: name,
Protocol: params.Protocol, Protocol: params.Protocol,
Conn: conn, Conn: conn,
JoinedRooms: map[connector.RoomID]bool{}, JoinedRooms: map[connector.RoomID]bool{},
} }
conn.SetHandler(account) conn.SetHandler(account)

View file

@ -6,7 +6,7 @@ import (
type MxError struct { type MxError struct {
ErrCode string `json:"errcode"` ErrCode string `json:"errcode"`
ErrMsg string `json:"error"` ErrMsg string `json:"error"`
} }
func (e *MxError) Error() string { func (e *MxError) Error() string {
@ -18,12 +18,12 @@ type Transaction struct {
} }
type Event struct { type Event struct {
Content map[string]interface{} `json:"content"` Content map[string]interface{} `json:"content"`
Type string `json:"type"` Type string `json:"type"`
EventId string `json:"event_id"` EventId string `json:"event_id"`
RoomId string `json:"room_id"` RoomId string `json:"room_id"`
Sender string `json:"sender"` Sender string `json:"sender"`
OriginServerTs int `json:"origin_server_ts"` OriginServerTs int `json:"origin_server_ts"`
} }
type RegisterRequest struct { type RegisterRequest struct {
@ -31,9 +31,9 @@ type RegisterRequest struct {
} }
type RegisterResponse struct { type RegisterResponse struct {
UserId string `json:"user_id"` UserId string `json:"user_id"`
AccessToken string `json:"access_token"` AccessToken string `json:"access_token"`
DeviceId string `json:"device_id"` DeviceId string `json:"device_id"`
} }
type ProfileDisplaynameRequest struct { type ProfileDisplaynameRequest struct {
@ -41,23 +41,23 @@ type ProfileDisplaynameRequest struct {
} }
type CreateRoomRequest struct { type CreateRoomRequest struct {
Preset string `json:"preset"` Preset string `json:"preset"`
RoomAliasName string `json:"room_alias_name"` RoomAliasName string `json:"room_alias_name"`
Name string `json:"name"` Name string `json:"name"`
Topic string `json:"topic"` Topic string `json:"topic"`
Invite []string `json:"invite"` Invite []string `json:"invite"`
CreationContent map[string]interface{} `json:"creation_content"` CreationContent map[string]interface{} `json:"creation_content"`
PowerLevels map[string]interface{} `json:"power_level_content_override"` PowerLevels map[string]interface{} `json:"power_level_content_override"`
} }
type CreateRoomNoAliasRequest struct { type CreateRoomNoAliasRequest struct {
Preset string `json:"preset"` Preset string `json:"preset"`
Name string `json:"name"` Name string `json:"name"`
Topic string `json:"topic"` Topic string `json:"topic"`
Invite []string `json:"invite"` Invite []string `json:"invite"`
CreationContent map[string]interface{} `json:"creation_content"` CreationContent map[string]interface{} `json:"creation_content"`
PowerLevels map[string]interface{} `json:"power_level_content_override"` PowerLevels map[string]interface{} `json:"power_level_content_override"`
IsDirect bool `json:"is_direct"` IsDirect bool `json:"is_direct"`
} }
type CreateRoomResponse struct { type CreateRoomResponse struct {
@ -65,7 +65,7 @@ type CreateRoomResponse struct {
} }
type DirectoryRoomResponse struct { type DirectoryRoomResponse struct {
RoomId string `json:"room_id"` RoomId string `json:"room_id"`
Servers []string `json:"string"` Servers []string `json:"string"`
} }
@ -84,4 +84,3 @@ type RoomJoinResponse struct {
type RoomSendResponse struct { type RoomSendResponse struct {
EventId string `json:"event_id"` EventId string `json:"event_id"`
} }

View file

@ -5,21 +5,21 @@ import (
) )
type Registration struct { type Registration struct {
Id string `yaml:"id"` Id string `yaml:"id"`
Url string `yaml:"url"` Url string `yaml:"url"`
AsToken string `yaml:"as_token"` AsToken string `yaml:"as_token"`
HsToken string `yaml:"hs_token"` HsToken string `yaml:"hs_token"`
SenderLocalpart string `yaml:"sender_localpart"` SenderLocalpart string `yaml:"sender_localpart"`
Namespaces RegistrationNamespaceSet `yaml:"namespaces"` Namespaces RegistrationNamespaceSet `yaml:"namespaces"`
} }
type RegistrationNamespaceSet struct { type RegistrationNamespaceSet struct {
Users []RegistrationNamespace `yaml:"users"` Users []RegistrationNamespace `yaml:"users"`
Aliases []RegistrationNamespace `yaml:"aliases"` Aliases []RegistrationNamespace `yaml:"aliases"`
Rooms []RegistrationNamespace `yaml:"rooms"` Rooms []RegistrationNamespace `yaml:"rooms"`
} }
type RegistrationNamespace struct { type RegistrationNamespace struct {
Exclusive bool `yaml:"exclusive"` Exclusive bool `yaml:"exclusive"`
Regex string `yaml:"regex"` Regex string `yaml:"regex"`
} }