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.



1359
1360
1361
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1359

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>)


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

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



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

def applied_license
  @applied_license
end

#boot_conversionString

Optional. By default the virtual machine will keep its existing boot option. Setting this property will trigger an internal process which will convert the virtual machine from using the existing boot option to another. Corresponds to the JSON property bootConversion

Returns:

  • (String)


1256
1257
1258
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1256

def boot_conversion
  @boot_conversion
end

#boot_optionString

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

Returns:

  • (String)


1261
1262
1263
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1261

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. Options for instance behavior when the host machine undergoes maintenance that may temporarily impact instance performance. Corresponds to the JSON property computeScheduling



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

def compute_scheduling
  @compute_scheduling
end

#disk_typeString

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

Returns:

  • (String)


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

def disk_type
  @disk_type
end

#enable_integrity_monitoringBoolean Also known as: enable_integrity_monitoring?

Optional. Defines whether the instance has integrity monitoring enabled. Corresponds to the JSON property enableIntegrityMonitoring

Returns:

  • (Boolean)


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

def enable_integrity_monitoring
  @enable_integrity_monitoring
end

#enable_vtpmBoolean Also known as: enable_vtpm?

Optional. Defines whether the instance has vTPM enabled. Corresponds to the JSON property enableVtpm

Returns:

  • (Boolean)


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

def enable_vtpm
  @enable_vtpm
end

#encryptionGoogle::Apis::VmmigrationV1::Encryption

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



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

def encryption
  @encryption
end

#hostnameString

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

Returns:

  • (String)


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

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>)


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

def labels
  @labels
end

#license_typeString

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

Returns:

  • (String)


1305
1306
1307
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1305

def license_type
  @license_type
end

#machine_typeString

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

Returns:

  • (String)


1310
1311
1312
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1310

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)


1315
1316
1317
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1315

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>)


1320
1321
1322
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1320

def 
  @metadata
end

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

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



1325
1326
1327
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1325

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>)


1330
1331
1332
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1330

def network_tags
  @network_tags
end

#projectString

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

Returns:

  • (String)


1335
1336
1337
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1335

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)


1341
1342
1343
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1341

def secure_boot
  @secure_boot
end

#service_accountString

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

Returns:

  • (String)


1347
1348
1349
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1347

def 
  @service_account
end

#vm_nameString

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

Returns:

  • (String)


1352
1353
1354
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1352

def vm_name
  @vm_name
end

#zoneString

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

Returns:

  • (String)


1357
1358
1359
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1357

def zone
  @zone
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



1364
1365
1366
1367
1368
1369
1370
1371
1372
1373
1374
1375
1376
1377
1378
1379
1380
1381
1382
1383
1384
1385
1386
1387
# File 'lib/google/apis/vmmigration_v1/classes.rb', line 1364

def update!(**args)
  @additional_licenses = args[:additional_licenses] if args.key?(:additional_licenses)
  @applied_license = args[:applied_license] if args.key?(:applied_license)
  @boot_conversion = args[:boot_conversion] if args.key?(:boot_conversion)
  @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)
  @enable_integrity_monitoring = args[:enable_integrity_monitoring] if args.key?(:enable_integrity_monitoring)
  @enable_vtpm = args[:enable_vtpm] if args.key?(:enable_vtpm)
  @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