U
    W+dr                     @   sX   d dl Z d dlmZ d dlmZ d dlmZ d dlmZ d dl	m
Z
 G dd deZdS )	    N)json)AWSQueryConnection)
RegionInfo)JSONResponseError)
exceptionsc                
       s   e Zd ZdZdZdZdZdZdZe	Z
ejejejejejejejejejd	Z fdd	Zd
d Zd+ddZd,ddZd-ddZdd Zd.ddZd/ddZd0ddZd1ddZdd Z d2dd Z!d!d" Z"d#d$ Z#d%d& Z$d3d'd(Z%d)d* Z&  Z'S )4SupportConnectiona	  
    AWS Support
    The AWS Support API reference is intended for programmers who need
    detailed information about the AWS Support operations and data
    types. This service enables you to manage your AWS Support cases
    programmatically. It uses HTTP methods that return results in JSON
    format.

    The AWS Support service also exposes a set of `Trusted Advisor`_
    features. You can retrieve a list of checks and their
    descriptions, get check results, specify checks to refresh, and
    get the refresh status of checks.

    The following list describes the AWS Support case management
    operations:


    + **Service names, issue categories, and available severity
      levels. **The DescribeServices and DescribeSeverityLevels
      operations return AWS service names, service codes, service
      categories, and problem severity levels. You use these values when
      you call the CreateCase operation.
    + **Case creation, case details, and case resolution.** The
      CreateCase, DescribeCases, DescribeAttachment, and ResolveCase
      operations create AWS Support cases, retrieve information about
      cases, and resolve cases.
    + **Case communication.** The DescribeCommunications,
      AddCommunicationToCase, and AddAttachmentsToSet operations
      retrieve and add communications and attachments to AWS Support
      cases.


    The following list describes the operations available from the AWS
    Support service for Trusted Advisor:


    + DescribeTrustedAdvisorChecks returns the list of checks that run
      against your AWS resources.
    + Using the `CheckId` for a specific check returned by
      DescribeTrustedAdvisorChecks, you can call
      DescribeTrustedAdvisorCheckResult to obtain the results for the
      check you specified.
    + DescribeTrustedAdvisorCheckSummaries returns summarized results
      for one or more Trusted Advisor checks.
    + RefreshTrustedAdvisorCheck requests that Trusted Advisor rerun a
      specified check.
    + DescribeTrustedAdvisorCheckRefreshStatuses reports the refresh
      status of one or more checks.


    For authentication of requests, AWS Support uses `Signature
    Version 4 Signing Process`_.

    See `About the AWS Support API`_ in the AWS Support User Guide for
    information about how to use this service to create and manage
    your support cases, and how to call Trusted Advisor for results of
    checks on your resources.
    z
