Дамп Symfony2 активов для Amazon S3

Я бы захотел сбросить свои активы на мой ведро s3 в производстве, после развертывания с capifony в Symfony 2. Я нашел некоторое решение, но не знаю, как лучше всего использовать.

Возможно, дамп активов с Zend_Service_Amazon_S3, но я думаю, что это немного перехитрить, чтобы импортировать рамки Zend только для этого. - http://permalink.gmane.org/gmane.comp.php.symfony.symfony2/54

Я также нашел это: https://github.com/symfony/symfony/pull/108, где я могу сказать AsseticBundle имя ведра, но я не нашел, где предоставить ключ и секрет для моей учетной записи aws.

Можете ли вы указать лучшее решение или дать мне подробную информацию о вышеупомянутых.

Ответ 1

Итак, что я сделал, и он работает.

Добавьте в composer.json и установите его

"aws/aws-sdk-php": "2.6.16",

Создайте сервис:

<?php

namespace My\AcmeBundle\Amazon;

use Aws\Common\Aws;

class StreamWrapperS3 {

    protected $s3;

    public function __construct($key, $secret, $region) {

        $aws = array(
            'key'    => $key,
            'secret' => $secret,
            'region' => $region
        );

        $this->s3 = Aws::factory($aws)->get('s3');

    }

    public function registerStreamWrapper() {
        $this->s3->registerStreamWrapper();
    }

}

Объявить службу в config.yml или включить ее в файл

services:
    my_amazon_s3:
        class: My\AcmeBundle\Amazon\StreamWrapperS3
        arguments: [%aws_key%, %aws_secret_key%, %aws_region%]

Добавьте параметры в parameters.yml

Заменить метод boot() на AppKernel.php:

public function boot() {
    parent::boot();
    $s3client = $this->container->get('my_amazon_s3');;
    $s3client->registerStreamWrapper();
}

В config_prod.yml добавить:

framework:
    templating:
        assets_base_url: https://sa-east-1.amazonaws.com/your-bucket-name
assetic:
    write_to: 's3://your-bucket-name'

Наконец, добавьте фильтр с вашими ресурсами, чтобы правильно переписать пути:

{% stylesheets filter='cssrewrite'
    'bundles/...' %}
    <link rel="stylesheet" href="{{ asset_url }}" /> {# asset just to be sure that url will be right #}
{% endstylesheets %}

Итак, каждый раз, когда вы что-то изменили, нужно запускать:

php app/console cache:clear --env=prod
php app/console assets:install --env=prod
php app/console assetic:dump --env=prod

Очень важная деталь, которая заняла почти 2 дня моего времени, вам нужно обновить CORS из Amazon S3, чтобы получить доступ к некоторым файлам, например, в качестве шрифтов добавить внутри twitter bootstrap css. Мои разрешения CORS следующие:

<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
    <CORSRule>
        <AllowedOrigin>*</AllowedOrigin>
        <AllowedMethod>GET</AllowedMethod>
        <AllowedMethod>PUT</AllowedMethod>
        <AllowedMethod>POST</AllowedMethod>
        <AllowedMethod>DELETE</AllowedMethod>
        <MaxAgeSeconds>3000</MaxAgeSeconds>
        <AllowedHeader>*</AllowedHeader>
    </CORSRule>
</CORSConfiguration>

Ответ 2

На самом деле вам действительно не нужно и, возможно, даже не стоит, введите свой ключ в код приложения. В Amazon S3 вы можете указать доступ отправителем, в этом случае вы являетесь адресом производственного сервера.

Взгляните на предоставленную ссылку: https://forums.aws.amazon.com/thread.jspa?messageID=236066

Это позволит вам свободно писать с этого сервера на свое ведро. Помните также об отказе в доступе от всех других ip.

Ответ 3

Я также нашел это: https://github.com/symfony/symfony/pull/108, где я могу сказать AsseticBundle имя ведра, но я не нашел где предоставить ключ и секрет для моей учетной записи aws.

Это должно сработать - просто используйте следующую форму при указании URL-адрес ведра S3:

# config_prod.yml
assetic:
    write_to: s3://{key}:{secret}@{bucket}/