Skip to content

Commit

Permalink
Merge pull request #422 from /issues/324
Browse files Browse the repository at this point in the history
Issue #324 - support setting limit and threshold overrides from local or S3 JSON file
  • Loading branch information
jantman authored Aug 29, 2019
2 parents f948232 + 9ca832e commit aad5ba6
Show file tree
Hide file tree
Showing 7 changed files with 1,327 additions and 845 deletions.
2 changes: 2 additions & 0 deletions CHANGES.rst
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ Unreleased Changes
* Stop referencing deprecated ``botocore.vendored.requests.exceptions.ConnectTimeout`` in favor of new, and higher-level, ``botocore.exceptions.ConnectionError``
* In :py:meth:`awslimitchecker.utils._get_latest_version`, replace use of ``botocore.vendored.requests`` with ``urllib3``.

* `Issue #324 <https://github.com/jantman/awslimitchecker/issues/324>`__ - Support loading :ref:`limit overrides <cli_usage.limit_overrides>` and/or :ref:`threshold overrides <cli_usage.threshold_overrides>` from a JSON file either stored locally or in S3 via new ``--limit-override-json`` and ``--threshold-override-json`` CLI options.

7.0.0 (2019-08-13)
------------------

Expand Down
56 changes: 56 additions & 0 deletions awslimitchecker/runner.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,11 +42,17 @@
import logging
import json
import termcolor
import boto3

from .checker import AwsLimitChecker
from .utils import StoreKeyValuePair, dict2cols
from .limit import SOURCE_TA, SOURCE_API

try:
from urllib.parse import urlparse
except ImportError:
from urlparse import urlparse

logging.basicConfig(level=logging.WARNING)
logger = logging.getLogger()

Expand Down Expand Up @@ -125,6 +131,16 @@ def parse_args(self, argv):
help='override a single AWS limit, specified in '
'"service_name/limit_name=value" format; can be '
'specified multiple times.')
p.add_argument('--limit-override-json', action='store', type=str,
default=None,
help='Absolute or relative path, or s3:// URL, to a '
'JSON file specifying limit overrides. See docs '
'for expected format.')
p.add_argument('--threshold-override-json', action='store', type=str,
default=None,
help='Absolute or relative path, or s3:// URL, to a '
'JSON file specifying threshold overrides. See '
'docs for expected format.')
p.add_argument('-u', '--show-usage', action='store_true',
default=False,
help='find and print the current usage of all AWS '
Expand Down Expand Up @@ -349,6 +365,38 @@ def set_limit_overrides(self, overrides):
svc, limit = key.split('/')
self.checker.set_limit_override(svc, limit, int(overrides[key]))

def load_json(self, path):
"""Load JSON from either a local file or S3"""
if path.startswith('s3://'):
parsed = urlparse(path)
s3key = parsed.path.lstrip('/')
logger.debug(
'Reading JSON from S3 bucket "%s" key "%s"',
parsed.netloc, s3key
)
client = boto3.client('s3')
resp = client.get_object(Bucket=parsed.netloc, Key=s3key)
data = resp['Body'].read()
else:
logger.debug('Reading JSON from: %s', path)
with open(path, 'r') as fh:
data = fh.read()
if isinstance(data, type(b'')):
data = data.decode()
return json.loads(data)

def set_limit_overrides_from_json(self, path):
j = self.load_json(path)
logger.debug('Limit overrides: %s', j)
self.checker.set_limit_overrides(j)
logger.debug('Done setting limit overrides from JSON.')

def set_threshold_overrides_from_json(self, path):
j = self.load_json(path)
logger.debug('Threshold overrides: %s', j)
self.checker.set_threshold_overrides(j)
logger.debug('Done setting threshold overrides from JSON.')

def console_entry_point(self):
args = self.parse_args(sys.argv[1:])
self.service_name = args.service
Expand Down Expand Up @@ -398,6 +446,14 @@ def console_entry_point(self):
for check in args.skip_check:
self.skip_check.append(check)

if args.limit_override_json is not None:
self.set_limit_overrides_from_json(args.limit_override_json)

if args.threshold_override_json is not None:
self.set_threshold_overrides_from_json(
args.threshold_override_json
)

if len(args.limit) > 0:
self.set_limit_overrides(args.limit)

Expand Down
Loading

0 comments on commit aad5ba6

Please sign in to comment.