2013-04-15z	us-east-1zsupport.us-east-1.amazonaws.comZSupportZAWSSupport_20130415)	CaseCreationLimitExceededAttachmentLimitExceededCaseIdNotFoundDescribeAttachmentLimitExceededAttachmentSetIdNotFoundInternalServerErrorAttachmentSetExpiredAttachmentIdNotFoundAttachmentSetSizeLimitExceededc                    sZ   | dd }|s t| | j| j}d|ks4|d d kr>|j|d< tt| jf | || _d S )Nregionhost)	popr   DefaultRegionNameDefaultRegionEndpointendpointsuperr   __init__r   )selfkwargsr   	__class__ 7/tmp/pip-unpacked-wheel-dlxw5sjy/boto/support/layer1.pyr   n   s    
zSupportConnection.__init__c                 C   s   dgS )Nzhmac-v4r   )r   r   r   r   _required_auth_capabilityz   s    z+SupportConnection._required_auth_capabilityNc                 C   s,   d|i}|dk	r||d< | j dt|dS )a   
        Adds one or more attachments to an attachment set. If an
        `AttachmentSetId` is not specified, a new attachment set is
        created, and the ID of the set is returned in the response. If
        an `AttachmentSetId` is specified, the attachments are added
        to the specified set, if it exists.

        An attachment set is a temporary container for attachments
        that are to be added to a case or case communication. The set
        is available for one hour after it is created; the
        `ExpiryTime` returned in the response indicates when the set
        expires. The maximum number of attachments in a set is 3, and
        the maximum size of any attachment in the set is 5 MB.

        :type attachment_set_id: string
        :param attachment_set_id: The ID of the attachment set. If an
            `AttachmentSetId` is not specified, a new attachment set is
            created, and the ID of the set is returned in the response. If an
            `AttachmentSetId` is specified, the attachments are added to the
            specified set, if it exists.

        :type attachments: list
        :param attachments: One or more attachments to add to the set. The
            limit is 3 attachments per set, and the size limit is 5 MB per
            attachment.

        attachmentsNattachmentSetIdZAddAttachmentsToSetactionbodymake_requestr   dumps)r   r    attachment_set_idparamsr   r   r   add_attachments_to_set}   s    z(SupportConnection.add_attachments_to_setc                 C   sL   d|i}|dk	r||d< |dk	r(||d< |dk	r8||d< | j dt|dS )aN  
        Adds additional customer communication to an AWS Support case.
        You use the `CaseId` value to identify the case to add
        communication to. You can list a set of email addresses to
        copy on the communication using the `CcEmailAddresses` value.
        The `CommunicationBody` value contains the text of the
        communication.

        The response indicates the success or failure of the request.

        This operation implements a subset of the behavior on the AWS
        Support `Your Support Cases`_ web form.

        :type case_id: string
        :param case_id: The AWS Support case ID requested or returned in the
            call. The case ID is an alphanumeric string formatted as shown in
            this example: case- 12345678910-2013-c4c1d2bf33c5cf47

        :type communication_body: string
        :param communication_body: The body of an email communication to add to
            the support case.

        :type cc_email_addresses: list
        :param cc_email_addresses: The email addresses in the CC line of an
            email to be added to the support case.

        :type attachment_set_id: string
        :param attachment_set_id: The ID of a set of one or more attachments
            for the communication to add to the case. Create the set by calling
            AddAttachmentsToSet

        communicationBodyNcaseIdccEmailAddressesr!   ZAddCommunicationToCaser"   r%   )r   communication_bodycase_idcc_email_addressesr(   r)   r   r   r   add_communication_to_case   s    #z+SupportConnection.add_communication_to_casec
                 C   s   ||d}
|dk	r||
d< |dk	r*||
d< |dk	r:||
d< |dk	rJ||
d< |dk	rZ||
d< |dk	rj||
d< |	dk	rz|	|
d	< | j d
t|
dS )a  
        Creates a new case in the AWS Support Center. This operation
        is modeled on the behavior of the AWS Support Center `Open a
        new case`_ page. Its parameters require you to specify the
        following information:


        #. **IssueType.** The type of issue for the case. You can
           specify either "customer-service" or "technical." If you do
           not indicate a value, the default is "technical."
        #. **ServiceCode.** The code for an AWS service. You obtain
           the `ServiceCode` by calling DescribeServices.
        #. **CategoryCode.** The category for the service defined for
           the `ServiceCode` value. You also obtain the category code for
           a service by calling DescribeServices. Each AWS service
           defines its own set of category codes.
        #. **SeverityCode.** A value that indicates the urgency of the
           case, which in turn determines the response time according to
           your service level agreement with AWS Support. You obtain the
           SeverityCode by calling DescribeSeverityLevels.
        #. **Subject.** The **Subject** field on the AWS Support
           Center `Open a new case`_ page.
        #. **CommunicationBody.** The **Description** field on the AWS
           Support Center `Open a new case`_ page.
        #. **AttachmentSetId.** The ID of a set of attachments that
           has been created by using AddAttachmentsToSet.
        #. **Language.** The human language in which AWS Support
           handles the case. English and Japanese are currently
           supported.
        #. **CcEmailAddresses.** The AWS Support Center **CC** field
           on the `Open a new case`_ page. You can list email addresses
           to be copied on any correspondence about the case. The account
           that opens the case is already identified by passing the AWS
           Credentials in the HTTP POST method or in a method or function
           call from one of the programming languages supported by an
           `AWS SDK`_.


        A successful CreateCase request returns an AWS Support case
        number. Case numbers are used by the DescribeCases operation
        to retrieve existing AWS Support cases.

        :type subject: string
        :param subject: The title of the AWS Support case.

        :type service_code: string
        :param service_code: The code for the AWS service returned by the call
            to DescribeServices.

        :type severity_code: string
        :param severity_code: The code for the severity level returned by the
            call to DescribeSeverityLevels.

        :type category_code: string
        :param category_code: The category of problem for the AWS Support case.

        :type communication_body: string
        :param communication_body: The communication body text when you create
            an AWS Support case by calling CreateCase.

        :type cc_email_addresses: list
        :param cc_email_addresses: A list of email addresses that AWS Support
            copies on case correspondence.

        :type language: string
        :param language: The ISO 639-1 code for the language in which AWS
            provides support. AWS Support currently supports English ("en") and
            Japanese ("ja"). Language parameters must be passed explicitly for
            operations that take them.

        :type issue_type: string
        :param issue_type: The type of issue for the case. You can specify
            either "customer-service" or "technical." If you do not indicate a
            value, the default is "technical."

        :type attachment_set_id: string
        :param attachment_set_id: The ID of a set of one or more attachments
            for the case. Create the set by using AddAttachmentsToSet.

        )subjectr+   NZserviceCodeZseverityCodeZcategoryCoder-   languageZ	issueTyper!   Z
