Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added remote_copy_manager.rb file #5

Open
wants to merge 4 commits into
base: master
Choose a base branch
from
Open
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
293 changes: 293 additions & 0 deletions lib/Hpe3parSdk/remote_copy_manager.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,293 @@
require_relative 'util'
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add copyright

require_relative 'constants'
require_relative 'exceptions'
require_relative 'ssh'
require_relative 'models'

module Hpe3parSdk
class RemoteCopyManager
def initialize(http, ssh)
@http = http
@ssh = ssh
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add here
@remotecopy_uri = '/remotecopy'
@remotecopygroup_uri = '/remotecopygroups'

end

def get_remote_copy_info()
response, body = @http.get('/remotecopy')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add the endpoint urls in the initialize method for 'remotecopy' and 'remotecopygroups'
And change it to response, body = @http.get(@host_uri) and similarly make changes everywhere else for remotecopy and remotecopygroup

body
end

def get_remote_copy_groups()
response, body = @http.get('/remotecopygroups', body: info)
body
end

def get_remote_copy_group(name)
response, body = @http.get('/remotecopygroups/#{name}')
body
end

def create_remote_copy_group(name, targets, optional = nil)
info = { 'name' => name,
'targets' => targets
}
info = Util.merge_hash(info, optional) if optional
response, body = @http.post('/remotecopygroups', body: info)
body
end

