Subversion Repositories SmartDukaan

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
8224 manish.sha 1
/******************************************************************************* 
2
 *  Copyright 2009 Amazon Services.
3
 *  Licensed under the Apache License, Version 2.0 (the "License"); 
4
 *  
5
 *  You may not use this file except in compliance with the License. 
6
 *  You may obtain a copy of the License at: http://aws.amazon.com/apache2.0
7
 *  This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR 
8
 *  CONDITIONS OF ANY KIND, either express or implied. See the License for the 
9
 *  specific language governing permissions and limitations under the License.
10
 * ***************************************************************************** 
11
 *
12
 *  Marketplace Web Service Java Library
13
 *  API Version: 2009-01-01
14
 *  Generated: Wed Feb 18 13:28:48 PST 2009 
15
 * 
16
 */
17
 
18
 
19
 
20
package com.amazonaws.mws.samples;
21
 
22
import java.util.List;
23
import java.util.ArrayList;
24
import com.amazonaws.mws.*;
25
import com.amazonaws.mws.model.*;
26
import java.util.concurrent.Future;
27
 
28
/**
29
 *
30
 * Get Report Schedule Count  Samples
31
 *
32
 *
33
 */
34
public class GetReportScheduleCountAsyncSample {
35
 
36
    /**
37
     * Just add a few required parameters, and try the service
38
     * Get Report Schedule Count functionality
39
     *
40
     * @param args unused
41
     */
42
    public static void main(String... args) {
43
 
44
        /************************************************************************
45
         * Access Key ID and Secret Access Key ID, obtained from:
46
         * http://aws.amazon.com
47
         ***********************************************************************/
48
        final String accessKeyId = "<Your Access Key ID>";
49
        final String secretAccessKey = "<Your Secret Access Key>";
50
        final String appName = "<Your Application or Company Name>";
51
        final String appVersion = "<Your Application Version or Build Number or Release Date>";
52
 
53
 
54
        MarketplaceWebServiceConfig config = new MarketplaceWebServiceConfig();
55
 
56
        /************************************************************************
57
         * Uncomment to set the appropriate MWS endpoint.
58
         ************************************************************************/
59
        // US
60
        // config.setServiceURL("https://mws.amazonservices.com");
61
        // UK
62
        // config.setServiceURL("https://mws.amazonservices.co.uk");
63
        // Germany
64
        // config.setServiceURL("https://mws.amazonservices.de");
65
        // France
66
        // config.setServiceURL("https://mws.amazonservices.fr");
67
        // Italy
68
        // config.setServiceURL("https://mws.amazonservices.it");
69
        // Japan
70
        // config.setServiceURL("https://mws.amazonservices.jp");
71
        // China
72
        // config.setServiceURL("https://mws.amazonservices.com.cn");
73
        // Canada
74
        // config.setServiceURL("https://mws.amazonservices.ca");
75
        // India
76
        // config.setServiceURL("https://mws.amazonservices.in");
77
 
78
        /************************************************************************
79
         * The argument (35) set below is the number of threads client should
80
         * spawn for processing.
81
         ***********************************************************************/
82
 
83
        config.setMaxAsyncThreads(35);
84
 
85
        /************************************************************************
86
         * You can also try advanced configuration options. Available options are:
87
         *
88
         *  - Signature Version
89
         *  - Proxy Host and Proxy Port
90
         *  - User Agent String to be sent to Marketplace Web Service
91
         *
92
         ***********************************************************************/
93
 
94
        /************************************************************************
95
         * Instantiate Http Client Implementation of Marketplace Web Service        
96
         ***********************************************************************/
97
 
98
        MarketplaceWebService service = new MarketplaceWebServiceClient(
99
                accessKeyId, secretAccessKey, appName, appVersion, config);
100
 
101
        /************************************************************************
102
         * Setup requests parameters and invoke parallel processing. Of course
103
         * in real world application, there will be much more than a couple of
104
         * requests to process.
105
         ***********************************************************************/
106
 
107
        /************************************************************************
108
         * Marketplace and Merchant IDs are required parameters for all 
109
         * Marketplace Web Service calls.
110
         ***********************************************************************/
111
        final String merchantId = "<Your Merchant ID>";
112
 
113
        GetReportScheduleCountRequest requestOne = new GetReportScheduleCountRequest();
114
        requestOne.setMerchant( merchantId );
115
        // @TODO: set request parameters here
116
 
117
        GetReportScheduleCountRequest requestTwo = new GetReportScheduleCountRequest();
118
        requestTwo.setMerchant( merchantId );
119
        // @TODO: set second request parameters here
120
 
121
        List<GetReportScheduleCountRequest> requests = new ArrayList<GetReportScheduleCountRequest>();
122
        requests.add(requestOne);
123
        requests.add(requestTwo);
124
 
125
        // invokeGetReportScheduleCount(service, requests);
126
 
127
    }
128
 
129
 
130
 
131
    /**
132
     * Get Report Schedule Count request sample
133
     * returns the number of report schedules
134
     *   
135
     * @param service instance of MarketplaceWebService service
136
     * @param requests list of requests to process
137
     */
138
    public static void invokeGetReportScheduleCount(MarketplaceWebService service, List<GetReportScheduleCountRequest> requests) {
139
        List<Future<GetReportScheduleCountResponse>> responses = new ArrayList<Future<GetReportScheduleCountResponse>>();
140
        for (GetReportScheduleCountRequest request : requests) {
141
            responses.add(service.getReportScheduleCountAsync(request));
142
        }
143
        for (Future<GetReportScheduleCountResponse> future : responses) {
144
            while (!future.isDone()) {
145
                Thread.yield();
146
            }
147
            try {
148
                GetReportScheduleCountResponse response = future.get();
149
                // Original request corresponding to this response, if needed:
150
                GetReportScheduleCountRequest originalRequest = requests.get(responses.indexOf(future));
151
                System.out.println("Response request id: " + response.getResponseMetadata().getRequestId());
152
                System.out.println(response.getResponseHeaderMetadata());
153
                System.out.println();
154
            } catch (Exception e) {
155
                if (e.getCause() instanceof MarketplaceWebServiceException) {
156
                    MarketplaceWebServiceException exception = MarketplaceWebServiceException.class.cast(e.getCause());
157
                    System.out.println("Caught Exception: " + exception.getMessage());
158
                    System.out.println("Response Status Code: " + exception.getStatusCode());
159
                    System.out.println("Error Code: " + exception.getErrorCode());
160
                    System.out.println("Error Type: " + exception.getErrorType());
161
                    System.out.println("Request ID: " + exception.getRequestId());
162
                    System.out.print("XML: " + exception.getXML());
163
                    System.out.println("ResponseHeaderMetadata: " + exception.getResponseHeaderMetadata());
164
                } else {
165
                    e.printStackTrace();
166
                }
167
            }
168
        }
169
    }
170
 
171
}