2018-03-21 19:43:21 +00:00
|
|
|
// Copyright 2016-2018, Pulumi Corporation. All rights reserved.
|
2017-06-21 17:31:06 +00:00
|
|
|
|
|
|
|
package provider
|
|
|
|
|
|
|
|
import (
|
|
|
|
"golang.org/x/net/context"
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
|
2017-09-22 02:18:21 +00:00
|
|
|
"github.com/pulumi/pulumi/pkg/diag"
|
|
|
|
"github.com/pulumi/pulumi/pkg/util/contract"
|
2017-11-09 01:08:51 +00:00
|
|
|
"github.com/pulumi/pulumi/pkg/util/rpcutil"
|
2017-09-22 02:18:21 +00:00
|
|
|
lumirpc "github.com/pulumi/pulumi/sdk/proto/go"
|
2017-06-21 17:31:06 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// HostClient is a client interface into the host's engine RPC interface.
|
|
|
|
type HostClient struct {
|
|
|
|
conn *grpc.ClientConn
|
|
|
|
client lumirpc.EngineClient
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewHostClient dials the target address, connects over gRPC, and returns a client interface.
|
|
|
|
func NewHostClient(addr string) (*HostClient, error) {
|
2017-11-09 01:08:51 +00:00
|
|
|
conn, err := grpc.Dial(addr, grpc.WithInsecure(), grpc.WithUnaryInterceptor(
|
|
|
|
rpcutil.OpenTracingClientInterceptor(),
|
|
|
|
))
|
2017-06-21 17:31:06 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &HostClient{
|
|
|
|
conn: conn,
|
|
|
|
client: lumirpc.NewEngineClient(conn),
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Close closes and renders the connection and client unusable.
|
|
|
|
func (host *HostClient) Close() error {
|
|
|
|
return host.conn.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Log logs a global message, including errors and warnings.
|
2017-11-09 01:08:51 +00:00
|
|
|
func (host *HostClient) Log(context context.Context, sev diag.Severity, msg string) error {
|
2017-06-21 17:31:06 +00:00
|
|
|
var rpcsev lumirpc.LogSeverity
|
|
|
|
switch sev {
|
|
|
|
case diag.Debug:
|
|
|
|
rpcsev = lumirpc.LogSeverity_DEBUG
|
|
|
|
case diag.Info:
|
|
|
|
rpcsev = lumirpc.LogSeverity_INFO
|
|
|
|
case diag.Warning:
|
|
|
|
rpcsev = lumirpc.LogSeverity_WARNING
|
|
|
|
case diag.Error:
|
|
|
|
rpcsev = lumirpc.LogSeverity_ERROR
|
|
|
|
default:
|
|
|
|
contract.Failf("Unrecognized log severity type: %v", sev)
|
|
|
|
}
|
2017-11-09 01:08:51 +00:00
|
|
|
_, err := host.client.Log(context, &lumirpc.LogRequest{
|
2017-06-21 17:31:06 +00:00
|
|
|
Severity: rpcsev,
|
|
|
|
Message: msg,
|
|
|
|
})
|
|
|
|
return err
|
|
|
|
}
|