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 rpc
import (
"errors"
"net"
"strings"
"syscall"
"github.com/spiral/roadrunner/service"
)
// Config defines RPC service config.
type Config struct {
// Indicates if RPC connection is enabled.
Enable bool
// AddListener string
Listen string
}
// Hydrate must populate Config values using given Config source. Must return error if Config is not valid.
func (c *Config) Hydrate(cfg service.Config) error {
if err := cfg.Unmarshal(c); err != nil {
return err
}
return c.Valid()
}
// Valid returns nil if config is valid.
func (c *Config) Valid() error {
if dsn := strings.Split(c.Listen, "://"); len(dsn) != 2 {
return errors.New("invalid socket DSN (tcp://:6001, unix://rpc.sock)")
}
if dsn := strings.Split(c.Listen, "://"); len(dsn) != 2 {
return errors.New("invalid socket DSN (tcp://:6001, unix://rpc.sock)")
}
return nil
}
// Listener creates new rpc socket Listener.
func (c *Config) Listener() (net.Listener, error) {
dsn := strings.Split(c.Listen, "://")
if len(dsn) != 2 {
return nil, errors.New("invalid socket DSN (tcp://:6001, unix://rpc.sock)")
}
if dsn[0] == "unix" {
syscall.Unlink(dsn[1])
}
return net.Listen(dsn[0], dsn[1])
}
// Dialer creates rpc socket Dialer.
func (c *Config) Dialer() (net.Conn, error) {
dsn := strings.Split(c.Listen, "://")
if len(dsn) != 2 {
return nil, errors.New("invalid socket DSN (tcp://:6001, unix://rpc.sock)")
}
return net.Dial(dsn[0], dsn[1])
}
|