Browse Source

small cleanups

pull/1/head
Nils Decker 9 years ago
parent
commit
cf9eea02f6
  1. 50
      fritzbox_upnp/service.go
  2. 14
      main.go

50
fritzbox_upnp/service.go

@ -20,15 +20,15 @@ import (
const text_xml = `text/xml; charset="utf-8"`
var ErrResultWithoutChardata = errors.New("result without chardata")
var ErrInvalidSOAPResponse = errors.New("invalid SOAP response")
type Root struct {
BaseUrl string
Device UpnpDevice `xml:"device"`
Services map[string]*UpnpService
Device Device `xml:"device"`
Services map[string]*Service
}
type UpnpDevice struct {
type Device struct {
root *Root
DeviceType string `xml:"deviceType"`
@ -41,14 +41,14 @@ type UpnpDevice struct {
ModelUrl string `xml:"modelURL"`
UDN string `xml:"UDN"`
Services []*UpnpService `xml:"serviceList>service"`
Devices []*UpnpDevice `xml:"deviceList>device"`
Services []*Service `xml:"serviceList>service"`
Devices []*Device `xml:"deviceList>device"`
PresentationUrl string `xml:"presentationURL"`
}
type UpnpService struct {
Device *UpnpDevice
type Service struct {
Device *Device
ServiceType string `xml:"serviceType"`
ServiceId string `xml:"serviceId"`
@ -56,24 +56,24 @@ type UpnpService struct {
EventSubUrl string `xml:"eventSubURL"`
SCPDUrl string `xml:"SCPDURL"`
Actions map[string]*UpnpAction
StateVariables []*UpnpStateVariable
Actions map[string]*Action
StateVariables []*StateVariable
}
type upnpScpd struct {
Actions []*UpnpAction `xml:"actionList>action"`
StateVariables []*UpnpStateVariable `xml:"serviceStateTable>stateVariable"`
type scpdRoot struct {
Actions []*Action `xml:"actionList>action"`
StateVariables []*StateVariable `xml:"serviceStateTable>stateVariable"`
}
type UpnpAction struct {
service *UpnpService
type Action struct {
service *Service
Name string `xml:"name"`
Arguments []*Argument `xml:"argumentList>argument"`
ArgumentMap map[string]*Argument
}
func (a *UpnpAction) IsGetOnly() bool {
func (a *Action) IsGetOnly() bool {
for _, a := range a.Arguments {
if a.Direction == "in" {
return false
@ -86,10 +86,10 @@ type Argument struct {
Name string `xml:"name"`
Direction string `xml:"direction"`
RelatedStateVariable string `xml:"relatedStateVariable"`
StateVariable *UpnpStateVariable
StateVariable *StateVariable
}
type UpnpStateVariable struct {
type StateVariable struct {
Name string `xml:"name"`
DataType string `xml:"dataType"`
DefaultValue string `xml:"defaultValue"`
@ -113,11 +113,11 @@ func (r *Root) load() error {
return err
}
r.Services = make(map[string]*UpnpService)
r.Services = make(map[string]*Service)
return r.Device.fillServices(r)
}
func (d *UpnpDevice) fillServices(r *Root) error {
func (d *Device) fillServices(r *Root) error {
d.root = r
for _, s := range d.Services {
@ -128,7 +128,7 @@ func (d *UpnpDevice) fillServices(r *Root) error {
return err
}
var scpd upnpScpd
var scpd scpdRoot
dec := xml.NewDecoder(response.Body)
err = dec.Decode(&scpd)
@ -136,7 +136,7 @@ func (d *UpnpDevice) fillServices(r *Root) error {
return err
}
s.Actions = make(map[string]*UpnpAction)
s.Actions = make(map[string]*Action)
for _, a := range scpd.Actions {
s.Actions[a.Name] = a
}
@ -168,7 +168,7 @@ func (d *UpnpDevice) fillServices(r *Root) error {
return nil
}
func (a *UpnpAction) Call() (Result, error) {
func (a *Action) Call() (Result, error) {
bodystr := fmt.Sprintf(`
<?xml version='1.0' encoding='utf-8'?>
<s:Envelope s:encodingStyle='http://schemas.xmlsoap.org/soap/encoding/' xmlns:s='http://schemas.xmlsoap.org/soap/envelope/'>
@ -204,7 +204,7 @@ func (a *UpnpAction) Call() (Result, error) {
}
func (a *UpnpAction) parseSoapResponse(r io.Reader) (Result, error) {
func (a *Action) parseSoapResponse(r io.Reader) (Result, error) {
res := make(Result)
dec := xml.NewDecoder(r)
@ -234,7 +234,7 @@ func (a *UpnpAction) parseSoapResponse(r io.Reader) (Result, error) {
case xml.CharData:
val = string(element)
default:
return nil, ErrResultWithoutChardata
return nil, ErrInvalidSOAPResponse
}
converted, err := convertResult(val, arg)

14
main.go

@ -32,6 +32,7 @@ type Metric struct {
OkValue string
Desc *prometheus.Desc
MetricType prometheus.ValueType
}
var metrics = []*Metric{
@ -45,6 +46,8 @@ var metrics = []*Metric{
[]string{"gateway"},
nil,
),
MetricType: prometheus.CounterValue,
},
{
Service: "urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1",
@ -56,6 +59,7 @@ var metrics = []*Metric{
[]string{"gateway"},
nil,
),
MetricType: prometheus.CounterValue,
},
{
Service: "urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1",
@ -67,6 +71,7 @@ var metrics = []*Metric{
[]string{"gateway"},
nil,
),
MetricType: prometheus.CounterValue,
},
{
Service: "urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1",
@ -78,6 +83,7 @@ var metrics = []*Metric{
[]string{"gateway"},
nil,
),
MetricType: prometheus.CounterValue,
},
{
Service: "urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1",
@ -89,6 +95,7 @@ var metrics = []*Metric{
[]string{"gateway"},
nil,
),
MetricType: prometheus.GaugeValue,
},
{
Service: "urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1",
@ -100,6 +107,7 @@ var metrics = []*Metric{
[]string{"gateway"},
nil,
),
MetricType: prometheus.GaugeValue,
},
{
Service: "urn:schemas-upnp-org:service:WANCommonInterfaceConfig:1",
@ -112,6 +120,7 @@ var metrics = []*Metric{
[]string{"gateway"},
nil,
),
MetricType: prometheus.GaugeValue,
},
{
Service: "urn:schemas-upnp-org:service:WANIPConnection:1",
@ -124,6 +133,7 @@ var metrics = []*Metric{
[]string{"gateway"},
nil,
),
MetricType: prometheus.GaugeValue,
},
{
Service: "urn:schemas-upnp-org:service:WANIPConnection:1",
@ -135,6 +145,7 @@ var metrics = []*Metric{
[]string{"gateway"},
nil,
),
MetricType: prometheus.GaugeValue,
},
}
@ -211,11 +222,10 @@ func (fc *FritzboxCollector) Collect(ch chan<- prometheus.Metric) {
ch <- prometheus.MustNewConstMetric(
m.Desc,
prometheus.CounterValue, // TODO
m.MetricType,
floatval,
fc.Gateway,
)
}
}

Loading…
Cancel
Save