Merge pull request #125598 from princepereira/ppereira-hcsshim-vendor-master
vendor: bump hcsshim from v0.8.25 to v0.8.26.
This commit is contained in:
		
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							@@ -12,7 +12,7 @@ require (
 | 
			
		||||
	bitbucket.org/bertimus9/systemstat v0.5.0
 | 
			
		||||
	github.com/JeffAshton/win_pdh v0.0.0-20161109143554-76bb4ee9f0ab
 | 
			
		||||
	github.com/Microsoft/go-winio v0.6.0
 | 
			
		||||
	github.com/Microsoft/hcsshim v0.8.25
 | 
			
		||||
	github.com/Microsoft/hcsshim v0.8.26
 | 
			
		||||
	github.com/armon/circbuf v0.0.0-20150827004946-bbbad097214e
 | 
			
		||||
	github.com/armon/go-socks5 v0.0.0-20160902184237-e75332964ef5
 | 
			
		||||
	github.com/blang/semver/v4 v4.0.0
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
									
									
								
							@@ -145,8 +145,8 @@ github.com/MakeNowJust/heredoc v1.0.0/go.mod h1:mG5amYoWBHf8vpLOuehzbGGw0EHxpZZ6
 | 
			
		||||
github.com/Microsoft/go-winio v0.4.17/go.mod h1:JPGBdM1cNvN/6ISo+n8V5iA4v8pBzdOpzfwIujj1a84=
 | 
			
		||||
github.com/Microsoft/go-winio v0.6.0 h1:slsWYD/zyx7lCXoZVlvQrj0hPTM1HI4+v1sIda2yDvg=
 | 
			
		||||
github.com/Microsoft/go-winio v0.6.0/go.mod h1:cTAf44im0RAYeL23bpB+fzCyDH2MJiz2BO69KH/soAE=
 | 
			
		||||
github.com/Microsoft/hcsshim v0.8.25 h1:fRMwXiwk3qDwc0P05eHnh+y2v07JdtsfQ1fuAc69m9g=
 | 
			
		||||
github.com/Microsoft/hcsshim v0.8.25/go.mod h1:4zegtUJth7lAvFyc6cH2gGQ5B3OFQim01nnU2M8jKDg=
 | 
			
		||||
github.com/Microsoft/hcsshim v0.8.26 h1:770C4dtDITZUaMQ9d6lVPdM8Lq4S0E0Tthy6T91mDMo=
 | 
			
		||||
github.com/Microsoft/hcsshim v0.8.26/go.mod h1:4zegtUJth7lAvFyc6cH2gGQ5B3OFQim01nnU2M8jKDg=
 | 
			
		||||
github.com/NYTimes/gziphandler v1.1.1 h1:ZUDjpQae29j0ryrS0u/B8HZfJBtBQHjqw2rQ2cqUQ3I=
 | 
			
		||||
github.com/NYTimes/gziphandler v1.1.1/go.mod h1:n/CVRwUEOgIxrgPvAQhUUr9oeUtvrhMomdKFjzJNB0c=
 | 
			
		||||
github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU=
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										12
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcn.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcn.go
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -264,6 +264,18 @@ func SetPolicySupported() error {
 | 
			
		||||
	return platformDoesNotSupportError("SetPolicy")
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// ModifyLoadbalancerSupported returns an error if the HCN version does not support ModifyLoadbalancer.
 | 
			
		||||
func ModifyLoadbalancerSupported() error {
 | 
			
		||||
	supported, err := GetCachedSupportedFeatures()
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	if supported.ModifyLoadbalancer {
 | 
			
		||||
		return nil
 | 
			
		||||
	}
 | 
			
		||||
	return platformDoesNotSupportError("ModifyLoadbalancer")
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// VxlanPortSupported returns an error if the HCN version does not support configuring the VXLAN TCP port.
 | 
			
		||||
func VxlanPortSupported() error {
 | 
			
		||||
	supported, err := GetCachedSupportedFeatures()
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										6
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnerrors.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnerrors.go
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -10,6 +10,7 @@ import (
 | 
			
		||||
	"github.com/Microsoft/hcsshim/internal/hcserror"
 | 
			
		||||
	"github.com/Microsoft/hcsshim/internal/interop"
 | 
			
		||||
	"github.com/sirupsen/logrus"
 | 
			
		||||
	"golang.org/x/sys/windows"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
@@ -50,6 +51,7 @@ type ErrorCode uint32
 | 
			
		||||
const (
 | 
			
		||||
	ERROR_NOT_FOUND                     = 0x490
 | 
			
		||||
	HCN_E_PORT_ALREADY_EXISTS ErrorCode = 0x803b0013
 | 
			
		||||
	HCN_E_NOTIMPL             ErrorCode = ErrorCode(windows.E_NOTIMPL)
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type HcnError struct {
 | 
			
		||||
@@ -77,6 +79,10 @@ func IsPortAlreadyExistsError(err error) bool {
 | 
			
		||||
	return CheckErrorWithCode(err, HCN_E_PORT_ALREADY_EXISTS)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func IsNotImplemented(err error) bool {
 | 
			
		||||
	return CheckErrorWithCode(err, HCN_E_NOTIMPL)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func new(hr error, title string, rest string) error {
 | 
			
		||||
	err := &HcnError{}
 | 
			
		||||
	hcsError := hcserror.New(hr, title, rest)
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										11
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnglobals.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnglobals.go
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -76,6 +76,17 @@ var (
 | 
			
		||||
 | 
			
		||||
	//HNS 14.0 allows for TierAcl Policy support
 | 
			
		||||
	TierAclPolicyVersion = VersionRanges{VersionRange{MinVersion: Version{Major: 14, Minor: 0}, MaxVersion: Version{Major: math.MaxInt32, Minor: math.MaxInt32}}}
 | 
			
		||||
 | 
			
		||||
	//HNS 15.0 allows for NetworkACL Policy support
 | 
			
		||||
	NetworkACLPolicyVersion = VersionRanges{VersionRange{MinVersion: Version{Major: 15, Minor: 0}, MaxVersion: Version{Major: math.MaxInt32, Minor: math.MaxInt32}}}
 | 
			
		||||
 | 
			
		||||
	//HNS 15.0 allows for NestedIpSet support
 | 
			
		||||
	NestedIpSetVersion = VersionRanges{VersionRange{MinVersion: Version{Major: 15, Minor: 0}, MaxVersion: Version{Major: math.MaxInt32, Minor: math.MaxInt32}}}
 | 
			
		||||
 | 
			
		||||
	//HNS 15.1 allows support for DisableHostPort flag.
 | 
			
		||||
	DisableHostPortVersion = VersionRanges{VersionRange{MinVersion: Version{Major: 15, Minor: 1}, MaxVersion: Version{Major: math.MaxInt32, Minor: math.MaxInt32}}}
 | 
			
		||||
	// HNS 15.4 allows for Modify Loadbalancer support
 | 
			
		||||
	ModifyLoadbalancerVersion = VersionRanges{VersionRange{MinVersion: Version{Major: 15, Minor: 4}, MaxVersion: Version{Major: math.MaxInt32, Minor: math.MaxInt32}}}
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// GetGlobals returns the global properties of the HCN Service.
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										64
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnloadbalancer.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										64
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnloadbalancer.go
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -28,14 +28,14 @@ type HostComputeLoadBalancer struct {
 | 
			
		||||
	Flags                LoadBalancerFlags         `json:",omitempty"` // 0: None, 1: EnableDirectServerReturn
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
//LoadBalancerFlags modify settings for a loadbalancer.
 | 
			
		||||
// LoadBalancerFlags modify settings for a loadbalancer.
 | 
			
		||||
type LoadBalancerFlags uint32
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	// LoadBalancerFlagsNone is the default.
 | 
			
		||||
	LoadBalancerFlagsNone LoadBalancerFlags = 0
 | 
			
		||||
	// LoadBalancerFlagsDSR enables Direct Server Return (DSR)
 | 
			
		||||
	LoadBalancerFlagsDSR LoadBalancerFlags = 1
 | 
			
		||||
	LoadBalancerFlagsDSR  LoadBalancerFlags = 1
 | 
			
		||||
	LoadBalancerFlagsIPv6 LoadBalancerFlags = 2
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
@@ -161,6 +161,49 @@ func createLoadBalancer(settings string) (*HostComputeLoadBalancer, error) {
 | 
			
		||||
	return &outputLoadBalancer, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func updateLoadBalancer(loadbalancerId string, settings string) (*HostComputeLoadBalancer, error) {
 | 
			
		||||
	loadBalancerGuid, err := guid.FromString(loadbalancerId)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, errInvalidLoadBalancerID
 | 
			
		||||
	}
 | 
			
		||||
	// Update loadBalancer.
 | 
			
		||||
	var (
 | 
			
		||||
		loadBalancerHandle hcnLoadBalancer
 | 
			
		||||
		resultBuffer       *uint16
 | 
			
		||||
		propertiesBuffer   *uint16
 | 
			
		||||
	)
 | 
			
		||||
	hr := hcnOpenLoadBalancer(&loadBalancerGuid, &loadBalancerHandle, &resultBuffer)
 | 
			
		||||
	if err := checkForErrors("hcnOpenLoadBalancer", hr, resultBuffer); err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	hr = hcnModifyLoadBalancer(loadBalancerHandle, settings, &resultBuffer)
 | 
			
		||||
	if err := checkForErrors("hcnModifyLoadBalancer", hr, resultBuffer); err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	// Query loadBalancer.
 | 
			
		||||
	hcnQuery := defaultQuery()
 | 
			
		||||
	query, err := json.Marshal(hcnQuery)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	hr = hcnQueryLoadBalancerProperties(loadBalancerHandle, string(query), &propertiesBuffer, &resultBuffer)
 | 
			
		||||
	if err := checkForErrors("hcnQueryLoadBalancerProperties", hr, resultBuffer); err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	properties := interop.ConvertAndFreeCoTaskMemString(propertiesBuffer)
 | 
			
		||||
	// Close loadBalancer.
 | 
			
		||||
	hr = hcnCloseLoadBalancer(loadBalancerHandle)
 | 
			
		||||
	if err := checkForErrors("hcnCloseLoadBalancer", hr, nil); err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	// Convert output to HostComputeLoadBalancer
 | 
			
		||||
	var outputLoadBalancer HostComputeLoadBalancer
 | 
			
		||||
	if err := json.Unmarshal([]byte(properties), &outputLoadBalancer); err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
	return &outputLoadBalancer, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func deleteLoadBalancer(loadBalancerId string) error {
 | 
			
		||||
	loadBalancerGuid, err := guid.FromString(loadBalancerId)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
@@ -235,6 +278,23 @@ func (loadBalancer *HostComputeLoadBalancer) Create() (*HostComputeLoadBalancer,
 | 
			
		||||
	return loadBalancer, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Update Loadbalancer.
 | 
			
		||||
func (loadBalancer *HostComputeLoadBalancer) Update(hnsLoadbalancerID string) (*HostComputeLoadBalancer, error) {
 | 
			
		||||
	logrus.Debugf("hcn::HostComputeLoadBalancer::Create id=%s", hnsLoadbalancerID)
 | 
			
		||||
 | 
			
		||||
	jsonString, err := json.Marshal(loadBalancer)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	logrus.Debugf("hcn::HostComputeLoadBalancer::Update JSON: %s", jsonString)
 | 
			
		||||
	loadBalancer, hcnErr := updateLoadBalancer(hnsLoadbalancerID, string(jsonString))
 | 
			
		||||
	if hcnErr != nil {
 | 
			
		||||
		return nil, hcnErr
 | 
			
		||||
	}
 | 
			
		||||
	return loadBalancer, nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Delete LoadBalancer.
 | 
			
		||||
func (loadBalancer *HostComputeLoadBalancer) Delete() error {
 | 
			
		||||
	logrus.Debugf("hcn::HostComputeLoadBalancer::Delete id=%s", loadBalancer.Id)
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										9
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnpolicy.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnpolicy.go
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -141,10 +141,11 @@ type QosPolicySetting struct {
 | 
			
		||||
 | 
			
		||||
// OutboundNatPolicySetting sets outbound Network Address Translation on an Endpoint.
 | 
			
		||||
type OutboundNatPolicySetting struct {
 | 
			
		||||
	VirtualIP    string   `json:",omitempty"`
 | 
			
		||||
	Exceptions   []string `json:",omitempty"`
 | 
			
		||||
	Destinations []string `json:",omitempty"`
 | 
			
		||||
	Flags        NatFlags `json:",omitempty"`
 | 
			
		||||
	VirtualIP        string   `json:",omitempty"`
 | 
			
		||||
	Exceptions       []string `json:",omitempty"`
 | 
			
		||||
	Destinations     []string `json:",omitempty"`
 | 
			
		||||
	Flags            NatFlags `json:",omitempty"`
 | 
			
		||||
	MaxPortPoolUsage uint16   `json:",omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// SDNRoutePolicySetting sets SDN Route on an Endpoint.
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										8
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnsupport.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								vendor/github.com/Microsoft/hcsshim/hcn/hcnsupport.go
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -32,6 +32,10 @@ type SupportedFeatures struct {
 | 
			
		||||
	L4Proxy                  bool        `json:"L4Proxy"`    // network policy that applies VFP rules to all endpoints on the network to redirect traffic
 | 
			
		||||
	L4WfpProxy               bool        `json:"L4WfpProxy"` // endpoint policy that applies WFP filters to redirect traffic to/from that endpoint
 | 
			
		||||
	TierAcl                  bool        `json:"TierAcl"`
 | 
			
		||||
	NetworkACL               bool        `json:"NetworkACL"`
 | 
			
		||||
	NestedIpSet              bool        `json:"NestedIpSet"`
 | 
			
		||||
	DisableHostPort          bool        `json:"DisableHostPort"`
 | 
			
		||||
	ModifyLoadbalancer       bool        `json:"ModifyLoadbalancer"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// AclFeatures are the supported ACL possibilities.
 | 
			
		||||
@@ -107,6 +111,10 @@ func getSupportedFeatures() (SupportedFeatures, error) {
 | 
			
		||||
	features.L4Proxy = isFeatureSupported(globals.Version, L4ProxyPolicyVersion)
 | 
			
		||||
	features.L4WfpProxy = isFeatureSupported(globals.Version, L4WfpProxyPolicyVersion)
 | 
			
		||||
	features.TierAcl = isFeatureSupported(globals.Version, TierAclPolicyVersion)
 | 
			
		||||
	features.NetworkACL = isFeatureSupported(globals.Version, NetworkACLPolicyVersion)
 | 
			
		||||
	features.NestedIpSet = isFeatureSupported(globals.Version, NestedIpSetVersion)
 | 
			
		||||
	features.DisableHostPort = isFeatureSupported(globals.Version, DisableHostPortVersion)
 | 
			
		||||
	features.ModifyLoadbalancer = isFeatureSupported(globals.Version, ModifyLoadbalancerVersion)
 | 
			
		||||
 | 
			
		||||
	logrus.WithFields(logrus.Fields{
 | 
			
		||||
		"version":           fmt.Sprintf("%+v", globals.Version),
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										7
									
								
								vendor/github.com/Microsoft/hcsshim/internal/hns/hnspolicy.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								vendor/github.com/Microsoft/hcsshim/internal/hns/hnspolicy.go
									
									
									
										generated
									
									
										vendored
									
									
								
							@@ -56,9 +56,10 @@ type PaPolicy struct {
 | 
			
		||||
 | 
			
		||||
type OutboundNatPolicy struct {
 | 
			
		||||
	Policy
 | 
			
		||||
	VIP          string   `json:"VIP,omitempty"`
 | 
			
		||||
	Exceptions   []string `json:"ExceptionList,omitempty"`
 | 
			
		||||
	Destinations []string `json:",omitempty"`
 | 
			
		||||
	VIP              string   `json:"VIP,omitempty"`
 | 
			
		||||
	Exceptions       []string `json:"ExceptionList,omitempty"`
 | 
			
		||||
	Destinations     []string `json:",omitempty"`
 | 
			
		||||
	MaxPortPoolUsage uint16   `json:",omitempty"`
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type ProxyPolicy struct {
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										2
									
								
								vendor/modules.txt
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/modules.txt
									
									
									
									
										vendored
									
									
								
							@@ -19,7 +19,7 @@ github.com/Microsoft/go-winio/internal/socket
 | 
			
		||||
github.com/Microsoft/go-winio/pkg/guid
 | 
			
		||||
github.com/Microsoft/go-winio/pkg/security
 | 
			
		||||
github.com/Microsoft/go-winio/vhd
 | 
			
		||||
# github.com/Microsoft/hcsshim v0.8.25
 | 
			
		||||
# github.com/Microsoft/hcsshim v0.8.26
 | 
			
		||||
## explicit; go 1.13
 | 
			
		||||
github.com/Microsoft/hcsshim
 | 
			
		||||
github.com/Microsoft/hcsshim/computestorage
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user