CreateCaser"   r%   )r   r2   r.   Zservice_codeZseverity_codeZcategory_coder0   r3   Z
issue_typer(   r)   r   r   r   create_case   s(    UzSupportConnection.create_casec                 C   s   d|i}| j dt|dS )a  
        Returns the attachment that has the specified ID. Attachment
        IDs are generated by the case management system when you add
        an attachment to a case or case communication. Attachment IDs
        are returned in the AttachmentDetails objects that are
        returned by the DescribeCommunications operation.

        :type attachment_id: string
        :param attachment_id: The ID of the attachment to return. Attachment
            IDs are returned by the DescribeCommunications operation.

        ZattachmentIdZDescribeAttachmentr"   r%   )r   Zattachment_idr)   r   r   r   describe_attachment5  s    z%SupportConnection.describe_attachmentc
                 C   s   i }
|dk	r||
d< |dk	r$||
d< |dk	r4||
d< |dk	rD||
d< |dk	rT||
d< |dk	rd||
d< |dk	rt||
d< |dk	r||
d	< |	dk	r|	|
d
< | j dt|
dS )aY	  
        Returns a list of cases that you specify by passing one or
        more case IDs. In addition, you can filter the cases by date
        by setting values for the `AfterTime` and `BeforeTime` request
        parameters.

        Case data is available for 12 months after creation. If a case
        was created more than 12 months ago, a request for data might
        cause an error.

        The response returns the following in JSON format:


        #. One or more CaseDetails data types.
        #. One or more `NextToken` values, which specify where to
           paginate the returned records represented by the `CaseDetails`
           objects.

        :type case_id_list: list
        :param case_id_list: A list of ID numbers of the support cases you want
            returned. The maximum number of cases is 100.

        :type display_id: string
        :param display_id: The ID displayed for a case in the AWS Support
            Center user interface.

        :type after_time: string
        :param after_time: The start date for a filtered date search on support
            case communications. Case communications are available for 12
            months after creation.

        :type before_time: string
        :param before_time: The end date for a filtered date search on support
            case communications. Case communications are available for 12
            months after creation.

        :type include_resolved_cases: boolean
        :param include_resolved_cases: Specifies whether resolved support cases
            should be included in the DescribeCases results. The default is
            false .

        :type next_token: string
        :param next_token: A resumption point for pagination.

        :type max_results: integer
        :param max_results: The maximum number of results to return before
            paginating.

        :type language: string
        :param language: The ISO 639-1 code for the language in which AWS
            provides support. AWS Support currently supports English ("en") and
            Japanese ("ja"). Language parameters must be passed explicitly for
            operations that take them.

        :type include_communications: boolean
        :param include_communications: Specifies whether communications should
            be included in the DescribeCases results. The default is true .

        NZ
