2017 © Pedro Peláez
 

twig-extension twig-asset-version-extension

image

ivoba/twig-asset-version-extension

  • Wednesday, December 17, 2014
  • by ivoba
  • Repository
  • 1 Watchers
  • 0 Stars
  • 18,311 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

Asset Version Twig Extension

Render versioned asset filenames in twig., (*1)

Build Status, (*2)

Install

Use composer:, (*3)

require ivoba/twig-asset-version-extension

Usage

In your twig files:, (*4)

<script src="{{ asset_versioned('/dist/js/script.js') }}"></script>

This will render : /dist/js/script.12345.js, (*5)

Where 12345 is by default the md5 content digest of the file., (*6)

The trick is to leave the file with the original filename: /dist/js/script.js
and let the webserver rewrite the url by pattern., (*7)

F.e, for the above pattern and apache mod_rewrite you could use:, (*8)

RewriteRule ^dist/(.+)\.(.+)\.(js|css|png|jpg|gif)$ /dist/$1.$3 [L]

For nginx:, (*9)

location ~* ^.+\.(dist)$ {
        rewrite ^(.+)\.(\d+)\.(dist)$ $1.$3 last;
        expires 31536000s;

Integration

Silex:

Register the Twig Extension:, (*10)

$app['twig'] = $app->share($app->extend('twig', function ($twig, $app) {
    $twig->addExtension(new \Ivoba\AssetVersion\Twig\AssetVersionExtension(new \Ivoba\AssetVersion\Version\Md5ContentAssetVersion(),
                                                                           new \Ivoba\AssetVersion\Namer\DefaultNamer(),
                                                                            __DIR__. '/../web'));
    return $twig;
}));

Symfony:

Add this in your services.xml:, (*11)

<service id="ivoba_asset_version.version.md5_content"
         class="Ivoba\AssetVersion\Version\Md5ContentAssetVersion">
</service>
<service id="ivoba_asset_version.namer.default"
         class="Ivoba\AssetVersion\Namer\DefaultNamer">
</service>
<service id="ivoba_asset_version.twig.asset_version_extension"
         class="Ivoba\AssetVersion\Twig\AssetVersionExtension">
    <argument type="service" id="ivoba_asset_version.version.md5_content"/>
    <argument type="service" id="ivoba_asset_version.namer.default"/>
    <argument>%asset_dir%</argument>
    <tag name="twig.extension"/>
</service>

Extend

You can create your own Version or Namer class by implementing their resp. interfaces and pass them to the extension.
F.e if you prefer timestamp as version or a different pattern in the filename., (*12)

In the Extension you can add options as 4th parameter, as for now it only offers options['asset.directory'], as standard directory for assets., (*13)

Credits

Read more about the idea:, (*14)

http://www.particletree.com/notebook/automatically-version-your-css-and-javascript-files/, (*15)

http://www.bephpug.de/folien/asset_fingerprinting_with_php_demo_2012-08-07.pdf, (*16)

The Versions

17/12 2014

dev-master

9999999-dev

  Sources   Download

MIT

The Requires

 

The Development Requires

twig assets cachebuster

17/12 2014

v1.0.0

1.0.0.0

  Sources   Download

MIT

The Requires

 

The Development Requires

twig assets cachebuster