File: side-by-side.rst

package info (click to toggle)
aws-sdk-for-php 2.7.2-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 14,448 kB
  • ctags: 10,879
  • sloc: php: 157,235; python: 233; makefile: 184; xml: 28; sh: 5
file content (277 lines) | stat: -rw-r--r-- 10,428 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
==================
Side-by-side Guide
==================

This guide helps you install, configure, and run Version 1 and Version 2 of the AWS SDK for PHP side-by-side within the
same application or project. Please see the :doc:`migration-guide` for more information on migrating code from the
original AWS SDK for PHP to Version 2.

Since Version 2 of the AWS SDK for PHP now supports all of the AWS services supported by Version 1 (and more), it is
recommended that you should begin migrating your code to use Version 2 of the SDK. Using both SDKs side-by-side may be
helpful if your use case requires you to migrate only sections of your code at a time.

Installing and Including the SDKs
---------------------------------

To install and include the SDKs in your project, you must first choose whether or not to use Composer.

Using Composer
~~~~~~~~~~~~~~

Using `Composer <http://getcomposer.org>`_ is the recommended way to install both versions of the AWS SDK for PHP.
Composer is a dependency management tool for PHP that allows you to declare the dependencies your project requres and
installs them into your project. In order to simultaneously use both versions of the SDK in the same project through
Composer, you must do the following:

#. Add both of the SDKs as dependencies in your project's ``composer.json`` file.

   .. code-block:: js

        {
            "require": {
                "aws/aws-sdk-php": "*",
                "amazonwebservices/aws-sdk-for-php": "*"
            }
        }

   **Note:** Consider tightening your dependencies to a known version when deploying mission critical applications
   (e.g., ``2.0.*``).

#. Download and install Composer.

   .. code-block:: sh

        curl -s "http://getcomposer.org/installer" | php

#. Install your dependencies.

   .. code-block:: sh

        php composer.phar install

#. Require Composer's autoloader.

   Composer also prepares an autoload file that's capable of autoloading all of the classes in any of the libraries that
   it downloads. To use it, just add the following line to your code's bootstrap process.

   .. code-block:: php

        require '/path/to/sdk/vendor/autoload.php';

You can find out more on how to install Composer, configure autoloading, and other best-practices for defining
dependencies at `getcomposer.org <http://getcomposer.org>`_.

Without Composer
~~~~~~~~~~~~~~~~

Without Composer, you must manage your own project dependencies.

#. Download both of the SDKs (via PEAR, GitHub, or the AWS website) into a location accessible by your project. Make
   certain to use the pre-packaged ``aws.phar`` file, which includes all of the dependencies for the AWS SDK for PHP.

#. In your code's bootstrap process, you need to explicitly require the bootstrap file from Version 1 of the SDK and the
   ``aws.phar`` file containing Version 2 of the SDK:

   .. code-block:: php

        // Include each of the SDK's bootstrap files to setup autoloading
        require '/path/to/sdk.class.php'; // Load the Version 1 bootstrap file
        require '/path/to/aws.phar';      // Load the Version 2 pre-packaged phar file

Configuring and Instantiating the SDKs
--------------------------------------

How you configure and instantiate the SDKs is determined by whether or not you are using the service builder
(``Aws\Common\Aws`` class).

Instantiating Clients via the Service Builder
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The service builder (``Aws\Common\Aws class``) in the AWS SDK for PHP enables configuring all service clients with the
same credentials. It also accepts additional settings for some or all of the clients. The service builder functionality
is inherited from the `Guzzle <http://guzzlephp.org>`_ project.

You can pass the service builder a configuration file containing your credentials and other settings. It will then
inject these into all of the service clients your code instantiates. For more information about the configuration file,
please read the :doc:`configuration` section of the guide. When using both SDKs side-by-side, your configuration file
must include the following line:

.. code-block:: php

    'includes' => array('_sdk1'),

This will automatically set up the service clients from Version 1 of the SDK making them accessible through the service
builder by keys such as ``v1.s3`` and ``v1.cloudformation``. Here is an example configuration file that includes
referencing the Version 1 of the SDK:

.. code-block:: php

    <?php return array(
        'includes' => array('_sdk1'),
        'services' => array(
            'default_settings' => array(
                'params' => array(
                    'key'    => 'your-aws-access-key-id',
                    'secret' => 'your-aws-secret-access-key',
                    'region' => 'us-west-2'
                )
            )
        )
    );

Your code must instantiate the service builder through its factory method by passing in the path of the configuration
file. Your code then retrieves instances of the specific service clients from the returned builder object.

.. code-block:: php

    use Aws\Common\Aws;

    // Instantiate the service builder
    $aws = Aws::factory('/path/to/your/config.php');

    // Instantiate S3 clients via the service builder
    $s3v1 = $aws->get('v1.s3');  // All Version 1 clients are prefixed with "v1."
    $s3v2 = $aws->get('s3');

