From a8448c45fa13cc614e9c45d8a5ed559b02d67b71 Mon Sep 17 00:00:00 2001 From: Xing Yang Date: Sun, 7 Oct 2018 18:38:16 -0700 Subject: [PATCH] Add Topology for Snapshot This PR adds topology requirements for snapshots. --- csi.proto | 207 +++++++---- lib/go/csi/v0/csi.pb.go | 790 ++++++++++++++++++++++------------------ spec.md | 206 +++++++---- 3 files changed, 703 insertions(+), 500 deletions(-) diff --git a/csi.proto b/csi.proto index 2b11288c..3d18fd30 100644 --- a/csi.proto +++ b/csi.proto @@ -130,13 +130,21 @@ message PluginCapability { // as specific RPCs as indicated by ControllerGetCapabilities. CONTROLLER_SERVICE = 1; - // ACCESSIBILITY_CONSTRAINTS indicates that the volumes for this - // plugin may not be equally accessible by all nodes in the + // VOLUME_ACCESSIBILITY_CONSTRAINTS indicates that the volumes for + // this plugin may not be equally accessible by all nodes in the // cluster. The CO MUST use the topology information returned by // CreateVolumeRequest along with the topology information // returned by NodeGetInfo to ensure that a given volume is // accessible from a given node when scheduling workloads. - ACCESSIBILITY_CONSTRAINTS = 2; + VOLUME_ACCESSIBILITY_CONSTRAINTS = 2; + + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS indicates that the snapshots + // for this plugin may not be equally accessible by all nodes in + // the cluster. The CO MUST use the topology information returned + // by CreateSnapshotRequest along with the topology information + // returned by NodeGetInfo to ensure that a given snapshot is + // accessible from a given node when scheduling workloads. + SNAPSHOT_ACCESSIBILITY_CONSTRAINTS = 3; } Type type = 1; } @@ -231,10 +239,10 @@ message CreateVolumeRequest { // topological accessibility information supported by the SP. // This field is OPTIONAL. // This field SHALL NOT be specified unless the SP has the - // ACCESSIBILITY_CONSTRAINTS plugin capability. + // VOLUME_ACCESSIBILITY_CONSTRAINTS plugin capability. // If this field is not specified and the SP has the - // ACCESSIBILITY_CONSTRAINTS plugin capability, the SP MAY choose - // where the provisioned volume is accessible from. + // VOLUME_ACCESSIBILITY_CONSTRAINTS plugin capability, the SP MAY + // choose where the provisioned volume is accessible from. TopologyRequirement accessibility_requirements = 7; } @@ -368,7 +376,7 @@ message Volume { // Specifies where (regions, zones, racks, etc.) the provisioned // volume is accessible from. // A plugin that returns this field MUST also set the - // ACCESSIBILITY_CONSTRAINTS plugin capability. + // VOLUME_ACCESSIBILITY_CONSTRAINTS plugin capability. // An SP MAY specify multiple topologies to indicate the volume is // accessible from multiple locations. // COs MAY use this information along with the topology information @@ -394,99 +402,109 @@ message Volume { } message TopologyRequirement { - // Specifies the list of topologies the provisioned volume MUST be - // accessible from. + // Specifies the list of topologies the provisioned volume or + // snapshot MUST be accessible from. // This field is OPTIONAL. If TopologyRequirement is specified either // requisite or preferred or both MUST be specified. // - // If requisite is specified, the provisioned volume MUST be - // accessible from at least one of the requisite topologies. + // If requisite is specified, the provisioned volume or snapshot MUST + // be accessible from at least one of the requisite topologies. // // Given - // x = number of topologies provisioned volume is accessible from + // x = number of topologies provisioned volume or snapshot is + // accessible from // n = number of requisite topologies // The CO MUST ensure n >= 1. The SP MUST ensure x >= 1 - // If x==n, than the SP MUST make the provisioned volume available to - // all topologies from the list of requisite topologies. If it is - // unable to do so, the SP MUST fail the CreateVolume call. - // For example, if a volume should be accessible from a single zone, - // and requisite = + // If x==n, than the SP MUST make the provisioned volume or snapshot + // available to all topologies from the list of requisite topologies. + // If it is unable to do so, the SP MUST fail the CreateVolume or + // CreateSnapshot call. For example, if a volume or snapshot should be + // accessible from a single zone, and + // requisite = // {"region": "R1", "zone": "Z2"} - // then the provisioned volume MUST be accessible from the "region" - // "R1" and the "zone" "Z2". - // Similarly, if a volume should be accessible from two zones, and + // then the provisioned volume or snapshot MUST be accessible from + // the "region" "R1" and the "zone" "Z2". + // Similarly, if a volume or snapshot should be accessible from two + // zones, and // requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"} - // then the provisioned volume MUST be accessible from the "region" - // "R1" and both "zone" "Z2" and "zone" "Z3". + // then the provisioned volume or snapshot MUST be accessible from the + // "region" "R1" and both "zone" "Z2" and "zone" "Z3". // // If xn, than the SP MUST make the provisioned volume available from - // all topologies from the list of requisite topologies and MAY choose - // the remaining x-n unique topologies from the list of all possible - // topologies. If it is unable to do so, the SP MUST fail the - // CreateVolume call. - // For example, if a volume should be accessible from two zones, and + // If x>n, than the SP MUST make the provisioned volume or snapshot + // available from all topologies from the list of requisite topologies + // and MAY choose the remaining x-n unique topologies from the list of + // all possible topologies. If it is unable to do so, the SP MUST fail + // the CreateVolume or CreateSnapshot call. + // For example, if a volume or snapshot should be accessible from two + // zones, and // requisite = // {"region": "R1", "zone": "Z2"} - // then the provisioned volume MUST be accessible from the "region" - // "R1" and the "zone" "Z2" and the SP may select the second zone - // independently, e.g. "R1/Z4". + // then the provisioned volume or snapshot MUST be accessible from the + // "region" "R1" and the "zone" "Z2" and the SP may select the second + // zone independently, e.g. "R1/Z4". repeated Topology requisite = 1; - // Specifies the list of topologies the CO would prefer the volume to - // be provisioned in. + // Specifies the list of topologies the CO would prefer the volume or + // snapshot to be provisioned in. // // This field is OPTIONAL. If TopologyRequirement is specified either // requisite or preferred or both MUST be specified. // - // An SP MUST attempt to make the provisioned volume available using - // the preferred topologies in order from first to last. + // An SP MUST attempt to make the provisioned volume or snapshot + // available using the preferred topologies in order from first to + // last. // // If requisite is specified, all topologies in preferred list MUST // also be present in the list of requisite topologies. // - // If the SP is unable to to make the provisioned volume available - // from any of the preferred topologies, the SP MAY choose a topology - // from the list of requisite topologies. + // If the SP is unable to to make the provisioned volume or snapshot + // available from any of the preferred topologies, the SP MAY choose + // a topology from the list of requisite topologies. // If the list of requisite topologies is not specified, then the SP // MAY choose from the list of all possible topologies. // If the list of requisite topologies is specified and the SP is - // unable to to make the provisioned volume available from any of the - // requisite topologies it MUST fail the CreateVolume call. + // unable to to make the provisioned volume or snapshot available from + // any of the requisite topologies it MUST fail the CreateVolume or + // CreateSnapshot call. // // Example 1: - // Given a volume should be accessible from a single zone, and - // requisite = + // Given a volume or snapshot should be accessible from a single zone, + // and requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"} // preferred = // {"region": "R1", "zone": "Z3"} // then the the SP SHOULD first attempt to make the provisioned volume - // available from "zone" "Z3" in the "region" "R1" and fall back to - // "zone" "Z2" in the "region" "R1" if that is not possible. + // or snapshot available from "zone" "Z3" in the "region" "R1" and + // fall back to "zone" "Z2" in the "region" "R1" if that is not + // possible. // // Example 2: - // Given a volume should be accessible from a single zone, and - // requisite = + // Given a volume or snapshot should be accessible from a single zone, + // and requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"}, // {"region": "R1", "zone": "Z4"}, @@ -495,17 +513,20 @@ message TopologyRequirement { // {"region": "R1", "zone": "Z4"}, // {"region": "R1", "zone": "Z2"} // then the the SP SHOULD first attempt to make the provisioned volume - // accessible from "zone" "Z4" in the "region" "R1" and fall back to - // "zone" "Z2" in the "region" "R1" if that is not possible. If that - // is not possible, the SP may choose between either the "zone" - // "Z3" or "Z5" in the "region" "R1". + // or snapshot accessible from "zone" "Z4" in the "region" "R1" and + // fall back to "zone" "Z2" in the "region" "R1" if that is not + // possible. If that is not possible, the SP may choose between either + // the "zone" "Z3" or "Z5" in the "region" "R1". // // Example 3: - // Given a volume should be accessible from TWO zones (because an - // opaque parameter in CreateVolumeRequest, for example, specifies - // the volume is accessible from two zones, aka synchronously - // replicated), and - // requisite = + // A volume or snapshot MAY be required to be accessible from TWO + // zones. This MAY be indicated by an opaque parameter in + // CreateVolumeRequest that specifies the volume to be accessible from + // two zones, aka synchronously replicated. While accessibility + // requirements MAY be satisfied by replication, CO MUST NOT assume + // accessibility requires replication. + // Given a volume or snapshot should be accessible from TWO zone, + // and requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"}, // {"region": "R1", "zone": "Z4"}, @@ -514,10 +535,10 @@ message TopologyRequirement { // {"region": "R1", "zone": "Z5"}, // {"region": "R1", "zone": "Z3"} // then the the SP SHOULD first attempt to make the provisioned volume - // accessible from the combination of the two "zones" "Z5" and "Z3" in - // the "region" "R1". If that's not possible, it should fall back to - // a combination of "Z5" and other possibilities from the list of - // requisite. If that's not possible, it should fall back to a + // or snapshot accessible from the combination of the two "zones" "Z5" + // and "Z3" in the "region" "R1". If that's not possible, it should + // fall back to a combination of "Z5" and other possibilities from the + // list of requisite. If that's not possible, it should fall back to a // combination of "Z3" and other possibilities from the list of // requisite. If that's not possible, it should fall back to a // combination of other possibilities from the list of requisite. @@ -642,7 +663,7 @@ message ValidateVolumeCapabilitiesRequest { // A caller MAY specify multiple topologies to indicate they believe // the volume to be accessible from multiple locations. // This field is OPTIONAL. This field SHALL NOT be set unless the - // plugin advertises the ACCESSIBILITY_CONSTRAINTS capability. + // plugin advertises the VOLUME_ACCESSIBILITY_CONSTRAINTS capability. repeated Topology accessible_topology = 4; } @@ -708,7 +729,7 @@ message GetCapacityRequest { // `accessible_topology`. This is the same as the // `accessible_topology` the CO returns in a `CreateVolumeResponse`. // This field is OPTIONAL. This field SHALL NOT be set unless the - // plugin advertises the ACCESSIBILITY_CONSTRAINTS capability. + // plugin advertises the VOLUME_ACCESSIBILITY_CONSTRAINTS capability. Topology accessible_topology = 3; } @@ -785,6 +806,19 @@ message CreateSnapshotRequest { // - Specify primary or secondary for replication systems that // support snapshotting only on primary. map parameters = 4; + + // Specifies where (regions, zones, racks, etc.) the provisioned + // snapshot MUST be accessible from. + // An SP SHALL advertise the requirements for topological + // accessibility information in documentation. COs SHALL only specify + // topological accessibility information supported by the SP. + // This field is OPTIONAL. + // This field SHALL NOT be specified unless the SP has the + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability. + // If this field is not specified and the SP has the + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability, the SP MAY + // choose where the provisioned snapshot is accessible from. + TopologyRequirement accessibility_requirements = 5; } message CreateSnapshotResponse { @@ -825,6 +859,33 @@ message Snapshot { // The status of a snapshot. SnapshotStatus status = 5; + + // Specifies where (regions, zones, racks, etc.) the provisioned + // snapshot is accessible from. + // A plugin that returns this field MUST also set the + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability. + // An SP MAY specify multiple topologies to indicate the snapshot is + // accessible from multiple locations. + // COs MAY use this information along with the topology information + // returned by NodeGetInfo to ensure that a given snapshot is + // accessible from a given node when scheduling workloads. + // This field is OPTIONAL. If it is not specified, the CO MAY assume + // the snapshot is equally accessible from all nodes in the cluster + // and may schedule workloads referencing the snapshot on any + // available node. + // + // Example 1: + // accessible_topology = {"region": "R1", "zone": "Z2"} + // Indicates a snapshot accessible only from the "region" "R1" and the + // "zone" "Z2". + // + // Example 2: + // accessible_topology = + // {"region": "R1", "zone": "Z2"}, + // {"region": "R1", "zone": "Z3"} + // Indicates a snapshot accessible from both "zone" "Z2" and "zone" + // "Z3" in the "region" "R1". + repeated Topology accessible_topology = 6; } // The status of a snapshot. @@ -1120,10 +1181,12 @@ message NodeGetInfoResponse { // Specifies where (regions, zones, racks, etc.) the node is // accessible from. // A plugin that returns this field MUST also set the - // ACCESSIBILITY_CONSTRAINTS plugin capability. + // VOLUME_ACCESSIBILITY_CONSTRAINTS or + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability. // COs MAY use this information along with the topology information - // returned in CreateVolumeResponse to ensure that a given volume is - // accessible from a given node when scheduling workloads. + // returned in CreateVolumeResponse CreateSnapshotResponse to ensure + // that a given volume or snapshot is accessible from a given node + // when scheduling workloads. // This field is OPTIONAL. If it is not specified, the CO MAY assume // the node is not subject to any topological constraint, and MAY // schedule workloads that reference any volume V, such that there are diff --git a/lib/go/csi/v0/csi.pb.go b/lib/go/csi/v0/csi.pb.go index c76730cd..55a2e4fb 100644 --- a/lib/go/csi/v0/csi.pb.go +++ b/lib/go/csi/v0/csi.pb.go @@ -37,31 +37,40 @@ const ( // attempt to invoke the REQUIRED ControllerService RPCs, as well // as specific RPCs as indicated by ControllerGetCapabilities. PluginCapability_Service_CONTROLLER_SERVICE PluginCapability_Service_Type = 1 - // ACCESSIBILITY_CONSTRAINTS indicates that the volumes for this - // plugin may not be equally accessible by all nodes in the + // VOLUME_ACCESSIBILITY_CONSTRAINTS indicates that the volumes for + // this plugin may not be equally accessible by all nodes in the // cluster. The CO MUST use the topology information returned by // CreateVolumeRequest along with the topology information // returned by NodeGetInfo to ensure that a given volume is // accessible from a given node when scheduling workloads. - PluginCapability_Service_ACCESSIBILITY_CONSTRAINTS PluginCapability_Service_Type = 2 + PluginCapability_Service_VOLUME_ACCESSIBILITY_CONSTRAINTS PluginCapability_Service_Type = 2 + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS indicates that the snapshots + // for this plugin may not be equally accessible by all nodes in + // the cluster. The CO MUST use the topology information returned + // by CreateSnapshotRequest along with the topology information + // returned by NodeGetInfo to ensure that a given snapshot is + // accessible from a given node when scheduling workloads. + PluginCapability_Service_SNAPSHOT_ACCESSIBILITY_CONSTRAINTS PluginCapability_Service_Type = 3 ) var PluginCapability_Service_Type_name = map[int32]string{ 0: "UNKNOWN", 1: "CONTROLLER_SERVICE", - 2: "ACCESSIBILITY_CONSTRAINTS", + 2: "VOLUME_ACCESSIBILITY_CONSTRAINTS", + 3: "SNAPSHOT_ACCESSIBILITY_CONSTRAINTS", } var PluginCapability_Service_Type_value = map[string]int32{ - "UNKNOWN": 0, - "CONTROLLER_SERVICE": 1, - "ACCESSIBILITY_CONSTRAINTS": 2, + "UNKNOWN": 0, + "CONTROLLER_SERVICE": 1, + "VOLUME_ACCESSIBILITY_CONSTRAINTS": 2, + "SNAPSHOT_ACCESSIBILITY_CONSTRAINTS": 3, } func (x PluginCapability_Service_Type) String() string { return proto.EnumName(PluginCapability_Service_Type_name, int32(x)) } func (PluginCapability_Service_Type) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{4, 0, 0} + return fileDescriptor_csi_932e42b466eac230, []int{4, 0, 0} } type VolumeCapability_AccessMode_Mode int32 @@ -105,7 +114,7 @@ func (x VolumeCapability_AccessMode_Mode) String() string { return proto.EnumName(VolumeCapability_AccessMode_Mode_name, int32(x)) } func (VolumeCapability_AccessMode_Mode) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{10, 2, 0} + return fileDescriptor_csi_932e42b466eac230, []int{10, 2, 0} } type ControllerServiceCapability_RPC_Type int32 @@ -151,7 +160,7 @@ func (x ControllerServiceCapability_RPC_Type) String() string { return proto.EnumName(ControllerServiceCapability_RPC_Type_name, int32(x)) } func (ControllerServiceCapability_RPC_Type) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{29, 0, 0} + return fileDescriptor_csi_932e42b466eac230, []int{29, 0, 0} } type SnapshotStatus_Type int32 @@ -193,7 +202,7 @@ func (x SnapshotStatus_Type) String() string { return proto.EnumName(SnapshotStatus_Type_name, int32(x)) } func (SnapshotStatus_Type) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{33, 0} + return fileDescriptor_csi_932e42b466eac230, []int{33, 0} } type VolumeUsage_Unit int32 @@ -219,7 +228,7 @@ func (x VolumeUsage_Unit) String() string { return proto.EnumName(VolumeUsage_Unit_name, int32(x)) } func (VolumeUsage_Unit) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{48, 0} + return fileDescriptor_csi_932e42b466eac230, []int{48, 0} } type NodeServiceCapability_RPC_Type int32 @@ -248,7 +257,7 @@ func (x NodeServiceCapability_RPC_Type) String() string { return proto.EnumName(NodeServiceCapability_RPC_Type_name, int32(x)) } func (NodeServiceCapability_RPC_Type) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{53, 0, 0} + return fileDescriptor_csi_932e42b466eac230, []int{53, 0, 0} } type GetPluginInfoRequest struct { @@ -261,7 +270,7 @@ func (m *GetPluginInfoRequest) Reset() { *m = GetPluginInfoRequest{} } func (m *GetPluginInfoRequest) String() string { return proto.CompactTextString(m) } func (*GetPluginInfoRequest) ProtoMessage() {} func (*GetPluginInfoRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{0} + return fileDescriptor_csi_932e42b466eac230, []int{0} } func (m *GetPluginInfoRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GetPluginInfoRequest.Unmarshal(m, b) @@ -303,7 +312,7 @@ func (m *GetPluginInfoResponse) Reset() { *m = GetPluginInfoResponse{} } func (m *GetPluginInfoResponse) String() string { return proto.CompactTextString(m) } func (*GetPluginInfoResponse) ProtoMessage() {} func (*GetPluginInfoResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{1} + return fileDescriptor_csi_932e42b466eac230, []int{1} } func (m *GetPluginInfoResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GetPluginInfoResponse.Unmarshal(m, b) @@ -354,7 +363,7 @@ func (m *GetPluginCapabilitiesRequest) Reset() { *m = GetPluginCapabilit func (m *GetPluginCapabilitiesRequest) String() string { return proto.CompactTextString(m) } func (*GetPluginCapabilitiesRequest) ProtoMessage() {} func (*GetPluginCapabilitiesRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{2} + return fileDescriptor_csi_932e42b466eac230, []int{2} } func (m *GetPluginCapabilitiesRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GetPluginCapabilitiesRequest.Unmarshal(m, b) @@ -387,7 +396,7 @@ func (m *GetPluginCapabilitiesResponse) Reset() { *m = GetPluginCapabili func (m *GetPluginCapabilitiesResponse) String() string { return proto.CompactTextString(m) } func (*GetPluginCapabilitiesResponse) ProtoMessage() {} func (*GetPluginCapabilitiesResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{3} + return fileDescriptor_csi_932e42b466eac230, []int{3} } func (m *GetPluginCapabilitiesResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GetPluginCapabilitiesResponse.Unmarshal(m, b) @@ -428,7 +437,7 @@ func (m *PluginCapability) Reset() { *m = PluginCapability{} } func (m *PluginCapability) String() string { return proto.CompactTextString(m) } func (*PluginCapability) ProtoMessage() {} func (*PluginCapability) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{4} + return fileDescriptor_csi_932e42b466eac230, []int{4} } func (m *PluginCapability) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PluginCapability.Unmarshal(m, b) @@ -538,7 +547,7 @@ func (m *PluginCapability_Service) Reset() { *m = PluginCapability_Servi func (m *PluginCapability_Service) String() string { return proto.CompactTextString(m) } func (*PluginCapability_Service) ProtoMessage() {} func (*PluginCapability_Service) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{4, 0} + return fileDescriptor_csi_932e42b466eac230, []int{4, 0} } func (m *PluginCapability_Service) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_PluginCapability_Service.Unmarshal(m, b) @@ -575,7 +584,7 @@ func (m *ProbeRequest) Reset() { *m = ProbeRequest{} } func (m *ProbeRequest) String() string { return proto.CompactTextString(m) } func (*ProbeRequest) ProtoMessage() {} func (*ProbeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{5} + return fileDescriptor_csi_932e42b466eac230, []int{5} } func (m *ProbeRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ProbeRequest.Unmarshal(m, b) @@ -626,7 +635,7 @@ func (m *ProbeResponse) Reset() { *m = ProbeResponse{} } func (m *ProbeResponse) String() string { return proto.CompactTextString(m) } func (*ProbeResponse) ProtoMessage() {} func (*ProbeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{6} + return fileDescriptor_csi_932e42b466eac230, []int{6} } func (m *ProbeResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ProbeResponse.Unmarshal(m, b) @@ -698,10 +707,10 @@ type CreateVolumeRequest struct { // topological accessibility information supported by the SP. // This field is OPTIONAL. // This field SHALL NOT be specified unless the SP has the - // ACCESSIBILITY_CONSTRAINTS plugin capability. + // VOLUME_ACCESSIBILITY_CONSTRAINTS plugin capability. // If this field is not specified and the SP has the - // ACCESSIBILITY_CONSTRAINTS plugin capability, the SP MAY choose - // where the provisioned volume is accessible from. + // VOLUME_ACCESSIBILITY_CONSTRAINTS plugin capability, the SP MAY + // choose where the provisioned volume is accessible from. AccessibilityRequirements *TopologyRequirement `protobuf:"bytes,7,opt,name=accessibility_requirements,json=accessibilityRequirements,proto3" json:"accessibility_requirements,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` @@ -712,7 +721,7 @@ func (m *CreateVolumeRequest) Reset() { *m = CreateVolumeRequest{} } func (m *CreateVolumeRequest) String() string { return proto.CompactTextString(m) } func (*CreateVolumeRequest) ProtoMessage() {} func (*CreateVolumeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{7} + return fileDescriptor_csi_932e42b466eac230, []int{7} } func (m *CreateVolumeRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_CreateVolumeRequest.Unmarshal(m, b) @@ -796,7 +805,7 @@ func (m *VolumeContentSource) Reset() { *m = VolumeContentSource{} } func (m *VolumeContentSource) String() string { return proto.CompactTextString(m) } func (*VolumeContentSource) ProtoMessage() {} func (*VolumeContentSource) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{8} + return fileDescriptor_csi_932e42b466eac230, []int{8} } func (m *VolumeContentSource) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_VolumeContentSource.Unmarshal(m, b) @@ -910,7 +919,7 @@ func (m *VolumeContentSource_SnapshotSource) Reset() { *m = VolumeConten func (m *VolumeContentSource_SnapshotSource) String() string { return proto.CompactTextString(m) } func (*VolumeContentSource_SnapshotSource) ProtoMessage() {} func (*VolumeContentSource_SnapshotSource) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{8, 0} + return fileDescriptor_csi_932e42b466eac230, []int{8, 0} } func (m *VolumeContentSource_SnapshotSource) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_VolumeContentSource_SnapshotSource.Unmarshal(m, b) @@ -951,7 +960,7 @@ func (m *CreateVolumeResponse) Reset() { *m = CreateVolumeResponse{} } func (m *CreateVolumeResponse) String() string { return proto.CompactTextString(m) } func (*CreateVolumeResponse) ProtoMessage() {} func (*CreateVolumeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{9} + return fileDescriptor_csi_932e42b466eac230, []int{9} } func (m *CreateVolumeResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_CreateVolumeResponse.Unmarshal(m, b) @@ -998,7 +1007,7 @@ func (m *VolumeCapability) Reset() { *m = VolumeCapability{} } func (m *VolumeCapability) String() string { return proto.CompactTextString(m) } func (*VolumeCapability) ProtoMessage() {} func (*VolumeCapability) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{10} + return fileDescriptor_csi_932e42b466eac230, []int{10} } func (m *VolumeCapability) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_VolumeCapability.Unmarshal(m, b) @@ -1147,7 +1156,7 @@ func (m *VolumeCapability_BlockVolume) Reset() { *m = VolumeCapability_B func (m *VolumeCapability_BlockVolume) String() string { return proto.CompactTextString(m) } func (*VolumeCapability_BlockVolume) ProtoMessage() {} func (*VolumeCapability_BlockVolume) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{10, 0} + return fileDescriptor_csi_932e42b466eac230, []int{10, 0} } func (m *VolumeCapability_BlockVolume) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_VolumeCapability_BlockVolume.Unmarshal(m, b) @@ -1187,7 +1196,7 @@ func (m *VolumeCapability_MountVolume) Reset() { *m = VolumeCapability_M func (m *VolumeCapability_MountVolume) String() string { return proto.CompactTextString(m) } func (*VolumeCapability_MountVolume) ProtoMessage() {} func (*VolumeCapability_MountVolume) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{10, 1} + return fileDescriptor_csi_932e42b466eac230, []int{10, 1} } func (m *VolumeCapability_MountVolume) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_VolumeCapability_MountVolume.Unmarshal(m, b) @@ -1234,7 +1243,7 @@ func (m *VolumeCapability_AccessMode) Reset() { *m = VolumeCapability_Ac func (m *VolumeCapability_AccessMode) String() string { return proto.CompactTextString(m) } func (*VolumeCapability_AccessMode) ProtoMessage() {} func (*VolumeCapability_AccessMode) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{10, 2} + return fileDescriptor_csi_932e42b466eac230, []int{10, 2} } func (m *VolumeCapability_AccessMode) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_VolumeCapability_AccessMode.Unmarshal(m, b) @@ -1282,7 +1291,7 @@ func (m *CapacityRange) Reset() { *m = CapacityRange{} } func (m *CapacityRange) String() string { return proto.CompactTextString(m) } func (*CapacityRange) ProtoMessage() {} func (*CapacityRange) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{11} + return fileDescriptor_csi_932e42b466eac230, []int{11} } func (m *CapacityRange) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_CapacityRange.Unmarshal(m, b) @@ -1343,7 +1352,7 @@ type Volume struct { // Specifies where (regions, zones, racks, etc.) the provisioned // volume is accessible from. // A plugin that returns this field MUST also set the - // ACCESSIBILITY_CONSTRAINTS plugin capability. + // VOLUME_ACCESSIBILITY_CONSTRAINTS plugin capability. // An SP MAY specify multiple topologies to indicate the volume is // accessible from multiple locations. // COs MAY use this information along with the topology information @@ -1375,7 +1384,7 @@ func (m *Volume) Reset() { *m = Volume{} } func (m *Volume) String() string { return proto.CompactTextString(m) } func (*Volume) ProtoMessage() {} func (*Volume) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{12} + return fileDescriptor_csi_932e42b466eac230, []int{12} } func (m *Volume) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Volume.Unmarshal(m, b) @@ -1431,98 +1440,108 @@ func (m *Volume) GetAccessibleTopology() []*Topology { } type TopologyRequirement struct { - // Specifies the list of topologies the provisioned volume MUST be - // accessible from. + // Specifies the list of topologies the provisioned volume or + // snapshot MUST be accessible from. // This field is OPTIONAL. If TopologyRequirement is specified either // requisite or preferred or both MUST be specified. // - // If requisite is specified, the provisioned volume MUST be - // accessible from at least one of the requisite topologies. + // If requisite is specified, the provisioned volume or snapshot MUST + // be accessible from at least one of the requisite topologies. // // Given - // x = number of topologies provisioned volume is accessible from + // x = number of topologies provisioned volume or snapshot is + // accessible from // n = number of requisite topologies // The CO MUST ensure n >= 1. The SP MUST ensure x >= 1 - // If x==n, than the SP MUST make the provisioned volume available to - // all topologies from the list of requisite topologies. If it is - // unable to do so, the SP MUST fail the CreateVolume call. - // For example, if a volume should be accessible from a single zone, - // and requisite = + // If x==n, than the SP MUST make the provisioned volume or snapshot + // available to all topologies from the list of requisite topologies. + // If it is unable to do so, the SP MUST fail the CreateVolume or + // CreateSnapshot call. For example, if a volume or snapshot should be + // accessible from a single zone, and + // requisite = // {"region": "R1", "zone": "Z2"} - // then the provisioned volume MUST be accessible from the "region" - // "R1" and the "zone" "Z2". - // Similarly, if a volume should be accessible from two zones, and + // then the provisioned volume or snapshot MUST be accessible from + // the "region" "R1" and the "zone" "Z2". + // Similarly, if a volume or snapshot should be accessible from two + // zones, and // requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"} - // then the provisioned volume MUST be accessible from the "region" - // "R1" and both "zone" "Z2" and "zone" "Z3". + // then the provisioned volume or snapshot MUST be accessible from the + // "region" "R1" and both "zone" "Z2" and "zone" "Z3". // // If xn, than the SP MUST make the provisioned volume available from - // all topologies from the list of requisite topologies and MAY choose - // the remaining x-n unique topologies from the list of all possible - // topologies. If it is unable to do so, the SP MUST fail the - // CreateVolume call. - // For example, if a volume should be accessible from two zones, and + // If x>n, than the SP MUST make the provisioned volume or snapshot + // available from all topologies from the list of requisite topologies + // and MAY choose the remaining x-n unique topologies from the list of + // all possible topologies. If it is unable to do so, the SP MUST fail + // the CreateVolume or CreateSnapshot call. + // For example, if a volume or snapshot should be accessible from two + // zones, and // requisite = // {"region": "R1", "zone": "Z2"} - // then the provisioned volume MUST be accessible from the "region" - // "R1" and the "zone" "Z2" and the SP may select the second zone - // independently, e.g. "R1/Z4". + // then the provisioned volume or snapshot MUST be accessible from the + // "region" "R1" and the "zone" "Z2" and the SP may select the second + // zone independently, e.g. "R1/Z4". Requisite []*Topology `protobuf:"bytes,1,rep,name=requisite,proto3" json:"requisite,omitempty"` - // Specifies the list of topologies the CO would prefer the volume to - // be provisioned in. + // Specifies the list of topologies the CO would prefer the volume or + // snapshot to be provisioned in. // // This field is OPTIONAL. If TopologyRequirement is specified either // requisite or preferred or both MUST be specified. // - // An SP MUST attempt to make the provisioned volume available using - // the preferred topologies in order from first to last. + // An SP MUST attempt to make the provisioned volume or snapshot + // available using the preferred topologies in order from first to + // last. // // If requisite is specified, all topologies in preferred list MUST // also be present in the list of requisite topologies. // - // If the SP is unable to to make the provisioned volume available - // from any of the preferred topologies, the SP MAY choose a topology - // from the list of requisite topologies. + // If the SP is unable to to make the provisioned volume or snapshot + // available from any of the preferred topologies, the SP MAY choose + // a topology from the list of requisite topologies. // If the list of requisite topologies is not specified, then the SP // MAY choose from the list of all possible topologies. // If the list of requisite topologies is specified and the SP is - // unable to to make the provisioned volume available from any of the - // requisite topologies it MUST fail the CreateVolume call. + // unable to to make the provisioned volume or snapshot available from + // any of the requisite topologies it MUST fail the CreateVolume or + // CreateSnapshot call. // // Example 1: - // Given a volume should be accessible from a single zone, and - // requisite = + // Given a volume or snapshot should be accessible from a single zone, + // and requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"} // preferred = // {"region": "R1", "zone": "Z3"} // then the the SP SHOULD first attempt to make the provisioned volume - // available from "zone" "Z3" in the "region" "R1" and fall back to - // "zone" "Z2" in the "region" "R1" if that is not possible. + // or snapshot available from "zone" "Z3" in the "region" "R1" and + // fall back to "zone" "Z2" in the "region" "R1" if that is not + // possible. // // Example 2: - // Given a volume should be accessible from a single zone, and - // requisite = + // Given a volume or snapshot should be accessible from a single zone, + // and requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"}, // {"region": "R1", "zone": "Z4"}, @@ -1531,17 +1550,20 @@ type TopologyRequirement struct { // {"region": "R1", "zone": "Z4"}, // {"region": "R1", "zone": "Z2"} // then the the SP SHOULD first attempt to make the provisioned volume - // accessible from "zone" "Z4" in the "region" "R1" and fall back to - // "zone" "Z2" in the "region" "R1" if that is not possible. If that - // is not possible, the SP may choose between either the "zone" - // "Z3" or "Z5" in the "region" "R1". + // or snapshot accessible from "zone" "Z4" in the "region" "R1" and + // fall back to "zone" "Z2" in the "region" "R1" if that is not + // possible. If that is not possible, the SP may choose between either + // the "zone" "Z3" or "Z5" in the "region" "R1". // // Example 3: - // Given a volume should be accessible from TWO zones (because an - // opaque parameter in CreateVolumeRequest, for example, specifies - // the volume is accessible from two zones, aka synchronously - // replicated), and - // requisite = + // A volume or snapshot MAY be required to be accessible from TWO + // zones. This MAY be indicated by an opaque parameter in + // CreateVolumeRequest that specifies the volume to be accessible from + // two zones, aka synchronously replicated. While accessibility + // requirements MAY be satisfied by replication, CO MUST NOT assume + // accessibility requires replication. + // Given a volume or snapshot should be accessible from TWO zone, + // and requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"}, // {"region": "R1", "zone": "Z4"}, @@ -1550,10 +1572,10 @@ type TopologyRequirement struct { // {"region": "R1", "zone": "Z5"}, // {"region": "R1", "zone": "Z3"} // then the the SP SHOULD first attempt to make the provisioned volume - // accessible from the combination of the two "zones" "Z5" and "Z3" in - // the "region" "R1". If that's not possible, it should fall back to - // a combination of "Z5" and other possibilities from the list of - // requisite. If that's not possible, it should fall back to a + // or snapshot accessible from the combination of the two "zones" "Z5" + // and "Z3" in the "region" "R1". If that's not possible, it should + // fall back to a combination of "Z5" and other possibilities from the + // list of requisite. If that's not possible, it should fall back to a // combination of "Z3" and other possibilities from the list of // requisite. If that's not possible, it should fall back to a // combination of other possibilities from the list of requisite. @@ -1567,7 +1589,7 @@ func (m *TopologyRequirement) Reset() { *m = TopologyRequirement{} } func (m *TopologyRequirement) String() string { return proto.CompactTextString(m) } func (*TopologyRequirement) ProtoMessage() {} func (*TopologyRequirement) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{13} + return fileDescriptor_csi_932e42b466eac230, []int{13} } func (m *TopologyRequirement) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_TopologyRequirement.Unmarshal(m, b) @@ -1638,7 +1660,7 @@ func (m *Topology) Reset() { *m = Topology{} } func (m *Topology) String() string { return proto.CompactTextString(m) } func (*Topology) ProtoMessage() {} func (*Topology) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{14} + return fileDescriptor_csi_932e42b466eac230, []int{14} } func (m *Topology) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Topology.Unmarshal(m, b) @@ -1682,7 +1704,7 @@ func (m *DeleteVolumeRequest) Reset() { *m = DeleteVolumeRequest{} } func (m *DeleteVolumeRequest) String() string { return proto.CompactTextString(m) } func (*DeleteVolumeRequest) ProtoMessage() {} func (*DeleteVolumeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{15} + return fileDescriptor_csi_932e42b466eac230, []int{15} } func (m *DeleteVolumeRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DeleteVolumeRequest.Unmarshal(m, b) @@ -1726,7 +1748,7 @@ func (m *DeleteVolumeResponse) Reset() { *m = DeleteVolumeResponse{} } func (m *DeleteVolumeResponse) String() string { return proto.CompactTextString(m) } func (*DeleteVolumeResponse) ProtoMessage() {} func (*DeleteVolumeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{16} + return fileDescriptor_csi_932e42b466eac230, []int{16} } func (m *DeleteVolumeResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DeleteVolumeResponse.Unmarshal(m, b) @@ -1776,7 +1798,7 @@ func (m *ControllerPublishVolumeRequest) Reset() { *m = ControllerPublis func (m *ControllerPublishVolumeRequest) String() string { return proto.CompactTextString(m) } func (*ControllerPublishVolumeRequest) ProtoMessage() {} func (*ControllerPublishVolumeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{17} + return fileDescriptor_csi_932e42b466eac230, []int{17} } func (m *ControllerPublishVolumeRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ControllerPublishVolumeRequest.Unmarshal(m, b) @@ -1853,7 +1875,7 @@ func (m *ControllerPublishVolumeResponse) Reset() { *m = ControllerPubli func (m *ControllerPublishVolumeResponse) String() string { return proto.CompactTextString(m) } func (*ControllerPublishVolumeResponse) ProtoMessage() {} func (*ControllerPublishVolumeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{18} + return fileDescriptor_csi_932e42b466eac230, []int{18} } func (m *ControllerPublishVolumeResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ControllerPublishVolumeResponse.Unmarshal(m, b) @@ -1904,7 +1926,7 @@ func (m *ControllerUnpublishVolumeRequest) Reset() { *m = ControllerUnpu func (m *ControllerUnpublishVolumeRequest) String() string { return proto.CompactTextString(m) } func (*ControllerUnpublishVolumeRequest) ProtoMessage() {} func (*ControllerUnpublishVolumeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{19} + return fileDescriptor_csi_932e42b466eac230, []int{19} } func (m *ControllerUnpublishVolumeRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ControllerUnpublishVolumeRequest.Unmarshal(m, b) @@ -1955,7 +1977,7 @@ func (m *ControllerUnpublishVolumeResponse) Reset() { *m = ControllerUnp func (m *ControllerUnpublishVolumeResponse) String() string { return proto.CompactTextString(m) } func (*ControllerUnpublishVolumeResponse) ProtoMessage() {} func (*ControllerUnpublishVolumeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{20} + return fileDescriptor_csi_932e42b466eac230, []int{20} } func (m *ControllerUnpublishVolumeResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ControllerUnpublishVolumeResponse.Unmarshal(m, b) @@ -1990,7 +2012,7 @@ type ValidateVolumeCapabilitiesRequest struct { // A caller MAY specify multiple topologies to indicate they believe // the volume to be accessible from multiple locations. // This field is OPTIONAL. This field SHALL NOT be set unless the - // plugin advertises the ACCESSIBILITY_CONSTRAINTS capability. + // plugin advertises the VOLUME_ACCESSIBILITY_CONSTRAINTS capability. AccessibleTopology []*Topology `protobuf:"bytes,4,rep,name=accessible_topology,json=accessibleTopology,proto3" json:"accessible_topology,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` @@ -2001,7 +2023,7 @@ func (m *ValidateVolumeCapabilitiesRequest) Reset() { *m = ValidateVolum func (m *ValidateVolumeCapabilitiesRequest) String() string { return proto.CompactTextString(m) } func (*ValidateVolumeCapabilitiesRequest) ProtoMessage() {} func (*ValidateVolumeCapabilitiesRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{21} + return fileDescriptor_csi_932e42b466eac230, []int{21} } func (m *ValidateVolumeCapabilitiesRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ValidateVolumeCapabilitiesRequest.Unmarshal(m, b) @@ -2066,7 +2088,7 @@ func (m *ValidateVolumeCapabilitiesResponse) Reset() { *m = ValidateVolu func (m *ValidateVolumeCapabilitiesResponse) String() string { return proto.CompactTextString(m) } func (*ValidateVolumeCapabilitiesResponse) ProtoMessage() {} func (*ValidateVolumeCapabilitiesResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{22} + return fileDescriptor_csi_932e42b466eac230, []int{22} } func (m *ValidateVolumeCapabilitiesResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ValidateVolumeCapabilitiesResponse.Unmarshal(m, b) @@ -2124,7 +2146,7 @@ func (m *ListVolumesRequest) Reset() { *m = ListVolumesRequest{} } func (m *ListVolumesRequest) String() string { return proto.CompactTextString(m) } func (*ListVolumesRequest) ProtoMessage() {} func (*ListVolumesRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{23} + return fileDescriptor_csi_932e42b466eac230, []int{23} } func (m *ListVolumesRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListVolumesRequest.Unmarshal(m, b) @@ -2176,7 +2198,7 @@ func (m *ListVolumesResponse) Reset() { *m = ListVolumesResponse{} } func (m *ListVolumesResponse) String() string { return proto.CompactTextString(m) } func (*ListVolumesResponse) ProtoMessage() {} func (*ListVolumesResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{24} + return fileDescriptor_csi_932e42b466eac230, []int{24} } func (m *ListVolumesResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListVolumesResponse.Unmarshal(m, b) @@ -2221,7 +2243,7 @@ func (m *ListVolumesResponse_Entry) Reset() { *m = ListVolumesResponse_E func (m *ListVolumesResponse_Entry) String() string { return proto.CompactTextString(m) } func (*ListVolumesResponse_Entry) ProtoMessage() {} func (*ListVolumesResponse_Entry) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{24, 0} + return fileDescriptor_csi_932e42b466eac230, []int{24, 0} } func (m *ListVolumesResponse_Entry) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListVolumesResponse_Entry.Unmarshal(m, b) @@ -2265,7 +2287,7 @@ type GetCapacityRequest struct { // `accessible_topology`. This is the same as the // `accessible_topology` the CO returns in a `CreateVolumeResponse`. // This field is OPTIONAL. This field SHALL NOT be set unless the - // plugin advertises the ACCESSIBILITY_CONSTRAINTS capability. + // plugin advertises the VOLUME_ACCESSIBILITY_CONSTRAINTS capability. AccessibleTopology *Topology `protobuf:"bytes,3,opt,name=accessible_topology,json=accessibleTopology,proto3" json:"accessible_topology,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` @@ -2276,7 +2298,7 @@ func (m *GetCapacityRequest) Reset() { *m = GetCapacityRequest{} } func (m *GetCapacityRequest) String() string { return proto.CompactTextString(m) } func (*GetCapacityRequest) ProtoMessage() {} func (*GetCapacityRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{25} + return fileDescriptor_csi_932e42b466eac230, []int{25} } func (m *GetCapacityRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GetCapacityRequest.Unmarshal(m, b) @@ -2334,7 +2356,7 @@ func (m *GetCapacityResponse) Reset() { *m = GetCapacityResponse{} } func (m *GetCapacityResponse) String() string { return proto.CompactTextString(m) } func (*GetCapacityResponse) ProtoMessage() {} func (*GetCapacityResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{26} + return fileDescriptor_csi_932e42b466eac230, []int{26} } func (m *GetCapacityResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_GetCapacityResponse.Unmarshal(m, b) @@ -2371,7 +2393,7 @@ func (m *ControllerGetCapabilitiesRequest) Reset() { *m = ControllerGetC func (m *ControllerGetCapabilitiesRequest) String() string { return proto.CompactTextString(m) } func (*ControllerGetCapabilitiesRequest) ProtoMessage() {} func (*ControllerGetCapabilitiesRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{27} + return fileDescriptor_csi_932e42b466eac230, []int{27} } func (m *ControllerGetCapabilitiesRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ControllerGetCapabilitiesRequest.Unmarshal(m, b) @@ -2404,7 +2426,7 @@ func (m *ControllerGetCapabilitiesResponse) Reset() { *m = ControllerGet func (m *ControllerGetCapabilitiesResponse) String() string { return proto.CompactTextString(m) } func (*ControllerGetCapabilitiesResponse) ProtoMessage() {} func (*ControllerGetCapabilitiesResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{28} + return fileDescriptor_csi_932e42b466eac230, []int{28} } func (m *ControllerGetCapabilitiesResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ControllerGetCapabilitiesResponse.Unmarshal(m, b) @@ -2445,7 +2467,7 @@ func (m *ControllerServiceCapability) Reset() { *m = ControllerServiceCa func (m *ControllerServiceCapability) String() string { return proto.CompactTextString(m) } func (*ControllerServiceCapability) ProtoMessage() {} func (*ControllerServiceCapability) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{29} + return fileDescriptor_csi_932e42b466eac230, []int{29} } func (m *ControllerServiceCapability) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ControllerServiceCapability.Unmarshal(m, b) @@ -2555,7 +2577,7 @@ func (m *ControllerServiceCapability_RPC) Reset() { *m = ControllerServi func (m *ControllerServiceCapability_RPC) String() string { return proto.CompactTextString(m) } func (*ControllerServiceCapability_RPC) ProtoMessage() {} func (*ControllerServiceCapability_RPC) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{29, 0} + return fileDescriptor_csi_932e42b466eac230, []int{29, 0} } func (m *ControllerServiceCapability_RPC) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ControllerServiceCapability_RPC.Unmarshal(m, b) @@ -2603,17 +2625,29 @@ type CreateSnapshotRequest struct { // - Specify if the snapshot should be replicated to some place. // - Specify primary or secondary for replication systems that // support snapshotting only on primary. - Parameters map[string]string `protobuf:"bytes,4,rep,name=parameters,proto3" json:"parameters,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` - XXX_NoUnkeyedLiteral struct{} `json:"-"` - XXX_unrecognized []byte `json:"-"` - XXX_sizecache int32 `json:"-"` + Parameters map[string]string `protobuf:"bytes,4,rep,name=parameters,proto3" json:"parameters,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"bytes,2,opt,name=value,proto3"` + // Specifies where (regions, zones, racks, etc.) the provisioned + // snapshot MUST be accessible from. + // An SP SHALL advertise the requirements for topological + // accessibility information in documentation. COs SHALL only specify + // topological accessibility information supported by the SP. + // This field is OPTIONAL. + // This field SHALL NOT be specified unless the SP has the + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability. + // If this field is not specified and the SP has the + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability, the SP MAY + // choose where the provisioned snapshot is accessible from. + AccessibilityRequirements *TopologyRequirement `protobuf:"bytes,5,opt,name=accessibility_requirements,json=accessibilityRequirements,proto3" json:"accessibility_requirements,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` } func (m *CreateSnapshotRequest) Reset() { *m = CreateSnapshotRequest{} } func (m *CreateSnapshotRequest) String() string { return proto.CompactTextString(m) } func (*CreateSnapshotRequest) ProtoMessage() {} func (*CreateSnapshotRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{30} + return fileDescriptor_csi_932e42b466eac230, []int{30} } func (m *CreateSnapshotRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_CreateSnapshotRequest.Unmarshal(m, b) @@ -2661,6 +2695,13 @@ func (m *CreateSnapshotRequest) GetParameters() map[string]string { return nil } +func (m *CreateSnapshotRequest) GetAccessibilityRequirements() *TopologyRequirement { + if m != nil { + return m.AccessibilityRequirements + } + return nil +} + type CreateSnapshotResponse struct { // Contains all attributes of the newly created snapshot that are // relevant to the CO along with information required by the Plugin @@ -2675,7 +2716,7 @@ func (m *CreateSnapshotResponse) Reset() { *m = CreateSnapshotResponse{} func (m *CreateSnapshotResponse) String() string { return proto.CompactTextString(m) } func (*CreateSnapshotResponse) ProtoMessage() {} func (*CreateSnapshotResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{31} + return fileDescriptor_csi_932e42b466eac230, []int{31} } func (m *CreateSnapshotResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_CreateSnapshotResponse.Unmarshal(m, b) @@ -2728,17 +2769,43 @@ type Snapshot struct { // field is REQUIRED. CreatedAt int64 `protobuf:"varint,4,opt,name=created_at,json=createdAt,proto3" json:"created_at,omitempty"` // The status of a snapshot. - Status *SnapshotStatus `protobuf:"bytes,5,opt,name=status,proto3" json:"status,omitempty"` - XXX_NoUnkeyedLiteral struct{} `json:"-"` - XXX_unrecognized []byte `json:"-"` - XXX_sizecache int32 `json:"-"` + Status *SnapshotStatus `protobuf:"bytes,5,opt,name=status,proto3" json:"status,omitempty"` + // Specifies where (regions, zones, racks, etc.) the provisioned + // snapshot is accessible from. + // A plugin that returns this field MUST also set the + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability. + // An SP MAY specify multiple topologies to indicate the snapshot is + // accessible from multiple locations. + // COs MAY use this information along with the topology information + // returned by NodeGetInfo to ensure that a given snapshot is + // accessible from a given node when scheduling workloads. + // This field is OPTIONAL. If it is not specified, the CO MAY assume + // the snapshot is equally accessible from all nodes in the cluster + // and may schedule workloads referencing the snapshot on any + // available node. + // + // Example 1: + // accessible_topology = {"region": "R1", "zone": "Z2"} + // Indicates a snapshot accessible only from the "region" "R1" and the + // "zone" "Z2". + // + // Example 2: + // accessible_topology = + // {"region": "R1", "zone": "Z2"}, + // {"region": "R1", "zone": "Z3"} + // Indicates a snapshot accessible from both "zone" "Z2" and "zone" + // "Z3" in the "region" "R1". + AccessibleTopology []*Topology `protobuf:"bytes,6,rep,name=accessible_topology,json=accessibleTopology,proto3" json:"accessible_topology,omitempty"` + XXX_NoUnkeyedLiteral struct{} `json:"-"` + XXX_unrecognized []byte `json:"-"` + XXX_sizecache int32 `json:"-"` } func (m *Snapshot) Reset() { *m = Snapshot{} } func (m *Snapshot) String() string { return proto.CompactTextString(m) } func (*Snapshot) ProtoMessage() {} func (*Snapshot) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{32} + return fileDescriptor_csi_932e42b466eac230, []int{32} } func (m *Snapshot) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_Snapshot.Unmarshal(m, b) @@ -2793,6 +2860,13 @@ func (m *Snapshot) GetStatus() *SnapshotStatus { return nil } +func (m *Snapshot) GetAccessibleTopology() []*Topology { + if m != nil { + return m.AccessibleTopology + } + return nil +} + // The status of a snapshot. type SnapshotStatus struct { // This field is REQUIRED. @@ -2809,7 +2883,7 @@ func (m *SnapshotStatus) Reset() { *m = SnapshotStatus{} } func (m *SnapshotStatus) String() string { return proto.CompactTextString(m) } func (*SnapshotStatus) ProtoMessage() {} func (*SnapshotStatus) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{33} + return fileDescriptor_csi_932e42b466eac230, []int{33} } func (m *SnapshotStatus) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_SnapshotStatus.Unmarshal(m, b) @@ -2860,7 +2934,7 @@ func (m *DeleteSnapshotRequest) Reset() { *m = DeleteSnapshotRequest{} } func (m *DeleteSnapshotRequest) String() string { return proto.CompactTextString(m) } func (*DeleteSnapshotRequest) ProtoMessage() {} func (*DeleteSnapshotRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{34} + return fileDescriptor_csi_932e42b466eac230, []int{34} } func (m *DeleteSnapshotRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DeleteSnapshotRequest.Unmarshal(m, b) @@ -2904,7 +2978,7 @@ func (m *DeleteSnapshotResponse) Reset() { *m = DeleteSnapshotResponse{} func (m *DeleteSnapshotResponse) String() string { return proto.CompactTextString(m) } func (*DeleteSnapshotResponse) ProtoMessage() {} func (*DeleteSnapshotResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{35} + return fileDescriptor_csi_932e42b466eac230, []int{35} } func (m *DeleteSnapshotResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_DeleteSnapshotResponse.Unmarshal(m, b) @@ -2958,7 +3032,7 @@ func (m *ListSnapshotsRequest) Reset() { *m = ListSnapshotsRequest{} } func (m *ListSnapshotsRequest) String() string { return proto.CompactTextString(m) } func (*ListSnapshotsRequest) ProtoMessage() {} func (*ListSnapshotsRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{36} + return fileDescriptor_csi_932e42b466eac230, []int{36} } func (m *ListSnapshotsRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListSnapshotsRequest.Unmarshal(m, b) @@ -3024,7 +3098,7 @@ func (m *ListSnapshotsResponse) Reset() { *m = ListSnapshotsResponse{} } func (m *ListSnapshotsResponse) String() string { return proto.CompactTextString(m) } func (*ListSnapshotsResponse) ProtoMessage() {} func (*ListSnapshotsResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{37} + return fileDescriptor_csi_932e42b466eac230, []int{37} } func (m *ListSnapshotsResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListSnapshotsResponse.Unmarshal(m, b) @@ -3069,7 +3143,7 @@ func (m *ListSnapshotsResponse_Entry) Reset() { *m = ListSnapshotsRespon func (m *ListSnapshotsResponse_Entry) String() string { return proto.CompactTextString(m) } func (*ListSnapshotsResponse_Entry) ProtoMessage() {} func (*ListSnapshotsResponse_Entry) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{37, 0} + return fileDescriptor_csi_932e42b466eac230, []int{37, 0} } func (m *ListSnapshotsResponse_Entry) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_ListSnapshotsResponse_Entry.Unmarshal(m, b) @@ -3131,7 +3205,7 @@ func (m *NodeStageVolumeRequest) Reset() { *m = NodeStageVolumeRequest{} func (m *NodeStageVolumeRequest) String() string { return proto.CompactTextString(m) } func (*NodeStageVolumeRequest) ProtoMessage() {} func (*NodeStageVolumeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{38} + return fileDescriptor_csi_932e42b466eac230, []int{38} } func (m *NodeStageVolumeRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeStageVolumeRequest.Unmarshal(m, b) @@ -3203,7 +3277,7 @@ func (m *NodeStageVolumeResponse) Reset() { *m = NodeStageVolumeResponse func (m *NodeStageVolumeResponse) String() string { return proto.CompactTextString(m) } func (*NodeStageVolumeResponse) ProtoMessage() {} func (*NodeStageVolumeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{39} + return fileDescriptor_csi_932e42b466eac230, []int{39} } func (m *NodeStageVolumeResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeStageVolumeResponse.Unmarshal(m, b) @@ -3239,7 +3313,7 @@ func (m *NodeUnstageVolumeRequest) Reset() { *m = NodeUnstageVolumeReque func (m *NodeUnstageVolumeRequest) String() string { return proto.CompactTextString(m) } func (*NodeUnstageVolumeRequest) ProtoMessage() {} func (*NodeUnstageVolumeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{40} + return fileDescriptor_csi_932e42b466eac230, []int{40} } func (m *NodeUnstageVolumeRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeUnstageVolumeRequest.Unmarshal(m, b) @@ -3283,7 +3357,7 @@ func (m *NodeUnstageVolumeResponse) Reset() { *m = NodeUnstageVolumeResp func (m *NodeUnstageVolumeResponse) String() string { return proto.CompactTextString(m) } func (*NodeUnstageVolumeResponse) ProtoMessage() {} func (*NodeUnstageVolumeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{41} + return fileDescriptor_csi_932e42b466eac230, []int{41} } func (m *NodeUnstageVolumeResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeUnstageVolumeResponse.Unmarshal(m, b) @@ -3349,7 +3423,7 @@ func (m *NodePublishVolumeRequest) Reset() { *m = NodePublishVolumeReque func (m *NodePublishVolumeRequest) String() string { return proto.CompactTextString(m) } func (*NodePublishVolumeRequest) ProtoMessage() {} func (*NodePublishVolumeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{42} + return fileDescriptor_csi_932e42b466eac230, []int{42} } func (m *NodePublishVolumeRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodePublishVolumeRequest.Unmarshal(m, b) @@ -3435,7 +3509,7 @@ func (m *NodePublishVolumeResponse) Reset() { *m = NodePublishVolumeResp func (m *NodePublishVolumeResponse) String() string { return proto.CompactTextString(m) } func (*NodePublishVolumeResponse) ProtoMessage() {} func (*NodePublishVolumeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{43} + return fileDescriptor_csi_932e42b466eac230, []int{43} } func (m *NodePublishVolumeResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodePublishVolumeResponse.Unmarshal(m, b) @@ -3471,7 +3545,7 @@ func (m *NodeUnpublishVolumeRequest) Reset() { *m = NodeUnpublishVolumeR func (m *NodeUnpublishVolumeRequest) String() string { return proto.CompactTextString(m) } func (*NodeUnpublishVolumeRequest) ProtoMessage() {} func (*NodeUnpublishVolumeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{44} + return fileDescriptor_csi_932e42b466eac230, []int{44} } func (m *NodeUnpublishVolumeRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeUnpublishVolumeRequest.Unmarshal(m, b) @@ -3515,7 +3589,7 @@ func (m *NodeUnpublishVolumeResponse) Reset() { *m = NodeUnpublishVolume func (m *NodeUnpublishVolumeResponse) String() string { return proto.CompactTextString(m) } func (*NodeUnpublishVolumeResponse) ProtoMessage() {} func (*NodeUnpublishVolumeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{45} + return fileDescriptor_csi_932e42b466eac230, []int{45} } func (m *NodeUnpublishVolumeResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeUnpublishVolumeResponse.Unmarshal(m, b) @@ -3553,7 +3627,7 @@ func (m *NodeGetVolumeStatsRequest) Reset() { *m = NodeGetVolumeStatsReq func (m *NodeGetVolumeStatsRequest) String() string { return proto.CompactTextString(m) } func (*NodeGetVolumeStatsRequest) ProtoMessage() {} func (*NodeGetVolumeStatsRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{46} + return fileDescriptor_csi_932e42b466eac230, []int{46} } func (m *NodeGetVolumeStatsRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeGetVolumeStatsRequest.Unmarshal(m, b) @@ -3599,7 +3673,7 @@ func (m *NodeGetVolumeStatsResponse) Reset() { *m = NodeGetVolumeStatsRe func (m *NodeGetVolumeStatsResponse) String() string { return proto.CompactTextString(m) } func (*NodeGetVolumeStatsResponse) ProtoMessage() {} func (*NodeGetVolumeStatsResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{47} + return fileDescriptor_csi_932e42b466eac230, []int{47} } func (m *NodeGetVolumeStatsResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeGetVolumeStatsResponse.Unmarshal(m, b) @@ -3647,7 +3721,7 @@ func (m *VolumeUsage) Reset() { *m = VolumeUsage{} } func (m *VolumeUsage) String() string { return proto.CompactTextString(m) } func (*VolumeUsage) ProtoMessage() {} func (*VolumeUsage) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{48} + return fileDescriptor_csi_932e42b466eac230, []int{48} } func (m *VolumeUsage) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_VolumeUsage.Unmarshal(m, b) @@ -3705,7 +3779,7 @@ func (m *NodeGetIdRequest) Reset() { *m = NodeGetIdRequest{} } func (m *NodeGetIdRequest) String() string { return proto.CompactTextString(m) } func (*NodeGetIdRequest) ProtoMessage() {} func (*NodeGetIdRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{49} + return fileDescriptor_csi_932e42b466eac230, []int{49} } func (m *NodeGetIdRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeGetIdRequest.Unmarshal(m, b) @@ -3739,7 +3813,7 @@ func (m *NodeGetIdResponse) Reset() { *m = NodeGetIdResponse{} } func (m *NodeGetIdResponse) String() string { return proto.CompactTextString(m) } func (*NodeGetIdResponse) ProtoMessage() {} func (*NodeGetIdResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{50} + return fileDescriptor_csi_932e42b466eac230, []int{50} } func (m *NodeGetIdResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeGetIdResponse.Unmarshal(m, b) @@ -3776,7 +3850,7 @@ func (m *NodeGetCapabilitiesRequest) Reset() { *m = NodeGetCapabilitiesR func (m *NodeGetCapabilitiesRequest) String() string { return proto.CompactTextString(m) } func (*NodeGetCapabilitiesRequest) ProtoMessage() {} func (*NodeGetCapabilitiesRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{51} + return fileDescriptor_csi_932e42b466eac230, []int{51} } func (m *NodeGetCapabilitiesRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeGetCapabilitiesRequest.Unmarshal(m, b) @@ -3809,7 +3883,7 @@ func (m *NodeGetCapabilitiesResponse) Reset() { *m = NodeGetCapabilities func (m *NodeGetCapabilitiesResponse) String() string { return proto.CompactTextString(m) } func (*NodeGetCapabilitiesResponse) ProtoMessage() {} func (*NodeGetCapabilitiesResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{52} + return fileDescriptor_csi_932e42b466eac230, []int{52} } func (m *NodeGetCapabilitiesResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeGetCapabilitiesResponse.Unmarshal(m, b) @@ -3850,7 +3924,7 @@ func (m *NodeServiceCapability) Reset() { *m = NodeServiceCapability{} } func (m *NodeServiceCapability) String() string { return proto.CompactTextString(m) } func (*NodeServiceCapability) ProtoMessage() {} func (*NodeServiceCapability) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{53} + return fileDescriptor_csi_932e42b466eac230, []int{53} } func (m *NodeServiceCapability) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeServiceCapability.Unmarshal(m, b) @@ -3960,7 +4034,7 @@ func (m *NodeServiceCapability_RPC) Reset() { *m = NodeServiceCapability func (m *NodeServiceCapability_RPC) String() string { return proto.CompactTextString(m) } func (*NodeServiceCapability_RPC) ProtoMessage() {} func (*NodeServiceCapability_RPC) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{53, 0} + return fileDescriptor_csi_932e42b466eac230, []int{53, 0} } func (m *NodeServiceCapability_RPC) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeServiceCapability_RPC.Unmarshal(m, b) @@ -3997,7 +4071,7 @@ func (m *NodeGetInfoRequest) Reset() { *m = NodeGetInfoRequest{} } func (m *NodeGetInfoRequest) String() string { return proto.CompactTextString(m) } func (*NodeGetInfoRequest) ProtoMessage() {} func (*NodeGetInfoRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{54} + return fileDescriptor_csi_932e42b466eac230, []int{54} } func (m *NodeGetInfoRequest) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeGetInfoRequest.Unmarshal(m, b) @@ -4031,10 +4105,12 @@ type NodeGetInfoResponse struct { // Specifies where (regions, zones, racks, etc.) the node is // accessible from. // A plugin that returns this field MUST also set the - // ACCESSIBILITY_CONSTRAINTS plugin capability. + // VOLUME_ACCESSIBILITY_CONSTRAINTS or + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability. // COs MAY use this information along with the topology information - // returned in CreateVolumeResponse to ensure that a given volume is - // accessible from a given node when scheduling workloads. + // returned in CreateVolumeResponse CreateSnapshotResponse to ensure + // that a given volume or snapshot is accessible from a given node + // when scheduling workloads. // This field is OPTIONAL. If it is not specified, the CO MAY assume // the node is not subject to any topological constraint, and MAY // schedule workloads that reference any volume V, such that there are @@ -4055,7 +4131,7 @@ func (m *NodeGetInfoResponse) Reset() { *m = NodeGetInfoResponse{} } func (m *NodeGetInfoResponse) String() string { return proto.CompactTextString(m) } func (*NodeGetInfoResponse) ProtoMessage() {} func (*NodeGetInfoResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_csi_d2a705310653d01b, []int{55} + return fileDescriptor_csi_932e42b466eac230, []int{55} } func (m *NodeGetInfoResponse) XXX_Unmarshal(b []byte) error { return xxx_messageInfo_NodeGetInfoResponse.Unmarshal(m, b) @@ -5032,205 +5108,207 @@ var _Node_serviceDesc = grpc.ServiceDesc{ } func init() { - proto.RegisterFile("github.com/container-storage-interface/spec/csi.proto", fileDescriptor_csi_d2a705310653d01b) -} - -var fileDescriptor_csi_d2a705310653d01b = []byte{ - // 3125 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xcc, 0x3a, 0x4d, 0x6f, 0x23, 0xc7, - 0xb1, 0x1a, 0x7e, 0xe8, 0xa3, 0xb4, 0x92, 0xb9, 0xad, 0x2f, 0x6a, 0x24, 0xed, 0x6a, 0x67, 0xbd, - 0xf6, 0x7a, 0xdf, 0x2e, 0xe5, 0xa7, 0xf7, 0x6c, 0xf8, 0xd9, 0x6b, 0xbf, 0x50, 0x14, 0x2d, 0xd1, - 0x2b, 0x51, 0xca, 0x90, 0x92, 0xb1, 0x1b, 0x1b, 0xe3, 0x11, 0xd9, 0xe2, 0x4e, 0x4c, 0xcd, 0xd0, - 0x33, 0x43, 0x65, 0x95, 0x5b, 0x12, 0x20, 0x48, 0x72, 0x4a, 0x7e, 0x81, 0x01, 0xdf, 0x12, 0xc4, - 0x08, 0x10, 0xe4, 0x16, 0x20, 0xb7, 0x00, 0x39, 0xe5, 0x9c, 0x53, 0x72, 0x0e, 0x92, 0x63, 0x4e, - 0x01, 0x02, 0x04, 0x3d, 0xdd, 0x33, 0x9c, 0x6e, 0xf6, 0xf0, 0xc3, 0xbb, 0x30, 0x72, 0x22, 0xa7, - 0xaa, 0xba, 0xaa, 0xba, 0xba, 0xaa, 0xba, 0xaa, 0x66, 0xe0, 0x8d, 0x96, 0xe5, 0x3f, 0xed, 0x9e, - 0x15, 0x1a, 0xce, 0xc5, 0x56, 0xc3, 0xb1, 0x7d, 0xd3, 0xb2, 0xb1, 0xfb, 0xc0, 0xf3, 0x1d, 0xd7, - 0x6c, 0xe1, 0x07, 0x96, 0xed, 0x63, 0xf7, 0xdc, 0x6c, 0xe0, 0x2d, 0xaf, 0x83, 0x1b, 0x5b, 0x0d, - 0xcf, 0x2a, 0x74, 0x5c, 0xc7, 0x77, 0xd0, 0x24, 0xf9, 0x7b, 0xf9, 0xba, 0x7a, 0xa3, 0xe5, 0x38, - 0xad, 0x36, 0xde, 0x0a, 0xa0, 0x67, 0xdd, 0xf3, 0xad, 0xef, 0xb8, 0x66, 0xa7, 0x83, 0x5d, 0x8f, - 0xd2, 0x69, 0xcb, 0xb0, 0xb8, 0x87, 0xfd, 0xe3, 0x76, 0xb7, 0x65, 0xd9, 0x15, 0xfb, 0xdc, 0xd1, - 0xf1, 0x67, 0x5d, 0xec, 0xf9, 0xda, 0x9f, 0x14, 0x58, 0x12, 0x10, 0x5e, 0xc7, 0xb1, 0x3d, 0x8c, - 0x10, 0x64, 0x6c, 0xf3, 0x02, 0xe7, 0x95, 0x4d, 0xe5, 0xee, 0x8c, 0x1e, 0xfc, 0x47, 0x77, 0x60, - 0xfe, 0x12, 0xdb, 0x4d, 0xc7, 0x35, 0x2e, 0xb1, 0xeb, 0x59, 0x8e, 0x9d, 0x4f, 0x05, 0xd8, 0x39, - 0x0a, 0x3d, 0xa5, 0x40, 0xb4, 0x07, 0xd3, 0x17, 0xa6, 0x6d, 0x9d, 0x63, 0xcf, 0xcf, 0xa7, 0x37, - 0xd3, 0x77, 0x67, 0xb7, 0xff, 0xab, 0x40, 0xf5, 0x2c, 0x48, 0x65, 0x15, 0x0e, 0x19, 0x75, 0xd9, - 0xf6, 0xdd, 0x2b, 0x3d, 0x5a, 0xac, 0xbe, 0x03, 0x73, 0x1c, 0x0a, 0xe5, 0x20, 0xfd, 0x29, 0xbe, - 0x62, 0x3a, 0x91, 0xbf, 0x68, 0x11, 0xb2, 0x97, 0x66, 0xbb, 0x8b, 0x99, 0x26, 0xf4, 0xe1, 0xed, - 0xd4, 0x5b, 0x8a, 0x76, 0x03, 0xd6, 0x23, 0x69, 0x25, 0xb3, 0x63, 0x9e, 0x59, 0x6d, 0xcb, 0xb7, - 0xb0, 0x17, 0x6e, 0xfd, 0x63, 0xd8, 0x48, 0xc0, 0x33, 0x0b, 0x3c, 0x84, 0x6b, 0x8d, 0x18, 0x3c, - 0x9f, 0x0a, 0xb6, 0x92, 0x0f, 0xb7, 0x22, 0xac, 0xbc, 0xd2, 0x39, 0x6a, 0xed, 0x6f, 0x0a, 0xe4, - 0x44, 0x12, 0xf4, 0x10, 0xa6, 0x3c, 0xec, 0x5e, 0x5a, 0x0d, 0x6a, 0xd7, 0xd9, 0xed, 0xcd, 0x24, - 0x6e, 0x85, 0x1a, 0xa5, 0xdb, 0x9f, 0xd0, 0xc3, 0x25, 0xea, 0x4f, 0x15, 0x98, 0x62, 0x60, 0xf4, - 0x7f, 0x90, 0xf1, 0xaf, 0x3a, 0x94, 0xcd, 0xfc, 0xf6, 0x9d, 0x61, 0x6c, 0x0a, 0xf5, 0xab, 0x0e, - 0xd6, 0x83, 0x25, 0xda, 0x07, 0x90, 0x21, 0x4f, 0x68, 0x16, 0xa6, 0x4e, 0xaa, 0x8f, 0xaa, 0x47, - 0x1f, 0x56, 0x73, 0x13, 0x68, 0x19, 0x50, 0xe9, 0xa8, 0x5a, 0xd7, 0x8f, 0x0e, 0x0e, 0xca, 0xba, - 0x51, 0x2b, 0xeb, 0xa7, 0x95, 0x52, 0x39, 0xa7, 0xa0, 0x0d, 0x58, 0x2d, 0x96, 0x4a, 0xe5, 0x5a, - 0xad, 0xb2, 0x53, 0x39, 0xa8, 0xd4, 0x1f, 0x1b, 0xa5, 0xa3, 0x6a, 0xad, 0xae, 0x17, 0x2b, 0xd5, - 0x7a, 0x2d, 0x97, 0xda, 0x99, 0xa4, 0x6a, 0x68, 0xf3, 0x70, 0xed, 0xd8, 0x75, 0xce, 0x70, 0x68, - 0xdc, 0x22, 0xcc, 0xb1, 0x67, 0x66, 0xcc, 0xd7, 0x21, 0xeb, 0x62, 0xb3, 0x79, 0xc5, 0xf6, 0xad, - 0x16, 0xa8, 0xc3, 0x16, 0x42, 0x87, 0x2d, 0xec, 0x38, 0x4e, 0xfb, 0x94, 0x1c, 0x9e, 0x4e, 0x09, - 0xb5, 0x2f, 0xb3, 0xb0, 0x50, 0x72, 0xb1, 0xe9, 0xe3, 0x53, 0xa7, 0xdd, 0xbd, 0x08, 0x59, 0x4b, - 0x1d, 0xf3, 0x21, 0xcc, 0x13, 0xe3, 0x37, 0x2c, 0xff, 0xca, 0x70, 0x4d, 0xbb, 0x45, 0xdd, 0x61, - 0x76, 0x7b, 0x29, 0xb4, 0x4b, 0x89, 0x61, 0x75, 0x82, 0xd4, 0xe7, 0x1a, 0xf1, 0x47, 0x54, 0x81, - 0x85, 0xcb, 0x40, 0x84, 0xc1, 0x9d, 0x77, 0x9a, 0x3f, 0x6f, 0xaa, 0x45, 0xec, 0xbc, 0xd1, 0x25, - 0x0f, 0xb1, 0xb0, 0x87, 0x1e, 0x01, 0x74, 0x4c, 0xd7, 0xbc, 0xc0, 0x3e, 0x76, 0xbd, 0x7c, 0x86, - 0x77, 0x7e, 0xc9, 0x6e, 0x0a, 0xc7, 0x11, 0x35, 0x75, 0xfe, 0xd8, 0x72, 0xe4, 0xc3, 0x2a, 0x49, - 0x05, 0xae, 0xd3, 0x6e, 0x63, 0xd7, 0x68, 0x04, 0xab, 0x0d, 0x0f, 0x37, 0x5c, 0xec, 0x7b, 0xf9, - 0x6c, 0xc0, 0xfb, 0xad, 0x41, 0xbc, 0x4b, 0xd1, 0x62, 0x8a, 0xad, 0xd1, 0xa5, 0x54, 0xd0, 0x4a, - 0x43, 0x8e, 0x45, 0x47, 0xb0, 0x14, 0x5a, 0xc3, 0xb1, 0x7d, 0x6c, 0xfb, 0x86, 0xe7, 0x74, 0xdd, - 0x06, 0xce, 0x4f, 0x06, 0x26, 0x5d, 0x13, 0xec, 0x41, 0x69, 0x6a, 0x01, 0x89, 0xce, 0xec, 0xc8, - 0x01, 0xd1, 0x13, 0x50, 0xcd, 0x46, 0x03, 0x7b, 0x9e, 0x45, 0x0d, 0x67, 0xb8, 0xf8, 0xb3, 0xae, - 0xe5, 0xe2, 0x0b, 0x6c, 0xfb, 0x5e, 0x7e, 0x8a, 0xe7, 0x5a, 0x77, 0x3a, 0x4e, 0xdb, 0x69, 0x5d, - 0xe9, 0x3d, 0x1a, 0x7d, 0x95, 0x5b, 0x1e, 0xc3, 0x78, 0xea, 0xbb, 0xf0, 0x92, 0x60, 0xc1, 0x71, - 0x72, 0x84, 0xfa, 0x01, 0xac, 0x0f, 0x32, 0xd2, 0x58, 0xf9, 0xe6, 0xc7, 0x0a, 0x2c, 0x48, 0x6c, - 0x82, 0xf6, 0x61, 0xda, 0xb3, 0xcd, 0x8e, 0xf7, 0xd4, 0xf1, 0x99, 0xf3, 0xdf, 0x1b, 0x60, 0xc2, - 0x42, 0x8d, 0xd1, 0xd2, 0xc7, 0xfd, 0x09, 0x3d, 0x5a, 0xad, 0x6e, 0xc2, 0x3c, 0x8f, 0x45, 0xf3, - 0x90, 0xb2, 0x9a, 0x4c, 0xbd, 0x94, 0xd5, 0x8c, 0xc2, 0xf1, 0x3d, 0x58, 0xe4, 0x1d, 0x82, 0x45, - 0xe1, 0x2b, 0x30, 0x49, 0x4f, 0x88, 0x69, 0x32, 0xcf, 0x6b, 0xa2, 0x33, 0xac, 0xf6, 0x8b, 0x0c, - 0xe4, 0x44, 0x7f, 0x47, 0x0f, 0x21, 0x7b, 0xd6, 0x76, 0x1a, 0x9f, 0xb2, 0xb5, 0x2f, 0x27, 0x05, - 0x46, 0x61, 0x87, 0x50, 0x51, 0xe8, 0xfe, 0x84, 0x4e, 0x17, 0x91, 0xd5, 0x17, 0x4e, 0xd7, 0xf6, - 0x59, 0x64, 0x26, 0xaf, 0x3e, 0x24, 0x54, 0xbd, 0xd5, 0xc1, 0x22, 0xb4, 0x0b, 0xb3, 0xd4, 0x09, - 0x8c, 0x0b, 0xa7, 0x89, 0xf3, 0xe9, 0x80, 0xc7, 0xed, 0x44, 0x1e, 0xc5, 0x80, 0xf6, 0xd0, 0x69, - 0x62, 0x1d, 0xcc, 0xe8, 0xbf, 0x3a, 0x07, 0xb3, 0x31, 0xdd, 0xd4, 0x3d, 0x98, 0x8d, 0x09, 0x43, - 0x2b, 0x30, 0x75, 0xee, 0x19, 0x51, 0x56, 0x9d, 0xd1, 0x27, 0xcf, 0xbd, 0x20, 0x51, 0xde, 0x84, - 0xd9, 0x40, 0x0b, 0xe3, 0xbc, 0x6d, 0xb6, 0xe8, 0x3d, 0x30, 0xa3, 0x43, 0x00, 0x7a, 0x9f, 0x40, - 0xd4, 0xbf, 0x2b, 0x00, 0x3d, 0x91, 0xe8, 0x21, 0x64, 0x02, 0x2d, 0x69, 0x6e, 0xbe, 0x3b, 0x82, - 0x96, 0x85, 0x40, 0xd5, 0x60, 0x95, 0xf6, 0xb9, 0x02, 0x99, 0x80, 0x8d, 0x98, 0x9f, 0x6b, 0x95, - 0xea, 0xde, 0x41, 0xd9, 0xa8, 0x1e, 0xed, 0x96, 0x8d, 0x0f, 0xf5, 0x4a, 0xbd, 0xac, 0xe7, 0x14, - 0xb4, 0x06, 0x2b, 0x71, 0xb8, 0x5e, 0x2e, 0xee, 0x96, 0x75, 0xe3, 0xa8, 0x7a, 0xf0, 0x38, 0x97, - 0x42, 0x2a, 0x2c, 0x1f, 0x9e, 0x1c, 0xd4, 0x2b, 0xfd, 0xb8, 0x34, 0x5a, 0x87, 0x7c, 0x0c, 0xc7, - 0x78, 0x30, 0xb6, 0x19, 0xc2, 0x36, 0x86, 0xa5, 0x7f, 0x19, 0x32, 0xbb, 0x33, 0x17, 0x1d, 0x46, - 0xe0, 0x6c, 0x1f, 0xc2, 0x1c, 0x97, 0x5e, 0x49, 0x99, 0xc0, 0x42, 0xbc, 0x69, 0x9c, 0x5d, 0xf9, - 0xd8, 0x0b, 0x2c, 0x91, 0xd6, 0xe7, 0x42, 0xe8, 0x0e, 0x01, 0x12, 0xb3, 0xb6, 0xad, 0x0b, 0xcb, - 0x67, 0x34, 0xa9, 0x80, 0x06, 0x02, 0x50, 0x40, 0xa0, 0xfd, 0x3e, 0x05, 0x93, 0xec, 0x6c, 0xee, - 0xc4, 0x12, 0x3c, 0xc7, 0x32, 0x84, 0x52, 0x96, 0x34, 0x1e, 0x52, 0x61, 0x3c, 0xa0, 0xf7, 0x00, - 0x4c, 0xdf, 0x77, 0xad, 0xb3, 0xae, 0x1f, 0x25, 0xf4, 0x1b, 0xfc, 0x79, 0x14, 0x8a, 0x11, 0x01, - 0xcb, 0xc0, 0xbd, 0x15, 0x68, 0x07, 0xe6, 0x85, 0x24, 0x98, 0x19, 0x9e, 0x04, 0xe7, 0x1a, 0x5c, - 0xfc, 0x17, 0x61, 0x21, 0xcc, 0x5f, 0x6d, 0x6c, 0xf8, 0x2c, 0xbf, 0xb1, 0xfc, 0x9d, 0xeb, 0xcb, - 0x7b, 0xa8, 0x47, 0x1c, 0xc2, 0x48, 0x96, 0x13, 0xb4, 0x1c, 0x2b, 0x33, 0x75, 0x61, 0x41, 0x92, - 0x56, 0x51, 0x01, 0x66, 0x82, 0x03, 0xf1, 0x2c, 0x9f, 0xf8, 0xaa, 0x5c, 0x9d, 0x1e, 0x09, 0xa1, - 0xef, 0xb8, 0xf8, 0x1c, 0xbb, 0x2e, 0x6e, 0xb2, 0x62, 0x48, 0x42, 0x1f, 0x91, 0x68, 0x3f, 0x50, - 0x60, 0x3a, 0x84, 0xa3, 0xb7, 0x61, 0xda, 0xc3, 0x2d, 0x9a, 0xf2, 0x15, 0xfe, 0x1c, 0x42, 0x9a, - 0x42, 0x8d, 0x11, 0xb0, 0x32, 0x30, 0xa4, 0x27, 0x65, 0x20, 0x87, 0x1a, 0x6b, 0xf3, 0xff, 0x50, - 0x60, 0x61, 0x17, 0xb7, 0xb1, 0x58, 0x46, 0xac, 0xc1, 0x0c, 0xbb, 0xe6, 0xa2, 0x0c, 0x3a, 0x4d, - 0x01, 0x95, 0xa6, 0x70, 0xf3, 0x36, 0x83, 0xe5, 0xd1, 0xcd, 0x9b, 0xe2, 0x6f, 0x5e, 0x09, 0xf3, - 0xd8, 0xcd, 0x4b, 0xb1, 0x49, 0x37, 0x2f, 0x87, 0xe5, 0x6f, 0xa3, 0xfe, 0x85, 0x63, 0x6d, 0x7b, - 0x19, 0x16, 0x79, 0xc5, 0xe8, 0x0d, 0xa0, 0xfd, 0x36, 0x03, 0x37, 0x7a, 0x42, 0x8e, 0xbb, 0x67, - 0x6d, 0xcb, 0x7b, 0x3a, 0x86, 0x65, 0x56, 0x60, 0xca, 0x76, 0x9a, 0x01, 0x8a, 0xca, 0x9c, 0x24, - 0x8f, 0x95, 0x26, 0x2a, 0xc3, 0x75, 0xb1, 0x88, 0xba, 0x62, 0x79, 0x3a, 0xb9, 0x84, 0xca, 0x5d, - 0x8a, 0x97, 0x8c, 0x0a, 0xd3, 0xa4, 0xfc, 0x73, 0xec, 0xf6, 0x55, 0x10, 0x6b, 0xd3, 0x7a, 0xf4, - 0x8c, 0xbe, 0xaf, 0x80, 0x1a, 0x3b, 0x96, 0x0e, 0x55, 0x5e, 0xa8, 0x88, 0x76, 0xa3, 0x8a, 0x68, - 0xe0, 0x2e, 0xfb, 0xd1, 0xdc, 0x19, 0xe5, 0x1b, 0x09, 0x68, 0x64, 0x45, 0xfb, 0x8c, 0x65, 0x96, - 0xc9, 0x40, 0xf4, 0xc3, 0x11, 0x45, 0xd3, 0x27, 0x31, 0xef, 0x30, 0x5b, 0xf4, 0xc0, 0xea, 0x23, - 0xd8, 0x18, 0xa8, 0xe5, 0x58, 0xa5, 0x4e, 0x09, 0x96, 0xa4, 0x72, 0xc7, 0xf2, 0xaa, 0xdf, 0x29, - 0x70, 0x33, 0x71, 0x73, 0xac, 0xc6, 0xf8, 0x16, 0x5c, 0x0b, 0x4f, 0xc6, 0xb2, 0xcf, 0x1d, 0x16, - 0xed, 0x6f, 0x0d, 0xb5, 0x0d, 0xeb, 0x05, 0x19, 0x94, 0xf4, 0x87, 0xd4, 0x2e, 0xb3, 0x9d, 0x1e, - 0x44, 0x7d, 0x0f, 0x72, 0x22, 0xc1, 0x58, 0x1b, 0xf8, 0x4d, 0x0a, 0x36, 0x7b, 0x1a, 0x9c, 0xd8, - 0x9d, 0x17, 0x17, 0x00, 0x3f, 0x51, 0x60, 0x3d, 0xe6, 0x9d, 0x5d, 0x5b, 0xf4, 0x4f, 0x7a, 0xfd, - 0xec, 0xf7, 0x1b, 0x42, 0xae, 0x86, 0x8c, 0x80, 0xf3, 0xd1, 0x58, 0x2c, 0x88, 0x04, 0xea, 0x61, - 0xfc, 0x9c, 0xa4, 0xcb, 0xc7, 0x32, 0xdb, 0x6d, 0xb8, 0x35, 0x40, 0x5d, 0x96, 0x5a, 0xbe, 0x97, - 0x86, 0x5b, 0xa7, 0x66, 0xdb, 0x6a, 0x46, 0x75, 0xa7, 0xa4, 0xed, 0x1e, 0x6c, 0xdc, 0x84, 0x4e, - 0x2c, 0xf5, 0x15, 0x3a, 0xb1, 0xb6, 0x2c, 0x4e, 0xe9, 0x11, 0xfc, 0x7f, 0xc4, 0x68, 0x98, 0xb6, - 0xa3, 0x86, 0x6a, 0xd2, 0x25, 0x9f, 0x19, 0xe3, 0x92, 0x7f, 0x21, 0x01, 0xfa, 0x11, 0x68, 0x83, - 0x36, 0xc5, 0x42, 0x74, 0x1d, 0x66, 0xbc, 0x6e, 0xa7, 0xe3, 0xb8, 0x3e, 0xa6, 0x67, 0x30, 0xad, - 0xf7, 0x00, 0x28, 0x0f, 0x53, 0x17, 0xd8, 0xf3, 0xcc, 0x56, 0xc8, 0x3f, 0x7c, 0xd4, 0x3e, 0x02, - 0x74, 0x60, 0x79, 0xac, 0x5e, 0x8e, 0x4e, 0x94, 0x94, 0xc7, 0xe6, 0x33, 0x03, 0xdb, 0xbe, 0x6b, - 0xb1, 0xc2, 0x2c, 0xab, 0xc3, 0x85, 0xf9, 0xac, 0x4c, 0x21, 0xa4, 0x78, 0xf3, 0x7c, 0xd3, 0xf5, - 0x2d, 0xbb, 0x65, 0xf8, 0xce, 0xa7, 0x38, 0x1a, 0x1b, 0x85, 0xd0, 0x3a, 0x01, 0x6a, 0x5f, 0x28, - 0xb0, 0xc0, 0xb1, 0x67, 0xda, 0xbe, 0x03, 0x53, 0x3d, 0xde, 0xc4, 0x9e, 0xb7, 0x42, 0x7b, 0x4a, - 0xa8, 0x0b, 0xf4, 0x84, 0xc2, 0x15, 0x68, 0x03, 0xc0, 0xc6, 0xcf, 0x7c, 0x4e, 0xee, 0x0c, 0x81, - 0x04, 0x32, 0xd5, 0x2d, 0xc8, 0x52, 0x23, 0x8f, 0xda, 0x19, 0x7d, 0x99, 0x02, 0xb4, 0x87, 0xfd, - 0xa8, 0xe0, 0x65, 0x36, 0x48, 0x70, 0x5c, 0xe5, 0x2b, 0x38, 0xee, 0x07, 0xdc, 0x08, 0x81, 0xba, - 0xfe, 0xbd, 0xd8, 0xfc, 0x4c, 0x10, 0x3d, 0x70, 0x82, 0x90, 0xe0, 0x96, 0xf4, 0x5a, 0x1e, 0xb9, - 0xf6, 0x7c, 0x8e, 0x0e, 0x5b, 0xdb, 0x85, 0x05, 0x4e, 0x67, 0x76, 0xa6, 0x0f, 0x00, 0x99, 0x97, - 0xa6, 0xd5, 0x36, 0x89, 0x5e, 0x61, 0x0d, 0xcf, 0x6a, 0xfa, 0xeb, 0x11, 0x26, 0x5c, 0xa6, 0x69, - 0xf1, 0xac, 0xcd, 0xf8, 0x89, 0xf3, 0xbc, 0x76, 0x3c, 0x47, 0xf5, 0xd1, 0x30, 0xb9, 0x7b, 0xd2, - 0x99, 0xde, 0xed, 0xfe, 0x9c, 0xcc, 0xe6, 0x66, 0x89, 0xe3, 0xbd, 0x3f, 0xa6, 0x60, 0x6d, 0x00, - 0x35, 0x7a, 0x07, 0xd2, 0x6e, 0xa7, 0xc1, 0x9c, 0xe9, 0xd5, 0x11, 0xf8, 0x17, 0xf4, 0xe3, 0xd2, - 0xfe, 0x84, 0x4e, 0x56, 0xa9, 0x7f, 0x55, 0x20, 0xad, 0x1f, 0x97, 0xd0, 0x37, 0xb8, 0x21, 0xdf, - 0xfd, 0x11, 0xb9, 0xc4, 0x67, 0x7d, 0xa4, 0x99, 0xec, 0x1f, 0xf6, 0xe5, 0x61, 0xb1, 0xa4, 0x97, - 0x8b, 0xf5, 0xb2, 0xb1, 0x5b, 0x3e, 0x28, 0xd7, 0xcb, 0xc6, 0xe9, 0xd1, 0xc1, 0xc9, 0x61, 0x39, - 0xa7, 0x90, 0xae, 0xf0, 0xf8, 0x64, 0xe7, 0xa0, 0x52, 0xdb, 0x37, 0x4e, 0xaa, 0xe1, 0x3f, 0x86, - 0x4d, 0xa1, 0x1c, 0x5c, 0x3b, 0xa8, 0xd4, 0xea, 0x0c, 0x50, 0xcb, 0xa5, 0x09, 0x64, 0xaf, 0x5c, - 0x37, 0x4a, 0xc5, 0xe3, 0x62, 0xa9, 0x52, 0x7f, 0x9c, 0xcb, 0x90, 0x9e, 0x93, 0xe7, 0x5d, 0xab, - 0x16, 0x8f, 0x6b, 0xfb, 0x47, 0xf5, 0x5c, 0x16, 0x21, 0x98, 0x0f, 0xd6, 0x87, 0xa0, 0x5a, 0x6e, - 0x32, 0x1a, 0x59, 0x7c, 0x9e, 0x86, 0x25, 0x36, 0x81, 0x61, 0x33, 0x8e, 0x30, 0xb6, 0xee, 0x42, - 0x8e, 0x36, 0x5f, 0x86, 0x78, 0x71, 0xcc, 0x53, 0xf8, 0x69, 0x78, 0x7d, 0x84, 0xa3, 0xc1, 0x54, - 0x6c, 0x34, 0xd8, 0x81, 0x95, 0x70, 0x72, 0xc6, 0xf8, 0x0a, 0x17, 0xb2, 0x30, 0x42, 0x13, 0xa4, - 0x0b, 0x50, 0xee, 0x02, 0x5e, 0x6a, 0xc8, 0x70, 0xe8, 0x50, 0x32, 0x03, 0x7c, 0x30, 0x58, 0xc8, - 0x80, 0x18, 0x56, 0xf7, 0x41, 0x4d, 0xd6, 0x61, 0xac, 0x12, 0xf0, 0x39, 0x43, 0xf9, 0x7d, 0x58, - 0x16, 0xb5, 0x67, 0x51, 0x75, 0xbf, 0x6f, 0xc4, 0x15, 0xe5, 0x96, 0x88, 0x36, 0xa2, 0xd0, 0x7e, - 0xad, 0xc0, 0x74, 0x08, 0x26, 0xf9, 0xd9, 0xb3, 0xbe, 0x8b, 0xb9, 0xa6, 0x7e, 0x86, 0x40, 0xe4, - 0x0d, 0xbd, 0xcc, 0x17, 0xd2, 0x52, 0x5f, 0xd8, 0x00, 0xa0, 0xc7, 0xd3, 0x34, 0x4c, 0x3f, 0x68, - 0x25, 0xd2, 0xfa, 0x0c, 0x83, 0x14, 0x49, 0xf3, 0x3b, 0xe9, 0xf9, 0xa6, 0xdf, 0x25, 0x6d, 0x03, - 0x51, 0x78, 0x59, 0x54, 0xb8, 0x16, 0x60, 0x75, 0x46, 0x45, 0x02, 0x69, 0x9e, 0x47, 0xa1, 0x2d, - 0x2e, 0x3a, 0xd7, 0xe4, 0x0c, 0x62, 0xc1, 0x48, 0x2e, 0xd6, 0x26, 0xf6, 0x4d, 0xab, 0xed, 0x85, - 0x17, 0x2b, 0x7b, 0xd4, 0x76, 0x64, 0x51, 0x3a, 0x03, 0x59, 0xbd, 0x5c, 0xdc, 0x7d, 0x9c, 0x53, - 0xd0, 0x1c, 0xcc, 0x9c, 0x1c, 0x1f, 0x1c, 0x15, 0x77, 0x2b, 0xd5, 0xbd, 0x5c, 0x0a, 0x2d, 0xc0, - 0x4b, 0x65, 0x5d, 0x3f, 0xd2, 0x8d, 0x1e, 0x30, 0x4d, 0x1a, 0xdd, 0x25, 0xd6, 0x34, 0x0a, 0x01, - 0x74, 0x13, 0x66, 0x23, 0xdf, 0x8f, 0x62, 0x07, 0x42, 0x50, 0xa5, 0x49, 0x62, 0x24, 0xec, 0x71, - 0xc5, 0x18, 0x91, 0x36, 0xbb, 0xa2, 0xfb, 0xf2, 0x50, 0x3e, 0x46, 0x9a, 0x32, 0x1c, 0x71, 0xea, - 0xe4, 0x45, 0x63, 0x79, 0x65, 0x1e, 0x96, 0x45, 0xa5, 0x58, 0x3d, 0xfa, 0x73, 0x05, 0x16, 0x49, - 0x85, 0x10, 0x22, 0x5e, 0x74, 0xc1, 0x32, 0x86, 0x33, 0x0a, 0x27, 0x90, 0x11, 0x4f, 0x40, 0xfb, - 0xa5, 0x02, 0x4b, 0x82, 0xae, 0x2c, 0xb6, 0xde, 0x15, 0xab, 0x9f, 0xdb, 0xf1, 0xea, 0xa7, 0x8f, - 0x7e, 0xcc, 0xfa, 0xe7, 0x8d, 0xb0, 0xfe, 0x19, 0x2f, 0x84, 0x7f, 0x96, 0x85, 0xe5, 0xaa, 0xd3, - 0xc4, 0x35, 0xdf, 0x6c, 0x8d, 0x33, 0x57, 0xd1, 0x85, 0xde, 0x90, 0x7a, 0xd7, 0x56, 0x28, 0x49, - 0xce, 0x72, 0x70, 0x4b, 0x88, 0x0a, 0xb0, 0xe0, 0xf9, 0x66, 0x2b, 0x38, 0x2b, 0xd3, 0x6d, 0x61, - 0xdf, 0xe8, 0x98, 0xfe, 0x53, 0x76, 0x10, 0xd7, 0x19, 0xaa, 0x1e, 0x60, 0x8e, 0x4d, 0xff, 0xa9, - 0x7c, 0x50, 0x91, 0x19, 0x7b, 0x50, 0x71, 0x06, 0x28, 0xe8, 0x03, 0x89, 0x00, 0xf1, 0xad, 0xcc, - 0xff, 0x0e, 0xd9, 0x50, 0x04, 0xe6, 0x42, 0x25, 0x67, 0x0b, 0x60, 0x64, 0x26, 0xcf, 0x1a, 0x86, - 0x89, 0x18, 0x75, 0xc6, 0xf0, 0x9c, 0x0d, 0x35, 0xe9, 0x5a, 0xa4, 0xbb, 0xf9, 0xfa, 0x67, 0x13, - 0xab, 0xb0, 0xd2, 0x67, 0x0b, 0x96, 0x09, 0x5a, 0x90, 0x27, 0xa8, 0x13, 0xdb, 0x1b, 0xd3, 0x5f, - 0x13, 0x7c, 0x2b, 0x95, 0xe0, 0x5b, 0xda, 0x1a, 0xac, 0x4a, 0x04, 0x31, 0x2d, 0xfe, 0x9c, 0xa5, - 0x6a, 0x8c, 0x3f, 0x74, 0xab, 0x4b, 0xc3, 0xe6, 0xbf, 0xe3, 0x2e, 0x20, 0x1d, 0x34, 0xbd, 0xd8, - 0xc0, 0xb9, 0x09, 0xb3, 0x71, 0x3a, 0x96, 0xc4, 0xfc, 0x21, 0x91, 0x95, 0x7d, 0xae, 0x11, 0xe0, - 0xa4, 0x30, 0x02, 0xfc, 0x36, 0x2c, 0x06, 0x51, 0x27, 0xce, 0x56, 0xa6, 0xf8, 0x6b, 0x2a, 0xd1, - 0x22, 0x31, 0x04, 0x17, 0x7b, 0x41, 0x2c, 0x0b, 0x93, 0xbe, 0x86, 0x2c, 0xfa, 0xa6, 0x03, 0x41, - 0x6f, 0x0e, 0x15, 0xf4, 0x75, 0xc5, 0x5f, 0x99, 0x7a, 0xfd, 0x7f, 0xc4, 0x74, 0x90, 0x79, 0xbf, - 0x74, 0xae, 0xa7, 0x3d, 0x01, 0x95, 0x86, 0xc6, 0xf8, 0x23, 0x37, 0xc1, 0xf1, 0x52, 0xa2, 0xe3, - 0x69, 0x1b, 0xb0, 0x26, 0xe5, 0xcd, 0x44, 0x3f, 0xa6, 0x7a, 0xed, 0x61, 0x36, 0x2c, 0x20, 0x95, - 0x99, 0x37, 0xaa, 0x64, 0x86, 0x8c, 0x4b, 0xa6, 0xa0, 0x40, 0xf2, 0x1e, 0xdd, 0x95, 0xc8, 0x9a, - 0xdd, 0xdd, 0xaf, 0x41, 0xb6, 0x1b, 0xcc, 0x51, 0xe8, 0xcd, 0xbd, 0xc0, 0x07, 0xc1, 0x09, 0x41, - 0xe9, 0x94, 0x42, 0xfb, 0x95, 0x02, 0xb3, 0x31, 0x30, 0x5a, 0x87, 0x99, 0xa8, 0x0d, 0x0e, 0xcb, - 0xe2, 0x08, 0x40, 0xce, 0xc0, 0x77, 0x7c, 0xb3, 0xcd, 0x5e, 0x9a, 0xd1, 0x07, 0xd2, 0xfe, 0x74, - 0x3d, 0x4c, 0x6b, 0x90, 0xb4, 0x1e, 0xfc, 0x47, 0xf7, 0x21, 0xd3, 0xb5, 0x2d, 0x5a, 0x00, 0xcf, - 0x8b, 0x61, 0x18, 0x88, 0x2a, 0x9c, 0xd8, 0x96, 0xaf, 0x07, 0x54, 0xda, 0x3d, 0xc8, 0x90, 0xa7, - 0xbe, 0x3a, 0x74, 0xe7, 0x71, 0xbd, 0x5c, 0xcb, 0x29, 0x08, 0x60, 0xb2, 0x52, 0x3d, 0xda, 0x2d, - 0xd7, 0x72, 0x29, 0x0d, 0x41, 0x8e, 0x6d, 0xbd, 0xd2, 0x0c, 0x7b, 0xf0, 0xfb, 0x70, 0x3d, 0x06, - 0x63, 0x56, 0x88, 0x4d, 0x4c, 0x95, 0xf8, 0xc4, 0x54, 0x5b, 0x8f, 0x8c, 0x27, 0xeb, 0xe7, 0x3f, - 0xa1, 0x87, 0x9a, 0xd4, 0xc9, 0x17, 0x85, 0x4e, 0x9e, 0x9a, 0x78, 0x83, 0xbb, 0x16, 0x87, 0xf4, - 0xf0, 0x7f, 0x51, 0xd8, 0xe5, 0xd5, 0xd7, 0xbd, 0xbf, 0x11, 0xef, 0xde, 0x6f, 0x0d, 0xe4, 0x19, - 0xef, 0xdb, 0x7f, 0xc8, 0xfa, 0xf6, 0xb7, 0xb9, 0xce, 0xe0, 0x95, 0xa1, 0xeb, 0xe3, 0x1d, 0x7b, - 0x29, 0xa1, 0x61, 0xaf, 0xd5, 0x8b, 0x7b, 0x65, 0xe3, 0xa4, 0x4a, 0x7f, 0xa3, 0x86, 0x7d, 0x11, - 0x72, 0xa4, 0x01, 0xa7, 0xcf, 0x46, 0xad, 0x5e, 0xe4, 0x3e, 0xcb, 0x59, 0x04, 0x14, 0x9e, 0x47, - 0xec, 0xa3, 0xaf, 0x2f, 0x14, 0x58, 0xe0, 0xc0, 0x43, 0x0e, 0x0a, 0x6d, 0xc1, 0x22, 0x29, 0x98, - 0xa9, 0xdf, 0x7b, 0x46, 0x07, 0xbb, 0x06, 0xc1, 0x30, 0xef, 0xbb, 0x7e, 0x61, 0x3e, 0x63, 0x53, - 0xb8, 0x63, 0xec, 0x12, 0xc6, 0x2f, 0x60, 0xee, 0xb4, 0xfd, 0x4f, 0x05, 0xa6, 0x2b, 0x4d, 0x6c, - 0xfb, 0xe4, 0x3c, 0xaa, 0x30, 0xc7, 0x7d, 0x39, 0x86, 0xd6, 0x13, 0x3e, 0x28, 0x0b, 0x36, 0xa8, - 0x6e, 0x0c, 0xfc, 0xdc, 0x4c, 0x9b, 0x40, 0xe7, 0xb1, 0xaf, 0xde, 0xb8, 0xe1, 0xdb, 0xcb, 0x7d, - 0x2b, 0x25, 0xae, 0xa9, 0xde, 0x19, 0x42, 0x15, 0xc9, 0x79, 0x13, 0xb2, 0xc1, 0x67, 0x50, 0x68, - 0x31, 0xfa, 0x40, 0x2b, 0xf6, 0x95, 0x94, 0xba, 0x24, 0x40, 0xc3, 0x75, 0xdb, 0xff, 0x9a, 0x02, - 0xe8, 0x4d, 0x79, 0xd0, 0x23, 0xb8, 0x16, 0xff, 0x9c, 0x03, 0xad, 0x0d, 0xf8, 0xea, 0x47, 0x5d, - 0x97, 0x23, 0x23, 0x9d, 0x1e, 0xc1, 0xb5, 0xf8, 0x9b, 0xc1, 0x1e, 0x33, 0xc9, 0x8b, 0xcc, 0x1e, - 0x33, 0xe9, 0xcb, 0xc4, 0x09, 0xd4, 0x86, 0x95, 0x84, 0x17, 0x3a, 0xe8, 0x95, 0xd1, 0xde, 0x86, - 0xa9, 0xaf, 0x8e, 0xf8, 0x66, 0x48, 0x9b, 0x40, 0x2e, 0xac, 0x26, 0xbe, 0x86, 0x40, 0x77, 0x47, - 0x7d, 0xb1, 0xa2, 0xbe, 0x36, 0x02, 0x65, 0x24, 0xb3, 0x0b, 0x6a, 0xf2, 0x44, 0x1d, 0xbd, 0x36, - 0xf2, 0xab, 0x04, 0xf5, 0xde, 0x28, 0xa4, 0x91, 0xd8, 0x7d, 0x98, 0x8d, 0x4d, 0xb7, 0x91, 0x2a, - 0x1d, 0x79, 0x53, 0xc6, 0x6b, 0x03, 0xc6, 0xe1, 0x94, 0x53, 0x6c, 0x02, 0xdb, 0xe3, 0xd4, 0x3f, - 0x4a, 0xee, 0x71, 0x92, 0x8c, 0x6c, 0x45, 0xf3, 0x0b, 0x79, 0x59, 0x66, 0x7e, 0x79, 0x62, 0x97, - 0x99, 0x3f, 0x21, 0xc9, 0x6b, 0x13, 0xe8, 0x9b, 0x30, 0xcf, 0x0f, 0x9d, 0xd0, 0xc6, 0xc0, 0x51, - 0x9a, 0x7a, 0x23, 0x09, 0x1d, 0x67, 0xc9, 0x4f, 0x0c, 0x7a, 0x2c, 0xa5, 0xe3, 0x8d, 0x1e, 0xcb, - 0x84, 0x41, 0xc3, 0x04, 0xc9, 0x4f, 0x5c, 0x37, 0xde, 0xcb, 0x4f, 0xb2, 0x01, 0x44, 0x2f, 0x3f, - 0x49, 0x5b, 0x78, 0x6d, 0x62, 0xfb, 0x0f, 0x59, 0xc8, 0x04, 0x89, 0xb4, 0x0e, 0x2f, 0x09, 0x4d, - 0x0d, 0xba, 0x31, 0xb8, 0xf3, 0x53, 0x6f, 0x26, 0xe2, 0x23, 0x75, 0x9f, 0xd0, 0x6b, 0x9a, 0x6b, - 0x53, 0xd0, 0x66, 0x7c, 0x9d, 0xac, 0x55, 0x52, 0x6f, 0x0d, 0xa0, 0x10, 0x79, 0xf3, 0xb9, 0x60, - 0x73, 0x58, 0xbd, 0xcc, 0xf3, 0x4e, 0x8a, 0xff, 0x4f, 0xe8, 0xbd, 0x25, 0x46, 0xbe, 0xc6, 0xeb, - 0x25, 0x8d, 0xf9, 0xdb, 0x03, 0x69, 0x22, 0x09, 0x1f, 0x47, 0x17, 0x66, 0xac, 0x9e, 0x43, 0x9c, - 0x72, 0xd2, 0x32, 0x52, 0xd5, 0x06, 0x91, 0x44, 0xec, 0xcb, 0x30, 0x13, 0xd5, 0x47, 0x28, 0x2f, - 0x2c, 0x89, 0xca, 0x28, 0x75, 0x55, 0x82, 0x61, 0x3c, 0xd2, 0x3f, 0x4a, 0x29, 0xa1, 0x1d, 0xc4, - 0x10, 0x14, 0x75, 0x90, 0x05, 0xdf, 0xed, 0x81, 0x34, 0xf1, 0xa4, 0x11, 0xab, 0x10, 0x7a, 0x49, - 0xa3, 0xbf, 0x9a, 0xe8, 0x25, 0x0d, 0x49, 0x49, 0xa1, 0x4d, 0xec, 0x64, 0x9f, 0xa4, 0x1b, 0x9e, - 0x75, 0x36, 0x19, 0x7c, 0xe8, 0xfb, 0x3f, 0xff, 0x0e, 0x00, 0x00, 0xff, 0xff, 0xc4, 0x16, 0x0e, - 0x54, 0xe8, 0x2e, 0x00, 0x00, + proto.RegisterFile("github.com/container-storage-interface/spec/csi.proto", fileDescriptor_csi_932e42b466eac230) +} + +var fileDescriptor_csi_932e42b466eac230 = []byte{ + // 3153 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xcc, 0x5a, 0x4d, 0x70, 0x23, 0x47, + 0xf5, 0xf7, 0xe8, 0xcb, 0xf6, 0xf3, 0xda, 0xd1, 0xb6, 0xbf, 0xb4, 0x63, 0x7b, 0xd7, 0x3b, 0x9b, + 0xdd, 0x6c, 0xf6, 0xbf, 0x2b, 0xe7, 0x6f, 0x48, 0x2a, 0x24, 0x9b, 0x80, 0x2c, 0x2b, 0xb6, 0xb2, + 0xb6, 0x6c, 0x46, 0xb2, 0x53, 0xbb, 0x24, 0x35, 0x19, 0x4b, 0x6d, 0xed, 0x10, 0x79, 0x46, 0x99, + 0x19, 0x99, 0x35, 0x37, 0xa0, 0x8a, 0x02, 0x6e, 0x5c, 0xb9, 0x50, 0x95, 0x1b, 0x14, 0x29, 0x2e, + 0xdc, 0xa8, 0x82, 0x13, 0x55, 0x9c, 0x38, 0x73, 0x82, 0x33, 0x55, 0x1c, 0xe1, 0x02, 0x45, 0x15, + 0xd5, 0xd3, 0x3d, 0xa3, 0xe9, 0x56, 0x8f, 0x2c, 0x65, 0xb7, 0x52, 0x9c, 0xa4, 0x79, 0xef, 0xf5, + 0xeb, 0xd7, 0xaf, 0xdf, 0x7b, 0xfd, 0xfa, 0x37, 0x03, 0xaf, 0xb7, 0x2d, 0xff, 0x69, 0xef, 0xa4, + 0xd8, 0x74, 0xce, 0x36, 0x9a, 0x8e, 0xed, 0x9b, 0x96, 0x8d, 0xdd, 0x07, 0x9e, 0xef, 0xb8, 0x66, + 0x1b, 0x3f, 0xb0, 0x6c, 0x1f, 0xbb, 0xa7, 0x66, 0x13, 0x6f, 0x78, 0x5d, 0xdc, 0xdc, 0x68, 0x7a, + 0x56, 0xb1, 0xeb, 0x3a, 0xbe, 0x83, 0x72, 0xe4, 0xef, 0xf9, 0x6b, 0xea, 0xf5, 0xb6, 0xe3, 0xb4, + 0x3b, 0x78, 0x23, 0xa0, 0x9e, 0xf4, 0x4e, 0x37, 0xbe, 0xe3, 0x9a, 0xdd, 0x2e, 0x76, 0x3d, 0x2a, + 0xa7, 0x2d, 0xc1, 0xc2, 0x0e, 0xf6, 0x0f, 0x3b, 0xbd, 0xb6, 0x65, 0x57, 0xed, 0x53, 0x47, 0xc7, + 0x9f, 0xf6, 0xb0, 0xe7, 0x6b, 0x7f, 0x56, 0x60, 0x51, 0x60, 0x78, 0x5d, 0xc7, 0xf6, 0x30, 0x42, + 0x90, 0xb1, 0xcd, 0x33, 0x5c, 0x50, 0xd6, 0x95, 0xbb, 0xd3, 0x7a, 0xf0, 0x1f, 0xdd, 0x86, 0xb9, + 0x73, 0x6c, 0xb7, 0x1c, 0xd7, 0x38, 0xc7, 0xae, 0x67, 0x39, 0x76, 0x21, 0x15, 0x70, 0x67, 0x29, + 0xf5, 0x98, 0x12, 0xd1, 0x0e, 0x4c, 0x9d, 0x99, 0xb6, 0x75, 0x8a, 0x3d, 0xbf, 0x90, 0x5e, 0x4f, + 0xdf, 0x9d, 0xd9, 0xfc, 0xbf, 0x22, 0xb5, 0xb3, 0x28, 0x9d, 0xab, 0xb8, 0xcf, 0xa4, 0x2b, 0xb6, + 0xef, 0x5e, 0xe8, 0xd1, 0x60, 0xf5, 0x6d, 0x98, 0xe5, 0x58, 0x28, 0x0f, 0xe9, 0x4f, 0xf0, 0x05, + 0xb3, 0x89, 0xfc, 0x45, 0x0b, 0x90, 0x3d, 0x37, 0x3b, 0x3d, 0xcc, 0x2c, 0xa1, 0x0f, 0x6f, 0xa5, + 0xde, 0x54, 0xb4, 0xeb, 0xb0, 0x1a, 0xcd, 0x56, 0x36, 0xbb, 0xe6, 0x89, 0xd5, 0xb1, 0x7c, 0x0b, + 0x7b, 0xe1, 0xd2, 0x3f, 0x82, 0xb5, 0x04, 0x3e, 0xf3, 0xc0, 0x43, 0xb8, 0xd2, 0x8c, 0xd1, 0x0b, + 0xa9, 0x60, 0x29, 0x85, 0x70, 0x29, 0xc2, 0xc8, 0x0b, 0x9d, 0x93, 0xd6, 0x7e, 0x96, 0x82, 0xbc, + 0x28, 0x82, 0x1e, 0xc2, 0xa4, 0x87, 0xdd, 0x73, 0xab, 0x49, 0xfd, 0x3a, 0xb3, 0xb9, 0x9e, 0xa4, + 0xad, 0x58, 0xa7, 0x72, 0xbb, 0x13, 0x7a, 0x38, 0x44, 0xfd, 0xbd, 0x02, 0x93, 0x8c, 0x8c, 0xbe, + 0x06, 0x19, 0xff, 0xa2, 0x4b, 0xd5, 0xcc, 0x6d, 0xde, 0xbe, 0x4c, 0x4d, 0xb1, 0x71, 0xd1, 0xc5, + 0x7a, 0x30, 0x44, 0xbb, 0x80, 0x0c, 0x79, 0x42, 0x33, 0x30, 0x79, 0x54, 0x7b, 0x54, 0x3b, 0xf8, + 0xa0, 0x96, 0x9f, 0x40, 0x4b, 0x80, 0xca, 0x07, 0xb5, 0x86, 0x7e, 0xb0, 0xb7, 0x57, 0xd1, 0x8d, + 0x7a, 0x45, 0x3f, 0xae, 0x96, 0x2b, 0x79, 0x05, 0xbd, 0x0c, 0xeb, 0xc7, 0x07, 0x7b, 0x47, 0xfb, + 0x15, 0xa3, 0x54, 0x2e, 0x57, 0xea, 0xf5, 0xea, 0x56, 0x75, 0xaf, 0xda, 0x78, 0x6c, 0x94, 0x0f, + 0x6a, 0xf5, 0x86, 0x5e, 0xaa, 0xd6, 0x1a, 0xf5, 0x7c, 0x0a, 0xdd, 0x01, 0xad, 0x5e, 0x2b, 0x1d, + 0xd6, 0x77, 0x0f, 0x1a, 0x43, 0xe4, 0xd2, 0x5b, 0x39, 0x6a, 0xb5, 0x36, 0x07, 0x57, 0x0e, 0x5d, + 0xe7, 0x04, 0x87, 0x7b, 0x51, 0x82, 0x59, 0xf6, 0xcc, 0x7c, 0xff, 0x1a, 0x64, 0x5d, 0x6c, 0xb6, + 0x2e, 0x98, 0x9b, 0xd4, 0x22, 0x8d, 0xef, 0x62, 0x18, 0xdf, 0xc5, 0x2d, 0xc7, 0xe9, 0x1c, 0x93, + 0xbd, 0xd6, 0xa9, 0xa0, 0xf6, 0x79, 0x16, 0xe6, 0xcb, 0x2e, 0x36, 0x7d, 0x7c, 0xec, 0x74, 0x7a, + 0x67, 0xa1, 0x6a, 0x69, 0x1c, 0x3f, 0x84, 0x39, 0xb2, 0x57, 0x4d, 0xcb, 0xbf, 0x30, 0x5c, 0xd3, + 0x6e, 0xd3, 0xe8, 0x99, 0xd9, 0x5c, 0x0c, 0xdd, 0x58, 0x66, 0x5c, 0x9d, 0x30, 0xf5, 0xd9, 0x66, + 0xfc, 0x11, 0x55, 0x61, 0xfe, 0x3c, 0x98, 0xc2, 0xe0, 0xc2, 0x23, 0xcd, 0x87, 0x07, 0xb5, 0x22, + 0x16, 0x1e, 0xe8, 0x9c, 0xa7, 0x58, 0xd8, 0x43, 0x8f, 0x00, 0xba, 0xa6, 0x6b, 0x9e, 0x61, 0x1f, + 0xbb, 0x5e, 0x21, 0xc3, 0xe7, 0x8a, 0x64, 0x35, 0xc5, 0xc3, 0x48, 0x9a, 0xe6, 0x4a, 0x6c, 0x38, + 0xf2, 0xe1, 0x1a, 0xa9, 0x1c, 0xae, 0xd3, 0xe9, 0x60, 0xd7, 0x68, 0x06, 0xa3, 0x0d, 0x0f, 0x37, + 0x5d, 0xec, 0x7b, 0x85, 0x6c, 0xa0, 0xfb, 0xcd, 0x61, 0xba, 0xcb, 0xd1, 0x60, 0xca, 0xad, 0xd3, + 0xa1, 0x74, 0xa2, 0xe5, 0xa6, 0x9c, 0x8b, 0x0e, 0x60, 0x31, 0xf4, 0x86, 0x63, 0xfb, 0xd8, 0xf6, + 0x0d, 0xcf, 0xe9, 0xb9, 0x4d, 0x5c, 0xc8, 0x05, 0x2e, 0x5d, 0x11, 0xfc, 0x41, 0x65, 0xea, 0x81, + 0x88, 0xce, 0xfc, 0xc8, 0x11, 0xd1, 0x13, 0x50, 0xcd, 0x66, 0x13, 0x7b, 0x9e, 0x45, 0x1d, 0x67, + 0xb8, 0xf8, 0xd3, 0x9e, 0xe5, 0xe2, 0x33, 0x6c, 0xfb, 0x5e, 0x61, 0x92, 0xd7, 0xda, 0x70, 0xba, + 0x4e, 0xc7, 0x69, 0x5f, 0xe8, 0x7d, 0x19, 0xfd, 0x1a, 0x37, 0x3c, 0xc6, 0xf1, 0xd4, 0x77, 0xe0, + 0x25, 0xc1, 0x83, 0xe3, 0x94, 0x14, 0xf5, 0x7d, 0x58, 0x1d, 0xe6, 0xa4, 0xb1, 0xca, 0xd3, 0x8f, + 0x15, 0x98, 0x97, 0xf8, 0x04, 0xed, 0xc2, 0x94, 0x67, 0x9b, 0x5d, 0xef, 0xa9, 0xe3, 0xb3, 0xe0, + 0xbf, 0x37, 0xc4, 0x85, 0xc5, 0x3a, 0x93, 0xa5, 0x8f, 0xbb, 0x13, 0x7a, 0x34, 0x5a, 0x5d, 0x87, + 0x39, 0x9e, 0x8b, 0xe6, 0x20, 0x65, 0xb5, 0x98, 0x79, 0x29, 0xab, 0x15, 0xa5, 0xe3, 0xbb, 0xb0, + 0xc0, 0x07, 0x04, 0xcb, 0xc2, 0x3b, 0x90, 0xa3, 0x3b, 0xc4, 0x2c, 0x99, 0xe3, 0x2d, 0xd1, 0x19, + 0x57, 0xfb, 0x65, 0x06, 0xf2, 0x62, 0xbc, 0xa3, 0x87, 0x90, 0x3d, 0xe9, 0x38, 0xcd, 0x4f, 0xd8, + 0xd8, 0x97, 0x93, 0x12, 0xa3, 0xb8, 0x45, 0xa4, 0x28, 0x75, 0x77, 0x42, 0xa7, 0x83, 0xc8, 0xe8, + 0x33, 0xa7, 0x67, 0xfb, 0x2c, 0x33, 0x93, 0x47, 0xef, 0x13, 0xa9, 0xfe, 0xe8, 0x60, 0x10, 0xda, + 0x86, 0x19, 0x1a, 0x04, 0xc6, 0x99, 0xd3, 0xc2, 0x85, 0x74, 0xa0, 0xe3, 0x56, 0xa2, 0x8e, 0x52, + 0x20, 0xbb, 0xef, 0xb4, 0xb0, 0x0e, 0x66, 0xf4, 0x5f, 0x9d, 0x85, 0x99, 0x98, 0x6d, 0xea, 0x0e, + 0xcc, 0xc4, 0x26, 0x43, 0xcb, 0x30, 0x79, 0xea, 0x19, 0x51, 0x11, 0x9e, 0xd6, 0x73, 0xa7, 0x5e, + 0x50, 0x57, 0x6f, 0xc0, 0x4c, 0x60, 0x85, 0x71, 0xda, 0x31, 0xdb, 0xf4, 0xd8, 0x98, 0xd6, 0x21, + 0x20, 0xbd, 0x47, 0x28, 0xea, 0xdf, 0x15, 0x80, 0xfe, 0x94, 0xe8, 0x21, 0x64, 0x02, 0x2b, 0x69, + 0x29, 0xbf, 0x3b, 0x82, 0x95, 0xc5, 0xc0, 0xd4, 0x60, 0x94, 0xf6, 0x73, 0x05, 0x32, 0x81, 0x1a, + 0xb1, 0x9c, 0xd7, 0xab, 0xb5, 0x9d, 0xbd, 0x8a, 0x51, 0x3b, 0xd8, 0xae, 0x18, 0x1f, 0xe8, 0xd5, + 0x46, 0x45, 0xcf, 0x2b, 0x68, 0x05, 0x96, 0xe3, 0x74, 0xbd, 0x52, 0xda, 0xae, 0xe8, 0xc6, 0x41, + 0x6d, 0xef, 0x71, 0x3e, 0x85, 0x54, 0x58, 0xda, 0x3f, 0xda, 0x6b, 0x54, 0x07, 0x79, 0x69, 0xb4, + 0x0a, 0x85, 0x18, 0x8f, 0xe9, 0x60, 0x6a, 0x33, 0x44, 0x6d, 0x8c, 0x4b, 0xff, 0x32, 0x66, 0x76, + 0x6b, 0x36, 0xda, 0x8c, 0x20, 0xd8, 0x3e, 0x80, 0x59, 0xae, 0xbc, 0x92, 0xae, 0x82, 0xa5, 0x78, + 0xcb, 0x38, 0xb9, 0xf0, 0xb1, 0x17, 0x78, 0x22, 0xad, 0xcf, 0x86, 0xd4, 0x2d, 0x42, 0x24, 0x6e, + 0xed, 0x58, 0x67, 0x96, 0xcf, 0x64, 0x52, 0x81, 0x0c, 0x04, 0xa4, 0x40, 0x40, 0xfb, 0x43, 0x0a, + 0x72, 0x6c, 0x6f, 0x6e, 0xc7, 0x0a, 0x3c, 0xa7, 0x32, 0xa4, 0x52, 0x95, 0x34, 0x1f, 0x52, 0x61, + 0x3e, 0xa0, 0x77, 0x01, 0x4c, 0xdf, 0x77, 0xad, 0x93, 0x9e, 0x1f, 0x15, 0xf4, 0xeb, 0xfc, 0x7e, + 0x14, 0x4b, 0x91, 0x00, 0xab, 0xc0, 0xfd, 0x11, 0x68, 0x0b, 0xe6, 0x84, 0x22, 0x98, 0xb9, 0xbc, + 0x08, 0xce, 0x36, 0xb9, 0xfc, 0x2f, 0xc1, 0x7c, 0x58, 0xbf, 0x3a, 0xd8, 0xf0, 0x59, 0x7d, 0x63, + 0xf5, 0x3b, 0x3f, 0x50, 0xf7, 0x50, 0x5f, 0x38, 0xa4, 0x91, 0x2a, 0x27, 0x58, 0x39, 0x56, 0x65, + 0xea, 0xc1, 0xbc, 0xa4, 0xac, 0xa2, 0x22, 0x4c, 0x07, 0x1b, 0xe2, 0x59, 0x3e, 0x89, 0x55, 0xb9, + 0x39, 0x7d, 0x11, 0x22, 0xdf, 0x75, 0xf1, 0x29, 0x76, 0x5d, 0xdc, 0x62, 0xbd, 0x93, 0x44, 0x3e, + 0x12, 0xd1, 0x7e, 0xa0, 0xc0, 0x54, 0x48, 0x47, 0x6f, 0xc1, 0x94, 0x87, 0xdb, 0xb4, 0xe4, 0x2b, + 0xfc, 0x3e, 0x84, 0x32, 0xc5, 0x3a, 0x13, 0x60, 0x5d, 0x63, 0x28, 0x4f, 0xba, 0x46, 0x8e, 0x35, + 0xd6, 0xe2, 0xff, 0xa1, 0xc0, 0xfc, 0x36, 0xee, 0x60, 0xb1, 0x8d, 0x58, 0x81, 0x69, 0x76, 0xcc, + 0x45, 0x15, 0x74, 0x8a, 0x12, 0xaa, 0x2d, 0xe1, 0xe4, 0x6d, 0x05, 0xc3, 0xa3, 0x93, 0x37, 0xc5, + 0x9f, 0xbc, 0x12, 0xe5, 0xb1, 0x93, 0x97, 0x72, 0x93, 0x4e, 0x5e, 0x8e, 0xcb, 0x9f, 0x46, 0x83, + 0x03, 0xc7, 0x5a, 0xf6, 0x12, 0x2c, 0xf0, 0x86, 0xd1, 0x13, 0x40, 0xfb, 0x6d, 0x06, 0xae, 0xf7, + 0x27, 0x39, 0xec, 0x9d, 0x74, 0x2c, 0xef, 0xe9, 0x18, 0x9e, 0x59, 0x86, 0x49, 0xdb, 0x69, 0x05, + 0x2c, 0x3a, 0x67, 0x8e, 0x3c, 0x56, 0x5b, 0xa8, 0x02, 0x57, 0xc5, 0x26, 0xea, 0x82, 0xd5, 0xe9, + 0xe4, 0x16, 0x2a, 0x7f, 0x2e, 0x1e, 0x32, 0x2a, 0x4c, 0x91, 0xf6, 0xcf, 0xb1, 0x3b, 0x17, 0x41, + 0xae, 0x4d, 0xe9, 0xd1, 0x33, 0xfa, 0xbe, 0x02, 0x6a, 0x6c, 0x5b, 0xba, 0xd4, 0x78, 0xa1, 0x23, + 0xda, 0x8e, 0x3a, 0xa2, 0xa1, 0xab, 0x1c, 0x64, 0x73, 0x7b, 0x54, 0x68, 0x26, 0xb0, 0x91, 0x15, + 0xad, 0x33, 0x56, 0x59, 0x72, 0xc1, 0xd4, 0x0f, 0x47, 0x9c, 0x9a, 0x3e, 0x89, 0x75, 0x87, 0xf9, + 0xa2, 0x4f, 0x56, 0x1f, 0xc1, 0xda, 0x50, 0x2b, 0xc7, 0x6a, 0x75, 0xca, 0xb0, 0x28, 0x9d, 0x77, + 0xac, 0xa8, 0xfa, 0x9d, 0x02, 0x37, 0x12, 0x17, 0xc7, 0x7a, 0x8c, 0x6f, 0xc1, 0x95, 0x70, 0x67, + 0x2c, 0xfb, 0xd4, 0x61, 0xd9, 0xfe, 0xe6, 0xa5, 0xbe, 0x61, 0x57, 0x47, 0x46, 0x25, 0xd7, 0x49, + 0xea, 0x97, 0x99, 0x6e, 0x9f, 0xa2, 0xbe, 0x0b, 0x79, 0x51, 0x60, 0xac, 0x05, 0xfc, 0x26, 0x05, + 0xeb, 0x7d, 0x0b, 0x8e, 0xec, 0xee, 0x8b, 0x4b, 0x80, 0x9f, 0x28, 0xb0, 0x1a, 0x8b, 0xce, 0x9e, + 0x2d, 0xc6, 0x27, 0x3d, 0x7e, 0x76, 0x07, 0x1d, 0x21, 0x37, 0x43, 0x26, 0xc0, 0xc5, 0x68, 0x2c, + 0x17, 0x44, 0x01, 0x75, 0x3f, 0xbe, 0x4f, 0xd2, 0xe1, 0x63, 0xb9, 0xed, 0x16, 0xdc, 0x1c, 0x62, + 0x2e, 0x2b, 0x2d, 0xdf, 0x4b, 0xc3, 0xcd, 0x63, 0xb3, 0x63, 0xb5, 0xa2, 0xbe, 0x53, 0x72, 0x4b, + 0x1f, 0xee, 0xdc, 0x84, 0x9b, 0x58, 0xea, 0x0b, 0xdc, 0xc4, 0x3a, 0xb2, 0x3c, 0xa5, 0x5b, 0xf0, + 0xf5, 0x48, 0xd1, 0x65, 0xd6, 0x8e, 0x9a, 0xaa, 0x49, 0x87, 0x7c, 0x66, 0x8c, 0x43, 0xfe, 0x85, + 0x24, 0xe8, 0x87, 0xa0, 0x0d, 0x5b, 0x14, 0x4b, 0xd1, 0x55, 0x98, 0xf6, 0x7a, 0xdd, 0xae, 0xe3, + 0xfa, 0x98, 0xee, 0xc1, 0x94, 0xde, 0x27, 0xa0, 0x02, 0x4c, 0x9e, 0x61, 0xcf, 0x33, 0xdb, 0xa1, + 0xfe, 0xf0, 0x51, 0xfb, 0x10, 0xd0, 0x9e, 0xe5, 0xb1, 0x7e, 0x39, 0xda, 0x51, 0xd2, 0x1e, 0x9b, + 0xcf, 0x0c, 0x6c, 0xfb, 0xae, 0xc5, 0x1a, 0xb3, 0xac, 0x0e, 0x67, 0xe6, 0xb3, 0x0a, 0xa5, 0x90, + 0xe6, 0xcd, 0xf3, 0x4d, 0xd7, 0xb7, 0xec, 0xb6, 0xe1, 0x3b, 0x9f, 0xe0, 0x08, 0x65, 0x0a, 0xa9, + 0x0d, 0x42, 0xd4, 0x3e, 0x53, 0x60, 0x9e, 0x53, 0xcf, 0xac, 0x7d, 0x1b, 0x26, 0xfb, 0xba, 0x89, + 0x3f, 0x6f, 0x86, 0xfe, 0x94, 0x48, 0x17, 0xe9, 0x0e, 0x85, 0x23, 0xd0, 0x1a, 0x80, 0x8d, 0x9f, + 0xf9, 0xdc, 0xbc, 0xd3, 0x84, 0x12, 0xcc, 0xa9, 0x6e, 0x40, 0x96, 0x3a, 0x79, 0xd4, 0x9b, 0xd1, + 0xe7, 0x29, 0x40, 0x3b, 0xd8, 0x8f, 0x1a, 0x5e, 0xe6, 0x83, 0x84, 0xc0, 0x55, 0xbe, 0x40, 0xe0, + 0xbe, 0xcf, 0x41, 0x08, 0x34, 0xf4, 0xef, 0xc5, 0xe0, 0x36, 0x61, 0xea, 0xa1, 0x08, 0x42, 0x42, + 0x58, 0xd2, 0x63, 0x79, 0xe4, 0xde, 0xf3, 0x39, 0x6e, 0xd8, 0xda, 0x36, 0xcc, 0x73, 0x36, 0xb3, + 0x3d, 0x7d, 0x00, 0xc8, 0x3c, 0x37, 0xad, 0x8e, 0x49, 0xec, 0x0a, 0x7b, 0x78, 0xd6, 0xd3, 0x5f, + 0x8d, 0x38, 0xe1, 0x30, 0x4d, 0x8b, 0x57, 0x6d, 0xa6, 0x4f, 0x84, 0xff, 0x3a, 0xf1, 0x1a, 0x35, + 0x20, 0xc3, 0xe6, 0xdd, 0x91, 0x42, 0x80, 0xb7, 0x06, 0x6b, 0x32, 0x83, 0xd9, 0x12, 0xd1, 0xc0, + 0x3f, 0xa5, 0x60, 0x65, 0x88, 0x34, 0x7a, 0x1b, 0xd2, 0x6e, 0xb7, 0xc9, 0x82, 0xe9, 0x95, 0x11, + 0xf4, 0x17, 0xf5, 0xc3, 0xf2, 0xee, 0x84, 0x4e, 0x46, 0xa9, 0x7f, 0x53, 0x20, 0xad, 0x1f, 0x96, + 0xd1, 0x37, 0x38, 0x4c, 0xf0, 0xfe, 0x88, 0x5a, 0xe2, 0xd0, 0x20, 0xb9, 0x4c, 0x0e, 0x62, 0x83, + 0x05, 0x58, 0x28, 0xeb, 0x95, 0x52, 0xa3, 0x62, 0x6c, 0x57, 0xf6, 0x2a, 0x8d, 0x8a, 0x41, 0x11, + 0xc1, 0xbc, 0x42, 0x6e, 0x85, 0x87, 0x47, 0x5b, 0x7b, 0xd5, 0xfa, 0xae, 0x71, 0x54, 0x0b, 0xff, + 0x31, 0x6e, 0x0a, 0xe5, 0xe1, 0xca, 0x5e, 0xb5, 0xde, 0x60, 0x84, 0x7a, 0x3e, 0x4d, 0x28, 0x3b, + 0x95, 0x86, 0x51, 0x2e, 0x1d, 0x96, 0xca, 0xd5, 0xc6, 0xe3, 0x7c, 0x86, 0xdc, 0x39, 0x79, 0xdd, + 0x21, 0x8e, 0x98, 0xcf, 0x22, 0x04, 0x73, 0xc1, 0xf8, 0x90, 0x54, 0xcf, 0xe7, 0x22, 0xc8, 0xe2, + 0xdf, 0x69, 0x58, 0x64, 0x08, 0x0c, 0xc3, 0x38, 0xc2, 0xdc, 0xba, 0x0b, 0x79, 0x7a, 0xf9, 0x32, + 0xc4, 0x83, 0x63, 0x8e, 0xd2, 0x8f, 0xc3, 0xe3, 0x23, 0x84, 0x06, 0x53, 0x31, 0x68, 0xb0, 0x0b, + 0xcb, 0x21, 0x72, 0xc6, 0xf4, 0x0a, 0x07, 0xb2, 0x00, 0xa1, 0x09, 0xb3, 0x0b, 0x54, 0xee, 0x00, + 0x5e, 0x6c, 0xca, 0x78, 0x68, 0x5f, 0x82, 0x01, 0x3e, 0x18, 0x3e, 0xc9, 0xb0, 0x1c, 0x1e, 0x0e, + 0x9f, 0x65, 0x9f, 0x0b, 0x3e, 0xdb, 0x05, 0x35, 0x79, 0x7d, 0x63, 0xb5, 0x97, 0xcf, 0x59, 0x26, + 0xde, 0x83, 0x25, 0xd1, 0x33, 0x2c, 0x63, 0xef, 0x0f, 0xc0, 0x67, 0x51, 0xdd, 0x8a, 0x64, 0x23, + 0x09, 0xed, 0x9f, 0x0a, 0x4c, 0x85, 0x64, 0x52, 0xfb, 0x3d, 0xeb, 0xbb, 0x98, 0x03, 0x0c, 0xa6, + 0x09, 0x45, 0x0e, 0x16, 0xc8, 0xe2, 0x2c, 0x2d, 0x8d, 0xb3, 0x35, 0x00, 0xba, 0xf5, 0x2d, 0xc3, + 0xf4, 0x83, 0x6b, 0x4a, 0x5a, 0x9f, 0x66, 0x94, 0x12, 0xb9, 0x58, 0xe7, 0x3c, 0xdf, 0xf4, 0x7b, + 0xe1, 0xee, 0x2c, 0x89, 0x06, 0xd7, 0x03, 0xae, 0xce, 0xa4, 0x92, 0xaa, 0x74, 0x6e, 0xf4, 0xe6, + 0x81, 0xe4, 0xf9, 0x1c, 0xaf, 0x1d, 0x6d, 0x70, 0xc5, 0x63, 0x45, 0x6e, 0x43, 0xac, 0x56, 0x90, + 0x73, 0xbf, 0x85, 0x7d, 0xd3, 0xea, 0x78, 0xe1, 0xb9, 0xcf, 0x1e, 0xb5, 0x2d, 0x59, 0x11, 0x99, + 0x86, 0xac, 0x5e, 0x29, 0x6d, 0x3f, 0xce, 0x2b, 0x68, 0x16, 0xa6, 0x8f, 0x0e, 0xf7, 0x0e, 0x4a, + 0xdb, 0xd5, 0xda, 0x4e, 0x3e, 0x85, 0xe6, 0xe1, 0xa5, 0x8a, 0xae, 0x1f, 0xe8, 0x46, 0x9f, 0x98, + 0x26, 0xf7, 0xf0, 0x45, 0x76, 0xa7, 0x15, 0xf2, 0xfb, 0x06, 0xcc, 0x44, 0xa9, 0x19, 0xa5, 0x36, + 0x84, 0xa4, 0x6a, 0x8b, 0xa4, 0x70, 0x78, 0x05, 0x17, 0x53, 0x58, 0x7a, 0x17, 0x17, 0xb3, 0x8b, + 0xa7, 0xf2, 0x29, 0xdc, 0x92, 0xf1, 0x48, 0x5e, 0x24, 0x0f, 0x1a, 0x2b, 0xb0, 0x0b, 0xb0, 0x24, + 0x1a, 0xc5, 0xda, 0xe5, 0x5f, 0x28, 0xb0, 0x40, 0x1a, 0x98, 0x90, 0xf1, 0xa2, 0xfb, 0xa9, 0x31, + 0xe2, 0x59, 0xd8, 0x81, 0x8c, 0xb8, 0x03, 0xda, 0xaf, 0x14, 0x58, 0x14, 0x6c, 0x65, 0xe9, 0xf9, + 0x8e, 0xd8, 0x9c, 0xdd, 0x8a, 0x37, 0x67, 0x03, 0xf2, 0x63, 0xb6, 0x67, 0xaf, 0x87, 0xed, 0xd9, + 0x78, 0x55, 0xe0, 0xa7, 0x59, 0x58, 0xaa, 0x39, 0x2d, 0x5c, 0xf7, 0xcd, 0xf6, 0x38, 0xb0, 0x8f, + 0x2e, 0x5c, 0x5d, 0x69, 0x74, 0x6d, 0x84, 0x33, 0xc9, 0x55, 0x0e, 0xbf, 0xb1, 0xa2, 0x22, 0xcc, + 0x7b, 0xbe, 0xd9, 0x0e, 0xf6, 0xca, 0x74, 0xdb, 0xd8, 0x37, 0xba, 0xa6, 0xff, 0x94, 0x6d, 0xc4, + 0x55, 0xc6, 0x6a, 0x04, 0x9c, 0x43, 0xd3, 0x7f, 0x2a, 0xc7, 0x51, 0x32, 0x63, 0xe3, 0x28, 0x27, + 0x80, 0x82, 0x6b, 0x2a, 0x99, 0x40, 0x7c, 0x69, 0xf4, 0xd5, 0x4b, 0x16, 0x14, 0x91, 0xb9, 0x54, + 0xc9, 0xdb, 0x02, 0x19, 0x99, 0xc9, 0x50, 0xc8, 0x65, 0x53, 0x8c, 0x0a, 0x81, 0x3c, 0xe7, 0x7d, + 0x9f, 0x5c, 0xaa, 0xa4, 0xab, 0xf9, 0xf2, 0xa1, 0x93, 0x6b, 0xb0, 0x3c, 0xe0, 0x0b, 0x56, 0x09, + 0xda, 0x50, 0x20, 0xac, 0x23, 0xdb, 0x1b, 0x33, 0x5e, 0x13, 0x62, 0x2b, 0x95, 0x10, 0x5b, 0xda, + 0x0a, 0x5c, 0x93, 0x4c, 0xc4, 0xac, 0xf8, 0x4b, 0x96, 0x9a, 0x31, 0x3e, 0x26, 0xd8, 0x90, 0xa6, + 0xcd, 0xff, 0xc7, 0x43, 0x40, 0x8a, 0x83, 0xbd, 0xd8, 0xc4, 0xb9, 0x01, 0x33, 0x71, 0x39, 0x56, + 0xc4, 0xfc, 0x4b, 0x32, 0x2b, 0xfb, 0x5c, 0x08, 0x65, 0x4e, 0x40, 0x28, 0xbf, 0x0d, 0x0b, 0x41, + 0xd6, 0x89, 0xd0, 0xcf, 0x24, 0x7f, 0x4c, 0x25, 0x7a, 0x24, 0xc6, 0xe0, 0x72, 0x2f, 0xc8, 0x65, + 0x01, 0x88, 0x6c, 0xca, 0xb2, 0x6f, 0x2a, 0x98, 0xe8, 0x8d, 0x4b, 0x27, 0xfa, 0xb2, 0xf2, 0xaf, + 0x42, 0xa3, 0xfe, 0x7f, 0x02, 0xbc, 0x64, 0xd1, 0x2f, 0x85, 0x1d, 0xb5, 0x27, 0xa0, 0xd2, 0xd4, + 0x18, 0x1f, 0x11, 0x14, 0x02, 0x2f, 0x25, 0x06, 0x9e, 0xb6, 0x06, 0x2b, 0x52, 0xdd, 0x6c, 0xea, + 0xc7, 0xd4, 0xae, 0x1d, 0xcc, 0xb0, 0x0c, 0xd2, 0x99, 0x79, 0xa3, 0xce, 0xcc, 0x98, 0xf1, 0x99, + 0x29, 0x29, 0x98, 0x79, 0x87, 0xae, 0x4a, 0x54, 0xcd, 0xce, 0xee, 0x57, 0x21, 0xdb, 0x0b, 0x60, + 0x1e, 0x7a, 0x72, 0xcf, 0xf3, 0x49, 0x70, 0x44, 0x58, 0x3a, 0x95, 0xd0, 0x7e, 0xad, 0xc0, 0x4c, + 0x8c, 0x8c, 0x56, 0x61, 0x3a, 0xba, 0xa5, 0x87, 0x9d, 0x75, 0x44, 0x20, 0x7b, 0xe0, 0x3b, 0xbe, + 0xd9, 0x61, 0xef, 0xf4, 0xe8, 0x03, 0xb9, 0x9d, 0xf5, 0x3c, 0x4c, 0x7b, 0x90, 0xb4, 0x1e, 0xfc, + 0x47, 0xf7, 0x21, 0xd3, 0xb3, 0x2d, 0xda, 0x43, 0xcf, 0x89, 0x69, 0x18, 0x4c, 0x55, 0x3c, 0xb2, + 0x2d, 0x5f, 0x0f, 0xa4, 0xb4, 0x7b, 0x90, 0x21, 0x4f, 0x03, 0x7d, 0xe8, 0xd6, 0xe3, 0x46, 0xa5, + 0x9e, 0x57, 0x10, 0x40, 0xae, 0x5a, 0x3b, 0xd8, 0xae, 0xd4, 0xf3, 0x29, 0x0d, 0x41, 0x9e, 0x2d, + 0xbd, 0xda, 0x0a, 0x21, 0x82, 0xfb, 0x70, 0x35, 0x46, 0x63, 0x5e, 0x88, 0x01, 0xba, 0x4a, 0x1c, + 0xd0, 0xd5, 0x56, 0x23, 0xe7, 0xc9, 0xe0, 0x86, 0x8f, 0xe9, 0xa6, 0x26, 0x01, 0x0d, 0x25, 0x01, + 0x68, 0xa0, 0x2e, 0x5e, 0xe3, 0x8e, 0xc5, 0x4b, 0x20, 0x86, 0xbf, 0x2a, 0xec, 0xf0, 0x1a, 0x00, + 0x17, 0x5e, 0x8f, 0x83, 0x0b, 0x37, 0x87, 0xea, 0x8c, 0xc3, 0x0a, 0x3f, 0x64, 0xb0, 0xc2, 0x5b, + 0xdc, 0xcd, 0xe0, 0xce, 0xa5, 0xe3, 0xe3, 0x80, 0x42, 0x39, 0x01, 0x4f, 0xa8, 0x37, 0x4a, 0x3b, + 0x15, 0xe3, 0xa8, 0x46, 0x7f, 0x23, 0x3c, 0x61, 0x01, 0xf2, 0x3b, 0x95, 0x10, 0x30, 0x30, 0xea, + 0x8d, 0x52, 0xa3, 0x9e, 0x4f, 0x45, 0x77, 0xfe, 0x05, 0x40, 0xe1, 0x7e, 0xc4, 0x3e, 0x61, 0xfb, + 0x4c, 0x81, 0x79, 0x8e, 0x7c, 0xc9, 0x46, 0xa1, 0x0d, 0x58, 0x20, 0x0d, 0x33, 0x8d, 0x7b, 0xcf, + 0xe8, 0x62, 0xd7, 0x20, 0x1c, 0x16, 0x7d, 0x57, 0xcf, 0xcc, 0x67, 0x0c, 0x24, 0x3c, 0xc4, 0x2e, + 0x51, 0xfc, 0x02, 0x60, 0xb1, 0xcd, 0x7f, 0x29, 0x30, 0x55, 0x6d, 0x61, 0xdb, 0x27, 0xfb, 0x51, + 0x83, 0x59, 0xee, 0x3b, 0x38, 0xb4, 0x9a, 0xf0, 0x79, 0x5c, 0xb0, 0x40, 0x75, 0x6d, 0xe8, 0xc7, + 0x73, 0xda, 0x04, 0x3a, 0x8d, 0x7d, 0xc3, 0xc7, 0x61, 0x83, 0x2f, 0x0f, 0x8c, 0x94, 0x84, 0xa6, + 0x7a, 0xfb, 0x12, 0xa9, 0x68, 0x9e, 0x37, 0x20, 0x1b, 0x7c, 0xa5, 0x85, 0x16, 0xa2, 0xcf, 0xcd, + 0x62, 0x1f, 0x71, 0xa9, 0x8b, 0x02, 0x35, 0x1c, 0xb7, 0xf9, 0x9f, 0x49, 0x80, 0x3e, 0x08, 0x85, + 0x1e, 0xc1, 0x95, 0xf8, 0xd7, 0x26, 0x68, 0x65, 0xc8, 0x47, 0x49, 0xea, 0xaa, 0x9c, 0x19, 0xd9, + 0xf4, 0x08, 0xae, 0xc4, 0x5f, 0x5c, 0xf6, 0x95, 0x49, 0xde, 0xb3, 0xf6, 0x95, 0x49, 0xdf, 0x75, + 0x4e, 0xa0, 0x0e, 0x2c, 0x27, 0xbc, 0x6f, 0x42, 0x77, 0x46, 0x7b, 0x59, 0xa7, 0xbe, 0x32, 0xe2, + 0x8b, 0x2b, 0x6d, 0x02, 0xb9, 0x70, 0x2d, 0xf1, 0x2d, 0x09, 0xba, 0x3b, 0xea, 0x7b, 0x1f, 0xf5, + 0xd5, 0x11, 0x24, 0xa3, 0x39, 0x7b, 0xa0, 0x26, 0x03, 0xfe, 0xe8, 0xd5, 0x91, 0xdf, 0x74, 0xa8, + 0xf7, 0x46, 0x11, 0x8d, 0xa6, 0xdd, 0x85, 0x99, 0x18, 0xf8, 0x8e, 0x54, 0x29, 0x22, 0x4f, 0x15, + 0xaf, 0x0c, 0x41, 0xeb, 0xa9, 0xa6, 0x18, 0x40, 0xdc, 0xd7, 0x34, 0x88, 0x74, 0xf7, 0x35, 0x49, + 0x10, 0x65, 0xd1, 0xfd, 0x42, 0x5d, 0x96, 0xb9, 0x5f, 0x5e, 0xd8, 0x65, 0xee, 0x4f, 0x28, 0xf2, + 0xda, 0x04, 0xfa, 0x26, 0xcc, 0xf1, 0xb8, 0x15, 0x5a, 0x1b, 0x8a, 0xf4, 0xa9, 0xd7, 0x93, 0xd8, + 0x71, 0x95, 0x3c, 0x62, 0xd0, 0x57, 0x29, 0x85, 0x37, 0xfa, 0x2a, 0x13, 0x80, 0x86, 0x09, 0x52, + 0x9f, 0xb8, 0xdb, 0x78, 0xbf, 0x3e, 0xc9, 0x00, 0x88, 0x7e, 0x7d, 0x92, 0x5e, 0xe1, 0xb5, 0x89, + 0xcd, 0x3f, 0x66, 0x21, 0x13, 0x14, 0xd2, 0x06, 0xbc, 0x24, 0x5c, 0x6a, 0xd0, 0xf5, 0xe1, 0x37, + 0x3f, 0xf5, 0x46, 0x22, 0x3f, 0x32, 0xf7, 0x09, 0x3d, 0xa6, 0xb9, 0x6b, 0x0a, 0x5a, 0x8f, 0x8f, + 0x93, 0x5d, 0x95, 0xd4, 0x9b, 0x43, 0x24, 0x44, 0xdd, 0x7c, 0x2d, 0x58, 0xbf, 0xac, 0x5f, 0xe6, + 0x75, 0x27, 0xe5, 0xff, 0xc7, 0xf4, 0xdc, 0x12, 0x33, 0x5f, 0xe3, 0xed, 0x92, 0xe6, 0xfc, 0xad, + 0xa1, 0x32, 0xd1, 0x0c, 0x1f, 0x45, 0x07, 0x66, 0xac, 0x9f, 0x43, 0x9c, 0x71, 0xd2, 0x36, 0x52, + 0xd5, 0x86, 0x89, 0x44, 0xea, 0x2b, 0x30, 0x1d, 0xf5, 0x47, 0xa8, 0x20, 0x0c, 0x89, 0xda, 0x28, + 0xf5, 0x9a, 0x84, 0xc3, 0x74, 0xa4, 0x7f, 0x94, 0x52, 0x42, 0x3f, 0x88, 0x29, 0x28, 0xda, 0x20, + 0x4b, 0xbe, 0x5b, 0x43, 0x65, 0xe2, 0x45, 0x23, 0xd6, 0x21, 0xf4, 0x8b, 0xc6, 0x60, 0x37, 0xd1, + 0x2f, 0x1a, 0x92, 0x96, 0x42, 0x9b, 0xd8, 0xca, 0x3e, 0x49, 0x37, 0x3d, 0xeb, 0x24, 0x17, 0x7c, + 0x87, 0xfc, 0x95, 0xff, 0x06, 0x00, 0x00, 0xff, 0xff, 0xa9, 0x00, 0x8e, 0x97, 0xb6, 0x2f, 0x00, + 0x00, } diff --git a/spec.md b/spec.md index 063f13e5..15e58d17 100644 --- a/spec.md +++ b/spec.md @@ -524,13 +524,21 @@ message PluginCapability { // as specific RPCs as indicated by ControllerGetCapabilities. CONTROLLER_SERVICE = 1; - // ACCESSIBILITY_CONSTRAINTS indicates that the volumes for this - // plugin may not be equally accessible by all nodes in the + // VOLUME_ACCESSIBILITY_CONSTRAINTS indicates that the volumes for + // this plugin may not be equally accessible by all nodes in the // cluster. The CO MUST use the topology information returned by // CreateVolumeRequest along with the topology information // returned by NodeGetInfo to ensure that a given volume is // accessible from a given node when scheduling workloads. - ACCESSIBILITY_CONSTRAINTS = 2; + VOLUME_ACCESSIBILITY_CONSTRAINTS = 2; + + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS indicates that the snapshots + // for this plugin may not be equally accessible by all nodes in + // the cluster. The CO MUST use the topology information returned + // by CreateSnapshotRequest along with the topology information + // returned by NodeGetInfo to ensure that a given snapshot is + // accessible from a given node when scheduling workloads. + SNAPSHOT_ACCESSIBILITY_CONSTRAINTS = 3; } Type type = 1; } @@ -673,10 +681,10 @@ message CreateVolumeRequest { // topological accessibility information supported by the SP. // This field is OPTIONAL. // This field SHALL NOT be specified unless the SP has the - // ACCESSIBILITY_CONSTRAINTS plugin capability. + // VOLUME_ACCESSIBILITY_CONSTRAINTS plugin capability. // If this field is not specified and the SP has the - // ACCESSIBILITY_CONSTRAINTS plugin capability, the SP MAY choose - // where the provisioned volume is accessible from. + // VOLUME_ACCESSIBILITY_CONSTRAINTS plugin capability, the SP MAY + // choose where the provisioned volume is accessible from. TopologyRequirement accessibility_requirements = 7; } @@ -810,7 +818,7 @@ message Volume { // Specifies where (regions, zones, racks, etc.) the provisioned // volume is accessible from. // A plugin that returns this field MUST also set the - // ACCESSIBILITY_CONSTRAINTS plugin capability. + // VOLUME_ACCESSIBILITY_CONSTRAINTS plugin capability. // An SP MAY specify multiple topologies to indicate the volume is // accessible from multiple locations. // COs MAY use this information along with the topology information @@ -836,99 +844,109 @@ message Volume { } message TopologyRequirement { - // Specifies the list of topologies the provisioned volume MUST be - // accessible from. + // Specifies the list of topologies the provisioned volume or + // snapshot MUST be accessible from. // This field is OPTIONAL. If TopologyRequirement is specified either // requisite or preferred or both MUST be specified. // - // If requisite is specified, the provisioned volume MUST be - // accessible from at least one of the requisite topologies. + // If requisite is specified, the provisioned volume or snapshot MUST + // be accessible from at least one of the requisite topologies. // // Given - // x = number of topologies provisioned volume is accessible from + // x = number of topologies provisioned volume or snapshot is + // accessible from // n = number of requisite topologies // The CO MUST ensure n >= 1. The SP MUST ensure x >= 1 - // If x==n, than the SP MUST make the provisioned volume available to - // all topologies from the list of requisite topologies. If it is - // unable to do so, the SP MUST fail the CreateVolume call. - // For example, if a volume should be accessible from a single zone, - // and requisite = + // If x==n, than the SP MUST make the provisioned volume or snapshot + // available to all topologies from the list of requisite topologies. + // If it is unable to do so, the SP MUST fail the CreateVolume or + // CreateSnapshot call. For example, if a volume or snapshot should be + // accessible from a single zone, and + // requisite = // {"region": "R1", "zone": "Z2"} - // then the provisioned volume MUST be accessible from the "region" - // "R1" and the "zone" "Z2". - // Similarly, if a volume should be accessible from two zones, and + // then the provisioned volume or snapshot MUST be accessible from + // the "region" "R1" and the "zone" "Z2". + // Similarly, if a volume or snapshot should be accessible from two + // zones, and // requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"} - // then the provisioned volume MUST be accessible from the "region" - // "R1" and both "zone" "Z2" and "zone" "Z3". + // then the provisioned volume or snapshot MUST be accessible from the + // "region" "R1" and both "zone" "Z2" and "zone" "Z3". // // If xn, than the SP MUST make the provisioned volume available from - // all topologies from the list of requisite topologies and MAY choose - // the remaining x-n unique topologies from the list of all possible - // topologies. If it is unable to do so, the SP MUST fail the - // CreateVolume call. - // For example, if a volume should be accessible from two zones, and + // If x>n, than the SP MUST make the provisioned volume or snapshot + // available from all topologies from the list of requisite topologies + // and MAY choose the remaining x-n unique topologies from the list of + // all possible topologies. If it is unable to do so, the SP MUST fail + // the CreateVolume or CreateSnapshot call. + // For example, if a volume or snapshot should be accessible from two + // zones, and // requisite = // {"region": "R1", "zone": "Z2"} - // then the provisioned volume MUST be accessible from the "region" - // "R1" and the "zone" "Z2" and the SP may select the second zone - // independently, e.g. "R1/Z4". + // then the provisioned volume or snapshot MUST be accessible from the + // "region" "R1" and the "zone" "Z2" and the SP may select the second + // zone independently, e.g. "R1/Z4". repeated Topology requisite = 1; - // Specifies the list of topologies the CO would prefer the volume to - // be provisioned in. + // Specifies the list of topologies the CO would prefer the volume or + // snapshot to be provisioned in. // // This field is OPTIONAL. If TopologyRequirement is specified either // requisite or preferred or both MUST be specified. // - // An SP MUST attempt to make the provisioned volume available using - // the preferred topologies in order from first to last. + // An SP MUST attempt to make the provisioned volume or snapshot + // available using the preferred topologies in order from first to + // last. // // If requisite is specified, all topologies in preferred list MUST // also be present in the list of requisite topologies. // - // If the SP is unable to to make the provisioned volume available - // from any of the preferred topologies, the SP MAY choose a topology - // from the list of requisite topologies. + // If the SP is unable to to make the provisioned volume or snapshot + // available from any of the preferred topologies, the SP MAY choose + // a topology from the list of requisite topologies. // If the list of requisite topologies is not specified, then the SP // MAY choose from the list of all possible topologies. // If the list of requisite topologies is specified and the SP is - // unable to to make the provisioned volume available from any of the - // requisite topologies it MUST fail the CreateVolume call. + // unable to to make the provisioned volume or snapshot available from + // any of the requisite topologies it MUST fail the CreateVolume or + // CreateSnapshot call. // // Example 1: - // Given a volume should be accessible from a single zone, and - // requisite = + // Given a volume or snapshot should be accessible from a single zone, + // and requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"} // preferred = // {"region": "R1", "zone": "Z3"} // then the the SP SHOULD first attempt to make the provisioned volume - // available from "zone" "Z3" in the "region" "R1" and fall back to - // "zone" "Z2" in the "region" "R1" if that is not possible. + // or snapshot available from "zone" "Z3" in the "region" "R1" and + // fall back to "zone" "Z2" in the "region" "R1" if that is not + // possible. // // Example 2: - // Given a volume should be accessible from a single zone, and - // requisite = + // Given a volume or snapshot should be accessible from a single zone, + // and requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"}, // {"region": "R1", "zone": "Z4"}, @@ -937,17 +955,19 @@ message TopologyRequirement { // {"region": "R1", "zone": "Z4"}, // {"region": "R1", "zone": "Z2"} // then the the SP SHOULD first attempt to make the provisioned volume - // accessible from "zone" "Z4" in the "region" "R1" and fall back to - // "zone" "Z2" in the "region" "R1" if that is not possible. If that - // is not possible, the SP may choose between either the "zone" - // "Z3" or "Z5" in the "region" "R1". + // or snapshot accessible from "zone" "Z4" in the "region" "R1" and + // fall back to "zone" "Z2" in the "region" "R1" if that is not + // possible. If that is not possible, the SP may choose between either + // the "zone" "Z3" or "Z5" in the "region" "R1". // // Example 3: - // Given a volume should be accessible from TWO zones (because an - // opaque parameter in CreateVolumeRequest, for example, specifies - // the volume is accessible from two zones, aka synchronously - // replicated), and - // requisite = + // A volume or snapshot MAY be required to be accessible from TWO + // zones. This MAY be indicated by an opaque parameter in + // CreateVolumeRequest that specifies the volume to be accessible from + // two zones. While accessibility requirements MAY be satisfied by + // replication, CO MUST NOT assume accessibility requires replication. + // Given a volume or snapshot should be accessible from TWO zones, + // and requisite = // {"region": "R1", "zone": "Z2"}, // {"region": "R1", "zone": "Z3"}, // {"region": "R1", "zone": "Z4"}, @@ -956,10 +976,10 @@ message TopologyRequirement { // {"region": "R1", "zone": "Z5"}, // {"region": "R1", "zone": "Z3"} // then the the SP SHOULD first attempt to make the provisioned volume - // accessible from the combination of the two "zones" "Z5" and "Z3" in - // the "region" "R1". If that's not possible, it should fall back to - // a combination of "Z5" and other possibilities from the list of - // requisite. If that's not possible, it should fall back to a + // or snapshot accessible from the combination of the two "zones" "Z5" + // and "Z3" in the "region" "R1". If that's not possible, it should + // fall back to a combination of "Z5" and other possibilities from the + // list of requisite. If that's not possible, it should fall back to a // combination of "Z3" and other possibilities from the list of // requisite. If that's not possible, it should fall back to a // combination of other possibilities from the list of requisite. @@ -1194,7 +1214,7 @@ message ValidateVolumeCapabilitiesRequest { // A caller MAY specify multiple topologies to indicate they believe // the volume to be accessible from multiple locations. // This field is OPTIONAL. This field SHALL NOT be set unless the - // plugin advertises the ACCESSIBILITY_CONSTRAINTS capability. + // plugin advertises the VOLUME_ACCESSIBILITY_CONSTRAINTS capability. repeated Topology accessible_topology = 4; } @@ -1298,7 +1318,7 @@ message GetCapacityRequest { // `accessible_topology`. This is the same as the // `accessible_topology` the CO returns in a `CreateVolumeResponse`. // This field is OPTIONAL. This field SHALL NOT be set unless the - // plugin advertises the ACCESSIBILITY_CONSTRAINTS capability. + // plugin advertises the VOLUME_ACCESSIBILITY_CONSTRAINTS capability. Topology accessible_topology = 3; } @@ -1410,6 +1430,19 @@ message CreateSnapshotRequest { // - Specify primary or secondary for replication systems that // support snapshotting only on primary. map parameters = 4; + + // Specifies where (regions, zones, racks, etc.) the provisioned + // snapshot MUST be accessible from. + // An SP SHALL advertise the requirements for topological + // accessibility information in documentation. COs SHALL only specify + // topological accessibility information supported by the SP. + // This field is OPTIONAL. + // This field SHALL NOT be specified unless the SP has the + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability. + // If this field is not specified and the SP has the + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability, the SP MAY + // choose where the provisioned snapshot is accessible from. + TopologyRequirement accessibility_requirements = 5; } message CreateSnapshotResponse { @@ -1450,6 +1483,33 @@ message Snapshot { // The status of a snapshot. SnapshotStatus status = 5; + + // Specifies where (regions, zones, racks, etc.) the provisioned + // snapshot is accessible from. + // A plugin that returns this field MUST also set the + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability. + // An SP MAY specify multiple topologies to indicate the snapshot is + // accessible from multiple locations. + // COs MAY use this information along with the topology information + // returned by NodeGetInfo to ensure that a given snapshot is + // accessible from a given node when scheduling workloads. + // This field is OPTIONAL. If it is not specified, the CO MAY assume + // the snapshot is equally accessible from all nodes in the cluster + // and may schedule workloads referencing the snapshot on any + // available node. + // + // Example 1: + // accessible_topology = {"region": "R1", "zone": "Z2"} + // Indicates a snapshot accessible only from the "region" "R1" and the + // "zone" "Z2". + // + // Example 2: + // accessible_topology = + // {"region": "R1", "zone": "Z2"}, + // {"region": "R1", "zone": "Z3"} + // Indicates a snapshot accessible from both "zone" "Z2" and "zone" + // "Z3" in the "region" "R1". + repeated Topology accessible_topology = 6; } // The status of a snapshot. @@ -2074,10 +2134,12 @@ message NodeGetInfoResponse { // Specifies where (regions, zones, racks, etc.) the node is // accessible from. // A plugin that returns this field MUST also set the - // ACCESSIBILITY_CONSTRAINTS plugin capability. + // VOLUME_ACCESSIBILITY_CONSTRAINTS or + // SNAPSHOT_ACCESSIBILITY_CONSTRAINTS plugin capability. // COs MAY use this information along with the topology information - // returned in CreateVolumeResponse to ensure that a given volume is - // accessible from a given node when scheduling workloads. + // returned in CreateVolumeResponse CreateSnapshotResponse to ensure + // that a given volume or snapshot is accessible from a given node + // when scheduling workloads. // This field is OPTIONAL. If it is not specified, the CO MAY assume // the node is not subject to any topological constraint, and MAY // schedule workloads that reference any volume V, such that there are