%PDF- %PDF-
Direktori : /usr/lib/python2.7/site-packages/salt/modules/ |
Current File : //usr/lib/python2.7/site-packages/salt/modules/boto_sqs.py |
# -*- coding: utf-8 -*- ''' Connection module for Amazon SQS .. versionadded:: 2014.7.0 :configuration: This module accepts explicit sqs credentials but can also utilize IAM roles assigned to the instance through Instance Profiles. Dynamic credentials are then automatically obtained from AWS API and no further configuration is necessary. More information available at: .. code-block:: text http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/iam-roles-for-amazon-ec2.html If IAM roles are not used you need to specify them either in a pillar or in the minion's config file: .. code-block:: yaml sqs.keyid: GKTADJGHEIQSXMKKRBJ08H sqs.key: askdjghsdfjkghWupUjasdflkdfklgjsdfjajkghs A region may also be specified in the configuration: .. code-block:: yaml sqs.region: us-east-1 If a region is not specified, the default is us-east-1. It's also possible to specify key, keyid and region via a profile, either as a passed in dict, or as a string to pull from pillars or minion config: .. code-block:: yaml myprofile: keyid: GKTADJGHEIQSXMKKRBJ08H key: askdjghsdfjkghWupUjasdflkdfklgjsdfjajkghs region: us-east-1 :depends: boto3 ''' # keep lint from choking on _get_conn and _cache_id # pylint: disable=E0602 from __future__ import absolute_import, print_function, unicode_literals # Import Python libs import logging # Import Salt libs import salt.utils.json import salt.utils.versions # Import 3rd-party libs from salt.ext import six from salt.ext.six.moves.urllib.parse import urlparse as _urlparse # pylint: disable=import-error,no-name-in-module log = logging.getLogger(__name__) __func_alias__ = { 'list_': 'list', } # Import third party libs try: # pylint: disable=unused-import import boto3 import botocore # pylint: enable=unused-import logging.getLogger('boto3').setLevel(logging.CRITICAL) HAS_BOTO3 = True except ImportError: HAS_BOTO3 = False def __virtual__(): ''' Only load if boto3 libraries exist. ''' has_boto_reqs = salt.utils.versions.check_boto_reqs() if has_boto_reqs is True: __utils__['boto3.assign_funcs'](__name__, 'sqs') return has_boto_reqs def _preprocess_attributes(attributes): ''' Pre-process incoming queue attributes before setting them ''' if isinstance(attributes, six.string_types): attributes = salt.utils.json.loads(attributes) def stringified(val): # Some attributes take full json policy documents, but they take them # as json strings. Convert the value back into a json string. if isinstance(val, dict): return salt.utils.json.dumps(val) return val return dict( (attr, stringified(val)) for attr, val in six.iteritems(attributes) ) def exists(name, region=None, key=None, keyid=None, profile=None): ''' Check to see if a queue exists. CLI Example: .. code-block:: bash salt myminion boto_sqs.exists myqueue region=us-east-1 ''' conn = _get_conn(region=region, key=key, keyid=keyid, profile=profile) try: conn.get_queue_url(QueueName=name) except botocore.exceptions.ClientError as e: missing_code = 'AWS.SimpleQueueService.NonExistentQueue' if e.response.get('Error', {}).get('Code') == missing_code: return {'result': False} return {'error': __utils__['boto3.get_error'](e)} return {'result': True} def create( name, attributes=None, region=None, key=None, keyid=None, profile=None, ): ''' Create an SQS queue. CLI Example: .. code-block:: bash salt myminion boto_sqs.create myqueue region=us-east-1 ''' conn = _get_conn(region=region, key=key, keyid=keyid, profile=profile) if attributes is None: attributes = {} attributes = _preprocess_attributes(attributes) try: conn.create_queue(QueueName=name, Attributes=attributes) except botocore.exceptions.ClientError as e: return {'error': __utils__['boto3.get_error'](e)} return {'result': True} def delete(name, region=None, key=None, keyid=None, profile=None): ''' Delete an SQS queue. CLI Example: .. code-block:: bash salt myminion boto_sqs.delete myqueue region=us-east-1 ''' conn = _get_conn(region=region, key=key, keyid=keyid, profile=profile) try: url = conn.get_queue_url(QueueName=name)['QueueUrl'] conn.delete_queue(QueueUrl=url) except botocore.exceptions.ClientError as e: return {'error': __utils__['boto3.get_error'](e)} return {'result': True} def list_(prefix='', region=None, key=None, keyid=None, profile=None): ''' Return a list of the names of all visible queues. .. versionadded:: 2016.11.0 CLI Example: .. code-block:: bash salt myminion boto_sqs.list region=us-east-1 ''' conn = _get_conn(region=region, key=key, keyid=keyid, profile=profile) def extract_name(queue_url): # Note: this logic taken from boto, so should be safe return _urlparse(queue_url).path.split('/')[2] try: r = conn.list_queues(QueueNamePrefix=prefix) # The 'QueueUrls' attribute is missing if there are no queues urls = r.get('QueueUrls', []) return {'result': [extract_name(url) for url in urls]} except botocore.exceptions.ClientError as e: return {'error': __utils__['boto3.get_error'](e)} def get_attributes(name, region=None, key=None, keyid=None, profile=None): ''' Return attributes currently set on an SQS queue. CLI Example: .. code-block:: bash salt myminion boto_sqs.get_attributes myqueue ''' conn = _get_conn(region=region, key=key, keyid=keyid, profile=profile) try: url = conn.get_queue_url(QueueName=name)['QueueUrl'] r = conn.get_queue_attributes(QueueUrl=url, AttributeNames=['All']) return {'result': r['Attributes']} except botocore.exceptions.ClientError as e: return {'error': __utils__['boto3.get_error'](e)} def set_attributes( name, attributes, region=None, key=None, keyid=None, profile=None, ): ''' Set attributes on an SQS queue. CLI Example: .. code-block:: bash salt myminion boto_sqs.set_attributes myqueue '{ReceiveMessageWaitTimeSeconds: 20}' region=us-east-1 ''' conn = _get_conn(region=region, key=key, keyid=keyid, profile=profile) attributes = _preprocess_attributes(attributes) try: url = conn.get_queue_url(QueueName=name)['QueueUrl'] conn.set_queue_attributes(QueueUrl=url, Attributes=attributes) except botocore.exceptions.ClientError as e: return {'error': __utils__['boto3.get_error'](e)} return {'result': True}