Instantiating Clients via Client Factories
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Your code can instantiate service clients using their respective ``factory()`` methods by passing in an array of
configuration data, including your credentials. The ``factory()`` will work for clients in either versions of the SDK.

.. code-block:: php

    use Aws\S3\S3Client;

    // Create an array of configuration options
    $config = array(
        'key'    => 'your-aws-access-key-id',
        'secret' => 'your-aws-secret-access-key',
    );

    // Instantiate Amazon S3 clients from both SDKs via their factory methods
    $s3v1 = AmazonS3::factory($config);
    $s3v2 = S3Client::factory($config);

Optionally, you could alias the classes to make it clearer which version of the SDK they are from.

.. code-block:: php

    use AmazonS3 as S3ClientV1;
    use Aws\S3\S3Client as S3ClientV2;

    $config = array(
        'key'    => 'your-aws-access-key-id',
        'secret' => 'your-aws-secret-access-key',
    );

    $s3v1 = S3ClientV1::factory($config);
    $s3v2 = S3ClientV2::factory($config);

Complete Examples
-----------------

The following two examples fully demonstrate including, configuring, instantiating, and using both SDKs side-by-side.
These examples adopt the recommended practices of using Composer and the service builder.

Example 1 - Dual Amazon S3 Clients
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

This example demonstrates using an Amazon S3 client from the AWS SDK for PHP working side-by-side with an Amazon S3
client from the first PHP SDK.

.. code-block:: php

    <?php

    require 'vendor/autoload.php';

    $aws = Aws\Common\Aws::factory('/path/to/config.json');

    $s3v1 = $aws->get('v1.s3');
    $s3v2 = $aws->get('s3');

    echo "ListBuckets with SDK Version 1:\n";
    echo "-------------------------------\n";
    $response = $s3v1->listBuckets();
    if ($response->isOK()) {
        foreach ($response->body->Buckets->Bucket as $bucket) {
            echo "- {$bucket->Name}\n";
        }
    } else {
        echo "Request failed.\n";
    }
    echo "\n";

    echo "ListBuckets with SDK Version 2:\n";
    echo "-------------------------------\n";
    try {
        $result = $s3v2->listBuckets();
        foreach ($result['Buckets'] as $bucket) {
            echo "- {$bucket['Name']}\n";
        }
    } catch (Aws\S3\Exception\S3Exception $e) {
        echo "Request failed.\n";
    }
    echo "\n";

Example 2 - Amazon DynamoDB and Amazon SNS Clients
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

This example shows how the AWS SDK for PHP DynamoDB client works together with the SNS client from the original SDK.
For this example, an ice cream parlor publishes a daily message (via SNS) containing its "flavors of the day" to
subscribers. First, it retrieves the flavors of the day from its DynamoDB database using the AWS SDK for PHP DynamoDB
client. It then uses the SNS client from the first SDK to publish a message to its SNS topic.

.. code-block:: php

    <?php

    require 'vendor/autoload.php';

    $aws = Aws\Common\Aws::factory('/path/to/config.php');

    // Instantiate the clients
    $ddb = $aws->get('dynamodb');
    $sns = $aws->get('v1.sns');
    $sns->set_region(AmazonSNS::REGION_US_W2);

    // Get today's flavors from DynamoDB using Version 2 of the SDK
    $date = new DateTime();
    $flavors = $ddb->getItem(array(
        'TableName' => 'flavors-of-the-day',
        'Key' => array(
            'HashKeyElement'  => array('N' => $date->format('n')),
            'RangeKeyElement' => array('N' => $date->format('j'))
        )
    ))->getResult()->getPath('Item/flavors/SS');

    // Generate the message
    $today = $date->format('l, F jS');
    $message = "It's {$today}, and here are our flavors of the day:\n";
    foreach ($flavors as $flavor) {
        $message .= "- {$flavor}\n";
    }
    $message .= "\nCome visit Mr. Foo\'s Ice Cream Parlor on 5th and Pine!\n";
    echo "{$message}\n";

    // Send today's flavors to subscribers using Version 1 of the SDK
    $response = $sns->publish('flavors-of-the-day-sns-topic', $message, array(
        'Subject' => 'Flavors of the Day - Mr. Foo\'s Ice Cream Parlor'
    ));
    if ($response->isOK()) {
        echo "Sent the flavors of the day to your subscribers.\n";
    } else {
        echo "There was an error sending the flavors of the day to your subscribers.\n";
    }

Final Notes
-----------

Remember that **instantiating clients from the original SDK using the service builder from AWS SDK for PHP does not
change how those clients work**. For example, notice the differences in response handling between SDK versions. For a
full list of differences between the versions, please see the :doc:`migration-guide`.

For more information about using the original version of the SDK, please see the `Version 1 API Documentation
<http://docs.aws.amazon.com/AWSSDKforPHP/latest/>`_ and the `Version 1 SDK README
<https://github.com/amazonwebservices/aws-sdk-for-php/blob/master/README.md>`_.