blob: 899a508362cb0506b94e4011fcd88a46cceb4358 (
plain)
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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
package http
import (
"errors"
"fmt"
"github.com/spiral/roadrunner"
"github.com/spiral/roadrunner/service"
"os"
"strings"
)
// Config configures RoadRunner HTTP server.
type Config struct {
// Port and port to handle as http server.
Address string
// SSL defines https server options.
SSL SSLConfig
// MaxRequestSize specified max size for payload body in megabytes, set 0 to unlimited.
MaxRequestSize int64
// Uploads configures uploads configuration.
Uploads *UploadsConfig
// Workers configures roadrunner server and worker pool.
Workers *roadrunner.ServerConfig
}
// SSLConfig defines https server configuration.
type SSLConfig struct {
// Port to listen as HTTPS server, defaults to 443.
Port int
// Redirect when enabled forces all http connections to switch to https.
Redirect bool
// Key defined private server key.
Key string
// Cert is https certificate.
Cert string
}
// EnableTLS returns true if rr must listen TLS connections.
func (c *Config) EnableTLS() bool {
return c.SSL.Key != "" || c.SSL.Cert != ""
}
// 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 c.Workers == nil {
c.Workers = &roadrunner.ServerConfig{}
}
if c.Uploads == nil {
c.Uploads = &UploadsConfig{}
}
if c.SSL.Port == 0 {
c.SSL.Port = 443
}
c.Uploads.InitDefaults()
c.Workers.InitDefaults()
if err := cfg.Unmarshal(c); err != nil {
return err
}
c.Workers.UpscaleDurations()
return c.Valid()
}
// Valid validates the configuration.
func (c *Config) Valid() error {
if c.Uploads == nil {
return errors.New("mailformed uploads config")
}
if c.Workers == nil {
return errors.New("mailformed workers config")
}
if c.Workers.Pool == nil {
return errors.New("mailformed workers config (pool config is missing)")
}
if err := c.Workers.Pool.Valid(); err != nil {
return err
}
if !strings.Contains(c.Address, ":") {
return errors.New("mailformed http server address")
}
if c.EnableTLS() {
if _, err := os.Stat(c.SSL.Key); err != nil {
if os.IsNotExist(err) {
return fmt.Errorf("key file '%s' does not exists", c.SSL.Key)
}
return err
}
if _, err := os.Stat(c.SSL.Cert); err != nil {
if os.IsNotExist(err) {
return fmt.Errorf("cert file '%s' does not exists", c.SSL.Cert)
}
return err
}
}
return nil
}
|