annotate adslstats.py @ 28:b474c873357d

add speed check script
author Daniel O'Connor <darius@dons.net.au>
date Sun, 12 Aug 2018 17:39:32 +0930
parents 607111929e2e
children 08cddcdb0db3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
1 #!/usr/bin/env python2
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
2 ############################################################################
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
3 #
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
4 # Parse DSL link stats for iiNet TG-1 & generate RRD archives & graphs
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
5 #
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
6 ############################################################################
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
7 #
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
8 # Copyright (C) 2017 Daniel O'Connor. All rights reserved.
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
9 #
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
10 # Redistribution and use in source and binary forms, with or without
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
11 # modification, are permitted provided that the following conditions
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
12 # are met:
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
13 # 1. Redistributions of source code must retain the above copyright
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
14 # notice, this list of conditions and the following disclaimer.
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
15 # 2. Redistributions in binary form must reproduce the above copyright
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
16 # notice, this list of conditions and the following disclaimer in the
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
17 # documentation and/or other materials provided with the distribution.
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
18 #
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
19 # THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
20 # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
21 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
22 # ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
23 # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
24 # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
25 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
26 # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
27 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
28 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
29 # SUCH DAMAGE.
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
30 #
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
31 ############################################################################
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
32
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
33 import base64
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
34 import binascii
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
35 import bs4
1
a795b6cd8b1a Add command line options.
Daniel O'Connor <darius@dons.net.au>
parents: 0
diff changeset
36 import ConfigParser
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
37 import json
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
38 import mechanize
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
39 import mysrp as srp
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
40 import argparse
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
41 import os
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
42 import os.path
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
43 import re
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
44 import requests
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
45 import rrdtool
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
46 import sys
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
47 import time
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
48 import urllib
1
a795b6cd8b1a Add command line options.
Daniel O'Connor <darius@dons.net.au>
parents: 0
diff changeset
49
a795b6cd8b1a Add command line options.
Daniel O'Connor <darius@dons.net.au>
parents: 0
diff changeset
50 conf = ConfigParser.ConfigParser()
a795b6cd8b1a Add command line options.
Daniel O'Connor <darius@dons.net.au>
parents: 0
diff changeset
51 conf.add_section('global')
a795b6cd8b1a Add command line options.
Daniel O'Connor <darius@dons.net.au>
parents: 0
diff changeset
52
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
53 conflist = []
1
a795b6cd8b1a Add command line options.
Daniel O'Connor <darius@dons.net.au>
parents: 0
diff changeset
54 if ('HOME' in os.environ):
a795b6cd8b1a Add command line options.
Daniel O'Connor <darius@dons.net.au>
parents: 0
diff changeset
55 conflist.append(os.path.expanduser('~/.adslstats.ini'))
a795b6cd8b1a Add command line options.
Daniel O'Connor <darius@dons.net.au>
parents: 0
diff changeset
56 conf.read(conflist)
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
57
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
58 usage = '''%prog [options]'''
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
59 parser = argparse.ArgumentParser(usage)
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
60 parser.add_argument('-v', '--verbose', action='store_true', default=False,
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
61 help='Enable debug output')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
62 parser.add_argument('-g', '--graph', action='store_true', default=False,
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
63 help='Generate a graph')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
64 parser.add_argument('-u', '--update', action='store_true', default=False,
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
65 help='Update RRD (implies -d)')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
66 parser.add_argument('-m', '--munin', action='store', default=None,
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
67 help='Output munin data for ARG')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
68 parser.add_argument('-a', '--username', action='store',
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
69 help='Username to login to modem')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
70 parser.add_argument('-p', '--password', action='store',
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
71 help='Password to login to modem')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
72 parser.add_argument('-n', '--name', action='store',
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
73 help='Hostname of modem')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
74 parser.add_argument('-b', '--base', action='store',
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
75 help='Base directory for RRD & PNGs')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
76 parser.add_argument('-c', '--cookiejar', action='store',
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
77 help='Location of cookiejar')
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
78
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
79 args = parser.parse_args()
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
80
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
81 # Handle options from conf and override with ini
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
82 def opthelper(args, conf, optname):
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
83 if args.__getattribute__(optname) == None:
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
84 if not conf.has_option('global', optname):
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
85 parser.error(optname + ' must be specified in config file or via commandline')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
86 else:
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
87 args.__setattr__(optname, conf.get('global', optname))
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
88
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
89 opthelper(args, conf, 'username')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
90 opthelper(args, conf, 'password')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
91 opthelper(args, conf, 'name')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
92 opthelper(args, conf, 'base')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
93 opthelper(args, conf, 'cookiejar')
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
94
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
95 # Expand path names
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
96 args.cookiejar = os.path.expanduser(args.cookiejar)
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
97 args.base = os.path.expanduser(args.base)
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
98
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
99 rrdname = "%s.rrd" % (args.base)
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
100 graphbasename = args.base
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
101
16
425d02592dce Rename ADSL to DSL
Daniel O'Connor <darius@dons.net.au>
parents: 15
diff changeset
102 class DSLStats(object):
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
103 def __str__(self):
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
104 s = '''Line Rate - Up: %d kbits, Down %d kbits
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
105 Maximum Rate - Up: %d kbit, Down %s kbit
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
106 Noise Margin - Up: %.1f dB, Down %.1f dB
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
107 Attenuation - Up: %.1f dB, Down %.1f dB
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
108 Power - Up: %.1f dBm, Down %.1f dBm
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
109 Uptime - %d sec''' % (self.upstream, self.downstream,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
110 self.upstreammax, self.downstreammax,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
111 self.nmup, self.nmdown,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
112 self.attenup, self.attendown,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
113 self.uppower, self.downpower,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
114 self.uptime)
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
115 return s
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
116
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
117 def getstats():
16
425d02592dce Rename ADSL to DSL
Daniel O'Connor <darius@dons.net.au>
parents: 15
diff changeset
118 stats = DSLStats()
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
119 parser = ConfigParser.ConfigParser()
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
120 base = 'http://%s' % (args.name)
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
121 br = mechanize.Browser()
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
122 #br.set_debug_http(True)
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
123 #br.set_debug_responses(True)
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
124 #br.set_debug_redirects(True)
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
125 cj = mechanize.LWPCookieJar()
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
126 if os.path.exists(args.cookiejar):
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
127 cj.load(args.cookiejar, ignore_discard = True)
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
128 br.set_cookiejar(cj)
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
129 if not fillstats(br, base, stats):
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
130 if not authenticate(br, base, args.username, args.password):
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
131 print('login failed')
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
132 return None
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
133 #print('login succeeded, getting stats')
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
134 fillstats(br, base, stats)
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
135
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
136 cj.save(args.cookiejar, ignore_discard = True)
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
137 return stats
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
138
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
139 def authenticate(br, base, username, password):
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
140 # Connect and authenticate
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
141 r = br.open(base)
26
04874587fb6e suppress new BeautifulSoup warning
Daniel O'Connor <darius@dons.net.au>
parents: 25
diff changeset
142 bs = bs4.BeautifulSoup(r, 'lxml')
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
143 token = bs.head.find(lambda tag: tag.has_attr('name') and tag['name'] == 'CSRFtoken')['content']
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
144 #print('Got CSRF token ' + token)
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
145
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
146 usr = srp.User(username, password, hash_alg = srp.SHA256, ng_type = srp.NG_2048)
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
147 uname, A = usr.start_authentication()
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
148
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
149 req = mechanize.Request(base + '/authenticate', data = urllib.urlencode({'CSRFtoken' : token, 'I' : uname, 'A' : binascii.hexlify(A)}))
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
150 r = br.open(req)
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
151 j = json.decoder.JSONDecoder().decode(r.read())
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
152 #print('Sent challenge, got ' + str(j))
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
153
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
154 M = usr.process_challenge(binascii.unhexlify(j['s']), binascii.unhexlify(j['B']))
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
155 req = mechanize.Request(base + '/authenticate', data = urllib.urlencode({'CSRFtoken' : token, 'M' : binascii.hexlify(M)}))
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
156 r = br.open(req)
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
157 j = json.decoder.JSONDecoder().decode(r.read())
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
158 #print('Got response ' + str(j))
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
159
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
160 usr.verify_session(binascii.unhexlify(j['M']))
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
161 if not usr.authenticated():
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
162 print('Failed to authenticate')
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
163 return False
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
164 return True
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
165
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
166 def fillstats(br, base, stats):
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
167 # Fetch stats and parse
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
168 r = br.open(base + '/modals/broadband-bridge-modal.lp')
26
04874587fb6e suppress new BeautifulSoup warning
Daniel O'Connor <darius@dons.net.au>
parents: 25
diff changeset
169 bs = bs4.BeautifulSoup(r, 'lxml')
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
170 if bs.find('div', 'login') != None:
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
171 return False
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
172
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
173 # Helper function to extract data
24
806b1ed7f1b5 Get units right for speeds.
Daniel O'Connor <darius@dons.net.au>
parents: 23
diff changeset
174 def getvals(bs, text, mult = 1):
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
175 subs = bs.findAll('label', text = text)[0].fetchNextSiblings()[0].strings
24
806b1ed7f1b5 Get units right for speeds.
Daniel O'Connor <darius@dons.net.au>
parents: 23
diff changeset
176 tmp = map(lambda s: float(s.split()[0]), subs)
806b1ed7f1b5 Get units right for speeds.
Daniel O'Connor <darius@dons.net.au>
parents: 23
diff changeset
177 return map(lambda s: s * mult, tmp)
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
178
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
179 if map(None, bs.findAll('label', text = 'DSL Status')[0].fetchNextSiblings()[0].strings)[0] == 'Up':
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
180 stats.linkup = True
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
181 else:
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
182 stats.linkup = False
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
183
24
806b1ed7f1b5 Get units right for speeds.
Daniel O'Connor <darius@dons.net.au>
parents: 23
diff changeset
184 stats.upstreammax, stats.downstreammax = getvals(bs, 'Maximum Line rate', 1e3)
806b1ed7f1b5 Get units right for speeds.
Daniel O'Connor <darius@dons.net.au>
parents: 23
diff changeset
185 stats.upstream, stats.downstream = getvals(bs, 'Line Rate', 1e3)
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
186 stats.uppower, stats.downpower = getvals(bs, 'Output Power')
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
187 stats.nmup, stats.nmdown = getvals(bs, 'Noise Margin')
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
188
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
189 # Line attenuation returns several values for each direction, parse specially and just take the first one
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
190 upattens, downattens = map(None, bs.findAll('label', text = 'Line Attenuation')[0].fetchNextSiblings()[0].strings)
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
191 stats.attenup = float(re.findall('([0-9.N/A]+)', upattens)[0])
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
192 stats.attendown = float(re.findall('([0-9.N/A]+)', downattens)[0])
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
193
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
194 # Convert something like '2days 17hours 28min 19sec' into seconds
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
195 uptime = re.findall('([0-9]+)', map(None, bs.findAll('label', text = 'DSL Uptime')[0].fetchNextSiblings()[0].strings)[0])
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
196 uptime.reverse() # End up with an array of seconds, minutes, hours, etc
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
197 mults = [1, 60, 60 * 60, 24 * 60 * 60]
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
198 if len(uptime) > mults:
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
199 print('Too many uptime elements to work out')
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
200 stats.uptime = None
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
201 else:
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
202 stats.uptime = reduce(lambda a, b: a + b, map(lambda a: int(a[0]) * a[1], zip(uptime, mults)))
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
203
23
4b6c811e77df Save & load session cookie so we don't have to reauth every time.
Daniel O'Connor <darius@dons.net.au>
parents: 22
diff changeset
204 return True
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
205
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
206 # Setup RRD
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
207 # We expect data to be logged every 5 minutes
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
208 # Average 12 5 minute points -> hourly stats (keep 168 - a weeks worth)
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
209 # Average 288 5 minute points -> daily stats (keep 1825 - 5 years worth)
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
210 # Detemine minimum & maximum for an hour and keep a weeks worth.
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
211 def makerrd(filename):
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
212 rrdtool.create(filename,
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
213 '--step', '300',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
214 'DS:upstream:GAUGE:3600:32:150000', # Upstream (kbits)
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
215 'DS:downstream:GAUGE:3600:32:150000', # Downstream (kbits)
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
216 'DS:upstreammax:GAUGE:3600:32:150000', # Upstream maximum (kbits)
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
217 'DS:downstreammax:GAUGE:3600:32:150000', # Downstream maximum (kbits)
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
218 'DS:nmup:GAUGE:3600:0:100', # Upstream Noise margin (dB)
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
219 'DS:nmdown:GAUGE:3600:0:100', # Downstream Noise margin (dB)
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
220 'DS:attenup:GAUGE:3600:0:100', # Upstream Attenuation (dB)
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
221 'DS:attendown:GAUGE:3600:0:100', # Downstream Attenuation (dB)
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
222 'DS:fecATUC:DERIVE:3600:0:U', # Upstream FEC error count
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
223 'DS:fecATUR:DERIVE:3600:0:U', # Downstream FEC error count
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
224 'DS:powerup:GAUGE:3600:-100:100', # Upstream Power (dBm)
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
225 'DS:powerdown:GAUGE:3600:-100:100', # Downstream Power (dBm)
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
226 'DS:uptime:DERIVE:3600:0:U', # Uptime (seconds)
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
227 'RRA:AVERAGE:0.1:12:168',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
228 'RRA:AVERAGE:0.1:288:1825',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
229 'RRA:MIN:0.1:12:168',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
230 'RRA:MAX:0.1:12:168')
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
231
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
232 # Update the RRD (format stats as expected)
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
233 def updaterrd(filename, tstamp, stats):
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
234 rrdtool.update(filename,
22
a53f90508a06 Switch to TG-1.
Daniel O'Connor <darius@dons.net.au>
parents: 21
diff changeset
235 '%d:%d:%d:%d:%d:%f:%f:%f:%f:U:U:%f:%f:%d' % (
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
236 tstamp,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
237 stats.upstream,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
238 stats.downstream,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
239 stats.upstreammax,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
240 stats.downstreammax,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
241 stats.nmup,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
242 stats.nmdown,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
243 stats.attenup,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
244 stats.attendown,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
245 stats.uppower,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
246 stats.downpower,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
247 stats.uptime))
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
248
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
249 # Open the URL and call the parser
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
250 def getdata():
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
251 stats = getstats()
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
252 return stats
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
253
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
254 # Generate a graph
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
255 def gengraph():
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
256
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
257 linkargs = (
5
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
258 '-a', 'SVG',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
259 '-X', '0',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
260 '-l', '0',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
261 '--vertical-label', 'kbit/sec',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
262 '--slope-mode',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
263
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
264 'DEF:upstream=%s:upstream:AVERAGE' % rrdname,
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
265 'DEF:upstreammin=%s:upstream:MIN' % rrdname,
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
266 'DEF:upstreammax=%s:upstream:MAX' % rrdname,
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
267 'CDEF:upstreamdif=upstreammax,upstreammin,-',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
268 'DEF:maxupstream=%s:upstreammax:AVERAGE' % rrdname,
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
269
27
607111929e2e rrd no longer likes LINE0 so work around it
Daniel O'Connor <darius@dons.net.au>
parents: 26
diff changeset
270 'LINE0.001:upstreammin#000000:',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
271 'AREA:upstreamdif#00dc76::STACK',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
272 'LINE1:upstream#00ff00:Upstream',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
273
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
274 'LINE1:maxupstream#0000ff:Upstream (maximum)',
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
275
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
276 'DEF:downstream=%s:downstream:AVERAGE' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
277 'DEF:downstreammin=%s:downstream:MIN' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
278 'DEF:downstreammax=%s:downstream:MAX' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
279 'CDEF:downstreamdif=downstreammax,downstreammin,-',
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
280 'DEF:maxdownstream=%s:downstreammax:AVERAGE' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
281
27
607111929e2e rrd no longer likes LINE0 so work around it
Daniel O'Connor <darius@dons.net.au>
parents: 26
diff changeset
282 'LINE0.001:downstreammin#000000:',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
283 'AREA:downstreamdif#ff8686::STACK',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
284 'LINE1:downstream#ff0000:Downstream',
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
285
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
286 'LINE1:maxdownstream#000000:Downstream (maximum)'
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
287 )
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
288
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
289 signalargs = (
5
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
290 '-a', 'SVG',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
291 '--vertical-label', 'dB',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
292 '--slope-mode',
15
7dbe86981f6b Make minimum level of dB graph 0 to make reading lower values easier.
Daniel O'Connor <darius@dons.net.au>
parents: 14
diff changeset
293 '-l', '0',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
294
19
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
295 'DEF:nmup=%s:nmup:AVERAGE' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
296 'DEF:nmupmin=%s:nmup:MIN' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
297 'DEF:nmupmax=%s:nmup:MAX' % rrdname,
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
298
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
299 'CDEF:nmupdif=nmupmax,nmupmin,-',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
300
27
607111929e2e rrd no longer likes LINE0 so work around it
Daniel O'Connor <darius@dons.net.au>
parents: 26
diff changeset
301 'LINE0.001:nmupmin#000000:',
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
302 'AREA:nmupdif#5c5cff::STACK',
19
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
303 'LINE1:nmup#0000ff:Noise Margin - Up',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
304
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
305 'DEF:nmdown=%s:nmdown:AVERAGE' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
306 'DEF:nmdownmin=%s:nmdown:MIN' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
307 'DEF:nmdownmax=%s:nmdown:MAX' % rrdname,
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
308
19
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
309 'CDEF:nmdowndif=nmdownmax,nmdownmin,-',
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
310
27
607111929e2e rrd no longer likes LINE0 so work around it
Daniel O'Connor <darius@dons.net.au>
parents: 26
diff changeset
311 'LINE0.001:nmdownmin#000000:',
19
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
312 'AREA:nmdowndif#009a00::STACK',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
313 'LINE1:nmdown#00ff00:Noise Margin - Down',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
314
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
315 'DEF:attenup=%s:attenup:AVERAGE' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
316 'DEF:attenupmin=%s:attenup:MIN' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
317 'DEF:attenupmax=%s:attenup:MAX' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
318
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
319 'CDEF:attenupdif=attenupmax,attenupmin,-',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
320
27
607111929e2e rrd no longer likes LINE0 so work around it
Daniel O'Connor <darius@dons.net.au>
parents: 26
diff changeset
321 'LINE0.001:attenupmin#000000:',
19
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
322 'AREA:attenupdif#f98100::STACK',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
323 'LINE1:attenup#ff0000:Attenuation - Up',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
324
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
325 'DEF:attendown=%s:attendown:AVERAGE' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
326 'DEF:attendownmin=%s:attendown:MIN' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
327 'DEF:attendownmax=%s:attendown:MAX' % rrdname,
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
328
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
329 'CDEF:attendowndif=attendownmax,attendownmin,-',
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
330
27
607111929e2e rrd no longer likes LINE0 so work around it
Daniel O'Connor <darius@dons.net.au>
parents: 26
diff changeset
331 'LINE0.001:attendownmin#000000:',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
332 'AREA:attendowndif#aaaaaa::STACK',
19
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
333 'LINE1:attendown#000000:Attenuation - Down',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
334
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
335 'DEF:powerup=%s:powerup:AVERAGE' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
336 'DEF:powerupmin=%s:powerup:MIN' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
337 'DEF:powerupmax=%s:powerup:MAX' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
338
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
339 'CDEF:powerupdif=powerupmax,powerupmin,-',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
340
27
607111929e2e rrd no longer likes LINE0 so work around it
Daniel O'Connor <darius@dons.net.au>
parents: 26
diff changeset
341 'LINE0.001:powerupmin#000000:',
19
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
342 'AREA:powerupdif#804007::STACK',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
343 'LINE1:powerup#ff800e:Power - Up (dBm)',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
344
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
345 'DEF:powerdown=%s:powerdown:AVERAGE' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
346 'DEF:powerdownmin=%s:powerdown:MIN' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
347 'DEF:powerdownmax=%s:powerdown:MAX' % rrdname,
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
348
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
349 'CDEF:powerdowndif=powerdownmax,powerdownmin,-',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
350
27
607111929e2e rrd no longer likes LINE0 so work around it
Daniel O'Connor <darius@dons.net.au>
parents: 26
diff changeset
351 'LINE0.001:powerdownmin#000000:',
19
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
352 'AREA:powerdowndif#604872::STACK',
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
353 'LINE1:powerdown#c090e5:Power - Down (dBm)',
20
38e3804d4f80 Plot FEC errors (probably, hard to test)
Daniel O'Connor <darius@dons.net.au>
parents: 19
diff changeset
354
21
8c44182a2984 Plot uptime.
Daniel O'Connor <darius@dons.net.au>
parents: 20
diff changeset
355 'DEF:uptime=%s:uptime:AVERAGE' % rrdname,
8c44182a2984 Plot uptime.
Daniel O'Connor <darius@dons.net.au>
parents: 20
diff changeset
356 'CDEF:uptimepct=uptime,10,*',
8c44182a2984 Plot uptime.
Daniel O'Connor <darius@dons.net.au>
parents: 20
diff changeset
357 'LINE1:uptimepct#606060:Uptime (10\'s%)',
19
5bec78c876db Properly re-arrange signal graph entries, show power.
Daniel O'Connor <darius@dons.net.au>
parents: 18
diff changeset
358 )
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
359
5
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
360 rrdtool.graph("%s-hour-link.svg" % (graphbasename),
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
361 '--width', '768',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
362 '--height', '256',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
363 '--start', 'end - 7d',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
364 '--end', 'now',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
365 *linkargs)
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
366
5
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
367 rrdtool.graph("%s-daily-link.svg" % (graphbasename),
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
368 '--width', '768',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
369 '--height', '256',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
370 '--start', 'end - 365d',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
371 '--end', 'now',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
372 *linkargs)
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
373
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
374
5
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
375 rrdtool.graph("%s-hour-signal.svg" % (graphbasename),
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
376 '--width', '768',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
377 '--height', '256',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
378 '--start', 'end - 7d',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
379 '--end', 'now',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
380 *signalargs)
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
381
5
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
382 rrdtool.graph("%s-daily-signal.svg" % (graphbasename),
072489c80c51 Change from PNG to SVG
Daniel O'Connor <darius@dons.net.au>
parents: 4
diff changeset
383 '--width', '768',
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
384 '--height', '256',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
385 '--start', 'end - 365d',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
386 '--end', 'now',
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
387 *signalargs)
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
388
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
389 if __name__ == "__main__":
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
390 names = ['Noise Margin (up)', 'Noise Margin (down)', 'Attenuation (up)', 'Attenuation (down)']
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
391 if args.munin != None:
17
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
392 # Handle the wrapper passing us its $0 as our $1
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
393 tmp = args.munin.split('_')
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
394 if len(tmp) > 1:
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
395 args.munin = tmp[-1]
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
396 if args.munin not in ['signal', 'sync']:
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
397 print "Unknown data type ", args.munin
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
398 sys.exit(1)
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
399 if len(args) > 0:
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
400 if args[0] == 'config':
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
401 if args.munin == 'signal':
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
402 print '''graph_category adsl
16
425d02592dce Rename ADSL to DSL
Daniel O'Connor <darius@dons.net.au>
parents: 15
diff changeset
403 graph_title DSL Signal Quality
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
404 graph_args --base 1000 -l 0
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
405 graph_vlabel dB'''
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
406 for n in names:
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
407 name = n.translate(None, ' ()').lower()
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
408 print '''%s.label %s
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
409 %s.type GAUGE
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
410 %s.max 100
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
411 %s.min 0''' % (name, n, name, name, name)
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
412 elif args.munin == 'sync':
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
413 print '''graph_category adsl
16
425d02592dce Rename ADSL to DSL
Daniel O'Connor <darius@dons.net.au>
parents: 15
diff changeset
414 graph_title DSL Sync Speed
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
415 graph_args --base 1024 -l 0
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
416 graph_vlabel kbit/sec
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
417 up.label Up
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
418 up.type GAUGE
17
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
419 up.max 150000
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
420 up.min 0
10
88cf0a88c826 Fix cut & paste error
Daniel O'Connor <darius@dons.net.au>
parents: 9
diff changeset
421 down.label Down
88cf0a88c826 Fix cut & paste error
Daniel O'Connor <darius@dons.net.au>
parents: 9
diff changeset
422 down.type GAUGE
17
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
423 down.max 15000
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
424 down.min 0
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
425 upmax.label Up (max)
17
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
426 upmax.type GAUGE
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
427 upmax.max 150000
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
428 upmax.min 0
18
ec994073f70a Gather more stats (not plotted yet).
Daniel O'Connor <darius@dons.net.au>
parents: 17
diff changeset
429 downmax.label Down (max)
17
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
430 downmax.type GAUGE
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
431 downmax.max 150000
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
432 downmax.min 0'''
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
433 sys.exit(0)
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
434 if args.update or args.munin:
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
435 stats = getdata()
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
436 if args.verbose:
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
437 if stats == None:
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
438 print "Modem is offline"
14
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
439 else:
2debc3fb4372 Update for VDSL modem (TP-Link W9970).
Daniel O'Connor <darius@dons.net.au>
parents: 13
diff changeset
440 print stats
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
441 if (args.update or args.munin != None) and stats != None:
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
442 if args.update:
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
443 try:
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
444 os.stat(rrdname)
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
445 except OSError, e:
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
446 if e.errno == 2:
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
447 print "rrd not found, creating.."
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
448 makerrd(rrdname)
13
bf46efd061d7 Remove debugging and restore RRD update
Daniel O'Connor <darius@dons.net.au>
parents: 12
diff changeset
449 updaterrd(rrdname, int(time.time()), stats)
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
450 if args.munin != None:
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
451 if args.munin == 'signal':
9
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
452 print '''noisemarginup.value %.1f
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
453 noisemargindown.value %.1f
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
454 attenuationup.value %.1f
8b5958404f81 Add support for running as a munin plugin and a simple wrapper script.
Daniel O'Connor <darius@dons.net.au>
parents: 8
diff changeset
455 attenuationdown.value %.1f''' % (stats.nmup, stats.nmdown, stats.attenup, stats.attendown)
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
456 elif args.munin == 'sync':
17
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
457 s = '''up.value %.1f
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
458 down.value %.1f\n''' % (stats.upstream, stats.downstream)
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
459 if hasattr(stats, 'upstreammax'):
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
460 s += '''upmax.value %.1f
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
461 downmax.value %.1f''' % (stats.upstreammax, stats.downstreammax)
43f54da8baf9 Add max sync speeds to munin (untested)
Daniel O'Connor <darius@dons.net.au>
parents: 16
diff changeset
462 print s
25
7571c101a4ee Read options properly so it's usable by others
Daniel O'Connor <darius@dons.net.au>
parents: 24
diff changeset
463 if args.graph:
0
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
464 gengraph()
98fe11ea4c82 Initial commit of Billion ADSL stats monitor using RRD.
darius@Inchoate
parents:
diff changeset
465