Skip to main content

Feature flags for Wagtail sites

Project description

Wagtail-Flags

Build Status Ethical open source

Feature flags allow you to toggle functionality based on configurable conditions.

Wagtail-Flags adds a Wagtail admin UI and Wagtail Site-based condition on top of Django-Flags. For a more complete overview of feature flags and how to use them, please see the Django-Flags documentation.

Feature flags in the Wagtail admin

Dependencies

  • Python 3.12+
  • Django 5.2 (LTS)+
  • Django-Flags 5.0
  • Wagtail 6.3+

It should be compatible at all intermediate versions, as well. If you find that it is not, please file an issue.

Installation

  1. Install Django-Flags and Wagtail-Flags:
pip install django-flags
pip install wagtail-flags
  1. Add flags and wagtailflags as installed apps in your Django settings.py:
INSTALLED_APPS = (
    ...
    'flags',
    'wagtailflags',
    ...
)

Usage

Please see the Django-Flags documentation for the most current information about defining and checking feature flags.

First, define the flag in Django settings.py:

FLAGS = {
    'MY_FLAG': []
}

Then use the flag in a Django template (mytemplate.html):

{% load feature_flags %}
{% flag_enabled 'MY_FLAG' as my_flag %}

{% if my_flag %}
  <div class="flagged-banner">
    I’m the result of a feature flag.
  </div>
{% endif %}

Next, configure a URL for that template (urls.py):

from django.urls import path
from django.views.generic import TemplateView

urlpatterns = [
    path(r'mypage/', TemplateView.as_view(template_name='mytemplate.html')),
]

Finally, add conditions for the flag in the Wagtail admin under "Settings", "Flags", "MY_FLAG":

Creating conditions in the Wagtail admin

Extended conditions

Wagtail-Flags adds the following conditions to Django-Flags:

site

Allows a flag to be enabled for a Wagtail site that matches the hostname and port in the condition value.

FLAGS = {
    'MY_FLAG': [
        {'condition': 'site', 'value': 'staging.mysite.com'}
    ],
}

Signals

Wagtail-Flags includes flag_enabled and flag_disabled signals that can be received when the "Enable for all requests" and "Disable for all requests" buttons are pressed in the admin. This is intended to enable things like front-end cache invalidation.

from django.dispatch import receiver

from wagtail.contrib.frontend_cache.utils import purge_url_from_cache

from wagtailflags.signals import flag_disabled, flag_enabled


@receiver(flag_enabled)
def purge_on_flag_enabled(sender, **kwargs):
    flag_name = kwargs["flag_name"]
    purge_url_from_cache(...)

@receiver(flag_disabled)
def purge_on_flag_disabled(sender, **kwargs):
    flag_name = kwargs["flag_name"]
    purge_url_from_cache(...)

Please note: These signals are only sent for manual presses of the "Enable for all requests" and "Disable for all requests" buttons in the admin. Other flag conditions may vary within and only be valid for a specific request cycle.

Getting help

Please add issues to the issue tracker.

Getting involved

General instructions on how to contribute can be found in CONTRIBUTING.

Licensing

  1. TERMS
  2. LICENSE
  3. CFPB Source Code Policy

Credits and references

  1. Forked from cfgov-refresh

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wagtail_flags-5.5.0.tar.gz (248.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

wagtail_flags-5.5.0-py3-none-any.whl (23.1 kB view details)

Uploaded Python 3

File details

Details for the file wagtail_flags-5.5.0.tar.gz.

File metadata

  • Download URL: wagtail_flags-5.5.0.tar.gz
  • Upload date:
  • Size: 248.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for wagtail_flags-5.5.0.tar.gz
Algorithm Hash digest
SHA256 db1bb45943d8c7180ce3447baf41e8ef4e62ba49764825a1c16eb1f50145635b
MD5 29e71ceb2871aa77c22eac910017e744
BLAKE2b-256 241e4cd185a8ea5baf711ee5813e2c0e631874645235d0b88654d4cd30b48320

See more details on using hashes here.

Provenance

The following attestation bundles were made for wagtail_flags-5.5.0.tar.gz:

Publisher: release.yml on cfpb/wagtail-flags

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file wagtail_flags-5.5.0-py3-none-any.whl.

File metadata

  • Download URL: wagtail_flags-5.5.0-py3-none-any.whl
  • Upload date:
  • Size: 23.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for wagtail_flags-5.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3a7bc91454d086bef5bcda80199de3185740836762f5c0ac07f4c424a1486770
MD5 e79ce8ae810c439d6ae2f2aae2443ee5
BLAKE2b-256 09d2f10d2bc54e1b6fc1a03bed2b14c1c6cc15ad1a2b8e84bec1faf209555b9f

See more details on using hashes here.

Provenance

The following attestation bundles were made for wagtail_flags-5.5.0-py3-none-any.whl:

Publisher: release.yml on cfpb/wagtail-flags

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page