/
clusterEventFuncs.go
64 lines (53 loc) · 1.88 KB
/
clusterEventFuncs.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
//Package shoset :
package shoset
import (
"errors"
"log"
"github.com/ditrit/gandalf/core/cluster/database"
"github.com/ditrit/gandalf/core/cluster/utils"
net "github.com/ditrit/shoset"
"github.com/ditrit/shoset/msg"
)
// HandleEvent : Cluster handle event function.
func HandleEvent(c *net.ShosetConn, message msg.Message) (err error) {
evt := message.(msg.Event)
ch := c.GetCh()
thisOne := ch.GetBindAddress()
err = nil
log.Println("Handle event")
log.Println(evt)
//ok := ch.Queue["evt"].Push(evt, c.GetRemoteShosetType(), c.GetBindAddress())
//if ok {
databaseConnection, ok := ch.Context["databaseConnection"].(*database.DatabaseConnection)
if ok {
//mapDatabaseClient := ch.Context["tenantDatabases"].(map[string]*gorm.DB)
//databasePath := ch.Context["databasePath"].(string)
//configurationCluster := ch.Context["configurationCluster"].(*cmodels.ConfigurationCluster)
if databaseConnection != nil {
databaseClient := databaseConnection.GetDatabaseClientByTenant(evt.GetTenant())
if databaseClient != nil {
ok := utils.CaptureMessage(message, "evt", databaseClient)
if ok {
log.Printf("Succes capture event %s on tenant %s \n", evt.GetEvent(), evt.GetTenant())
} else {
log.Printf("Error : Fail capture event %s on tenant %s \n", evt.GetEvent(), evt.GetTenant())
err = errors.New("Fail capture event" + evt.GetEvent() + " on tenant" + evt.GetTenant())
}
} else {
log.Println("Error : Can't get database client by tenant")
}
} else {
log.Println("Error : Database client map is empty")
}
ch.ConnsByName.IterateAll(
func(key string, val *net.ShosetConn) {
if key != thisOne && val.GetRemoteShosetType() == "a" && c.GetCh().Context["tenant"] == val.GetCh().Context["tenant"] {
val.SendMessage(evt)
log.Printf("%s : send event %s to %s\n", thisOne, evt.GetEvent(), val)
}
},
)
//}
}
return err
}