Fix uint out of value parsing for > 4 GiB traffic usage
This commit is contained in:
		@@ -1268,7 +1268,7 @@ func (client *WANCommonInterfaceConfig1) GetMaximumActiveConnections() (NewMaxim
 | 
				
			|||||||
	return
 | 
						return
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (client *WANCommonInterfaceConfig1) GetTotalBytesSent() (NewTotalBytesSent uint32, err error) {
 | 
					func (client *WANCommonInterfaceConfig1) GetTotalBytesSent() (NewTotalBytesSent uint64, err error) {
 | 
				
			||||||
	// Request structure.
 | 
						// Request structure.
 | 
				
			||||||
	request := interface{}(nil)
 | 
						request := interface{}(nil)
 | 
				
			||||||
	// BEGIN Marshal arguments into request.
 | 
						// BEGIN Marshal arguments into request.
 | 
				
			||||||
@@ -1287,14 +1287,14 @@ func (client *WANCommonInterfaceConfig1) GetTotalBytesSent() (NewTotalBytesSent
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	// BEGIN Unmarshal arguments from response.
 | 
						// BEGIN Unmarshal arguments from response.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if NewTotalBytesSent, err = soap.UnmarshalUi4(response.NewTotalBytesSent); err != nil {
 | 
						if NewTotalBytesSent, err = soap.UnmarshalUi8(response.NewTotalBytesSent); err != nil {
 | 
				
			||||||
		return
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	// END Unmarshal arguments from response.
 | 
						// END Unmarshal arguments from response.
 | 
				
			||||||
	return
 | 
						return
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (client *WANCommonInterfaceConfig1) GetTotalBytesReceived() (NewTotalBytesReceived uint32, err error) {
 | 
					func (client *WANCommonInterfaceConfig1) GetTotalBytesReceived() (NewTotalBytesReceived uint64, err error) {
 | 
				
			||||||
	// Request structure.
 | 
						// Request structure.
 | 
				
			||||||
	request := interface{}(nil)
 | 
						request := interface{}(nil)
 | 
				
			||||||
	// BEGIN Marshal arguments into request.
 | 
						// BEGIN Marshal arguments into request.
 | 
				
			||||||
@@ -1313,7 +1313,7 @@ func (client *WANCommonInterfaceConfig1) GetTotalBytesReceived() (NewTotalBytesR
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	// BEGIN Unmarshal arguments from response.
 | 
						// BEGIN Unmarshal arguments from response.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if NewTotalBytesReceived, err = soap.UnmarshalUi4(response.NewTotalBytesReceived); err != nil {
 | 
						if NewTotalBytesReceived, err = soap.UnmarshalUi8(response.NewTotalBytesReceived); err != nil {
 | 
				
			||||||
		return
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	// END Unmarshal arguments from response.
 | 
						// END Unmarshal arguments from response.
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -43,6 +43,27 @@ var dcpMetadata = []DCPMetadata{
 | 
				
			|||||||
		OfficialName: "Internet Gateway Device v1",
 | 
							OfficialName: "Internet Gateway Device v1",
 | 
				
			||||||
		DocURL:       "http://upnp.org/specs/gw/UPnP-gw-InternetGatewayDevice-v1-Device.pdf",
 | 
							DocURL:       "http://upnp.org/specs/gw/UPnP-gw-InternetGatewayDevice-v1-Device.pdf",
 | 
				
			||||||
		XMLSpecURL:   "http://upnp.org/specs/gw/UPnP-gw-IGD-TestFiles-20010921.zip",
 | 
							XMLSpecURL:   "http://upnp.org/specs/gw/UPnP-gw-IGD-TestFiles-20010921.zip",
 | 
				
			||||||
 | 
							Hacks: []DCPHackFn{
 | 
				
			||||||
 | 
								func(dcp *DCP) error {
 | 
				
			||||||
 | 
									for _, service := range dcp.Services {
 | 
				
			||||||
 | 
										if service.URN == "urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1" {
 | 
				
			||||||
 | 
											variables := service.SCPD.StateVariables
 | 
				
			||||||
 | 
											for key, variable := range variables {
 | 
				
			||||||
 | 
												varName := variable.Name
 | 
				
			||||||
 | 
												if varName == "TotalBytesSent" || varName == "TotalBytesReceived" {
 | 
				
			||||||
 | 
													// Fix size of total bytes which is by default ui4 or maximum 4 GiB.
 | 
				
			||||||
 | 
													variable.DataType.Name = "ui8"
 | 
				
			||||||
 | 
													variables[key] = variable
 | 
				
			||||||
 | 
												}
 | 
				
			||||||
 | 
											}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
											break
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									return nil
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
		Name:         "internetgateway2",
 | 
							Name:         "internetgateway2",
 | 
				
			||||||
@@ -370,6 +391,7 @@ var typeConvs = map[string]conv{
 | 
				
			|||||||
	"ui1":         conv{"Ui1", "uint8"},
 | 
						"ui1":         conv{"Ui1", "uint8"},
 | 
				
			||||||
	"ui2":         conv{"Ui2", "uint16"},
 | 
						"ui2":         conv{"Ui2", "uint16"},
 | 
				
			||||||
	"ui4":         conv{"Ui4", "uint32"},
 | 
						"ui4":         conv{"Ui4", "uint32"},
 | 
				
			||||||
 | 
						"ui8":         conv{"Ui8", "uint64"},
 | 
				
			||||||
	"i1":          conv{"I1", "int8"},
 | 
						"i1":          conv{"I1", "int8"},
 | 
				
			||||||
	"i2":          conv{"I2", "int16"},
 | 
						"i2":          conv{"I2", "int16"},
 | 
				
			||||||
	"i4":          conv{"I4", "int32"},
 | 
						"i4":          conv{"I4", "int32"},
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -47,6 +47,15 @@ func UnmarshalUi4(s string) (uint32, error) {
 | 
				
			|||||||
	return uint32(v), err
 | 
						return uint32(v), err
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func MarshalUi8(v uint64) (string, error) {
 | 
				
			||||||
 | 
						return strconv.FormatUint(v, 10), nil
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func UnmarshalUi8(s string) (uint64, error) {
 | 
				
			||||||
 | 
						v, err := strconv.ParseUint(s, 10, 64)
 | 
				
			||||||
 | 
						return uint64(v), err
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func MarshalI1(v int8) (string, error) {
 | 
					func MarshalI1(v int8) (string, error) {
 | 
				
			||||||
	return strconv.FormatInt(int64(v), 10), nil
 | 
						return strconv.FormatInt(int64(v), 10), nil
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user