-
Notifications
You must be signed in to change notification settings - Fork 7
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
base: master
Are you sure you want to change the base?
Changes from 3 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,293 @@ | ||
require_relative 'util' | ||
require_relative 'constants' | ||
require_relative 'exceptions' | ||
require_relative 'ssh' | ||
require_relative 'models' | ||
|
||
module Hpe3parSdk | ||
class RemoteCopyManager | ||
def initialize(http, ssh) | ||
@http = http | ||
@ssh = ssh | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Add here |
||
end | ||
|
||
def get_remote_copy_info() | ||
response, body = @http.get('/remotecopy') | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Add the endpoint urls in the initialize method for 'remotecopy' and 'remotecopygroups' |
||
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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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. |
||
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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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. |
||
'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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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. |
||
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 } | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Correct it to |
||
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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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\ | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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') | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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 } | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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') | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe 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 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add copyright