Bumps the go-deps group with 6 updates: | Package | From | To | | --- | --- | --- | | [github.com/aws/aws-sdk-go](https://github.com/aws/aws-sdk-go) | `1.45.10` | `1.45.16` | | [github.com/gophercloud/gophercloud](https://github.com/gophercloud/gophercloud) | `1.6.0` | `1.7.0` | | [github.com/openshift-online/ocm-sdk-go](https://github.com/openshift-online/ocm-sdk-go) | `0.1.364` | `0.1.371` | | [github.com/osbuild/images](https://github.com/osbuild/images) | `0.5.1-0.20230915095808-dd48a38be218` | `0.7.0` | | [github.com/vmware/govmomi](https://github.com/vmware/govmomi) | `0.30.7` | `0.31.0` | | [google.golang.org/api](https://github.com/googleapis/google-api-go-client) | `0.142.0` | `0.143.0` | Updates `github.com/aws/aws-sdk-go` from 1.45.10 to 1.45.16 - [Release notes](https://github.com/aws/aws-sdk-go/releases) - [Commits](https://github.com/aws/aws-sdk-go/compare/v1.45.10...v1.45.16) Updates `github.com/gophercloud/gophercloud` from 1.6.0 to 1.7.0 - [Release notes](https://github.com/gophercloud/gophercloud/releases) - [Changelog](https://github.com/gophercloud/gophercloud/blob/v1.7.0/CHANGELOG.md) - [Commits](https://github.com/gophercloud/gophercloud/compare/v1.6.0...v1.7.0) Updates `github.com/openshift-online/ocm-sdk-go` from 0.1.364 to 0.1.371 - [Release notes](https://github.com/openshift-online/ocm-sdk-go/releases) - [Changelog](https://github.com/openshift-online/ocm-sdk-go/blob/main/CHANGES.md) - [Commits](https://github.com/openshift-online/ocm-sdk-go/compare/v0.1.364...v0.1.371) Updates `github.com/osbuild/images` from 0.5.1-0.20230915095808-dd48a38be218 to 0.7.0 - [Release notes](https://github.com/osbuild/images/releases) - [Commits](https://github.com/osbuild/images/commits/v0.7.0) Updates `github.com/vmware/govmomi` from 0.30.7 to 0.31.0 - [Release notes](https://github.com/vmware/govmomi/releases) - [Changelog](https://github.com/vmware/govmomi/blob/main/CHANGELOG.md) - [Commits](https://github.com/vmware/govmomi/compare/v0.30.7...v0.31.0) Updates `google.golang.org/api` from 0.142.0 to 0.143.0 - [Release notes](https://github.com/googleapis/google-api-go-client/releases) - [Changelog](https://github.com/googleapis/google-api-go-client/blob/main/CHANGES.md) - [Commits](https://github.com/googleapis/google-api-go-client/compare/v0.142.0...v0.143.0) --- updated-dependencies: - dependency-name: github.com/aws/aws-sdk-go dependency-type: direct:production update-type: version-update:semver-patch dependency-group: go-deps - dependency-name: github.com/gophercloud/gophercloud dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: github.com/openshift-online/ocm-sdk-go dependency-type: direct:production update-type: version-update:semver-patch dependency-group: go-deps - dependency-name: github.com/osbuild/images dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: github.com/vmware/govmomi dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps - dependency-name: google.golang.org/api dependency-type: direct:production update-type: version-update:semver-minor dependency-group: go-deps ... Signed-off-by: dependabot[bot] <support@github.com>
141 lines
4.3 KiB
Go
141 lines
4.3 KiB
Go
/*
|
|
Copyright (c) 2020-2023 VMware, Inc. All Rights Reserved.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package internal
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net"
|
|
"net/http"
|
|
"net/url"
|
|
"os"
|
|
"path"
|
|
|
|
"github.com/vmware/govmomi/vim25"
|
|
"github.com/vmware/govmomi/vim25/mo"
|
|
"github.com/vmware/govmomi/vim25/soap"
|
|
"github.com/vmware/govmomi/vim25/types"
|
|
)
|
|
|
|
const (
|
|
vCenterHostGatewaySocket = "/var/run/envoy-hgw/hgw-pipe"
|
|
vCenterHostGatewaySocketEnv = "VCENTER_ENVOY_HOST_GATEWAY"
|
|
)
|
|
|
|
// InventoryPath composed of entities by Name
|
|
func InventoryPath(entities []mo.ManagedEntity) string {
|
|
val := "/"
|
|
|
|
for _, entity := range entities {
|
|
// Skip root folder in building inventory path.
|
|
if entity.Parent == nil {
|
|
continue
|
|
}
|
|
val = path.Join(val, entity.Name)
|
|
}
|
|
|
|
return val
|
|
}
|
|
|
|
func HostSystemManagementIPs(config []types.VirtualNicManagerNetConfig) []net.IP {
|
|
var ips []net.IP
|
|
|
|
for _, nc := range config {
|
|
if nc.NicType != string(types.HostVirtualNicManagerNicTypeManagement) {
|
|
continue
|
|
}
|
|
for ix := range nc.CandidateVnic {
|
|
for _, selectedVnicKey := range nc.SelectedVnic {
|
|
if nc.CandidateVnic[ix].Key != selectedVnicKey {
|
|
continue
|
|
}
|
|
ip := net.ParseIP(nc.CandidateVnic[ix].Spec.Ip.IpAddress)
|
|
if ip != nil {
|
|
ips = append(ips, ip)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return ips
|
|
}
|
|
|
|
// UsingEnvoySidecar determines if the given *vim25.Client is using vCenter's
|
|
// local Envoy sidecar (as opposed to using the HTTPS port.)
|
|
// Returns a boolean indicating whether to use the sidecar or not.
|
|
func UsingEnvoySidecar(c *vim25.Client) bool {
|
|
envoySidecarPort := os.Getenv("GOVMOMI_ENVOY_SIDECAR_PORT")
|
|
if envoySidecarPort == "" {
|
|
envoySidecarPort = "1080"
|
|
}
|
|
envoySidecarHost := os.Getenv("GOVMOMI_ENVOY_SIDECAR_HOST")
|
|
if envoySidecarHost == "" {
|
|
envoySidecarHost = "localhost"
|
|
}
|
|
return c.URL().Hostname() == envoySidecarHost && c.URL().Scheme == "http" && c.URL().Port() == envoySidecarPort
|
|
}
|
|
|
|
// ClientWithEnvoyHostGateway clones the provided soap.Client and returns a new
|
|
// one that uses a Unix socket to leverage vCenter's local Envoy host
|
|
// gateway.
|
|
// This should be used to construct clients that talk to ESX.
|
|
// This method returns a new *vim25.Client and does not modify the original input.
|
|
// This client disables HTTP keep alives and is intended for a single round
|
|
// trip. (eg. guest file transfer, datastore file transfer)
|
|
func ClientWithEnvoyHostGateway(vc *vim25.Client) *vim25.Client {
|
|
// Override the vim client with a new one that wraps a Unix socket transport.
|
|
// Using HTTP here so secure means nothing.
|
|
sc := soap.NewClient(vc.URL(), true)
|
|
// Clone the underlying HTTP transport, only replacing the dialer logic.
|
|
transport := sc.DefaultTransport().Clone()
|
|
hostGatewaySocketPath := os.Getenv(vCenterHostGatewaySocketEnv)
|
|
if hostGatewaySocketPath == "" {
|
|
hostGatewaySocketPath = vCenterHostGatewaySocket
|
|
}
|
|
transport.DialContext = func(_ context.Context, _, _ string) (net.Conn, error) {
|
|
return net.Dial("unix", hostGatewaySocketPath)
|
|
}
|
|
// We use this client for a single request, so we don't require keepalives.
|
|
transport.DisableKeepAlives = true
|
|
sc.Client = http.Client{
|
|
Transport: transport,
|
|
}
|
|
newVC := &vim25.Client{
|
|
Client: sc,
|
|
}
|
|
return newVC
|
|
}
|
|
|
|
// HostGatewayTransferURL rewrites the provided URL to be suitable for use
|
|
// with the Envoy host gateway on vCenter.
|
|
// It returns a copy of the provided URL with the host, scheme rewritten as needed.
|
|
// Receivers of such URLs must typically also use ClientWithEnvoyHostGateway to
|
|
// use the appropriate http.Transport to be able to make use of the host
|
|
// gateway.
|
|
// nil input yields an uninitialized struct.
|
|
func HostGatewayTransferURL(u *url.URL, hostMoref types.ManagedObjectReference) *url.URL {
|
|
if u == nil {
|
|
return &url.URL{}
|
|
}
|
|
// Make a copy of the provided URL.
|
|
turl := *u
|
|
turl.Host = "localhost"
|
|
turl.Scheme = "http"
|
|
oldPath := turl.Path
|
|
turl.Path = fmt.Sprintf("/hgw/%s%s", hostMoref.Value, oldPath)
|
|
return &turl
|
|
}
|