Encoder: Transform files on the fly

You can automatically convert the file with the encode argument. django-staticinline ships with a couple of encoders:

List of build-in encoders:

base64

Transforms the file content to a base64 encoded string.

{% load staticinline %}
My key: {% staticinline "mykey.pem" encode="base64" %}

Becomes:

My key: LS0tIFN1cGVyIFByaXZhdGUgS2V5IC0tLQo=

data

Transforms the content into a data URI for use in CSS url() and HTML src="" attributes.

{% load staticinline %}
ul.checklist li.complete {
    background: url('{% staticinline "icons/check.png" encode="data" %}');
}

Becomes:

ul.checklist li.complete {
    background: url('\
goAAAANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAABlBMVEUAAAD//\
/+l2Z/dAAAAM0lEQVR4nGP4/5/h/1+G/58ZDrAz3D/McH8yw83ND\
DeNGe4Ug9C9zwz3gVLMDA/A6P9/AFGGFyjOXZtQAAAAAElFTkSuQ\
mCC');
}

sri

Generates a sha256 hash of the file content, suitable for Subresource Integrity verifications.

{% load staticfiles %}
{% load staticinline %}

<link rel="stylesheet"
      href="{% static "base.css" %}"
      integrity="{% staticinline "base.css" encode="sri" %}"
      crossorigin="anonymous"/>

Becomes:

<link rel="stylesheet"
      href="/static/base.css"
      integrity="sha256-aeB9jNF0zyjK656631roQQOsKgRocLazJdr6fmleg4I"
      crossorigin="anonymous"/>

Add a custom Encoder

You can add custom encoder by extending the AppConfig. See the Django docs for further information about AppConfig applications.

# myproject/apps.py
from staticinline.apps import StaticInlineAppConfig

class CustomStaticInlineAppConfig(StaticInlineAppConfig):

    # Add the custom 'upper' encoder to the list of build-in encoders.
    def get_encoder(self):
        encoder = super().get_encoder()
        encoder.update({
            'upper': self.encode_upper,
        })
        return encoder

    # Define the encoder itself. `data` contains the file content
    # and we transform all characters to uppercase here.
    def encode_upper(self, data, path):
        return data.upper()

In your INSTALLED_APPS setting you now point to your custom AppConfig:

# settings.py
INSTALLED_APPS = [
    # 'staticinline.apps.StaticInlineAppConfig',
    'myproject.apps.CustomStaticInlineAppConfig',
]

In a template you call it with the respective name:

{% load staticinline %}

{% staticinline "my-poem.txt" encode="upper" %}