1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
|
# frozen_string_literal: true
require 'addressable'
module Fog
module Compute
class Aliyun
class Real
def delete_security_group_ip_rule(securitygroup_id, sourceCidrIp, nicType, option = {})
# {Aliyun API Reference}[https://docs.aliyun.com/?spm=5176.100054.3.1.DGkmH7#/pub/ecs/open-api/securitygroup&revokesecuritygroup]
action = 'RevokeSecurityGroup'
sigNonce = randonStr
time = Time.new.utc
parameters = defaultParameters(action, sigNonce, time)
pathUrl = defaultAliyunUri(action, sigNonce, time)
parameters['SecurityGroupId'] = securitygroup_id
pathUrl += '&SecurityGroupId='
pathUrl += securitygroup_id
parameters['SourceCidrIp'] = sourceCidrIp
pathUrl += '&SourceCidrIp='
pathUrl += Addressable::URI.encode_component(sourceCidrIp, Addressable::URI::CharacterClasses::UNRESERVED + '|')
nicType ||= 'intranet'
parameters['NicType'] = nicType
pathUrl += '&NicType='
pathUrl += nicType
portRange = option[:portRange]
portRange ||= '-1/-1'
parameters['PortRange'] = portRange
pathUrl += '&PortRange='
pathUrl += Addressable::URI.encode_component(portRange, Addressable::URI::CharacterClasses::UNRESERVED + '|')
protocol = option[:protocol]
protocol ||= 'all'
parameters['IpProtocol'] = protocol
pathUrl += '&IpProtocol='
pathUrl += protocol
policy = option[:policy]
policy ||= 'accept'
parameters['Policy'] = policy
pathUrl += '&Policy='
pathUrl += policy
priority = option[:priority]
priority ||= '1'
parameters['Priority'] = priority
pathUrl += '&Priority='
pathUrl += priority
signature = sign(@aliyun_accesskey_secret, parameters)
pathUrl += '&Signature='
pathUrl += signature
request(
expects: [200, 203],
method: 'GET',
path: pathUrl
)
end
end
end
end
end
|