lint: reformat python code with black
This commit is contained in:
parent
331beb01b4
commit
a406a7974b
88 changed files with 2579 additions and 1608 deletions
|
@ -13,33 +13,38 @@ from app.terraform import BaseAutomation
|
|||
|
||||
|
||||
def alarms_in_region(region: str, prefix: str, aspect: str) -> None:
|
||||
cloudwatch = boto3.client('cloudwatch',
|
||||
aws_access_key_id=app.config['AWS_ACCESS_KEY'],
|
||||
aws_secret_access_key=app.config['AWS_SECRET_KEY'],
|
||||
region_name=region)
|
||||
dist_paginator = cloudwatch.get_paginator('describe_alarms')
|
||||
cloudwatch = boto3.client(
|
||||
"cloudwatch",
|
||||
aws_access_key_id=app.config["AWS_ACCESS_KEY"],
|
||||
aws_secret_access_key=app.config["AWS_SECRET_KEY"],
|
||||
region_name=region,
|
||||
)
|
||||
dist_paginator = cloudwatch.get_paginator("describe_alarms")
|
||||
page_iterator = dist_paginator.paginate(AlarmNamePrefix=prefix)
|
||||
for page in page_iterator:
|
||||
for cw_alarm in page['MetricAlarms']:
|
||||
eotk_id = cw_alarm["AlarmName"][len(prefix):].split("-")
|
||||
group: Optional[Group] = Group.query.filter(func.lower(Group.group_name) == eotk_id[1]).first()
|
||||
for cw_alarm in page["MetricAlarms"]:
|
||||
eotk_id = cw_alarm["AlarmName"][len(prefix) :].split("-")
|
||||
group: Optional[Group] = Group.query.filter(
|
||||
func.lower(Group.group_name) == eotk_id[1]
|
||||
).first()
|
||||
if group is None:
|
||||
print("Unable to find group for " + cw_alarm['AlarmName'])
|
||||
print("Unable to find group for " + cw_alarm["AlarmName"])
|
||||
continue
|
||||
eotk = Eotk.query.filter(
|
||||
Eotk.group_id == group.id,
|
||||
Eotk.region == region
|
||||
Eotk.group_id == group.id, Eotk.region == region
|
||||
).first()
|
||||
if eotk is None:
|
||||
print("Skipping unknown instance " + cw_alarm['AlarmName'])
|
||||
print("Skipping unknown instance " + cw_alarm["AlarmName"])
|
||||
continue
|
||||
alarm = get_or_create_alarm(eotk.brn, aspect)
|
||||
if cw_alarm['StateValue'] == "OK":
|
||||
if cw_alarm["StateValue"] == "OK":
|
||||
alarm.update_state(AlarmState.OK, "CloudWatch alarm OK")
|
||||
elif cw_alarm['StateValue'] == "ALARM":
|
||||
elif cw_alarm["StateValue"] == "ALARM":
|
||||
alarm.update_state(AlarmState.CRITICAL, "CloudWatch alarm ALARM")
|
||||
else:
|
||||
alarm.update_state(AlarmState.UNKNOWN, f"CloudWatch alarm {cw_alarm['StateValue']}")
|
||||
alarm.update_state(
|
||||
AlarmState.UNKNOWN, f"CloudWatch alarm {cw_alarm['StateValue']}"
|
||||
)
|
||||
|
||||
|
||||
class AlarmEotkAwsAutomation(BaseAutomation):
|
||||
|
|
|
@ -16,20 +16,19 @@ class AlarmProxyAzureCdnAutomation(BaseAutomation):
|
|||
|
||||
def automate(self, full: bool = False) -> Tuple[bool, str]:
|
||||
credential = ClientSecretCredential(
|
||||
tenant_id=app.config['AZURE_TENANT_ID'],
|
||||
client_id=app.config['AZURE_CLIENT_ID'],
|
||||
client_secret=app.config['AZURE_CLIENT_SECRET'])
|
||||
client = AlertsManagementClient(
|
||||
credential,
|
||||
app.config['AZURE_SUBSCRIPTION_ID']
|
||||
tenant_id=app.config["AZURE_TENANT_ID"],
|
||||
client_id=app.config["AZURE_CLIENT_ID"],
|
||||
client_secret=app.config["AZURE_CLIENT_SECRET"],
|
||||
)
|
||||
firing = [x.name[len("bandwidth-out-high-bc-"):]
|
||||
for x in client.alerts.get_all()
|
||||
if x.name.startswith("bandwidth-out-high-bc-")
|
||||
and x.properties.essentials.monitor_condition == "Fired"]
|
||||
client = AlertsManagementClient(credential, app.config["AZURE_SUBSCRIPTION_ID"])
|
||||
firing = [
|
||||
x.name[len("bandwidth-out-high-bc-") :]
|
||||
for x in client.alerts.get_all()
|
||||
if x.name.startswith("bandwidth-out-high-bc-")
|
||||
and x.properties.essentials.monitor_condition == "Fired"
|
||||
]
|
||||
for proxy in Proxy.query.filter(
|
||||
Proxy.provider == "azure_cdn",
|
||||
Proxy.destroyed.is_(None)
|
||||
Proxy.provider == "azure_cdn", Proxy.destroyed.is_(None)
|
||||
):
|
||||
alarm = get_or_create_alarm(proxy.brn, "bandwidth-out-high")
|
||||
if proxy.origin.group.group_name.lower() not in firing:
|
||||
|
|
|
@ -16,9 +16,8 @@ def _cloudfront_quota() -> None:
|
|||
# It would be nice to learn this from the Service Quotas API, however
|
||||
# at the time of writing this comment, the current value for this quota
|
||||
# is not available from the API. It just doesn't return anything.
|
||||
max_count = int(current_app.config.get('AWS_CLOUDFRONT_MAX_DISTRIBUTIONS', 200))
|
||||
deployed_count = len(Proxy.query.filter(
|
||||
Proxy.destroyed.is_(None)).all())
|
||||
max_count = int(current_app.config.get("AWS_CLOUDFRONT_MAX_DISTRIBUTIONS", 200))
|
||||
deployed_count = len(Proxy.query.filter(Proxy.destroyed.is_(None)).all())
|
||||
message = f"{deployed_count} distributions deployed of {max_count} quota"
|
||||
alarm = get_or_create_alarm(
|
||||
BRN(
|
||||
|
@ -26,9 +25,9 @@ def _cloudfront_quota() -> None:
|
|||
product="mirror",
|
||||
provider="cloudfront",
|
||||
resource_type="quota",
|
||||
resource_id="distributions"
|
||||
resource_id="distributions",
|
||||
),
|
||||
"quota-usage"
|
||||
"quota-usage",
|
||||
)
|
||||
if deployed_count > max_count * 0.9:
|
||||
alarm.update_state(AlarmState.CRITICAL, message)
|
||||
|
@ -39,26 +38,30 @@ def _cloudfront_quota() -> None:
|
|||
|
||||
|
||||
def _proxy_alarms() -> None:
|
||||
cloudwatch = boto3.client('cloudwatch',
|
||||
aws_access_key_id=app.config['AWS_ACCESS_KEY'],
|
||||
aws_secret_access_key=app.config['AWS_SECRET_KEY'],
|
||||
region_name='us-east-2')
|
||||
dist_paginator = cloudwatch.get_paginator('describe_alarms')
|
||||
cloudwatch = boto3.client(
|
||||
"cloudwatch",
|
||||
aws_access_key_id=app.config["AWS_ACCESS_KEY"],
|
||||
aws_secret_access_key=app.config["AWS_SECRET_KEY"],
|
||||
region_name="us-east-2",
|
||||
)
|
||||
dist_paginator = cloudwatch.get_paginator("describe_alarms")
|
||||
page_iterator = dist_paginator.paginate(AlarmNamePrefix="bandwidth-out-high-")
|
||||
for page in page_iterator:
|
||||
for cw_alarm in page['MetricAlarms']:
|
||||
dist_id = cw_alarm["AlarmName"][len("bandwidth-out-high-"):]
|
||||
for cw_alarm in page["MetricAlarms"]:
|
||||
dist_id = cw_alarm["AlarmName"][len("bandwidth-out-high-") :]
|
||||
proxy = Proxy.query.filter(Proxy.slug == dist_id).first()
|
||||
if proxy is None:
|
||||
print("Skipping unknown proxy " + dist_id)
|
||||
continue
|
||||
alarm = get_or_create_alarm(proxy.brn, "bandwidth-out-high")
|
||||
if cw_alarm['StateValue'] == "OK":
|
||||
if cw_alarm["StateValue"] == "OK":
|
||||
alarm.update_state(AlarmState.OK, "CloudWatch alarm OK")
|
||||
elif cw_alarm['StateValue'] == "ALARM":
|
||||
elif cw_alarm["StateValue"] == "ALARM":
|
||||
alarm.update_state(AlarmState.CRITICAL, "CloudWatch alarm ALARM")
|
||||
else:
|
||||
alarm.update_state(AlarmState.UNKNOWN, f"CloudWatch alarm {cw_alarm['StateValue']}")
|
||||
alarm.update_state(
|
||||
AlarmState.UNKNOWN, f"CloudWatch alarm {cw_alarm['StateValue']}"
|
||||
)
|
||||
|
||||
|
||||
class AlarmProxyCloudfrontAutomation(BaseAutomation):
|
||||
|
|
|
@ -16,39 +16,25 @@ class AlarmProxyHTTPStatusAutomation(BaseAutomation):
|
|||
frequency = 45
|
||||
|
||||
def automate(self, full: bool = False) -> Tuple[bool, str]:
|
||||
proxies = Proxy.query.filter(
|
||||
Proxy.destroyed.is_(None)
|
||||
)
|
||||
proxies = Proxy.query.filter(Proxy.destroyed.is_(None))
|
||||
for proxy in proxies:
|
||||
try:
|
||||
if proxy.url is None:
|
||||
continue
|
||||
r = requests.get(proxy.url,
|
||||
allow_redirects=False,
|
||||
timeout=5)
|
||||
r = requests.get(proxy.url, allow_redirects=False, timeout=5)
|
||||
r.raise_for_status()
|
||||
alarm = get_or_create_alarm(proxy.brn, "http-status")
|
||||
if r.is_redirect:
|
||||
alarm.update_state(
|
||||
AlarmState.CRITICAL,
|
||||
f"{r.status_code} {r.reason}"
|
||||
AlarmState.CRITICAL, f"{r.status_code} {r.reason}"
|
||||
)
|
||||
else:
|
||||
alarm.update_state(
|
||||
AlarmState.OK,
|
||||
f"{r.status_code} {r.reason}"
|
||||
)
|
||||
alarm.update_state(AlarmState.OK, f"{r.status_code} {r.reason}")
|
||||
except requests.HTTPError:
|
||||
alarm = get_or_create_alarm(proxy.brn, "http-status")
|
||||
alarm.update_state(
|
||||
AlarmState.CRITICAL,
|
||||
f"{r.status_code} {r.reason}"
|
||||
)
|
||||
alarm.update_state(AlarmState.CRITICAL, f"{r.status_code} {r.reason}")
|
||||
except RequestException as e:
|
||||
alarm = get_or_create_alarm(proxy.brn, "http-status")
|
||||
alarm.update_state(
|
||||
AlarmState.CRITICAL,
|
||||
repr(e)
|
||||
)
|
||||
alarm.update_state(AlarmState.CRITICAL, repr(e))
|
||||
db.session.commit()
|
||||
return True, ""
|
||||
|
|
|
@ -13,33 +13,38 @@ from app.terraform import BaseAutomation
|
|||
|
||||
|
||||
def alarms_in_region(region: str, prefix: str, aspect: str) -> None:
|
||||
cloudwatch = boto3.client('cloudwatch',
|
||||
aws_access_key_id=app.config['AWS_ACCESS_KEY'],
|
||||
aws_secret_access_key=app.config['AWS_SECRET_KEY'],
|
||||
region_name=region)
|
||||
dist_paginator = cloudwatch.get_paginator('describe_alarms')
|
||||
cloudwatch = boto3.client(
|
||||
"cloudwatch",
|
||||
aws_access_key_id=app.config["AWS_ACCESS_KEY"],
|
||||
aws_secret_access_key=app.config["AWS_SECRET_KEY"],
|
||||
region_name=region,
|
||||
)
|
||||
dist_paginator = cloudwatch.get_paginator("describe_alarms")
|
||||
page_iterator = dist_paginator.paginate(AlarmNamePrefix=prefix)
|
||||
for page in page_iterator:
|
||||
for cw_alarm in page['MetricAlarms']:
|
||||
smart_id = cw_alarm["AlarmName"][len(prefix):].split("-")
|
||||
group: Optional[Group] = Group.query.filter(func.lower(Group.group_name) == smart_id[1]).first()
|
||||
for cw_alarm in page["MetricAlarms"]:
|
||||
smart_id = cw_alarm["AlarmName"][len(prefix) :].split("-")
|
||||
group: Optional[Group] = Group.query.filter(
|
||||
func.lower(Group.group_name) == smart_id[1]
|
||||
).first()
|
||||
if group is None:
|
||||
print("Unable to find group for " + cw_alarm['AlarmName'])
|
||||
print("Unable to find group for " + cw_alarm["AlarmName"])
|
||||
continue
|
||||
smart_proxy = SmartProxy.query.filter(
|
||||
SmartProxy.group_id == group.id,
|
||||
SmartProxy.region == region
|
||||
SmartProxy.group_id == group.id, SmartProxy.region == region
|
||||
).first()
|
||||
if smart_proxy is None:
|
||||
print("Skipping unknown instance " + cw_alarm['AlarmName'])
|
||||
print("Skipping unknown instance " + cw_alarm["AlarmName"])
|
||||
continue
|
||||
alarm = get_or_create_alarm(smart_proxy.brn, aspect)
|
||||
if cw_alarm['StateValue'] == "OK":
|
||||
if cw_alarm["StateValue"] == "OK":
|
||||
alarm.update_state(AlarmState.OK, "CloudWatch alarm OK")
|
||||
elif cw_alarm['StateValue'] == "ALARM":
|
||||
elif cw_alarm["StateValue"] == "ALARM":
|
||||
alarm.update_state(AlarmState.CRITICAL, "CloudWatch alarm ALARM")
|
||||
else:
|
||||
alarm.update_state(AlarmState.UNKNOWN, f"CloudWatch alarm {cw_alarm['StateValue']}")
|
||||
alarm.update_state(
|
||||
AlarmState.UNKNOWN, f"CloudWatch alarm {cw_alarm['StateValue']}"
|
||||
)
|
||||
|
||||
|
||||
class AlarmSmartAwsAutomation(BaseAutomation):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue