-
Notifications
You must be signed in to change notification settings - Fork 80
/
Copy pathazure_subnets.rb
99 lines (86 loc) · 4.21 KB
/
azure_subnets.rb
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
require "azure_generic_resources"
class AzureSubnets < AzureGenericResources
name "azure_subnets"
desc "Verifies settings for Azure Virtual Network Subnets"
example <<-EXAMPLE
describe azure_subnets(resource_group: 'RESOURCE_GROUP_NAME', vnet: 'VIRTUAL_NETWORK_NAME') do
it { should exist }
end
EXAMPLE
attr_reader :table
def initialize(opts = {})
# Options should be Hash type. Otherwise Ruby will raise an error when we try to access the keys.
raise ArgumentError, "Parameters must be provided in an Hash object." unless opts.is_a?(Hash)
# Azure REST API endpoint URL format listing all subnets in a virtual network:
# GET https://management.azure.com/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/
# Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets?api-version=2020-05-01
#
# The dynamic part that has to be created for this resource:
# Microsoft.Network/virtualNetworks/{virtualNetworkName}/subnets?api-version=2020-05-01
#
# Parameters acquired from environment variables:
# - {subscriptionId} => Required parameter. It will be acquired by the backend from environment variables.
#
# For parameters applicable to all resources, see project's README.
#
# User supplied parameters:
# - resource_group => Required parameter unless `resource_id` is provided. {resourceGroupName}
# - vnet => Required parameter unless `resource_id` is provided. Virtual network name. {virtualNetworkName}
# It has to be defined as a required parameter.
# opts[:required_parameters] = %i(vnet)
# - api_version => Optional parameter. The latest version will be used unless provided. api-version
#
# **`resource_group` will be added into the URL appropriately in the backend.
# We don't have to do anything here except making it mandatory (required) parameter.
#
# Following resource parameters have to be defined/created here.
# resource_provider => Microsoft.Network/virtualNetworks
# resource_path => {virtualNetworkName}/subnets
#
# The `specific_resource_constraint` method will validate the user input
# not to accept a different `resource_provider`.
#
opts[:resource_provider] = specific_resource_constraint("Microsoft.Network/virtualNetworks", opts)
opts[:required_parameters] = %i(resource_group vnet)
# Unless provided here, a generic display name will be created in the backend.
opts[:display_name] = "Subnets for #{opts[:vnet]} Virtual Network"
opts[:resource_path] = [opts[:vnet], "subnets"].join("/")
# static_resource parameter must be true for setting the resource_provider in the backend.
super(opts, true)
# Check if the resource is failed.
# It is recommended to check that after every usage of inherited methods or making API calls.
return if failed_resource?
# Define the column and field names for FilterTable.
# In most cases, the `column` should be the pluralized form of the `field`.
# @see https://github.com/inspec/inspec/blob/master/docs/dev/filtertable-usage.md
table_schema = [
{ column: :names, field: :name },
{ column: :etags, field: :etag },
{ column: :ids, field: :id },
]
# FilterTable is populated at the very end due to being an expensive operation.
AzureGenericResources.populate_filter_table(:table, table_schema)
end
def to_s
super(AzureSubnets)
end
end
# Provide the same functionality under the old resource name.
# This is for backward compatibility.
class AzurermSubnets < AzureSubnets
name "azurerm_subnets"
desc "Verifies settings for Azure Virtual Network Subnets"
example <<-EXAMPLE
azurerm_subnets(resource_group: 'example', vnet: 'virtual-network-name') do
it{ should exist }
end
EXAMPLE
def initialize(opts = {})
Inspec::Log.warn Helpers.resource_deprecation_message(@__resource_name__, AzureSubnets.name)
# Options should be Hash type. Otherwise Ruby will raise an error when we try to access the keys.
raise ArgumentError, "Parameters must be provided in an Hash object." unless opts.is_a?(Hash)
# For backward compatibility.
opts[:api_version] ||= "2018-02-01"
super
end
end