mirror of
https://github.com/XTLS/Xray-core.git
synced 2025-01-10 09:59:55 +00:00
fa5d7a255b
* v5: Health Check & LeastLoad Strategy (rebased from 2c5a71490368500a982018a74a6d519c7e121816) Some changes will be necessary to integrate it into V2Ray * Update proto * parse duration conf with time.Parse() * moving health ping to observatory as a standalone component * moving health ping to observatory as a standalone component: auto generated file * add initialization for health ping * incorporate changes in router implementation * support principle target output * add v4 json support for BurstObservatory & fix balancer reference * update API command * remove cancelled API * return zero length value when observer is not found * remove duplicated targeted dispatch * adjust test with updated structure * bug fix for observer * fix strategy selector * fix strategy least load * Fix ticker usage ticker.Close does not close ticker.C * feat: Replace default Health Ping URL to HTTPS (#1991) * fix selectLeastLoad() returns wrong number of nodes (#2083) * Test: fix leastload strategy unit test * fix(router): panic caused by concurrent map read and write (#2678) * Clean up code --------- Co-authored-by: Jebbs <qjebbs@gmail.com> Co-authored-by: Shelikhoo <xiaokangwang@outlook.com> Co-authored-by: 世界 <i@sekai.icu> Co-authored-by: Bernd Eichelberger <46166740+4-FLOSS-Free-Libre-Open-Source-Software@users.noreply.github.com> Co-authored-by: 秋のかえで <autmaple@protonmail.com> Co-authored-by: Rinka <kujourinka@gmail.com>
48 lines
1.5 KiB
Go
48 lines
1.5 KiB
Go
package conf
|
|
|
|
import (
|
|
"strings"
|
|
|
|
"github.com/xtls/xray-core/app/commander"
|
|
loggerservice "github.com/xtls/xray-core/app/log/command"
|
|
observatoryservice "github.com/xtls/xray-core/app/observatory/command"
|
|
handlerservice "github.com/xtls/xray-core/app/proxyman/command"
|
|
routerservice "github.com/xtls/xray-core/app/router/command"
|
|
statsservice "github.com/xtls/xray-core/app/stats/command"
|
|
"github.com/xtls/xray-core/common/serial"
|
|
)
|
|
|
|
type APIConfig struct {
|
|
Tag string `json:"tag"`
|
|
Services []string `json:"services"`
|
|
}
|
|
|
|
func (c *APIConfig) Build() (*commander.Config, error) {
|
|
if c.Tag == "" {
|
|
return nil, newError("API tag can't be empty.")
|
|
}
|
|
|
|
services := make([]*serial.TypedMessage, 0, 16)
|
|
for _, s := range c.Services {
|
|
switch strings.ToLower(s) {
|
|
case "reflectionservice":
|
|
services = append(services, serial.ToTypedMessage(&commander.ReflectionConfig{}))
|
|
case "handlerservice":
|
|
services = append(services, serial.ToTypedMessage(&handlerservice.Config{}))
|
|
case "loggerservice":
|
|
services = append(services, serial.ToTypedMessage(&loggerservice.Config{}))
|
|
case "statsservice":
|
|
services = append(services, serial.ToTypedMessage(&statsservice.Config{}))
|
|
case "observatoryservice":
|
|
services = append(services, serial.ToTypedMessage(&observatoryservice.Config{}))
|
|
case "routingservice":
|
|
services = append(services, serial.ToTypedMessage(&routerservice.Config{}))
|
|
}
|
|
}
|
|
|
|
return &commander.Config{
|
|
Tag: c.Tag,
|
|
Service: services,
|
|
}, nil
|
|
}
|