mirror of
https://github.com/go-micro/go-micro.git
synced 2025-01-05 10:20:53 +02:00
114 lines
2.6 KiB
Go
114 lines
2.6 KiB
Go
package eureka
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"fmt"
|
|
"net"
|
|
"strconv"
|
|
"strings"
|
|
|
|
"github.com/hudl/fargo"
|
|
"github.com/asim/go-micro/v3/registry"
|
|
)
|
|
|
|
func appToService(app *fargo.Application) []*registry.Service {
|
|
serviceMap := make(map[string]*registry.Service)
|
|
|
|
for _, instance := range app.Instances {
|
|
id := instance.Id()
|
|
addr := instance.IPAddr
|
|
port := instance.Port
|
|
|
|
var version string
|
|
var metadata map[string]string
|
|
var endpoints []*registry.Endpoint
|
|
|
|
// get version
|
|
if _, err := instance.Metadata.GetString("version"); err != nil {
|
|
continue
|
|
}
|
|
|
|
if k, err := instance.Metadata.GetString("endpoints"); err == nil {
|
|
json.Unmarshal([]byte(k), &endpoints)
|
|
}
|
|
|
|
if k, err := instance.Metadata.GetString("metadata"); err == nil {
|
|
json.Unmarshal([]byte(k), &metadata)
|
|
}
|
|
|
|
// get existing service
|
|
service, ok := serviceMap[version]
|
|
if !ok {
|
|
// create new if doesn't exist
|
|
service = ®istry.Service{
|
|
Name: strings.ToLower(app.Name),
|
|
Version: version,
|
|
Endpoints: endpoints,
|
|
}
|
|
}
|
|
|
|
host, _, _ := net.SplitHostPort(addr)
|
|
|
|
// append node
|
|
service.Nodes = append(service.Nodes, ®istry.Node{
|
|
Id: id,
|
|
Address: fmt.Sprintf("%s:%d", host, port),
|
|
Metadata: metadata,
|
|
})
|
|
|
|
// save
|
|
serviceMap[version] = service
|
|
}
|
|
|
|
services := make([]*registry.Service, 0, len(serviceMap))
|
|
for _, service := range serviceMap {
|
|
services = append(services, service)
|
|
}
|
|
|
|
return services
|
|
}
|
|
|
|
// only parses first node
|
|
func serviceToInstance(service *registry.Service) (*fargo.Instance, error) {
|
|
if len(service.Nodes) == 0 {
|
|
return nil, errors.New("Require nodes")
|
|
}
|
|
|
|
node := service.Nodes[0]
|
|
_, pt, _ := net.SplitHostPort(node.Address)
|
|
port, _ := strconv.Atoi(pt)
|
|
|
|
instance := &fargo.Instance{
|
|
App: service.Name,
|
|
HostName: node.Address,
|
|
IPAddr: node.Address,
|
|
VipAddress: node.Address,
|
|
SecureVipAddress: node.Address,
|
|
Port: port,
|
|
Status: fargo.UP,
|
|
UniqueID: func(i fargo.Instance) string {
|
|
return fmt.Sprintf("%s:%s", node.Address, node.Id)
|
|
},
|
|
DataCenterInfo: fargo.DataCenterInfo{Name: fargo.MyOwn},
|
|
}
|
|
|
|
// set version
|
|
instance.SetMetadataString("version", service.Version)
|
|
|
|
// set instance ID
|
|
instance.SetMetadataString("instanceId", node.Id)
|
|
|
|
// set endpoints
|
|
if b, err := json.Marshal(service.Endpoints); err == nil {
|
|
instance.SetMetadataString("endpoints", string(b))
|
|
}
|
|
|
|
// set metadata
|
|
if b, err := json.Marshal(node.Metadata); err == nil {
|
|
instance.SetMetadataString("metadata", string(b))
|
|
}
|
|
|
|
return instance, nil
|
|
}
|