
Research
/Security News
Bitwarden CLI Compromised in Ongoing Checkmarx Supply Chain Campaign
Bitwarden CLI 2026.4.0 was compromised in the Checkmarx supply chain campaign after attackers abused a GitHub Action in Bitwarden’s CI/CD pipeline.
django-recurrence
Advanced tools
.. image:: https://jazzband.co/static/img/badge.svg :target: https://jazzband.co/ :alt: Jazzband
.. image:: https://img.shields.io/github/stars/jazzband/django-recurrence.svg?label=Stars&style=socialcA :target: https://github.com/jazzband/django-recurrence :alt: GitHub
.. image:: https://img.shields.io/pypi/v/django-recurrence.svg :target: https://pypi.org/project/django-recurrence/ :alt: PyPI release
.. image:: https://img.shields.io/pypi/pyversions/django-recurrence.svg :target: https://pypi.org/project/django-recurrence/ :alt: Supported Python versions
.. image:: https://img.shields.io/pypi/djversions/django-recurrence.svg :target: https://pypi.org/project/django-recurrence/ :alt: Supported Django versions
.. image:: https://img.shields.io/readthedocs/django-recurrence.svg :target: https://django-recurrence.readthedocs.io/ :alt: Documentation
.. image:: https://github.com/jazzband/django-recurrence/workflows/Test/badge.svg :target: https://github.com/jazzband/django-recurrence/actions :alt: GitHub actions
.. image:: https://codecov.io/gh/jazzband/django-recurrence/branch/master/graph/badge.svg :target: https://codecov.io/gh/jazzband/django-recurrence :alt: Coverage
django-recurrence is a utility for working with recurring dates in Django.
dateutil.rrule) for specifying recurring date/times,RecurrenceField for storing recurring datetimes in the database, andRecurrenceField provides a Django model field which serializes
recurrence information for storage in the database.
For example - say you were storing information about a university course in your app. You could use a model like this:
.. code:: python
import recurrence.fields
class Course(models.Model): title = models.CharField(max_length=200) start = models.TimeField() end = models.TimeField() recurrences = recurrence.fields.RecurrenceField()
You’ll notice that I’m storing my own start and end time. The recurrence field only deals with recurrences not with specific time information. I have an event that starts at 2pm. Its recurrences would be “every Friday”.
For more information on installation and configuration see the documentation at:
https://django-recurrence.readthedocs.io/
If you have questions or have trouble using the app please file a bug report at:
https://github.com/jazzband/django-recurrence/issues
All contributions are welcome!
It is best to separate proposed changes and PRs into small, distinct patches by type so that they can be merged faster into upstream and released quicker.
One way to organize contributions would be to separate PRs for e.g.
Merging contributions requires passing the checks configured with the CI. This includes running tests and linters successfully on the currently officially supported Python and Django versions.
The test automation is run automatically with GitHub Actions, but you can
run it locally with the tox command before pushing commits.
This is a Jazzband <https://jazzband.co>_ project. By contributing you agree to abide by the Contributor Code of Conduct <https://jazzband.co/about/conduct>_ and follow the guidelines <https://jazzband.co/about/guidelines>_.
FAQs
Django utility wrapping dateutil.rrule
We found that django-recurrence demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 5 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Research
/Security News
Bitwarden CLI 2026.4.0 was compromised in the Checkmarx supply chain campaign after attackers abused a GitHub Action in Bitwarden’s CI/CD pipeline.

Research
/Security News
Docker and Socket have uncovered malicious Checkmarx KICS images and suspicious code extension releases in a broader supply chain compromise.

Product
Stay on top of alert changes with filtered subscriptions, batched summaries, and notification routing built for triage.