Flask-Asset does not create correct url on template

550 Views Asked by At

I cannot figure out why Flask-CDN is not building my templates with the Amazon CloudFront url for my static files. Here is my setup:

1) Configure cdn domain and ask Flask-Assets to use cdn:

class AppConfig(BaseConfig):
    DEBUG = False
    FLASK_ASSETS_USE_CDN = True
    CDN_DOMAIN = "mydomain.cloudfront.net"

2) The Flask app with the CDN object:

config_object = AppConfig
app = flask.Flask(config_object.PROJECT_NAME, static_folder='web/static')
app.config.from_object(config_object)

# Bundles are configured here (many of them!) to generate the app.js file

if config_object.DEBUG is False:
    CDN(app)

app.run(host='0.0.0.0')

3) The template that uses the assets:

{% assets "js_app" %}
<script type="text/javascript" src="{{ ASSET_URL }}"></script>
{% endassets %}

4) Finally, the html built by the server was:

<script type="text/javascript" src="/static/gen/app.js?40c12882"></script>

I'm wondering why the html doesn't contain my CDN domain, as it should have been generated like this:

<script type="text/javascript" src="http://mydomain.cloudfront.net/static/gen/app.js?40c12882"></script>

Thank you.

1

There are 1 best solutions below

3
On

Ok. Found the problem. The latest version of Flask-Assets on pip (0.10) does not contain the CDN feature described on docs for current version, that is 0.10.