Add better error messages
- Add status.json with HTTP status code table - Add error fetching on PingAdapter - Give warning on no alerts set
This commit is contained in:
parent
673e5bb0fc
commit
3437bd2b72
3 changed files with 25 additions and 3 deletions
|
@ -1,9 +1,11 @@
|
||||||
import asyncio
|
import asyncio
|
||||||
|
import json
|
||||||
import time
|
import time
|
||||||
import re
|
import re
|
||||||
|
|
||||||
PING_RGX = re.compile(r'(.+)( 0% packet loss)(.+)', re.I | re.M)
|
PING_RGX = re.compile(r'(.+)( 0% packet loss)(.+)', re.I | re.M)
|
||||||
PING_LATENCY_RGX = re.compile('time\=(\d+(\.\d+)?) ms', re.M)
|
PING_LATENCY_RGX = re.compile('time\=(\d+(\.\d+)?) ms', re.M)
|
||||||
|
PING_ERROR_RGX = re.compile('icmp_seq\=(\d+)\ ([^time].*)$', re.M)
|
||||||
|
|
||||||
|
|
||||||
class Adapter:
|
class Adapter:
|
||||||
|
@ -64,8 +66,11 @@ class PingAdapter(Adapter):
|
||||||
else:
|
else:
|
||||||
latency = 0
|
latency = 0
|
||||||
|
|
||||||
worker.log.info(f'alive={alive} latency={latency}ms')
|
err = PING_ERROR_RGX.search(out)
|
||||||
return cls._construct(alive, latency)
|
err_msg = err.group(2) if not alive and err else 'error not found'
|
||||||
|
|
||||||
|
worker.log.info(f'alive={alive} latency={latency}ms err={err_msg!r}')
|
||||||
|
return cls._construct(alive, latency, err_msg)
|
||||||
|
|
||||||
|
|
||||||
class HttpAdapter(Adapter):
|
class HttpAdapter(Adapter):
|
||||||
|
@ -75,6 +80,16 @@ class HttpAdapter(Adapter):
|
||||||
'db': ('timestamp', 'status', 'latency')
|
'db': ('timestamp', 'status', 'latency')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get_phrase(cls, status: int):
|
||||||
|
with open('./status.json', 'r') as fd:
|
||||||
|
statuses = json.load(fd)
|
||||||
|
|
||||||
|
try:
|
||||||
|
return statuses[str(status)]
|
||||||
|
except KeyError:
|
||||||
|
return 'Unknown status'
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
async def query(cls, worker, adp_args: dict):
|
async def query(cls, worker, adp_args: dict):
|
||||||
# yes, lots of attributes
|
# yes, lots of attributes
|
||||||
|
@ -93,7 +108,8 @@ class HttpAdapter(Adapter):
|
||||||
worker.log.info(f'status={resp.status} latency={latency}ms')
|
worker.log.info(f'status={resp.status} latency={latency}ms')
|
||||||
|
|
||||||
if not succ:
|
if not succ:
|
||||||
err_str = f'HTTP Status - {resp.status}'
|
status_phrase = cls.get_phrase(resp.status)
|
||||||
|
err_str = f'HTTP Status - {resp.status} - {status_phrase}'
|
||||||
return cls._construct(succ, latency, err_str)
|
return cls._construct(succ, latency, err_str)
|
||||||
|
|
||||||
return cls._construct(succ, latency if succ else 0)
|
return cls._construct(succ, latency if succ else 0)
|
||||||
|
|
|
@ -76,6 +76,7 @@ class ServiceWorker:
|
||||||
# extract latest and old from rows
|
# extract latest and old from rows
|
||||||
first, last = rows
|
first, last = rows
|
||||||
first_status, last_status = first[0], last[0]
|
first_status, last_status = first[0], last[0]
|
||||||
|
print(first_status, last_status)
|
||||||
|
|
||||||
# dont do anything if theres no change
|
# dont do anything if theres no change
|
||||||
# to the statuses
|
# to the statuses
|
||||||
|
@ -85,6 +86,10 @@ class ServiceWorker:
|
||||||
# oopsie whoopsie time to alertie owo
|
# oopsie whoopsie time to alertie owo
|
||||||
alerts = self.service.get('alerts', [])
|
alerts = self.service.get('alerts', [])
|
||||||
|
|
||||||
|
if not alerts:
|
||||||
|
self.log.warning(f'no alerts set for {self.name}')
|
||||||
|
return
|
||||||
|
|
||||||
for alert in alerts:
|
for alert in alerts:
|
||||||
try:
|
try:
|
||||||
alert_obj = self.manager.alerts[alert]
|
alert_obj = self.manager.alerts[alert]
|
||||||
|
|
1
status.json
Normal file
1
status.json
Normal file
|
@ -0,0 +1 @@
|
||||||
|
{"1xx": "**Informational**", "100": "Continue", "101": "Switching Protocols", "2xx": "**Successful**", "200": "OK", "201": "Created", "202": "Accepted", "203": "Non-Authoritative Information", "204": "No Content", "205": "Reset Content", "206": "Partial Content", "3xx": "**Redirection**", "300": "Multiple Choices", "301": "Moved Permanently", "302": "Found", "303": "See Other", "304": "Not Modified", "305": "Use Proxy", "307": "Temporary Redirect", "4xx": "**Client Error**", "400": "Bad Request", "401": "Unauthorized", "402": "Payment Required", "403": "Forbidden", "404": "Not Found", "405": "Method Not Allowed", "406": "Not Acceptable", "407": "Proxy Authentication Required", "408": "Request Timeout", "409": "Conflict", "410": "Gone", "411": "Length Required", "412": "Precondition Failed", "413": "Payload Too Large", "414": "URI Too Long", "415": "Unsupported Media Type", "416": "Range Not Satisfiable", "417": "Expectation Failed", "418": "I'm a teapot", "426": "Upgrade Required", "5xx": "**Server Error**", "500": "Internal Server Error", "501": "Not Implemented", "502": "Bad Gateway", "503": "Service Unavailable", "504": "Gateway Time-out", "505": "HTTP Version Not Supported", "102": "Processing", "207": "Multi-Status", "226": "IM Used", "308": "Permanent Redirect", "422": "Unprocessable Entity", "423": "Locked", "424": "Failed Dependency", "428": "Precondition Required", "429": "Too Many Requests", "431": "Request Header Fields Too Large", "451": "Unavailable For Legal Reasons", "506": "Variant Also Negotiates", "507": "Insufficient Storage", "511": "Network Authentication Required", "7xx": "**Developer Error**"}
|
Loading…
Reference in a new issue