pep8 and documentation
This commit is contained in:
14
libs/ce.py
14
libs/ce.py
@@ -9,7 +9,7 @@ import sys
|
||||
|
||||
pp = pprint.PrettyPrinter(indent=5, width=80)
|
||||
|
||||
#from http://docs.aws.amazon.com/general/latest/gr/rande.html
|
||||
# from http://docs.aws.amazon.com/general/latest/gr/rande.html
|
||||
regions = ['us-east-1', ]
|
||||
|
||||
'''
|
||||
@@ -21,16 +21,20 @@ AWS_ACCESS_KEY_ID = credentials.access_key
|
||||
|
||||
|
||||
def ce_get_cost_and_usage():
|
||||
'''
|
||||
Get cost and usage via cost explorer service - usually requires elevated prviliges
|
||||
'''
|
||||
try:
|
||||
for region in regions:
|
||||
client = boto3.client('ce', region_name=region)
|
||||
response = client.get_cost_and_usage(TimePeriod={'Start': '2018-01-01', 'End': '2018-04-01'}, Granularity='MONTHLY', Metrics=["BlendedCost", "UnblendedCost", "UsageQuantity"],)
|
||||
print(response)
|
||||
#if response.get('Services') is None:
|
||||
# This module needs to be further tested
|
||||
# if response.get('Services') is None:
|
||||
# print("{} likely does not have Pricing permissions\n" .format(AWS_ACCESS_KEY_ID))
|
||||
#elif len(response['Services']) <= 0:
|
||||
# elif len(response['Services']) <= 0:
|
||||
# print("[-] Describe Pricing Services allowed for {} but no results [-]" .format(region))
|
||||
#else:
|
||||
# else:
|
||||
# print("### {} Services ###" .format(region))
|
||||
# for tables in response['ServiceCode']:
|
||||
# pp.pprint(tables)
|
||||
@@ -39,7 +43,7 @@ def ce_get_cost_and_usage():
|
||||
if e.response['Error']['Code'] == 'UnauthorizedOperation':
|
||||
print('{} : (UnauthorizedOperation) when calling the DescribeInstances -- sure you have ec2 permissions?' .format(AWS_ACCESS_KEY_ID))
|
||||
elif e.response['Error']['Code'] == 'AccessDeniedException':
|
||||
print('{} : (AccessDenied) when calling the Get Cost & Usage' .format(AWS_ACCESS_KEY_ID))
|
||||
print('{} : (AccessDenied) when calling the Get Cost & Usage' .format(AWS_ACCESS_KEY_ID))
|
||||
elif e.response['Error']['Code'] == 'SubscriptionRequiredException':
|
||||
print('{} : Has permissions but isnt signed up for service - usually means you have a root account' .format(AWS_ACCESS_KEY_ID))
|
||||
else:
|
||||
|
||||
Reference in New Issue
Block a user