caseIdListZ	displayId	afterTime
beforeTimeZincludeResolvedCases	nextToken
maxResultsr3   ZincludeCommunicationsZDescribeCasesr"   r%   )r   Zcase_id_listZ
display_id
after_timebefore_timeZinclude_resolved_cases
next_tokenmax_resultsr3   Zinclude_communicationsr)   r   r   r   describe_casesF  s,    @z SupportConnection.describe_casesc                 C   s\   d|i}|dk	r||d< |dk	r(||d< |dk	r8||d< |dk	rH||d< | j dt|dS )	aa  
        Returns communications (and attachments) for one or more
        support cases. You can use the `AfterTime` and `BeforeTime`
        parameters to filter by date. You can use the `CaseId`
        parameter to restrict the results to a particular case.

        Case data is available for 12 months after creation. If a case
        was created more than 12 months ago, a request for data might
        cause an error.

        You can use the `MaxResults` and `NextToken` parameters to
        control the pagination of the result set. Set `MaxResults` to
        the number of cases you want displayed on each page, and use
        `NextToken` to specify the resumption of pagination.

        :type case_id: string
        :param case_id: The AWS Support case ID requested or returned in the
            call. The case ID is an alphanumeric string formatted as shown in
            this example: case- 12345678910-2013-c4c1d2bf33c5cf47

        :type before_time: string
        :param before_time: The end date for a filtered date search on support
            case communications. Case communications are available for 12
            months after creation.

        :type after_time: string
        :param after_time: The start date for a filtered date search on support
            case communications. Case communications are available for 12
            months after creation.

        :type next_token: string
        :param next_token: A resumption point for pagination.

        :type max_results: integer
        :param max_results: The maximum number of results to return before
            paginating.

        r,   Nr7   r6   r8   r9   ZDescribeCommunicationsr"   r%   )r   r/   r;   r:   r<   r=   r)   r   r   r   describe_communications  s    )z)SupportConnection.describe_communicationsc                 C   s8   i }|dk	r||d< |dk	r$||d< | j dt|dS )a  
        Returns the current list of AWS services and a list of service
        categories that applies to each one. You then use service
        names and categories in your CreateCase requests. Each AWS
        service has its own set of categories.

        The service codes and category codes correspond to the values
        that are displayed in the **Service** and **Category** drop-
        down lists on the AWS Support Center `Open a new case`_ page.
        The values in those fields, however, do not necessarily match
        the service codes and categories returned by the
        `DescribeServices` request. Always use the service codes and
        categories obtained programmatically. This practice ensures
        that you always have the most recent set of service and
        category codes.

        :type service_code_list: list
        :param service_code_list: A JSON-formatted list of service codes
            available for AWS services.

        :type language: string
        :param language: The ISO 639-1 code for the language in which AWS
            provides support. AWS Support currently supports English ("en") and
            Japanese ("ja"). Language parameters must be passed explicitly for
            operations that take them.

        NZserviceCodeListr3   ZDescribeServicesr"   r%   )r   Zservice_code_listr3   r)   r   r   r   describe_services  s    z#SupportConnection.describe_servicesc                 C   s(   i }|dk	r||d< | j dt|dS )a  
        Returns the list of severity levels that you can assign to an
        AWS Support case. The severity level for a case is also a
        field in the CaseDetails data type included in any CreateCase
        request.

        :type language: string
        :param language: The ISO 639-1 code for the language in which AWS
            provides support. AWS Support currently supports English ("en") and
            Japanese ("ja"). Language parameters must be passed explicitly for
            operations that take them.

        Nr3   ZDescribeSeverityLevelsr"   r%   r   r3   r)   r   r   r   describe_severity_levels  s    z*SupportConnection.describe_severity_levelsc                 C   s   d|i}| j dt|dS )a!  
        Returns the refresh status of the Trusted Advisor checks that
        have the specified check IDs. Check IDs can be obtained by
        calling DescribeTrustedAdvisorChecks.

        :type check_ids: list
        :param check_ids: The IDs of the Trusted Advisor checks.

        checkIdsZ*DescribeTrustedAdvisorCheckRefreshStatusesr"   r%   r   Z	check_idsr)   r   r   r   /describe_trusted_advisor_check_refresh_statuses	  s    
