-
Notifications
You must be signed in to change notification settings - Fork 119
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add Supermicro OEM AccountService (#374)
This adds an OEM version of the AccountService to expose a few OEM-specific properties. Signed-off-by: Sean McGinnis <[email protected]>
- Loading branch information
1 parent
0cb0c9c
commit 7257532
Showing
3 changed files
with
182 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
// | ||
// SPDX-License-Identifier: BSD-3-Clause | ||
// | ||
|
||
package smc | ||
|
||
import ( | ||
"encoding/json" | ||
|
||
"github.com/stmcginnis/gofish/redfish" | ||
) | ||
|
||
// AccountService is a Supermicro OEM instance of an AccountService. | ||
type AccountService struct { | ||
redfish.AccountService | ||
SMCLDAP struct { | ||
StartTLSEnabled bool | ||
} | ||
SMCActiveDirectory struct { | ||
DNSLookupEnable bool | ||
Prefix string | ||
Port int | ||
UserDomainNames []string | ||
DynamicServerAddresses []string | ||
} | ||
} | ||
|
||
// FromAccountService converts a standard AccountService object to the OEM implementation. | ||
func FromAccountService(accountService *redfish.AccountService) (*AccountService, error) { | ||
as := AccountService{ | ||
AccountService: *accountService, | ||
} | ||
|
||
var t struct { | ||
Oem struct { | ||
Supermicro struct { | ||
LDAP struct { | ||
StartTLSEnabled bool | ||
} `json:"LDAP"` | ||
ActiveDirectory struct { | ||
DNSLookupEnable bool | ||
Prefix string | ||
Port int | ||
UserDomainNames []string | ||
DynamicServerAddresses []string | ||
} `json:"ActiveDirectory"` | ||
} `json:"Supermicro"` | ||
} `json:"Oem"` | ||
} | ||
|
||
err := json.Unmarshal(accountService.RawData, &t) | ||
if err != nil { | ||
return nil, err | ||
} | ||
|
||
as.SMCLDAP.StartTLSEnabled = t.Oem.Supermicro.LDAP.StartTLSEnabled | ||
as.SMCActiveDirectory.DNSLookupEnable = t.Oem.Supermicro.ActiveDirectory.DNSLookupEnable | ||
as.SMCActiveDirectory.Prefix = t.Oem.Supermicro.ActiveDirectory.Prefix | ||
as.SMCActiveDirectory.Port = t.Oem.Supermicro.ActiveDirectory.Port | ||
as.SMCActiveDirectory.UserDomainNames = t.Oem.Supermicro.ActiveDirectory.UserDomainNames | ||
as.SMCActiveDirectory.DynamicServerAddresses = t.Oem.Supermicro.ActiveDirectory.DynamicServerAddresses | ||
|
||
return &as, nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,114 @@ | ||
// | ||
// SPDX-License-Identifier: BSD-3-Clause | ||
// | ||
|
||
package smc | ||
|
||
import ( | ||
"encoding/json" | ||
"testing" | ||
|
||
"github.com/stmcginnis/gofish/redfish" | ||
) | ||
|
||
var accountServiceBody = `{ | ||
"@odata.type": "#AccountService.v1_7_2.AccountService", | ||
"@odata.id": "/redfish/v1/AccountService", | ||
"Id": "AccountService", | ||
"Name": "Account Service", | ||
"Description": "Account Service", | ||
"Status": { | ||
"State": "Enabled", | ||
"Health": "OK" | ||
}, | ||
"ServiceEnabled": true, | ||
"MinPasswordLength": 8, | ||
"MaxPasswordLength": 20, | ||
"AuthFailureLoggingThreshold": 3, | ||
"AccountLockoutThreshold": 3, | ||
"AccountLockoutDuration": 30, | ||
"AccountLockoutCounterResetAfter": 30, | ||
"Accounts": { | ||
"@odata.id": "/redfish/v1/AccountService/Accounts" | ||
}, | ||
"Roles": { | ||
"@odata.id": "/redfish/v1/AccountService/Roles" | ||
}, | ||
"LDAP": { | ||
"AccountProviderType": "LDAPService", | ||
"ServiceEnabled": false, | ||
"ServiceAddresses": [], | ||
"Authentication": { | ||
"AuthenticationType": "UsernameAndPassword", | ||
"Username": "", | ||
"Password": null, | ||
"Oem": {} | ||
}, | ||
"PasswordSet": false, | ||
"RemoteRoleMapping": [], | ||
"LDAPService": { | ||
"SearchSettings": { | ||
"BaseDistinguishedNames": [] | ||
}, | ||
"Oem": {} | ||
} | ||
}, | ||
"ActiveDirectory": { | ||
"AccountProviderType": "ActiveDirectoryService", | ||
"ServiceEnabled": false, | ||
"ServiceAddresses": [], | ||
"Authentication": { | ||
"AuthenticationType": "UsernameAndPassword", | ||
"Username": "", | ||
"Password": null, | ||
"Oem": {} | ||
}, | ||
"PasswordSet": false, | ||
"RemoteRoleMapping": [] | ||
}, | ||
"Oem": { | ||
"Supermicro": { | ||
"@odata.type": "#SmcAccountServiceExtensions.v1_0_1.AccountService", | ||
"LDAP": { | ||
"StartTLSEnabled": true | ||
}, | ||
"ActiveDirectory": { | ||
"DNSLookupEnable": true, | ||
"Prefix": "ldap", | ||
"Port": 389, | ||
"UserDomainNames": ["example.com"], | ||
"DynamicServerAddresses": [] | ||
} | ||
} | ||
}, | ||
"@odata.etag": "\"01dc844f1c2c3fae22b77263291f161b\"" | ||
}` | ||
|
||
// TestSmcAccountServiceOem tests the parsing of the AccountService oem field | ||
func TestSmcAccountServiceOem(t *testing.T) { | ||
drive := &redfish.AccountService{} | ||
if err := json.Unmarshal([]byte(accountServiceBody), drive); err != nil { | ||
t.Fatalf("error decoding json: %v", err) | ||
} | ||
|
||
accountService, err := FromAccountService(drive) | ||
if err != nil { | ||
t.Fatalf("error getting oem info from drive: %v", err) | ||
} | ||
|
||
if accountService.ID != "AccountService" { | ||
t.Errorf("unexpected ID: %s", accountService.ID) | ||
} | ||
|
||
if !accountService.SMCLDAP.StartTLSEnabled { | ||
t.Errorf("unexpected StartTLSEnabled state: %t", accountService.SMCLDAP.StartTLSEnabled) | ||
} | ||
|
||
if !accountService.SMCActiveDirectory.DNSLookupEnable || | ||
accountService.SMCActiveDirectory.Prefix != "ldap" || | ||
accountService.SMCActiveDirectory.Port != 389 || | ||
len(accountService.SMCActiveDirectory.UserDomainNames) != 1 || | ||
accountService.SMCActiveDirectory.UserDomainNames[0] != "example.com" { | ||
t.Errorf("unexpected ActiveDirectory settings: %+v", accountService.SMCActiveDirectory) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters