Skip to content

Commit

Permalink
fix lighthouse import
Browse files Browse the repository at this point in the history
  • Loading branch information
mikatong committed Jan 30, 2024
1 parent e8fd943 commit 3e9ff88
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ func ResourceTencentCloudLighthouseInstance() *schema.Resource {
},
"period": {
Type: schema.TypeInt,
Required: true,
Optional: true,
Description: "Subscription period in months. Valid values: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 24, 36, 48, 60.",
},
"renew_flag": {
Expand All @@ -61,6 +61,7 @@ func ResourceTencentCloudLighthouseInstance() *schema.Resource {
"zone": {
Type: schema.TypeString,
Optional: true,
Computed: true,
Description: "List of availability zones. A random AZ is selected by default.",
},
"dry_run": {
Expand Down Expand Up @@ -206,6 +207,16 @@ func ResourceTencentCloudLighthouseInstance() *schema.Resource {
Computed: true,
Description: "Firewall template ID. If this parameter is not specified, the default firewall policy is used.",
},
"public_address": {
Type: schema.TypeString,
Computed: true,
Description: "Public address.",
},
"private_address": {
Type: schema.TypeString,
Computed: true,
Description: "Private address.",
},
},
}
}
Expand Down Expand Up @@ -259,7 +270,7 @@ func resourceTencentCloudLighthouseInstanceCreate(d *schema.ResourceData, meta i
if v, ok := loginConfigurationMap["auto_generate_password"]; ok {
loginConfiguration.AutoGeneratePassword = helper.String(v.(string))
}
if v, ok := loginConfigurationMap["password"]; ok {
if v, ok := loginConfigurationMap["password"]; ok && v.(string) != "" {
loginConfiguration.Password = helper.String(v.(string))
}
request.LoginConfiguration = &loginConfiguration
Expand Down Expand Up @@ -406,6 +417,14 @@ func resourceTencentCloudLighthouseInstanceRead(d *schema.ResourceData, meta int
_ = d.Set("zone", instance.Zone)
}

if len(instance.PublicAddresses) > 0 {
_ = d.Set("public_address", instance.PublicAddresses[0])
}

if len(instance.PrivateAddresses) > 0 {
_ = d.Set("private_address", instance.PrivateAddresses[0])
}

return nil
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ func TestAccTencentCloudLighthouseInstanceResource_basic(t *testing.T) {
t.Parallel()

resource.Test(t, resource.TestCase{
PreCheck: func() { tcacctest.AccPreCheckCommon(t, tcacctest.ACCOUNT_TYPE_PREPAY) },
PreCheck: func() { tcacctest.AccPreCheck(t) },
Providers: tcacctest.AccProviders,
Steps: []resource.TestStep{
{
Expand Down
5 changes: 3 additions & 2 deletions website/docs/r/lighthouse_instance.html.markdown
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,6 @@ The following arguments are supported:
* `blueprint_id` - (Required, String) ID of the Lighthouse image.
* `bundle_id` - (Required, String) ID of the Lighthouse package.
* `instance_name` - (Required, String) The display name of the Lighthouse instance.
* `period` - (Required, Int) Subscription period in months. Valid values: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 24, 36, 48, 60.
* `renew_flag` - (Required, String) Auto-Renewal flag. Valid values: NOTIFY_AND_AUTO_RENEW: notify upon expiration and renew automatically; NOTIFY_AND_MANUAL_RENEW: notify upon expiration but do not renew automatically. You need to manually renew DISABLE_NOTIFY_AND_AUTO_RENEW: neither notify upon expiration nor renew automatically. Default value: NOTIFY_AND_MANUAL_RENEW.
* `client_token` - (Optional, String) A unique string supplied by the client to ensure that the request is idempotent. Its maximum length is 64 ASCII characters. If this parameter is not specified, the idem-potency of the request cannot be guaranteed.
* `containers` - (Optional, List) Configuration of the containers to create.
Expand All @@ -102,6 +101,7 @@ The following arguments are supported:
* `is_update_bundle_id_auto_voucher` - (Optional, Bool) Whether the voucher is deducted automatically when update bundle id. Value range: `true`: indicates automatic deduction of vouchers, `false`: does not automatically deduct vouchers. Default value: `false`.
* `isolate_data_disk` - (Optional, Bool) Whether to return the mounted data disk. `true`: returns both the instance and the mounted data disk; `false`: returns the instance and no longer returns its mounted data disk. Default: `true`.
* `login_configuration` - (Optional, List) Login password of the instance. It is only available for Windows instances. If it is not specified, it means that the user choose to set the login password after the instance creation.
* `period` - (Optional, Int) Subscription period in months. Valid values: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 24, 36, 48, 60.
* `permit_default_key_pair_login` - (Optional, String, **Deprecated**) It has been deprecated from version v1.81.8. Use `tencentcloud_lighthouse_key_pair_attachment` manage key pair. Whether to allow login using the default key pair. `YES`: allow login; `NO`: disable login. Default: `YES`.
* `zone` - (Optional, String) List of availability zones. A random AZ is selected by default.

Expand Down Expand Up @@ -141,7 +141,8 @@ The `volumes` object of `containers` supports the following:
In addition to all arguments above, the following attributes are exported:

* `id` - ID of the resource.

* `private_address` - Private address.
* `public_address` - Public address.


## Import
Expand Down

0 comments on commit 3e9ff88

Please sign in to comment.