def remove_remote_copy_group(name, keep_snap = false)
if keep_snap
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This check is not needed, you can directly pass the keep_snap in the query.
@http.delete('/remotecopygroups/#{name}?keepSnap=#{keep_snap}'

snap_query = true
else
snap_query = false
end
response, body = @http.delete('/remotecopygroups/#{name}?keepSnap=#{snap_query}')
body
end

def modify_remote_copy_group(name, optional = nil)
info = {}
info = Util.merge_hash(info, optional) if optional
response, body = @http.put('/remotecopygroups/#{name}', body: info)
body
end

def add_volume_to_remote_copy_group(name, volumeName, targets, optional = nil, useHttpPost = false)
if not useHttpPost
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Create info hash variable outside the if condition in order to reduce similar lines of code and depending on the useHttpPost check add the action key to the info hash.

info = { 'action' => 1,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Don't hard code the value for action in the script. Add them in the constants.rb and access them here. This will give more clarity to what exactly action means for values.
This applies to all the places in the script where action is hard-coded.

'volumeName' => volumeName,
'targets' => targets
}
info = Util.merge_hash(info, optional) if optional
response, body = @http.put('/remotecopygroups/#{name}/volumes', body: info)
else
info = { 'volumeName' => volumeName,
'targets' => targets
}
info = Util.merge_hash(info, optional) if optional
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

move the below two lines outside the if condition as they are being repeated in if-else condition.
info = Util.merge_hash(info, optional) if optional
response, body = @http.post('/remotecopygroups/#{name}/volumes', body: info)

response, body = @http.post('/remotecopygroups/#{name}/volumes', body: info)
end
body
end

def remove_volume_from_remote_copy_group(name, volumeName, optional = nil, removeFromTarget = false, useHttpDelete = false)
if not useHttpDelete
if removeFromTarget
if optional
keep_snap = optional.fetch('keepSnap', false)
else
keep_snap = false
end

if keep_snap
cmd = ['dismissrcopyvv', '-f', '-keepsnap', '-removevv', volumeName, name]
command = cmd.join(" ")
else
cmd = ['dismissrcopyvv', '-f', '-removevv', volumeName, name]
command = cmd.join(" ")
end
@ssh.run(command)
else
info = { 'action' => 2, 'volumeName': volumeName }
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Correct it to
info = { 'action' => 2, 'volumeName' => volumeName } or use info = { 'action': 2, 'volumeName' : volumeName }

info = Util.merge_hash(info, optional) if optional
response, body = @http.put('/remotecopygroups/#{name}', body: info)
end
else
option = nil
if optional and optional.get('keepSnap') and removeFromTarget
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does .get() work or should it be fetch()?

raise "keepSnap and removeFromTarget cannot be bpoth\
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Typo mistake. Correct it to both

true while removing the volume from remote copy group"
else if optional and optional.get('keepSnap')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does .get() work or should it be fetch()?

option = 'keepSnap'
else if removeFromTarget
option = 'removeSecondaryVolume'
end
delete_url = '/remotecopygroups/#{name}/volumes/#{volumeName}'
if option
delete_url += '?#{option}=true'
end
response, body = @http.delete(delete_url)
end
body
end

def start_remote_copy_group(name, optional = nil)
info = { 'action' => 3 }
info = Util.merge_hash(info, optional) if optional
response, body = @http.put('/remotecopygroups/#{name}', body: info)
body
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Check here whether the response header will contain the necessary useful info or the body for the PUT calls and return accordingly.

end

def stop_remote_copy_group(name, optional = nil)
info = { 'action' => 4 }
info = Util.merge_hash(info, optional) if optional
response, body = @http.put('/remotecopygroups/#{name}', body: info)
body
end

def synchronize_remote_copy_group(name, optional = nil)
info = { 'action' => 5 }
info = Util.merge_hash(info, optional) if optional
volumes_url = '/remotecopygroups/#{name}'
@http.put(volumes_url, body: info)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add the volumes_url to the this line, no need to create a variable.

end

def recover_remote_copy_group(name, action, optional = nil)
info = { 'action' => action }
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add the action value to the constants and remove it from the method definition.

info = Util.merge_hash(info, optional) if optional
volumes_url = '/remotecopygroups/#{name}'
response, body = @http.put(volumes_url, body: info)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Add the volumes_url to the this line, no need to create a variable.

body
end

def admit_remote_copy_links( targetName, source_port, target_port_wwn_or_ip)
source_target_port_pair = source_port + ':' + target_port_wwn_or_ip
begin
cmd = ['admitrcopylink', targetName, source_target_port_pair]
command = cmd.join(" ")
response = @ssh.run(command)
if response != []
raise Hpe3parSdk::HPE3PARException(message: response)
end
rescue Hpe3parSdk::HPE3PARException => ex
raise Hpe3parSdk::HPE3PARException(ex.message)
end
response
end

def dismiss_remote_copy_links( targetName, source_port, target_port_wwn_or_ip)
source_target_port_pair = source_port + ':' + target_port_wwn_or_ip
begin
cmd = ['dismissrcopylink', targetName, source_target_port_pair]
command = cmd.join(" ")
response = @ssh.run(command)
if response != []
raise Hpe3parSdk::HPE3PARException(message: response)
end
rescue Hpe3parSdk::HPE3PARException => ex
raise Hpe3parSdk::HPE3PARException(ex.message)
end
response
end

def start_rcopy()
begin
cmd = ['startrcopy']
response = @ssh.run(cmd)
if response != []
raise Hpe3parSdk::HPE3PARException(message: response)
end
rescue Hpe3parSdk::HPE3PARException => ex
raise Hpe3parSdk::HPE3PARException(ex.message)
end
response
end

def rcopy_service_exists()
cmd = ['showrcopy']
response = @ssh.run(cmd)
rcopyservice_status = false
if response[2].include?('Started')
rcopyservice_status = true
end
rcopyservice_status
end

def get_remote_copy_link(link_name)
response, body = @http.get('/remotecopylinks/#{link_name}')
body
end

def rcopy_link_exists(targetName, local_port, target_system_peer_port)
rcopylink_exits = false
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

rename it to rcopylink_exists

link_name = targetName + '_' + local_port.replace(':', '_')
begin
response = get_remote_copy_link(link_name)
if response and response['address'] == target_system_peer_port
rcopylink_exits = true
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

rename it to rcopylink_exists

end
rescue Hpe3parSdk::HTTPNotFound => ex
pass
end
rcopylink_exits
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

rename it to rcopylink_exists

end

def admit_remote_copy_target( targetName, mode, remote_copy_group_name,
source_target_volume_pairs_list=[])
if source_target_volume_pairs_list == []
cmd = ['admitrcopytarget', targetName, mode, remote_copy_group_name]
else
cmd = ['admitrcopytarget', targetName, mode, remote_copy_group_name]
for volume_pair_tuple in source_target_volume_pairs_list
source_target_pair = volume_pair_tuple[0] + ':' + volume_pair_tuple[1]
cmd << source_target_pair
end
end
begin
command = cmd.join(" ")
response = @ssh.run(command)
if response != []
raise Hpe3parSdk::HPE3PARException(message: response)
end
rescue Hpe3parSdk::HPE3PARException => ex
raise Hpe3parSdk::HPE3PARException(ex.message)
end
response
end

def dismiss_remote_copy_target( targetName, remote_copy_group_name)
option = '-f'
cmd = ['dismissrcopytarget', option, targetName, remote_copy_group_name]
begin
command = cmd.join(" ")
response = @ssh.run(command)
if response != []
raise Hpe3parSdk::HPE3PARException(message: response)
end
rescue Hpe3parSdk::HPE3PARException => ex
raise Hpe3parSdk::HPE3PARException(ex.message)
end
response
end

def target_in_remote_copy_group_exists( target_name, remote_copy_group_name)
begin
contents = self.get_remote_copy_group(remote_copy_group_name)
for item in contents['targets']
if item['target'] == target_name
return true
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we returning true for all items? or we need to do it once all the items are iterated?

end
end
rescue Hpe3parSdk::HPE3PARException => ex
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are we not doing anything in the exception?

end
return false
end

def check_response(resp)
for r in resp
if 'error' in r.downcase or 'invalid' in r.downcase or 'the schedule format' in r.downcase
return r.strip
end
end
end

def create_schedule(schedule_name, task, taskfreq='@hourly')
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Move schedule client methods to new file. Also, move check_reponse() in the new file.

cmd = ['createsched']
cmd << "\""+task+"\""
if '@' not in taskfreq
cmd << "\""+taskfreq+"\""
else
cmd << taskfreq
end
cmd << schedule_name
begin
command = cmd.join(" ")
response = @ssh.run(command)
err_resp = check_response(response)
if err_resp
raise Hpe3parSdk::HPE3PARException(message: err_resp)
end
rescue Hpe3parSdk::HPE3PARException => ex
raise Hpe3parSdk::HPE3PARException(ex.message)
end
end