mirror of https://github.com/hashicorp/consul
agent: SCADA HTTP listener
parent
55597dc38f
commit
456645f2fb
|
@ -332,8 +332,21 @@ func (c *Command) setupAgent(config *Config, logOutput io.Writer, logWriter *log
|
||||||
c.Ui.Output("Starting Consul agent RPC...")
|
c.Ui.Output("Starting Consul agent RPC...")
|
||||||
c.rpcServer = NewAgentRPC(agent, rpcListener, logOutput, logWriter)
|
c.rpcServer = NewAgentRPC(agent, rpcListener, logOutput, logWriter)
|
||||||
|
|
||||||
if config.Ports.HTTP > 0 || config.Ports.HTTPS > 0 {
|
// Enable the SCADA integration
|
||||||
servers, err := NewHTTPServers(agent, config, logOutput)
|
var scadaList net.Listener
|
||||||
|
if config.AtlasCluster != "" {
|
||||||
|
provider, list, err := NewProvider(config, logOutput)
|
||||||
|
if err != nil {
|
||||||
|
agent.Shutdown()
|
||||||
|
c.Ui.Error(fmt.Sprintf("Error starting SCADA connection: %s", err))
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
c.scadaProvider = provider
|
||||||
|
scadaList = list
|
||||||
|
}
|
||||||
|
|
||||||
|
if config.Ports.HTTP > 0 || config.Ports.HTTPS > 0 || scadaList != nil {
|
||||||
|
servers, err := NewHTTPServers(agent, config, scadaList, logOutput)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
agent.Shutdown()
|
agent.Shutdown()
|
||||||
c.Ui.Error(fmt.Sprintf("Error starting http servers: %s", err))
|
c.Ui.Error(fmt.Sprintf("Error starting http servers: %s", err))
|
||||||
|
@ -383,18 +396,6 @@ func (c *Command) setupAgent(config *Config, logOutput io.Writer, logWriter *log
|
||||||
c.checkpointResults(checkpoint.Check(updateParams))
|
c.checkpointResults(checkpoint.Check(updateParams))
|
||||||
}()
|
}()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Enable the SCADA integration
|
|
||||||
if config.AtlasCluster != "" {
|
|
||||||
provider, err := NewProvider(config, logOutput)
|
|
||||||
if err != nil {
|
|
||||||
agent.Shutdown()
|
|
||||||
c.Ui.Error(fmt.Sprintf("Error starting SCADA connection: %s", err))
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
c.scadaProvider = provider
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,7 @@ type HTTPServer struct {
|
||||||
|
|
||||||
// NewHTTPServers starts new HTTP servers to provide an interface to
|
// NewHTTPServers starts new HTTP servers to provide an interface to
|
||||||
// the agent.
|
// the agent.
|
||||||
func NewHTTPServers(agent *Agent, config *Config, logOutput io.Writer) ([]*HTTPServer, error) {
|
func NewHTTPServers(agent *Agent, config *Config, scada net.Listener, logOutput io.Writer) ([]*HTTPServer, error) {
|
||||||
var tlsConfig *tls.Config
|
var tlsConfig *tls.Config
|
||||||
var list net.Listener
|
var list net.Listener
|
||||||
var httpAddr net.Addr
|
var httpAddr net.Addr
|
||||||
|
@ -136,6 +136,26 @@ func NewHTTPServers(agent *Agent, config *Config, logOutput io.Writer) ([]*HTTPS
|
||||||
servers = append(servers, srv)
|
servers = append(servers, srv)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if scada != nil {
|
||||||
|
// Create the mux
|
||||||
|
mux := http.NewServeMux()
|
||||||
|
|
||||||
|
// Create the server
|
||||||
|
srv := &HTTPServer{
|
||||||
|
agent: agent,
|
||||||
|
mux: mux,
|
||||||
|
listener: scada,
|
||||||
|
logger: log.New(logOutput, "", log.LstdFlags),
|
||||||
|
uiDir: config.UiDir,
|
||||||
|
addr: "SCADA",
|
||||||
|
}
|
||||||
|
srv.registerHandlers(false) // Never allow debug for SCADA
|
||||||
|
|
||||||
|
// Start the server
|
||||||
|
go http.Serve(list, mux)
|
||||||
|
servers = append(servers, srv)
|
||||||
|
}
|
||||||
|
|
||||||
return servers, nil
|
return servers, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,8 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
|
"net"
|
||||||
|
"strconv"
|
||||||
|
|
||||||
"github.com/hashicorp/scada-client"
|
"github.com/hashicorp/scada-client"
|
||||||
)
|
)
|
||||||
|
@ -27,8 +29,8 @@ func ProviderService(c *Config) *client.ProviderService {
|
||||||
"http": 1,
|
"http": 1,
|
||||||
},
|
},
|
||||||
Meta: map[string]string{
|
Meta: map[string]string{
|
||||||
"type": "",
|
"server": strconv.FormatBool(c.Server),
|
||||||
"datacenter": "",
|
"datacenter": c.Datacenter,
|
||||||
},
|
},
|
||||||
ResourceType: resourceType,
|
ResourceType: resourceType,
|
||||||
}
|
}
|
||||||
|
@ -48,7 +50,7 @@ func ProviderConfig(c *Config) *client.ProviderConfig {
|
||||||
|
|
||||||
// NewProvider creates a new SCADA provider using the
|
// NewProvider creates a new SCADA provider using the
|
||||||
// given configuration. Requests are routed to the
|
// given configuration. Requests are routed to the
|
||||||
func NewProvider(c *Config, logOutput io.Writer) (*client.Provider, error) {
|
func NewProvider(c *Config, logOutput io.Writer) (*client.Provider, net.Listener, error) {
|
||||||
// Get the configuration of the provider
|
// Get the configuration of the provider
|
||||||
config := ProviderConfig(c)
|
config := ProviderConfig(c)
|
||||||
config.Logger = log.New(logOutput, "", log.LstdFlags)
|
config.Logger = log.New(logOutput, "", log.LstdFlags)
|
||||||
|
@ -62,5 +64,9 @@ func NewProvider(c *Config, logOutput io.Writer) (*client.Provider, error) {
|
||||||
config.Handlers["http"] = nil
|
config.Handlers["http"] = nil
|
||||||
|
|
||||||
// Create the provider
|
// Create the provider
|
||||||
return client.NewProvider(config)
|
provider, err := client.NewProvider(config)
|
||||||
|
if err != nil {
|
||||||
|
return nil, nil, err
|
||||||
|
}
|
||||||
|
return provider, nil, nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue