django-letsencrypt 4.1.0__py3-none-any.whl → 6.0.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {django_letsencrypt-4.1.0.dist-info → django_letsencrypt-6.0.0.dist-info}/METADATA +50 -32
- {django_letsencrypt-4.1.0.dist-info → django_letsencrypt-6.0.0.dist-info}/RECORD +6 -6
- {django_letsencrypt-4.1.0.dist-info → django_letsencrypt-6.0.0.dist-info}/WHEEL +1 -1
- letsencrypt/__init__.py +2 -2
- {django_letsencrypt-4.1.0.dist-info → django_letsencrypt-6.0.0.dist-info/licenses}/LICENSE +0 -0
- {django_letsencrypt-4.1.0.dist-info → django_letsencrypt-6.0.0.dist-info}/top_level.txt +0 -0
|
@@ -1,42 +1,51 @@
|
|
|
1
|
-
Metadata-Version: 2.
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
2
|
Name: django-letsencrypt
|
|
3
|
-
Version:
|
|
3
|
+
Version: 6.0.0
|
|
4
4
|
Summary: A simple Django app to handle Let's Encrypt ACME challenges.
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
Platform: UNKNOWN
|
|
10
|
-
Classifier: Development Status :: 5 - Production/Stable
|
|
5
|
+
Author-email: Peter Urda <foss@urda.engineering>
|
|
6
|
+
License-Expression: Apache-2.0
|
|
7
|
+
Project-URL: Homepage, https://github.com/urda/django-letsencrypt
|
|
8
|
+
Classifier: Development Status :: 6 - Mature
|
|
11
9
|
Classifier: Environment :: Web Environment
|
|
12
10
|
Classifier: Framework :: Django
|
|
13
|
-
Classifier: Framework :: Django ::
|
|
14
|
-
Classifier: Framework :: Django ::
|
|
15
|
-
Classifier: Framework :: Django ::
|
|
11
|
+
Classifier: Framework :: Django :: 4
|
|
12
|
+
Classifier: Framework :: Django :: 4.2
|
|
13
|
+
Classifier: Framework :: Django :: 5
|
|
14
|
+
Classifier: Framework :: Django :: 5.2
|
|
15
|
+
Classifier: Framework :: Django :: 6
|
|
16
|
+
Classifier: Framework :: Django :: 6.0
|
|
17
|
+
Classifier: Framework :: Flake8
|
|
18
|
+
Classifier: Framework :: Pytest
|
|
19
|
+
Classifier: Framework :: tox
|
|
16
20
|
Classifier: Intended Audience :: Developers
|
|
17
|
-
Classifier:
|
|
21
|
+
Classifier: Intended Audience :: Information Technology
|
|
22
|
+
Classifier: Intended Audience :: System Administrators
|
|
18
23
|
Classifier: Natural Language :: English
|
|
19
24
|
Classifier: Operating System :: OS Independent
|
|
20
25
|
Classifier: Programming Language :: Python
|
|
21
26
|
Classifier: Programming Language :: Python :: 3
|
|
22
|
-
Classifier: Programming Language :: Python :: 3.7
|
|
23
|
-
Classifier: Programming Language :: Python :: 3.8
|
|
24
|
-
Classifier: Programming Language :: Python :: 3.9
|
|
25
27
|
Classifier: Programming Language :: Python :: 3.10
|
|
28
|
+
Classifier: Programming Language :: Python :: 3.11
|
|
29
|
+
Classifier: Programming Language :: Python :: 3.12
|
|
30
|
+
Classifier: Programming Language :: Python :: 3.13
|
|
31
|
+
Classifier: Programming Language :: Python :: 3.14
|
|
26
32
|
Classifier: Programming Language :: Python :: 3 :: Only
|
|
27
33
|
Classifier: Topic :: Internet
|
|
28
34
|
Classifier: Topic :: Internet :: WWW/HTTP
|
|
29
35
|
Classifier: Topic :: Internet :: WWW/HTTP :: Dynamic Content
|
|
30
|
-
|
|
36
|
+
Classifier: Topic :: Internet :: WWW/HTTP :: Site Management
|
|
37
|
+
Classifier: Topic :: Security
|
|
38
|
+
Requires-Python: <4,>=3.10
|
|
31
39
|
Description-Content-Type: text/markdown
|
|
32
40
|
License-File: LICENSE
|
|
33
|
-
Requires-Dist: Django
|
|
34
|
-
Requires-Dist: pytz
|
|
41
|
+
Requires-Dist: Django>=4.2.27
|
|
42
|
+
Requires-Dist: pytz>=2025.2
|
|
43
|
+
Dynamic: license-file
|
|
35
44
|
|
|
36
45
|
# Let's Encrypt App for Django
|
|
37
46
|
|
|
38
47
|
`django-letsencrypt` will allow you to add, remove, and update any
|
|
39
|
-
[ACME challenge](https://
|
|
48
|
+
[ACME challenge](https://datatracker.ietf.org/doc/html/rfc8555) objects you may
|
|
40
49
|
need through your Django admin interface. Simply add the `ACME challenge`
|
|
41
50
|
and `response` for your app to serve up the necessary information for
|
|
42
51
|
[Let's Encrypt](https://letsencrypt.org/how-it-works/) validation.
|
|
@@ -48,33 +57,35 @@ versions of Django supported, even multiple databases too!
|
|
|
48
57
|
And of course all wrapped up and published to
|
|
49
58
|
[PyPI](https://pypi.org/project/django-letsencrypt/) for standard installation!
|
|
50
59
|
|
|
51
|
-
|
|
60
|
+
## Supported Configurations
|
|
52
61
|
|
|
53
62
|
`django-letsencrypt` is tested across a number of configurations, here's what's
|
|
54
63
|
supported so far:
|
|
55
64
|
|
|
56
65
|
- Python Versions Supported:
|
|
57
|
-
- `3.
|
|
58
|
-
- `3.
|
|
59
|
-
- `3.
|
|
66
|
+
- `3.14` (with Django `6.0`, `5.2`)
|
|
67
|
+
- `3.13` (with Django `6.0`, `5.2`)
|
|
68
|
+
- `3.12` (with Django `6.0`, `5.2`, `4.2`)
|
|
69
|
+
- `3.11` (with Django `5.2`, `4.2`)
|
|
70
|
+
- `3.10` (with Django `5.2`, `4.2`)
|
|
60
71
|
- Django Versions Supported:
|
|
61
|
-
- `
|
|
62
|
-
- `
|
|
63
|
-
- `
|
|
72
|
+
- `6.0` minimum version `6.0.1`
|
|
73
|
+
- `5.2 LTS` minimum version `5.2.10`
|
|
74
|
+
- `4.2 LTS` minimum version `4.2.27`
|
|
64
75
|
- Databases Supported:
|
|
65
76
|
- `mysql`
|
|
66
77
|
- `postgres`
|
|
67
78
|
- `sqlite`
|
|
68
79
|
|
|
69
|
-
|
|
80
|
+
## Recent Build Status Badges
|
|
70
81
|
|
|
71
82
|
- [](https://github.com/urda/django-letsencrypt/actions/workflows/linting.yaml)
|
|
72
|
-
- [](https://github.com/urda/django-letsencrypt/actions/workflows/testing-42.yaml)
|
|
84
|
+
- [](https://github.com/urda/django-letsencrypt/actions/workflows/testing-52.yaml)
|
|
85
|
+
- [](https://github.com/urda/django-letsencrypt/actions/workflows/testing-60.yaml)
|
|
75
86
|
- [](https://codecov.io/gh/urda/django-letsencrypt)
|
|
76
87
|
|
|
77
|
-
|
|
88
|
+
## Installation & Configuration
|
|
78
89
|
|
|
79
90
|
1. `pip install django-letsencrypt`
|
|
80
91
|
|
|
@@ -109,7 +120,7 @@ re_path(r'^\.well-known/', include('letsencrypt.urls'))
|
|
|
109
120
|
|
|
110
121
|
7. Enjoy your easy to manage `ACME Challenges` inside your Django project!
|
|
111
122
|
|
|
112
|
-
|
|
123
|
+
## Example Project
|
|
113
124
|
|
|
114
125
|
If you would like a demo of how to use this application simply clone this project's
|
|
115
126
|
`git` repository from [GitHub](https://github.com/urda/django-letsencrypt),
|
|
@@ -118,4 +129,11 @@ take a moment to read the `README.md` file within the
|
|
|
118
129
|
directory, and follow the directions. That will spin up a small sample django
|
|
119
130
|
application already configured for you to try out.
|
|
120
131
|
|
|
132
|
+
## Development
|
|
121
133
|
|
|
134
|
+
1. Make sure you have installed [uv](https://docs.astral.sh/uv/) in your environment.
|
|
135
|
+
2. Clone the repo to your development machine.
|
|
136
|
+
3. Configure your `git` hooks with `git config core.hooksPath .githooks` for the project.
|
|
137
|
+
4. Run `uv sync` to create the virtual environment and install required dependencies.
|
|
138
|
+
5. Run `make test` for a singular test run.
|
|
139
|
+
6. Run `make run-tox` to run the entire `tox` suite.
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
|
|
1
|
+
django_letsencrypt-6.0.0.dist-info/licenses/LICENSE,sha256=eCE-vLWjRU-36lD22l8Lbp_XpPT1Esdl0o70KlwBYHo,11345
|
|
2
|
+
letsencrypt/__init__.py,sha256=-8kyCfJx0VqAlsX1pgSepYHFHCQLRPcbsb6L6RVXf_k,646
|
|
2
3
|
letsencrypt/admin.py,sha256=4m_fVteJeP6-BpvdyAcHEJ1s3zARl2F4y4h8a5uYS80,1758
|
|
3
4
|
letsencrypt/apps.py,sha256=KTY-mm_Pv5uHEhEKuPgMiJCTEq4-NtwOQK1D_gfTN2Y,751
|
|
4
5
|
letsencrypt/models.py,sha256=nU-sjVIb8V2_-TwxX7qxR1ioSwH00JxSDN-ePGsHKSY,1568
|
|
@@ -7,8 +8,7 @@ letsencrypt/urls.py,sha256=PKpM9a3pIszlZzOfam1l3os4fjChu8RCtMxDb5ReNMI,749
|
|
|
7
8
|
letsencrypt/views.py,sha256=YsdN-i4larvajzoQuTBAj9CX3watHOu1zYNESRBBR5E,893
|
|
8
9
|
letsencrypt/migrations/0001_squashed_0004_squash_for_mysql_support.py,sha256=R2-FB0gb6dIHVfM0RQOT2-qV0Iwn3i8g9WXvU9M4zc0,900
|
|
9
10
|
letsencrypt/migrations/__init__.py,sha256=753utKcjHt5snhTYhBfAY_5QBvTMpDF8zFkiAwbcn40,564
|
|
10
|
-
django_letsencrypt-
|
|
11
|
-
django_letsencrypt-
|
|
12
|
-
django_letsencrypt-
|
|
13
|
-
django_letsencrypt-
|
|
14
|
-
django_letsencrypt-4.1.0.dist-info/RECORD,,
|
|
11
|
+
django_letsencrypt-6.0.0.dist-info/METADATA,sha256=r4_RY3QsSwfDf6O-4lXxxxIDrZtnI1-6BdN3unFaIlw,5723
|
|
12
|
+
django_letsencrypt-6.0.0.dist-info/WHEEL,sha256=wUyA8OaulRlbfwMtmQsvNngGrxQHAvkKcvRmdizlJi0,92
|
|
13
|
+
django_letsencrypt-6.0.0.dist-info/top_level.txt,sha256=cDimIKtupoBiTWXykGSs1dP1xs8jrAoTwz1txrc2Img,12
|
|
14
|
+
django_letsencrypt-6.0.0.dist-info/RECORD,,
|
letsencrypt/__init__.py
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"""
|
|
2
|
-
Copyright 2016-
|
|
2
|
+
Copyright 2016-2026 Peter Urda
|
|
3
3
|
|
|
4
4
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
5
|
you may not use this file except in compliance with the License.
|
|
@@ -14,6 +14,6 @@ See the License for the specific language governing permissions and
|
|
|
14
14
|
limitations under the License.
|
|
15
15
|
"""
|
|
16
16
|
|
|
17
|
-
__version__ = '
|
|
17
|
+
__version__ = '6.0.0'
|
|
18
18
|
|
|
19
19
|
default_app_config = 'letsencrypt.apps.LetsEncryptConfig'
|
|
File without changes
|
|
File without changes
|