Class: Google::Apis::VmmigrationV1::ComputeEngineTargetDetails

Inherits:
Object
  • Object
show all
Includes:
Core::Hashable, Core::JsonObjectSupport
Defined in:
lib/google/apis/vmmigration_v1/classes.rb,
lib/google/apis/vmmigration_v1/representations.rb,
lib/google/apis/vmmigration_v1/representations.rb

Overview

ComputeEngineTargetDetails is a collection of details for creating a VM in a target Compute Engine project.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ ComputeEngineTargetDetails

Returns a new instance of ComputeEngineTargetDetails.



1302
1303
1304
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1302

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#additional_licensesArray<String>

Additional licenses to assign to the VM. Corresponds to the JSON property additionalLicenses

Returns:

  • (Array<String>)


1207
1208
1209
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1207

def additional_licenses
  @additional_licenses
end

#applied_licenseGoogle::Apis::VmmigrationV1::AppliedLicense

AppliedLicense holds the license data returned by adaptation module report. Corresponds to the JSON property appliedLicense



1212
1213
1214
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1212

def applied_license
  @applied_license
end

#boot_optionString

The VM Boot Option, as set in the source VM. Corresponds to the JSON property bootOption

Returns:

  • (String)


1217
1218
1219
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1217

def boot_option
  @boot_option
end

#compute_schedulingGoogle::Apis::VmmigrationV1::ComputeScheduling

Scheduling information for VM on maintenance/restart behaviour and node allocation in sole tenant nodes. Corresponds to the JSON property computeScheduling



1223
1224
1225
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1223

def compute_scheduling
  @compute_scheduling
end

#disk_typeString

The disk type to use in the VM. Corresponds to the JSON property diskType

Returns:

  • (String)


1228
1229
1230
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1228

def disk_type
  @disk_type
end

#encryptionGoogle::Apis::VmmigrationV1::Encryption

Encryption message describes the details of the applied encryption. Corresponds to the JSON property encryption



1233
1234
1235
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1233

def encryption
  @encryption
end

#hostnameString

The hostname to assign to the VM. Corresponds to the JSON property hostname

Returns:

  • (String)


1238
1239
1240
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1238

def hostname
  @hostname
end

#labelsHash<String,String>

A map of labels to associate with the VM. Corresponds to the JSON property labels

Returns:

  • (Hash<String,String>)


1243
1244
1245
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1243

def labels
  @labels
end

#license_typeString

The license type to use in OS adaptation. Corresponds to the JSON property licenseType

Returns:

  • (String)


1248
1249
1250
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1248

def license_type
  @license_type
end

#machine_typeString

The machine type to create the VM with. Corresponds to the JSON property machineType

Returns:

  • (String)


1253
1254
1255
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1253

def machine_type
  @machine_type
end

#machine_type_seriesString

The machine type series to create the VM with. Corresponds to the JSON property machineTypeSeries

Returns:

  • (String)


1258
1259
1260
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1258

def machine_type_series
  @machine_type_series
end

#metadataHash<String,String>

The metadata key/value pairs to assign to the VM. Corresponds to the JSON property metadata

Returns:

  • (Hash<String,String>)


1263
1264
1265
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1263

def 
  @metadata
end

#network_interfacesArray<Google::Apis::VmmigrationV1::NetworkInterface>

List of NICs connected to this VM. Corresponds to the JSON property networkInterfaces



1268
1269
1270
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1268

def network_interfaces
  @network_interfaces
end

#network_tagsArray<String>

A list of network tags to associate with the VM. Corresponds to the JSON property networkTags

Returns:

  • (Array<String>)


1273
1274
1275
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1273

def network_tags
  @network_tags
end

#projectString

The Google Cloud target project ID or project name. Corresponds to the JSON property project

Returns:

  • (String)


1278
1279
1280
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1278

def project
  @project
end

#secure_bootBoolean Also known as: secure_boot?

Defines whether the instance has Secure Boot enabled. This can be set to true only if the VM boot option is EFI. Corresponds to the JSON property secureBoot

Returns:

  • (Boolean)


1284
1285
1286
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1284

def secure_boot
  @secure_boot
end

#service_accountString

The service account to associate the VM with. Corresponds to the JSON property serviceAccount

Returns:

  • (String)


1290
1291
1292
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1290

def 
  @service_account
end

#vm_nameString

The name of the VM to create. Corresponds to the JSON property vmName

Returns:

  • (String)


1295
1296
1297
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1295

def vm_name
  @vm_name
end

#zoneString

The zone in which to create the VM. Corresponds to the JSON property zone

Returns:

  • (String)


1300
1301
1302
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1300

def zone
  @zone
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



1307
1308
1309
1310
1311
1312
1313
1314
1315
1316
1317
1318
1319
1320
1321
1322
1323
1324
1325
1326
1327
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1307

def update!(**args)
  @additional_licenses = args[:additional_licenses] if args.key?(:additional_licenses)
  @applied_license = args[:applied_license] if args.key?(:applied_license)
  @boot_option = args[:boot_option] if args.key?(:boot_option)
  @compute_scheduling = args[:compute_scheduling] if args.key?(:compute_scheduling)
  @disk_type = args[:disk_type] if args.key?(:disk_type)
  @encryption = args[:encryption] if args.key?(:encryption)
  @hostname = args[:hostname] if args.key?(:hostname)
  @labels = args[:labels] if args.key?(:labels)
  @license_type = args[:license_type] if args.key?(:license_type)
  @machine_type = args[:machine_type] if args.key?(:machine_type)
  @machine_type_series = args[:machine_type_series] if args.key?(:machine_type_series)
  @metadata = args[:metadata] if args.key?(:metadata)
  @network_interfaces = args[:network_interfaces] if args.key?(:network_interfaces)
  @network_tags = args[:network_tags] if args.key?(:network_tags)
  @project = args[:project] if args.key?(:project)
  @secure_boot = args[:secure_boot] if args.key?(:secure_boot)
  @service_account = args[:service_account] if args.key?(:service_account)
  @vm_name = args[:vm_name] if args.key?(:vm_name)
  @zone = args[:zone] if args.key?(:zone)
end