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:
Hendrik "T4cC0re" Meyer
2021-01-02 09:40:52 +01:00
committed by Paul Tyng
parent c5ff8c8593
commit 4aed7d703d
67 changed files with 2298 additions and 155 deletions

View File

@@ -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 UserGroup struct {
@@ -28,6 +30,27 @@ type UserGroup struct {
QOSRateMaxUp int `json:"qos_rate_max_up,omitempty"` // -1|[2-9]|[1-9][0-9]{1,4}|100000
}
func (dst *UserGroup) UnmarshalJSON(b []byte) error {
type Alias UserGroup
aux := &struct {
QOSRateMaxDown emptyStringInt `json:"qos_rate_max_down"`
QOSRateMaxUp emptyStringInt `json:"qos_rate_max_up"`
*Alias
}{
Alias: (*Alias)(dst),
}
err := json.Unmarshal(b, &aux)
if err != nil {
return fmt.Errorf("unable to unmarshal alias: %w", err)
}
dst.QOSRateMaxDown = int(aux.QOSRateMaxDown)
dst.QOSRateMaxUp = int(aux.QOSRateMaxUp)
return nil
}
func (c *Client) listUserGroup(ctx context.Context, site string) ([]UserGroup, error) {
var respBody struct {
Meta meta `json:"meta"`