zASupportConnection.describe_trusted_advisor_check_refresh_statusesc                 C   s,   d|i}|dk	r||d< | j dt|dS )a  
        Returns the results of the Trusted Advisor check that has the
        specified check ID. Check IDs can be obtained by calling
        DescribeTrustedAdvisorChecks.

        The response contains a TrustedAdvisorCheckResult object,
        which contains these three objects:


        + TrustedAdvisorCategorySpecificSummary
        + TrustedAdvisorResourceDetail
        + TrustedAdvisorResourcesSummary


        In addition, the response contains these fields:


        + **Status.** The alert status of the check: "ok" (green),
          "warning" (yellow), "error" (red), or "not_available".
        + **Timestamp.** The time of the last refresh of the check.
        + **CheckId.** The unique identifier for the check.

        :type check_id: string
        :param check_id: The unique identifier for the Trusted Advisor check.

        :type language: string
        :param language: The ISO 639-1 code for the language in which AWS
            provides support. AWS Support currently supports English ("en") and
            Japanese ("ja"). Language parameters must be passed explicitly for
            operations that take them.

        checkIdNr3   Z!DescribeTrustedAdvisorCheckResultr"   r%   )r   check_idr3   r)   r   r   r   %describe_trusted_advisor_check_result  s    !z7SupportConnection.describe_trusted_advisor_check_resultc                 C   s   d|i}| j dt|dS )a  
        Returns the summaries of the results of the Trusted Advisor
        checks that have the specified check IDs. Check IDs can be
        obtained by calling DescribeTrustedAdvisorChecks.

        The response contains an array of TrustedAdvisorCheckSummary
        objects.

        :type check_ids: list
        :param check_ids: The IDs of the Trusted Advisor checks.

        rC   Z$DescribeTrustedAdvisorCheckSummariesr"   r%   rD   r   r   r   (describe_trusted_advisor_check_summaries>  s    z:SupportConnection.describe_trusted_advisor_check_summariesc                 C   s   d|i}| j dt|dS )a  
        Returns information about all available Trusted Advisor
        checks, including name, ID, category, description, and
        metadata. You must specify a language code; English ("en") and
        Japanese ("ja") are currently supported. The response contains
        a TrustedAdvisorCheckDescription for each check.

        :type language: string
        :param language: The ISO 639-1 code for the language in which AWS
            provides support. AWS Support currently supports English ("en") and
            Japanese ("ja"). Language parameters must be passed explicitly for
            operations that take them.

        r3   ZDescribeTrustedAdvisorChecksr"   r%   rA   r   r   r   describe_trusted_advisor_checksO  s    z1SupportConnection.describe_trusted_advisor_checksc                 C   s   d|i}| j dt|dS )a  
        Requests a refresh of the Trusted Advisor check that has the
        specified check ID. Check IDs can be obtained by calling
        DescribeTrustedAdvisorChecks.

        The response contains a RefreshTrustedAdvisorCheckResult
        object, which contains these fields:


        + **Status.** The refresh status of the check: "none",
          "enqueued", "processing", "success", or "abandoned".
        + **MillisUntilNextRefreshable.** The amount of time, in
          milliseconds, until the check is eligible for refresh.
        + **CheckId.** The unique identifier for the check.

        :type check_id: string
        :param check_id: The unique identifier for the Trusted Advisor check.

        rF   ZRefreshTrustedAdvisorCheckr"   r%   )r   rG   r)   r   r   r   refresh_trusted_advisor_checkb  s    z/SupportConnection.refresh_trusted_advisor_checkc                 C   s(   i }|dk	r||d< | j dt|dS )a  
        Takes a `CaseId` and returns the initial state of the case
        along with the state of the case after the call to ResolveCase
        completed.

        :type case_id: string
        :param case_id: The AWS Support case ID requested or returned in the
            call. The case ID is an alphanumeric string formatted as shown in
            this example: case- 12345678910-2013-c4c1d2bf33c5cf47

        Nr,   ZResolveCaser"   r%   )r   r/   r)   r   r   r   resolve_casez  s    zSupportConnection.resolve_casec           
      C   s   d| j |f | jjdtt|d}| jdddi ||d}| j|d dd}| d	}t	j
| |jd
kr~|rt|S n8t|}|dd }| j|| j}	|	|j|j|dd S )Nz%s.%szapplication/x-amz-json-1.1)zX-Amz-TargetHostzContent-TypezContent-LengthPOST/)methodpathZ	auth_pathr)   headersdata
   )ZsenderZoverride_num_retrieszutf-8   Z__type)r$   )TargetPrefixr   r   strlenZbuild_base_http_requestZ_mexereaddecodebotologdebugstatusr   loadsget_faultsResponseErrorreason)
r   r#   r$   rR   http_requestresponseZresponse_bodyZ	json_bodyZ
fault_nameZexception_classr   r   r   r&     s6    
    


zSupportConnection.make_request)N)NNN)NNNNNNN)	NNNNNNNNN)NNNN)NN)N)N)N)(__name__
__module____qualname____doc__Z
APIVersionr   r   ZServiceNamerV   r   rb   r   r   r	   r
   r   r   r   r   r   r   ra   r   r   r*   r1   r4   r5   r>   r?   r@   rB   rE   rH   rI   rJ   rK   rL   r&   __classcell__r   r   r   r   r      sp   :
"   
-          
i           
V     
5
$

'
r   )r[   Zboto.compatr   Zboto.connectionr   Zboto.regioninfor   Zboto.exceptionr   Zboto.supportr   r   r   r   r   r   <module>   s   