- Register elasticsearch server
dics/container.go
, the name mustbima:interface:elasticsearch
{
Name: "bima:elasticsearch:client",
Scope: bima.Application,
Build: func(dsn string) (*elastic.Client, error) {
client, err := elastic.NewClient(
elastic.SetURL(dsn),
elastic.SetSniff(false),
elastic.SetHealthcheck(false),
elastic.SetGzip(true),
)
if err != nil {
return nil, nil
}
color.New(color.FgGreen).Print("✓ ")
fmt.Println("Elasticsearch configured")
return client, nil
},
Params: dingo.Params{
"0": "localhost:9200",
},
},
{
Name: "bima:interface:elasticsearch",
Scope: bima.Application,
Build: (*interfaces.Elasticsearch)(nil),
Params: dingo.Params{
"Client": dingo.Service("bima:elasticsearch:client"),
},
},
For elasticsearch, we use https://github.com/olivere/elastic
as library
-
You must use
mysql
orpostgresql
as driver -
Override
Sync()
in your server.go
func (s *Server) Sync(client *elastic.Client) {
ctx := context.WithValue(context.Background(), "scope", "sync")
var records []Todo
err := s.Module.Handler.FindBy(&records, repositories.Filter{
Field: "synced_at",
Operator: "<=",
Value: time.Now().Add(-5*time.Minute), //Last sync 5 minutes ago
})
if err != nil {
loggers.Logger.Error(ctx, err.Error())
}
index := fmt.Sprintf("%s_%s", s.Module.Model.Env.Service, s.Module.Model.TableName())
for _, d := range records {
data, _ := json.Marshal(d)
if d.SyncedAt.Valid {
query := elastic.NewMatchQuery("Id", d.Id)
result, _ := client.Search().Index(index).Query(query).Do(ctx)
if result != nil && result.Hits != nil {
for _, hit := range result.Hits.Hits {
client.Delete().Index(index).Id(hit.Id).Do(ctx)
}
}
data, _ := json.Marshal(d)
client.Index().Index(index).BodyJson(string(data)).Do(ctx)
} else {
client.Index().Index(index).BodyJson(string(data)).Do(ctx)
}
d.SetSyncedAt(time.Now())
d.Env = s.Module.Model.Env
s.Module.Handler.Repository.Update(&d)
}
}
- Rerun your service
-
Add package using
go get github.com/bimalabs/listeners
-
Add listeners to your
dics/container.go
{
Name: "bima:listener:elasticsearch:create",
Scope: bima.Application,
Build: func(env *configs.Env, client *elastic.Client) (*elasticsearch.CreateSyncElasticsearch, error) {
return &elasticsearch.CreateSyncElasticsearch{
Service: env.Service,
Elasticsearch: client,
}, nil
},
Params: dingo.Params{
"0": dingo.Service("bima:config"),
"1": dingo.Service("bima:elasticsearch:client"),
},
},
{
Name: "bima:listener:elasticsearch:update",
Scope: bima.Application,
Build: func(env *configs.Env, client *elastic.Client) (*elasticsearch.UpdateSyncElasticsearch, error) {
return &elasticsearch.UpdateSyncElasticsearch{
Service: env.Service,
Elasticsearch: client,
}, nil
},
Params: dingo.Params{
"0": dingo.Service("bima:config"),
"1": dingo.Service("bima:elasticsearch:client"),
},
},
{
Name: "bima:listener:elasticsearch:delete",
Scope: bima.Application,
Build: func(env *configs.Env, client *elastic.Client) (*elasticsearch.DeleteSyncElasticsearch, error) {
return &elasticsearch.DeleteSyncElasticsearch{
Service: env.Service,
Elasticsearch: client,
}, nil
},
Params: dingo.Params{
"0": dingo.Service("bima:config"),
"1": dingo.Service("bima:elasticsearch:client"),
},
},
- Add to your
configs/listeners.yaml
listeners:
- elasticsearch:create
- elasticsearch:update
- elasticsearch:delete