Generate UnmarshalJSON to handle emptyStringInt types
This commit changes the code generator to generate a `UnmarshalJSON` for each struct, so that if unmarshalled it properly handles UniFis varying integer values via the `emptyStringInt` type. Structs not including a field of `int` type will still have the function generated, but it will effectively do nothing. Fixes #18
This commit is contained in:
committed by
Paul Tyng
parent
c5ff8c8593
commit
4aed7d703d
@@ -5,13 +5,15 @@ package unifi
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// just to fix compile issues with the import
|
||||
var (
|
||||
_ fmt.Formatter
|
||||
_ context.Context
|
||||
_ fmt.Formatter
|
||||
_ json.Marshaler
|
||||
)
|
||||
|
||||
type HotspotPackage struct {
|
||||
@@ -54,6 +56,35 @@ type HotspotPackage struct {
|
||||
TrialReset float64 `json:"trial_reset,omitempty"`
|
||||
}
|
||||
|
||||
func (dst *HotspotPackage) UnmarshalJSON(b []byte) error {
|
||||
type Alias HotspotPackage
|
||||
aux := &struct {
|
||||
Hours emptyStringInt `json:"hours"`
|
||||
Index emptyStringInt `json:"index"`
|
||||
LimitDown emptyStringInt `json:"limit_down"`
|
||||
LimitQuota emptyStringInt `json:"limit_quota"`
|
||||
LimitUp emptyStringInt `json:"limit_up"`
|
||||
TrialDurationMinutes emptyStringInt `json:"trial_duration_minutes"`
|
||||
|
||||
*Alias
|
||||
}{
|
||||
Alias: (*Alias)(dst),
|
||||
}
|
||||
|
||||
err := json.Unmarshal(b, &aux)
|
||||
if err != nil {
|
||||
return fmt.Errorf("unable to unmarshal alias: %w", err)
|
||||
}
|
||||
dst.Hours = int(aux.Hours)
|
||||
dst.Index = int(aux.Index)
|
||||
dst.LimitDown = int(aux.LimitDown)
|
||||
dst.LimitQuota = int(aux.LimitQuota)
|
||||
dst.LimitUp = int(aux.LimitUp)
|
||||
dst.TrialDurationMinutes = int(aux.TrialDurationMinutes)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c *Client) listHotspotPackage(ctx context.Context, site string) ([]HotspotPackage, error) {
|
||||
var respBody struct {
|
||||
Meta meta `json:"meta"`
|
||||
|
||||
Reference in New Issue
Block a user