summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--service/env/provider.go7
-rw-r--r--service/env/service.go7
-rw-r--r--service/env/service_test.go18
-rw-r--r--service/http/config.go6
-rw-r--r--service/http/service.go4
-rw-r--r--service/rpc/service.go16
6 files changed, 49 insertions, 9 deletions
diff --git a/service/env/provider.go b/service/env/provider.go
index 2918f18c..d095009c 100644
--- a/service/env/provider.go
+++ b/service/env/provider.go
@@ -2,7 +2,10 @@ package env
// Provider aggregates list of environment variables. This interface can be used in custom implementation to drive
// values from external sources.
-type Provider interface {
+type Environment interface {
// GetEnv must return list of env variables.
GetEnv() (map[string]string, error)
-}
+
+ // SetEnv sets or creates environment value.
+ SetEnv(key, value string)
+} \ No newline at end of file
diff --git a/service/env/service.go b/service/env/service.go
index 0822d55a..b32a2f2b 100644
--- a/service/env/service.go
+++ b/service/env/service.go
@@ -15,7 +15,7 @@ func NewService(defaults map[string]string) *Service {
if s.values == nil {
s.values = make(map[string]string)
}
-
+
return s
}
@@ -33,3 +33,8 @@ func (s *Service) Init(cfg *Config) (bool, error) {
func (s *Service) GetEnv() (map[string]string, error) {
return s.values, nil
}
+
+// SetEnv sets or creates environment value.
+func (s *Service) SetEnv(key, value string) {
+ s.values[key] = value
+}
diff --git a/service/env/service_test.go b/service/env/service_test.go
index 69a2a375..10159857 100644
--- a/service/env/service_test.go
+++ b/service/env/service_test.go
@@ -22,3 +22,21 @@ func Test_Extend(t *testing.T) {
assert.Equal(t, "version", values["rr"])
assert.Equal(t, "value", values["key"])
}
+
+
+func Test_Set(t *testing.T) {
+ s := NewService(map[string]string{"rr": "version"})
+
+ s.Init(&Config{Values: map[string]string{"key": "value"}})
+ assert.Len(t, s.values, 2)
+
+ s.SetEnv("key","value-new")
+ s.SetEnv("other","new")
+
+ values, err := s.GetEnv()
+ assert.NoError(t, err)
+ assert.Len(t, values, 3)
+ assert.Equal(t, "version", values["rr"])
+ assert.Equal(t, "value-new", values["key"])
+ assert.Equal(t, "new", values["other"])
+} \ No newline at end of file
diff --git a/service/http/config.go b/service/http/config.go
index 20a247fb..3e08c72d 100644
--- a/service/http/config.go
+++ b/service/http/config.go
@@ -10,7 +10,7 @@ import (
// Config configures RoadRunner HTTP server.
type Config struct {
- // Enable enables http svc.
+ // Enable enables http service.
Enable bool
// Address and port to handle as http server.
@@ -32,6 +32,10 @@ func (c *Config) Hydrate(cfg service.Config) error {
return err
}
+ if !c.Enable {
+ return nil
+ }
+
if err := c.Valid(); err != nil {
return err
}
diff --git a/service/http/service.go b/service/http/service.go
index 9f62f5af..f988a843 100644
--- a/service/http/service.go
+++ b/service/http/service.go
@@ -20,7 +20,7 @@ type middleware func(f http.HandlerFunc) http.HandlerFunc
// Service manages rr, http servers.
type Service struct {
cfg *Config
- env env.Provider
+ env env.Environment
lsns []func(event int, ctx interface{})
mdws []middleware
mu sync.Mutex
@@ -42,7 +42,7 @@ func (s *Service) AddListener(l func(event int, ctx interface{})) {
// Init must return configure svc and return true if svc hasStatus enabled. Must return error in case of
// misconfiguration. Services must not be used without proper configuration pushed first.
-func (s *Service) Init(cfg *Config, r *rpc.Service, e env.Provider) (bool, error) {
+func (s *Service) Init(cfg *Config, r *rpc.Service, e env.Environment) (bool, error) {
if !cfg.Enable {
return false, nil
}
diff --git a/service/rpc/service.go b/service/rpc/service.go
index 6e231048..abeae240 100644
--- a/service/rpc/service.go
+++ b/service/rpc/service.go
@@ -5,11 +5,17 @@ import (
"github.com/spiral/goridge"
"net/rpc"
"sync"
+ "github.com/spiral/roadrunner/service/env"
)
-// ID contains default service name.
-const ID = "rpc"
+const (
+ // ID contains default service name.
+ ID = "rpc"
+ // ENV_KEY defines environment key to be used to store information about
+ // rpc server connection.
+ ENV_KEY = "RR_RPC"
+)
// Service is RPC service.
type Service struct {
cfg *Config
@@ -20,7 +26,7 @@ type Service struct {
}
// Init rpc service. Must return true if service is enabled.
-func (s *Service) Init(cfg *Config) (bool, error) {
+func (s *Service) Init(cfg *Config, env env.Environment) (bool, error) {
if !cfg.Enable {
return false, nil
}
@@ -28,6 +34,10 @@ func (s *Service) Init(cfg *Config) (bool, error) {
s.cfg = cfg
s.rpc = rpc.NewServer()
+ if env != nil {
+ env.SetEnv(ENV_KEY, cfg.Listen)
+ }
+
return true, nil
}