11

I am trying to integrate AWS PHP SDK for codeigniter

But its showing error as follows

An uncaught Exception was encountered
Type: Aws\Exception\CredentialsException

Message: Cannot read credentials from /.aws/credentials

Filename: /var/www/html/aws/Aws/Credentials/CredentialProvider.php

And on cli getting an error as -bash: /root/.aws/credentials: Permission denied

So after this i have allowed permission ... cli error has gone but php error Cannot read credentials from /.aws/credentials still remain.

Please help to solve this issue.

Thanks!

Deepali Jadhav
  • 540
  • 2
  • 8
  • 18

4 Answers4

27

If your are using IAM Role to EC2 Instance then there is no need of using following

'profile'=>'default',

i just remove above line which solved error "Cannot read credentials from /.aws/credentials"

Issue using an IAM role with PHP SDK

Deepali Jadhav
  • 540
  • 2
  • 8
  • 18
4

When running code on another AWS service, you do not work with key and secret, as you would on your local machine. Take a look at the answer I gave on another question.

Basically, your EC2 instance is assigned a service role. Then you would attach one or more IAM policies to that role. The IAM policies will determine what AWS resources and actions your EC2 instance can access.

In your PHP code you would instantiate your client using the CredentialProvider::defaultProvider(). If you were working with S3 for example, it would look like this.

$s3 = new S3Client([
    'region' =>'us-east-1',
    'credentials' => CredentialProvider::defaultProvider()
]);
Olivier De Meulder
  • 2,493
  • 3
  • 25
  • 30
2

When PHP is running under a service there is no "user". Therefore PHP will not attempt to access /root/.aws/credentials. If you review the error the path is /.aws/credentails.

To solve this problem create a new directory /.aws and copy the directory /root/.aws to /.aws

Improvement:

You have installed the PHP SDK inside your website root folder which makes these files accessible externally. SDKs should be installed outside of your website folders.

John Hanley
  • 74,467
  • 6
  • 95
  • 159
0

For me in the development environment i didn't use iam role so didn't need to access the .aws/credentials file.

By removing the 'profile'=>'default' from the $config you tell the SDK not to look for .aws/credentials file, and then you can call the service construction with key and secret

When using'profile'=>'default', the sdk will first look for the .aws/credentials file and if not exists will throw an exception

For example :

        $config = array(
            'region'  => $region,
            'version' => $version
        );

        $credentials = new Credentials($key, $secret);
        $config['credentials'] = $credentials;
        

        $dynamoDbClient = new DynamoDbClient($config);
ron
  • 726
  • 11
  • 16