Fix type of x_ssh_keys

The `unifi_settings_mgmt` resource fails for me with the following error:

```
Error: unable to decode body: GET s/default/get/setting/mgmt unable to unmarshal alias: json: cannot unmarshal object into Go struct field .x_ssh_keys of type string
```

My `x_ssh_keys` looks like this:

```
[
  {
    "name": "Laptop",
    "type": "ssh-rsa",
    "key": "REDACTED",
    "comment": "REDACTED",
    "date": "2021-02-25T08:26:04Z",
    "fingerprint": "REDACTED"
  }
]
```
This commit is contained in:
Joshua Spence
2021-06-12 14:04:32 +10:00
committed by Paul Tyng
parent fbed685c37
commit dd685c0447
2 changed files with 60 additions and 17 deletions

View File

@@ -306,6 +306,24 @@ func main() {
f.OmitEmpty = true f.OmitEmpty = true
return nil return nil
} }
case "SettingMgmt":
sshKeyField := NewFieldInfo(resource.StructName+"XSshKeys", "x_ssh_keys", "struct", "", false, false)
sshKeyField.Fields = map[string]*FieldInfo{
"name": NewFieldInfo("name", "name", "string", "", false, false),
"keyType": NewFieldInfo("keyType", "type", "string", "", false, false),
"key": NewFieldInfo("key", "key", "string", "", false, false),
"comment": NewFieldInfo("comment", "comment", "string", "", false, false),
"date": NewFieldInfo("date", "date", "string", "", false, false),
"fingerprint": NewFieldInfo("fingerprint", "fingerprint", "string", "", false, false),
}
resource.Types[sshKeyField.FieldName] = sshKeyField
resource.FieldProcessor = func(name string, f *FieldInfo) error {
if name == "XSshKeys" {
f.FieldType = sshKeyField.FieldName
}
return nil
}
case "SettingUsg": case "SettingUsg":
resource.FieldProcessor = func(name string, f *FieldInfo) error { resource.FieldProcessor = func(name string, f *FieldInfo) error {
if strings.HasSuffix(name, "Timeout") && name != "ArpCacheTimeout" { if strings.HasSuffix(name, "Timeout") && name != "ArpCacheTimeout" {

View File

@@ -27,23 +27,23 @@ type SettingMgmt struct {
Key string `json:"key"` Key string `json:"key"`
AdvancedFeatureEnabled bool `json:"advanced_feature_enabled"` AdvancedFeatureEnabled bool `json:"advanced_feature_enabled"`
AlertEnabled bool `json:"alert_enabled"` AlertEnabled bool `json:"alert_enabled"`
AutoUpgrade bool `json:"auto_upgrade"` AutoUpgrade bool `json:"auto_upgrade"`
BootSound bool `json:"boot_sound"` BootSound bool `json:"boot_sound"`
LedEnabled bool `json:"led_enabled"` LedEnabled bool `json:"led_enabled"`
OutdoorModeEnabled bool `json:"outdoor_mode_enabled"` OutdoorModeEnabled bool `json:"outdoor_mode_enabled"`
UnifiIDpEnabled bool `json:"unifi_idp_enabled"` UnifiIDpEnabled bool `json:"unifi_idp_enabled"`
WifimanEnabled bool `json:"wifiman_enabled"` WifimanEnabled bool `json:"wifiman_enabled"`
XMgmtKey string `json:"x_mgmt_key,omitempty"` // [0-9a-f]{32} XMgmtKey string `json:"x_mgmt_key,omitempty"` // [0-9a-f]{32}
XSshAuthPasswordEnabled bool `json:"x_ssh_auth_password_enabled"` XSshAuthPasswordEnabled bool `json:"x_ssh_auth_password_enabled"`
XSshBindWildcard bool `json:"x_ssh_bind_wildcard"` XSshBindWildcard bool `json:"x_ssh_bind_wildcard"`
XSshEnabled bool `json:"x_ssh_enabled"` XSshEnabled bool `json:"x_ssh_enabled"`
XSshKeys []string `json:"x_ssh_keys,omitempty"` XSshKeys []SettingMgmtXSshKeys `json:"x_ssh_keys,omitempty"`
XSshMd5Passwd string `json:"x_ssh_md5passwd,omitempty"` XSshMd5Passwd string `json:"x_ssh_md5passwd,omitempty"`
XSshPassword string `json:"x_ssh_password,omitempty"` // .{1,128} XSshPassword string `json:"x_ssh_password,omitempty"` // .{1,128}
XSshSha512Passwd string `json:"x_ssh_sha512passwd,omitempty"` XSshSha512Passwd string `json:"x_ssh_sha512passwd,omitempty"`
XSshUsername string `json:"x_ssh_username,omitempty"` // ^[_A-Za-z0-9][-_.A-Za-z0-9]{0,29}$ XSshUsername string `json:"x_ssh_username,omitempty"` // ^[_A-Za-z0-9][-_.A-Za-z0-9]{0,29}$
} }
func (dst *SettingMgmt) UnmarshalJSON(b []byte) error { func (dst *SettingMgmt) UnmarshalJSON(b []byte) error {
@@ -62,6 +62,31 @@ func (dst *SettingMgmt) UnmarshalJSON(b []byte) error {
return nil return nil
} }
type SettingMgmtXSshKeys struct {
comment string `json:"comment"`
date string `json:"date"`
fingerprint string `json:"fingerprint"`
key string `json:"key"`
keyType string `json:"type"`
name string `json:"name"`
}
func (dst *SettingMgmtXSshKeys) UnmarshalJSON(b []byte) error {
type Alias SettingMgmtXSshKeys
aux := &struct {
*Alias
}{
Alias: (*Alias)(dst),
}
err := json.Unmarshal(b, &aux)
if err != nil {
return fmt.Errorf("unable to unmarshal alias: %w", err)
}
return nil
}
func (c *Client) getSettingMgmt(ctx context.Context, site string) (*SettingMgmt, error) { func (c *Client) getSettingMgmt(ctx context.Context, site string) (*SettingMgmt, error) {
var respBody struct { var respBody struct {
Meta meta `json:"meta"` Meta meta `json:"meta"`