Documentation ¶
Overview ¶
This package provides a high-level interface to the E-series Web Services Proxy REST API.
Index ¶
- Constants
- Variables
- type ByFreeSpace
- type CallResponseError
- type Client
- func (d Client) Connect() (string, error)
- func (d Client) CreateHost(name string, iqn string, hostType string, hostGroup HostGroup) (HostEx, error)
- func (d Client) CreateHostGroup(name string) (HostGroup, error)
- func (d Client) CreateVolume(name string, volumeGroupRef string, size uint64, mediaType, fstype string) (VolumeEx, error)
- func (d Client) DeleteVolume(volume VolumeEx) error
- func (d Client) EnsureHostForIQN(iqn string) (HostEx, error)
- func (d Client) EnsureHostGroup() (HostGroup, error)
- func (d Client) GetChassisSerialNumber() (string, error)
- func (d Client) GetHostForIQN(iqn string) (HostEx, error)
- func (d Client) GetHostGroup(name string) (HostGroup, error)
- func (d Client) GetStorageSystem() (*StorageSystem, error)
- func (d *Client) GetTargetIQN() (string, error)
- func (d *Client) GetTargetSettings() (*IscsiTargetSettings, error)
- func (d Client) GetVolume(name string) (VolumeEx, error)
- func (d Client) GetVolumeByRef(volumeRef string) (VolumeEx, error)
- func (d Client) GetVolumePoolByRef(volumeGroupRef string) (VolumeGroupEx, error)
- func (d Client) GetVolumePools(mediaType string, minFreeSpaceBytes uint64, poolName string) ([]VolumeGroupEx, error)
- func (d Client) GetVolumes() ([]VolumeEx, error)
- func (d Client) InvokeAPI(requestBody []byte, method string, resourcePath string) (*http.Response, []byte, error)
- func (d Client) IsRefValid(ref string) bool
- func (d Client) ListVolumes() ([]string, error)
- func (d Client) MapVolume(volume VolumeEx, host HostEx) (LUNMapping, error)
- func (d Client) UnmapVolume(volume VolumeEx) error
- type ClientConfig
- type Error
- type HostCreateRequest
- type HostEx
- type HostExInitiator
- type HostExScsiNodeName
- type HostGroup
- type HostGroupCreateRequest
- type HostPort
- type HostType
- type IscsiTargetSettings
- type LUNMapping
- type MsgConnect
- type MsgConnectResponse
- type StorageSystem
- type VolumeCreateRequest
- type VolumeEx
- type VolumeGroupEx
- type VolumeMappingCreateRequest
- type VolumeTag
Constants ¶
const NullRef = "0000000000000000000000000000000000000000"
Variables ¶
var HostTypes = map[string]string{
"linux_atto": "LnxTPGSALUA",
"linux_dm_mp": "LnxALUA",
"linux_mpp_rdac": "LNX",
"linux_pathmanager": "LnxTPGSALUA_PM",
"linux_sf": "LnxTPGSALUA_SF",
"ontap": "ONTAP_ALUA",
"ontap_rdac": "ONTAP_RDAC",
"vmware": "VmwTPGSALUA",
"windows": "W2KNETNCL",
"windows_atto": "WinTPGSALUA",
"windows_clustered": "W2KNETCL",
}
Functions ¶
This section is empty.
Types ¶
type ByFreeSpace ¶
type ByFreeSpace []VolumeGroupEx
Functions to allow sorting storage pools by free space
func (ByFreeSpace) Len ¶
func (s ByFreeSpace) Len() int
func (ByFreeSpace) Less ¶
func (s ByFreeSpace) Less(i, j int) bool
func (ByFreeSpace) Swap ¶
func (s ByFreeSpace) Swap(i, j int)
type CallResponseError ¶
type CallResponseError struct { ErrorMsg string `json:"errorMessage"` LocalizedMsg string `json:"localizedMessage"` ReturnCode string `json:"retcode"` CodeType string `json:"codeType"` //'symbol', 'webservice', 'systemerror', 'devicemgrerror' }
Used for errors on RESTful calls to return what went wrong
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
Client is the object to use for interacting with the E-series API.
func NewAPIClient ¶
func NewAPIClient(config ClientConfig) *Client
NewAPIClient is a factory method for creating a new instance.
func (Client) CreateHost ¶
func (d Client) CreateHost(name string, iqn string, hostType string, hostGroup HostGroup) (HostEx, error)
CreateHost creates a Host on the array. If a HostGroup is specified, the Host is placed in that group.
func (Client) CreateHostGroup ¶
CreateHostGroup creates an E-series HostGroup object with the specified name and returns the resulting HostGroup structure.
func (Client) CreateVolume ¶
func (d Client) CreateVolume( name string, volumeGroupRef string, size uint64, mediaType, fstype string, ) (VolumeEx, error)
CreateVolume creates a volume (i.e. a LUN) on the array, and it returns the resulting VolumeEx structure.
func (Client) DeleteVolume ¶
DeleteVolume deletes a volume from the array.
func (Client) EnsureHostForIQN ¶
EnsureHostForIQN handles automatic E-series Host and Host Group creation. Given the IQN of a host, this method verifies whether a Host is already configured on the array. If so, the Host info is returned and no further action is taken. If not, this method chooses a unique name for the Host and creates it on the array. Once the Host is created, it is placed in the Host Group used for nDVP volumes.
func (Client) EnsureHostGroup ¶
EnsureHostGroup ensures that an E-series HostGroup exists to contain all Host objects created by the nDVP E-series driver. The group name is taken from the config structure. If the group exists, the group structure is returned and no further action is taken. If not, this method creates the group and returns the resulting group structure.
func (Client) GetChassisSerialNumber ¶
GetChassisSerialNumber returns the chassis serial number for this storage system.
func (Client) GetHostForIQN ¶
GetHostForIQN queries the Host objects on the array an returns one matching the supplied IQN. An empty struct is returned if a matching host is not found, so the caller should check for empty values in the result.
func (Client) GetHostGroup ¶
GetHostGroup returns an E-series HostGroup structure with the specified name. If no matching group is found, an empty structure is returned, so the caller should check for empty values in the result.
func (Client) GetStorageSystem ¶
func (d Client) GetStorageSystem() (*StorageSystem, error)
GetStorageSystem returns a struct detailing the storage system.
func (*Client) GetTargetIQN ¶
GetTargetIQN returns the IQN for the array.
func (*Client) GetTargetSettings ¶
func (d *Client) GetTargetSettings() (*IscsiTargetSettings, error)
GetTargetSettings returns the iSCSI target settings for the array.
func (Client) GetVolume ¶
GetVolume returns a volume structure from the array whose label matches the specified name. Use this method sparingly, at most once per workflow, because the Web Services Proxy does not support server-side filtering so the only choice is to read all volumes to find the one of interest. Most methods in this module operate on the returned VolumeEx structure, not the volume name, to minimize the need for calling this method.
func (Client) GetVolumeByRef ¶
GetVolumeByRef gets a single volume from the array.
func (Client) GetVolumePoolByRef ¶
func (d Client) GetVolumePoolByRef(volumeGroupRef string) (VolumeGroupEx, error)
GetVolumePoolByRef returns the pool with the specified volumeGroupRef.
func (Client) GetVolumePools ¶
func (d Client) GetVolumePools(mediaType string, minFreeSpaceBytes uint64, poolName string) ([]VolumeGroupEx, error)
GetVolumePools reads all pools on the array, including volume groups and dynamic disk pools. It then filters them based on several selection parameters and returns the ones that match.
func (Client) GetVolumes ¶
GetVolumes returns an array containing all the volumes on the array.
func (Client) InvokeAPI ¶
func (d Client) InvokeAPI(requestBody []byte, method string, resourcePath string) (*http.Response, []byte, error)
InvokeAPI makes a REST call to the Web Services Proxy. The body must be a marshaled JSON byte array (or nil). The method is the HTTP verb (i.e. GET, POST, ...). The resource path is appended to the base URL to identify the desired server resource; it should start with '/'.
func (Client) IsRefValid ¶
IsRefValid checks whether the supplied string is a valid E-series object reference as used by its REST API. Ref values are strings of all numerical digits that aren't all zeros (i.e. the null ref).
func (Client) ListVolumes ¶
ListVolumes returns an array containing all the volume names on the array.
func (Client) MapVolume ¶
func (d Client) MapVolume(volume VolumeEx, host HostEx) (LUNMapping, error)
MapVolume maps a volume to the specified host and returns the resulting LUN mapping. If the volume is already mapped to the specified host, either directly or to the containing host group, no action is taken. If the volume is mapped to a different host, the method returns an error. Note that if the host is in a group, the volume will actually be mapped to the group instead of the individual host.
func (Client) UnmapVolume ¶
UnmapVolume removes a mapping from the specified volume. If no map exists, no action is taken.
type ClientConfig ¶
type ClientConfig struct { // Web Proxy Services Info WebProxyHostname string WebProxyPort string WebProxyUseHTTP bool WebProxyVerifyTLS bool Username string Password string // Array Info ControllerA string ControllerB string PasswordArray string // Options PoolNameSearchPattern string DebugTraceFlags map[string]bool // Host Connectivity HostDataIP string //for iSCSI with multipathing this can be either IP or host // Internal Config Variables ArrayID string // Unique ID for array once added to web proxy services CompiledPoolNameSearchPattern *regexp.Regexp // Storage protocol of the driver (iSCSI, FC, etc) Protocol string AccessGroup string HostType string DriverName string Telemetry map[string]string ConfigVersion int }
ClientConfig holds configuration data for the API driver object.
type HostCreateRequest ¶
type HostEx ¶
type HostEx struct { HostRef string `json:"hostRef"` ClusterRef string `json:"clusterRef"` Label string `json:"label"` HostTypeIndex int `json:"hostTypeIndex"` Initiators []HostExInitiator `json:"initiators"` }
type HostExInitiator ¶
type HostExInitiator struct { InitiatorRef string `json:"initiatorRef"` NodeName HostExScsiNodeName `json:"nodeName"` Label string `json:"label"` }
type HostExScsiNodeName ¶
type HostGroupCreateRequest ¶
type IscsiTargetSettings ¶
type IscsiTargetSettings struct { TargetRef string `json:"targetRef"` NodeName struct { IoInterfaceType string `json:"ioInterfaceType"` IscsiNodeName string `json:"iscsiNodeName"` RemoteNodeWWN interface{} `json:"remoteNodeWWN"` } `json:"nodeName"` Alias struct { IoInterfaceType string `json:"ioInterfaceType"` IscsiAlias string `json:"iscsiAlias"` } `json:"alias"` ConfiguredAuthMethods struct { AuthMethodData []struct { AuthMethod string `json:"authMethod"` ChapSecret interface{} `json:"chapSecret"` } `json:"authMethodData"` } `json:"configuredAuthMethods"` Portals []struct { GroupTag int `json:"groupTag"` IPAddress struct { AddressType string `json:"addressType"` Ipv4Address string `json:"ipv4Address"` Ipv6Address interface{} `json:"ipv6Address"` } `json:"ipAddress"` TCPListenPort int `json:"tcpListenPort"` } `json:"portals"` }
type LUNMapping ¶
type MsgConnect ¶
type MsgConnect struct { ControllerAddresses []string `json:"controllerAddresses"` Password string `json:"password,omitempty"` }
Add array to Web Services Proxy
type MsgConnectResponse ¶
type StorageSystem ¶
type StorageSystem struct { ID string `json:"id"` Name string `json:"name"` Wwn string `json:"wwn"` PasswordStatus string `json:"passwordStatus"` PasswordSet bool `json:"passwordSet"` Status string `json:"status"` IP1 string `json:"ip1"` IP2 string `json:"ip2"` ManagementPaths []string `json:"managementPaths"` Controllers []struct { ControllerID string `json:"controllerId"` IPAddresses []string `json:"ipAddresses"` CertificateStatus string `json:"certificateStatus"` } `json:"controllers"` DriveCount int `json:"driveCount"` TrayCount int `json:"trayCount"` TraceEnabled bool `json:"traceEnabled"` Types string `json:"types"` Model string `json:"model"` MetaTags []interface{} `json:"metaTags"` HotSpareSize string `json:"hotSpareSize"` UsedPoolSpace string `json:"usedPoolSpace"` FreePoolSpace string `json:"freePoolSpace"` UnconfiguredSpace string `json:"unconfiguredSpace"` DriveTypes []string `json:"driveTypes"` HostSpareCountInStandby int `json:"hostSpareCountInStandby"` HotSpareCount int `json:"hotSpareCount"` HostSparesUsed int `json:"hostSparesUsed"` BootTime string `json:"bootTime"` FwVersion string `json:"fwVersion"` AppVersion string `json:"appVersion"` BootVersion string `json:"bootVersion"` NvsramVersion string `json:"nvsramVersion"` ChassisSerialNumber string `json:"chassisSerialNumber"` AccessVolume struct { Enabled bool `json:"enabled"` VolumeHandle int `json:"volumeHandle"` Capacity string `json:"capacity"` AccessVolumeRef string `json:"accessVolumeRef"` Reserved1 string `json:"reserved1"` ObjectType string `json:"objectType"` Wwn string `json:"wwn"` PreferredControllerID string `json:"preferredControllerId"` TotalSizeInBytes string `json:"totalSizeInBytes"` ListOfMappings []struct { LunMappingRef string `json:"lunMappingRef"` Lun int `json:"lun"` Ssid int `json:"ssid"` Perms int `json:"perms"` VolumeRef string `json:"volumeRef"` Type string `json:"type"` MapRef string `json:"mapRef"` ID string `json:"id"` } `json:"listOfMappings"` Mapped bool `json:"mapped"` CurrentControllerID string `json:"currentControllerId"` Name string `json:"name"` ID string `json:"id"` } `json:"accessVolume"` UnconfiguredSpaceByDriveType struct { } `json:"unconfiguredSpaceByDriveType"` MediaScanPeriod int `json:"mediaScanPeriod"` DriveChannelPortDisabled bool `json:"driveChannelPortDisabled"` RecoveryModeEnabled bool `json:"recoveryModeEnabled"` AutoLoadBalancingEnabled bool `json:"autoLoadBalancingEnabled"` HostConnectivityReportingEnabled bool `json:"hostConnectivityReportingEnabled"` RemoteMirroringEnabled bool `json:"remoteMirroringEnabled"` FcRemoteMirroringState string `json:"fcRemoteMirroringState"` AsupEnabled bool `json:"asupEnabled"` SecurityKeyEnabled bool `json:"securityKeyEnabled"` ExternalKeyEnabled bool `json:"externalKeyEnabled"` LastContacted string `json:"lastContacted"` DefinedPartitionCount int `json:"definedPartitionCount"` SimplexModeEnabled bool `json:"simplexModeEnabled"` EnabledManagementPorts interface{} `json:"enabledManagementPorts"` FreePoolSpaceAsString string `json:"freePoolSpaceAsString"` HotSpareSizeAsString string `json:"hotSpareSizeAsString"` UnconfiguredSpaceAsStrings string `json:"unconfiguredSpaceAsStrings"` UsedPoolSpaceAsString string `json:"usedPoolSpaceAsString"` }
type VolumeCreateRequest ¶
type VolumeCreateRequest struct { VolumeGroupRef string `json:"poolId"` Name string `json:"name"` SizeUnit string `json:"sizeUnit"` //bytes, b, kb, mb, gb, tb, pb, eb, zb, yb Size int `json:"size"` SegmentSize int `json:"segSize"` DataAssurance bool `json:"dataAssuranceEnabled,omitempty"` OwningController string `json:"owningControllerId,omitempty"` VolumeTags []VolumeTag `json:"metaTags,omitempty"` }
type VolumeEx ¶
type VolumeEx struct { IsOffline bool `json:"offline"` Label string `json:"label"` VolumeSize string `json:"capacity"` SegmentSize int `json:"segmentSize"` VolumeRef string `json:"volumeRef"` VolumeGroupRef string `json:"volumeGroupRef"` Mappings []LUNMapping `json:"listOfMappings"` IsMapped bool `json:"mapped"` VolumeTags []VolumeTag `json:"metadata"` }
type VolumeGroupEx ¶
type VolumeGroupEx struct { IsOffline bool `json:"offline"` WorldWideName string `json:"worldWideName"` VolumeGroupRef string `json:"volumeGroupRef"` Label string `json:"label"` FreeSpace string `json:"freeSpace"` // Documentation says this is an int but really it is a string! DriveMediaType string `json:"driveMediaType"` // 'hdd', 'ssd' }