Documentation ¶
Overview ¶
Copyright (c) 2019 Dell EMC Corporation All Rights Reserved
Index ¶
- Constants
- Variables
- func GetRunidLog(ctx context.Context) (context.Context, *logrus.Entry, string)
- func SingleAccessMode(accMode *csi.VolumeCapability_AccessMode) bool
- func ValidateAndGetProtocol(ctx context.Context, protocol, scProtocol string) (string, error)
- func ValidateControllerPublishRequest(ctx context.Context, req *csi.ControllerPublishVolumeRequest, ...) (protocol, nodeID string, err error)
- func ValidateCreateVolumeRequest(ctx context.Context, req *csi.CreateVolumeRequest) (protocol, storagePool string, size, tieringPolicy, hostIoSize int64, ...)
- type CRParams
- type Device
- type ISCSITargetInfo
- type Opts
- type Service
- type StorageArrayConfig
- type StorageArrayList
Constants ¶
View Source
const ( FC = "FC" ISCSI = "iSCSI" NFS = "NFS" ProtocolUnknown = "Unknown" ProtocolNFS = int(0) MAX_ENTRIES_SNAPSHOT = 100 MAX_ENTRIES_VOLUME = 100 AdditionalFilesystemSize = 1.5 * 1024 * 1024 * 1024 )
View Source
const ( // EnvEndpoint is the name of the environment variable used to set the // HTTP endpoint of the Unity Gateway EnvEndpoint = "X_CSI_UNITY_ENDPOINT" // EnvNodeName is the name of the enviroment variable used to set the // hostname where the node service is running EnvNodeName = "X_CSI_UNITY_NODENAME" // EnvAutoProbe is the name of the environment variable used to specify // that the controller service should automatically probe itself if it // receives incoming requests before having been probed, in direct // violation of the CSI spec EnvAutoProbe = "X_CSI_UNITY_AUTOPROBE" //EnvPvtMountDir is required to Node Unstage volume where the volume has been mounted //as a global mount via CSI-Unity v1.0 or v1.1 EnvPvtMountDir = "X_CSI_PRIVATE_MOUNT_DIR" //EnvEphemeralStagingPath EnvEphemeralStagingPath = "X_CSI_EPHEMERAL_STAGING_PATH" // EnvISCSIChroot is the path to which the driver will chroot before // running any iscsi commands. This value should only be set when instructed // by technical support. EnvISCSIChroot = "X_CSI_ISCSI_CHROOT" //Time interval to add node info to array. Default 60 minutes. SyncNodeInfoTimeInterval = "X_CSI_UNITY_SYNC_NODEINFO_INTERVAL" )
View Source
const ( // VendorVersion is the version of this Unity CSI. VendorVersion = "0.0.0" //Tcp dial default timeout in Milliseconds TcpDialTimeout = 1000 IScsiPort = "3260" )
Variables ¶
View Source
var ( LUNZHLU = 0 VolumeNameLengthConstraint = 63 )
View Source
var DriverConfig string
View Source
var Manifest = map[string]string{ "url": "http://github.com/dell/csi-unity", "semver": core.SemVer, "commit": core.CommitSha32, "formed": core.CommitTime.Format(time.RFC1123), }
Manifest is the SP's manifest.
View Source
var Name string
Functions ¶
func SingleAccessMode ¶ added in v1.4.0
func SingleAccessMode(accMode *csi.VolumeCapability_AccessMode) bool
SingleAccessMode returns true if only a single access is allowed SINGLE_NODE_WRITER or SINGLE_NODE_READER_ONLY
func ValidateAndGetProtocol ¶ added in v1.4.0
func ValidateControllerPublishRequest ¶ added in v1.4.0
func ValidateControllerPublishRequest(ctx context.Context, req *csi.ControllerPublishVolumeRequest, contextProtocol string) (protocol, nodeID string, err error)
ValidateControllerPublishRequest - method to validate Controller publish volume request
func ValidateCreateVolumeRequest ¶ added in v1.4.0
func ValidateCreateVolumeRequest(ctx context.Context, req *csi.CreateVolumeRequest) (protocol, storagePool string, size, tieringPolicy, hostIoSize int64, thin, dataReduction bool, err error)
ValidateCreateVolumeRequest - Validates all mandatory parameters in create volume request
Types ¶
type CRParams ¶ added in v1.4.0
type CRParams struct { VolumeName string Protocol string StoragePool string Desciption string HostIOLimitName string Thin bool DataReduction bool Size int64 TieringPolicy int64 HostIoSize int64 }
CRParams - defines placeholder for all create volume parameters
type ISCSITargetInfo ¶
ISCSITargetInfo represents basic information about iSCSI target
type Opts ¶
type Opts struct { NodeName string LongNodeName string Chroot string Thick bool AutoProbe bool PvtMountDir string Debug bool SyncNodeInfoTimeInterval int EnvEphemeralStagingTargetPath string }
Opts defines service configuration options.
type Service ¶
type Service interface { csi.ControllerServer csi.IdentityServer csi.NodeServer BeforeServe(context.Context, *gocsi.StoragePlugin, net.Listener) error }
Service is a CSI SP and idempotency.Provider.
type StorageArrayConfig ¶
type StorageArrayConfig struct { ArrayId string `json:"arrayId"` Username string `json:"username"` Password string `json:"password"` RestGateway string `json:"restGateway"` Insecure bool `json:"insecure, omitempty"` IsDefaultArray bool `json:"isDefaultArray, omitempty"` IsProbeSuccess bool IsHostAdded bool UnityClient *gounity.Client }
func (StorageArrayConfig) String ¶
func (s StorageArrayConfig) String() string
To display the StorageArrayConfig content
type StorageArrayList ¶
type StorageArrayList struct {
StorageArrayList []StorageArrayConfig `json:"storageArrayList"`
}
To parse the secret json file
Source Files ¶
Click to show internal directories.
Click to hide internal directories.