133 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
| package main
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 
 | |
| 	"github.com/unpoller/unpoller/pkg/poller"
 | |
| 	"golift.io/cnfg"
 | |
| )
 | |
| 
 | |
| // Only capital (exported) members are unmarshaled when passed into poller.NewOutput().
 | |
| type plugin struct {
 | |
| 	*Config `json:"mysql" toml:"mysql" xml:"mysql" yaml:"mysql"`
 | |
| 	poller.Collect
 | |
| }
 | |
| 
 | |
| var _ poller.OutputPlugin = &plugin{}
 | |
| 
 | |
| // Config represents the data that is unmarshalled from the up.conf config file for this plugins.
 | |
| // See up.conf.example.mysql for sample input data.
 | |
| type Config struct {
 | |
| 	Disable  bool          `json:"disable"  toml:"disable"  xml:"disable"  yaml:"disable"`
 | |
| 	Interval cnfg.Duration `json:"interval" toml:"interval" xml:"interval" yaml:"interval"`
 | |
| 	Host     string        `json:"host"     toml:"host"     xml:"host"     yaml:"host"`
 | |
| 	User     string        `json:"user"     toml:"user"     xml:"user"     yaml:"user"`
 | |
| 	Pass     string        `json:"pass"     toml:"pass"     xml:"pass"     yaml:"pass"`
 | |
| 	DB       string        `json:"db"       toml:"db"       xml:"db"       yaml:"db"`
 | |
| 	Devices  []Device      `json:"devices"  toml:"devices"  xml:"device"   yaml:"devices"`
 | |
| 	Clients  *Clients      `json:"clients"  toml:"clients"  xml:"clients"  yaml:"clients"`
 | |
| }
 | |
| 
 | |
| // Device represents the configuration to save a devices' data.
 | |
| // Type is one of uap, usw, ugw, udm.
 | |
| // Table represents the mysql table name we save these fields to.
 | |
| // Fields is a map of api response data key -> mysql column.
 | |
| type Device struct {
 | |
| 	Type   string            `json:"type"   toml:"type"   xml:"type"  yaml:"type"`
 | |
| 	Table  string            `json:"table"  toml:"table"  xml:"table" yaml:"table"`
 | |
| 	Fields map[string]string `json:"fields" toml:"fields" xml:"field" yaml:"fields"`
 | |
| }
 | |
| 
 | |
| // Clients represents the configuration to save clients' data.
 | |
| // Table represents the mysql table name we save these fields to.
 | |
| // Fields is a map of api response data key -> mysql column.
 | |
| type Clients struct {
 | |
| 	Table  string            `json:"table"  toml:"table"  xml:"table" yaml:"table"`
 | |
| 	Fields map[string]string `json:"fields" toml:"fields" xml:"field" yaml:"fields"`
 | |
| }
 | |
| 
 | |
| func init() {
 | |
| 	u := &plugin{Config: &Config{}}
 | |
| 
 | |
| 	poller.NewOutput(&poller.Output{
 | |
| 		Name:         "mysql",
 | |
| 		Config:       u, // pass in the struct *above* your config (so it can see the struct tags).
 | |
| 		OutputPlugin: u,
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func (p *plugin) Enabled() bool {
 | |
| 	if p == nil {
 | |
| 		return false
 | |
| 	}
 | |
| 	
 | |
| 	if p.Config == nil {
 | |
| 		return false
 | |
| 	}
 | |
| 	
 | |
| 	if p.Collect == nil {
 | |
| 		return false
 | |
| 	}
 | |
| 
 | |
| 	return !p.Disable
 | |
| }
 | |
| 
 | |
| func (p *plugin) DebugOutput() (bool, error) {
 | |
| 	if p == nil {
 | |
| 		return true, nil
 | |
| 	}
 | |
| 	
 | |
| 	if !p.Enabled() {
 | |
| 		return true, nil
 | |
| 	}
 | |
| 	
 | |
| 	if err := p.validateConfig(); err != nil {
 | |
| 		return false, err
 | |
| 	}
 | |
| 	
 | |
| 	return true, nil
 | |
| }
 | |
| 
 | |
| // Run gets called by poller core code. Return when the plugin stops working or has an error.
 | |
| // In other words, don't run your code in a go routine, it already is.
 | |
| func (p *plugin) Run(c poller.Collect) error {
 | |
| 	p.Collect = c
 | |
| 	if p.Config == nil || !p.Enabled() {
 | |
| 		return nil // no config or disabled, bail out.
 | |
| 	}
 | |
| 
 | |
| 	if err := p.validateConfig(); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	return p.runCollector()
 | |
| }
 | |
| 
 | |
| // validateConfig checks input sanity.
 | |
| func (p *plugin) validateConfig() error {
 | |
| 	if p.Interval.Duration == 0 {
 | |
| 		return fmt.Errorf("must provide a polling interval")
 | |
| 	}
 | |
| 
 | |
| 	if p.Clients == nil && len(p.Devices) == 0 {
 | |
| 		return fmt.Errorf("must configure client or device collection; both empty")
 | |
| 	}
 | |
| 
 | |
| 	for _, d := range p.Devices {
 | |
| 		if len(d.Fields) == 0 {
 | |
| 			return fmt.Errorf("no fields defined for device type %s, table %s", d.Type, d.Table)
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if p.Clients != nil && p.Clients.Fields == nil {
 | |
| 		return fmt.Errorf("no fields defined for clients; if you don't want to store client data, remove it from the config")
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // main() is required, but it shouldn't do much as it's not used in plugin mode.
 | |
| func main() {
 | |
| 	fmt.Println("this is a unifi-poller plugin; not an application")
 | |
| }
 |