mirror of
https://github.com/YunoHost-Apps/django-fmd_ynh.git
synced 2024-09-03 18:26:27 +02:00
Apply manageprojects updates
This commit is contained in:
parent
bcb4373e09
commit
3478ff08f7
19 changed files with 1008 additions and 913 deletions
4
.github/workflows/package_linter.yml
vendored
4
.github/workflows/package_linter.yml
vendored
|
@ -17,9 +17,9 @@ jobs:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Set up Python
|
- name: Set up Python
|
||||||
uses: actions/setup-python@v4
|
uses: actions/setup-python@v5
|
||||||
with:
|
with:
|
||||||
python-version: '3.9'
|
python-version: '3.11'
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: |
|
run: |
|
||||||
|
|
16
.github/workflows/tests.yml
vendored
16
.github/workflows/tests.yml
vendored
|
@ -14,7 +14,7 @@ jobs:
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
python-version: ["3.12", "3.11", "3.10"]
|
python-version: ['3.12', '3.11']
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
run: |
|
run: |
|
||||||
|
@ -22,9 +22,12 @@ jobs:
|
||||||
git clone https://github.com/$GITHUB_REPOSITORY.git .
|
git clone https://github.com/$GITHUB_REPOSITORY.git .
|
||||||
git fetch origin $GITHUB_SHA:temporary-ci-branch
|
git fetch origin $GITHUB_SHA:temporary-ci-branch
|
||||||
git checkout $GITHUB_SHA || (git fetch && git checkout $GITHUB_SHA)
|
git checkout $GITHUB_SHA || (git fetch && git checkout $GITHUB_SHA)
|
||||||
|
- name: 'fetch master'
|
||||||
|
run: |
|
||||||
|
git fetch origin master
|
||||||
|
|
||||||
- name: 'Set up Python ${{ matrix.python-version }}'
|
- name: 'Set up Python ${{ matrix.python-version }}'
|
||||||
uses: actions/setup-python@v4
|
uses: actions/setup-python@v5
|
||||||
# https://github.com/marketplace/actions/setup-python
|
# https://github.com/marketplace/actions/setup-python
|
||||||
with:
|
with:
|
||||||
python-version: '${{ matrix.python-version }}'
|
python-version: '${{ matrix.python-version }}'
|
||||||
|
@ -40,19 +43,20 @@ jobs:
|
||||||
run: |
|
run: |
|
||||||
./dev-cli.py --help
|
./dev-cli.py --help
|
||||||
|
|
||||||
- name: 'Safety'
|
- name: 'Run pip-audit'
|
||||||
run: |
|
run: |
|
||||||
./dev-cli.py safety
|
./dev-cli.py pip-audit
|
||||||
|
|
||||||
- name: 'Run tests with Python v${{ matrix.python-version }}'
|
- name: 'Run tests with Python v${{ matrix.python-version }}'
|
||||||
env:
|
env:
|
||||||
PYTHONUNBUFFERED: 1
|
PYTHONUNBUFFERED: 1
|
||||||
PYTHONWARNINGS: always
|
PYTHONWARNINGS: always
|
||||||
run: |
|
run: |
|
||||||
./dev-cli.py tox
|
.venv/bin/coverage erase
|
||||||
|
./dev-cli.py coverage
|
||||||
|
|
||||||
- name: 'Upload coverage report'
|
- name: 'Upload coverage report'
|
||||||
uses: codecov/codecov-action@v3
|
uses: codecov/codecov-action@v4
|
||||||
# https://github.com/marketplace/actions/codecov
|
# https://github.com/marketplace/actions/codecov
|
||||||
with:
|
with:
|
||||||
fail_ci_if_error: false
|
fail_ci_if_error: false
|
||||||
|
|
33
check_process
Normal file
33
check_process
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
# See here for more information
|
||||||
|
# https://github.com/YunoHost/package_check#syntax-check_process-file
|
||||||
|
|
||||||
|
# Move this file from check_process.default to check_process when you have filled it.
|
||||||
|
|
||||||
|
;; Test complet
|
||||||
|
; Manifest
|
||||||
|
domain="domain.tld" (DOMAIN)
|
||||||
|
path="/path" (PATH)
|
||||||
|
admin="john" (USER)
|
||||||
|
is_public=1 (PUBLIC|public=1|private=0)
|
||||||
|
password="pass"
|
||||||
|
port="666" (PORT)
|
||||||
|
; Checks
|
||||||
|
pkg_linter=1
|
||||||
|
setup_sub_dir=1
|
||||||
|
setup_root=1
|
||||||
|
setup_nourl=0
|
||||||
|
setup_private=0
|
||||||
|
setup_public=1
|
||||||
|
upgrade=1
|
||||||
|
backup_restore=1
|
||||||
|
multi_instance=1
|
||||||
|
port_already_use=0
|
||||||
|
change_url=1
|
||||||
|
;;; Options
|
||||||
|
Email=
|
||||||
|
Notification=none
|
||||||
|
;;; Upgrade options
|
||||||
|
; commit=CommitHash
|
||||||
|
name=Name and date of the commit.
|
||||||
|
manifest_arg=domain=DOMAIN&path=PATH&admin=USER&language=fr&is_public=1&password=pass&port=666&
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#
|
#
|
||||||
# This file is autogenerated by pip-compile with Python 3.11
|
# This file is autogenerated by pip-compile with Python 3.12
|
||||||
# by the following command:
|
# by the following command:
|
||||||
#
|
#
|
||||||
# ./dev-cli.py update
|
# ./dev-cli.py update
|
||||||
|
@ -45,75 +45,92 @@ bleach==6.1.0 \
|
||||||
--hash=sha256:0a31f1837963c41d46bbf1331b8778e1308ea0791db03cc4e7357b97cf42a8fe \
|
--hash=sha256:0a31f1837963c41d46bbf1331b8778e1308ea0791db03cc4e7357b97cf42a8fe \
|
||||||
--hash=sha256:3225f354cfc436b9789c66c4ee030194bee0568fbf9cbdad3bc8b5c26c5f12b6
|
--hash=sha256:3225f354cfc436b9789c66c4ee030194bee0568fbf9cbdad3bc8b5c26c5f12b6
|
||||||
# via django-tools
|
# via django-tools
|
||||||
bx-django-utils==77 \
|
bx-django-utils==79 \
|
||||||
--hash=sha256:1dcfb05c3c8aba6a41aa70a95e3367c833b5842d1359f693876443c8f21039c5 \
|
--hash=sha256:cb66087d4e9396281acf5a4394b749cff3062b66082d5726f6a8a342fdd35d0e \
|
||||||
--hash=sha256:c731a45f0ffdc3d0996c600a9270f95393c951f2024d7fa7da70d7b0f6448818
|
--hash=sha256:d50b10ace24b0b363574542faecf04a81029e2fec6d6e6525fe063ed06238e04
|
||||||
# via django-fmd
|
# via
|
||||||
bx-py-utils==92 \
|
# django-fmd
|
||||||
--hash=sha256:38641b2e1a09ed0c64cd6ba0e03c97fea347302439db0234a0492c365ae32719 \
|
# django-tools
|
||||||
--hash=sha256:849c59429af6ca0bf35265569884193c60be578285a66b533146e5782a10637b
|
bx-py-utils==98 \
|
||||||
|
--hash=sha256:30fb49b0f0b21c9fbd544895480a1aa9da63f410572e4b46afbca792e64cec98 \
|
||||||
|
--hash=sha256:ac8b193ff117420b77b43c043e50b195d6aa9ee7e72e22265ca699730b61f71f
|
||||||
# via
|
# via
|
||||||
# bx-django-utils
|
# bx-django-utils
|
||||||
# cli-base-utilities
|
# cli-base-utilities
|
||||||
# django-fmd
|
# django-fmd
|
||||||
# django-tools
|
# django-tools
|
||||||
certifi==2024.6.2 \
|
certifi==2024.7.4 \
|
||||||
--hash=sha256:3cd43f1c6fa7dedc5899d69d3ad0398fd018ad1a17fba83ddaf78aa46c747516 \
|
--hash=sha256:5a1e7645bc0ec61a09e26c36f6106dd4cf40c6db3a1fb6352b0244e7fb057c7b \
|
||||||
--hash=sha256:ddc6c8ce995e6987e7faf5e3f1b02b302836a0e5d98ece18392cb1a36c72ad56
|
--hash=sha256:c198e21b1289c2ab85ee4e67bb4b4ef3ead0892059901a8d5b622f24a1101e90
|
||||||
# via requests
|
# via requests
|
||||||
cffi==1.16.0 \
|
cffi==1.17.0 \
|
||||||
--hash=sha256:0c9ef6ff37e974b73c25eecc13952c55bceed9112be2d9d938ded8e856138bcc \
|
--hash=sha256:011aff3524d578a9412c8b3cfaa50f2c0bd78e03eb7af7aa5e0df59b158efb2f \
|
||||||
--hash=sha256:131fd094d1065b19540c3d72594260f118b231090295d8c34e19a7bbcf2e860a \
|
--hash=sha256:0a048d4f6630113e54bb4b77e315e1ba32a5a31512c31a273807d0027a7e69ab \
|
||||||
--hash=sha256:1b8ebc27c014c59692bb2664c7d13ce7a6e9a629be20e54e7271fa696ff2b417 \
|
--hash=sha256:0bb15e7acf8ab35ca8b24b90af52c8b391690ef5c4aec3d31f38f0d37d2cc499 \
|
||||||
--hash=sha256:2c56b361916f390cd758a57f2e16233eb4f64bcbeee88a4881ea90fca14dc6ab \
|
--hash=sha256:0d46ee4764b88b91f16661a8befc6bfb24806d885e27436fdc292ed7e6f6d058 \
|
||||||
--hash=sha256:2d92b25dbf6cae33f65005baf472d2c245c050b1ce709cc4588cdcdd5495b520 \
|
--hash=sha256:0e60821d312f99d3e1569202518dddf10ae547e799d75aef3bca3a2d9e8ee693 \
|
||||||
--hash=sha256:31d13b0f99e0836b7ff893d37af07366ebc90b678b6664c955b54561fc36ef36 \
|
--hash=sha256:0fdacad9e0d9fc23e519efd5ea24a70348305e8d7d85ecbb1a5fa66dc834e7fb \
|
||||||
--hash=sha256:32c68ef735dbe5857c810328cb2481e24722a59a2003018885514d4c09af9743 \
|
--hash=sha256:14b9cbc8f7ac98a739558eb86fabc283d4d564dafed50216e7f7ee62d0d25377 \
|
||||||
--hash=sha256:3686dffb02459559c74dd3d81748269ffb0eb027c39a6fc99502de37d501faa8 \
|
--hash=sha256:17c6d6d3260c7f2d94f657e6872591fe8733872a86ed1345bda872cfc8c74885 \
|
||||||
--hash=sha256:582215a0e9adbe0e379761260553ba11c58943e4bbe9c36430c4ca6ac74b15ed \
|
--hash=sha256:1a2ddbac59dc3716bc79f27906c010406155031a1c801410f1bafff17ea304d2 \
|
||||||
--hash=sha256:5b50bf3f55561dac5438f8e70bfcdfd74543fd60df5fa5f62d94e5867deca684 \
|
--hash=sha256:2404f3de742f47cb62d023f0ba7c5a916c9c653d5b368cc966382ae4e57da401 \
|
||||||
--hash=sha256:5bf44d66cdf9e893637896c7faa22298baebcd18d1ddb6d2626a6e39793a1d56 \
|
--hash=sha256:24658baf6224d8f280e827f0a50c46ad819ec8ba380a42448e24459daf809cf4 \
|
||||||
--hash=sha256:6602bc8dc6f3a9e02b6c22c4fc1e47aa50f8f8e6d3f78a5e16ac33ef5fefa324 \
|
--hash=sha256:24aa705a5f5bd3a8bcfa4d123f03413de5d86e497435693b638cbffb7d5d8a1b \
|
||||||
--hash=sha256:673739cb539f8cdaa07d92d02efa93c9ccf87e345b9a0b556e3ecc666718468d \
|
--hash=sha256:2770bb0d5e3cc0e31e7318db06efcbcdb7b31bcb1a70086d3177692a02256f59 \
|
||||||
--hash=sha256:68678abf380b42ce21a5f2abde8efee05c114c2fdb2e9eef2efdb0257fba1235 \
|
--hash=sha256:331ad15c39c9fe9186ceaf87203a9ecf5ae0ba2538c9e898e3a6967e8ad3db6f \
|
||||||
--hash=sha256:68e7c44931cc171c54ccb702482e9fc723192e88d25a0e133edd7aff8fcd1f6e \
|
--hash=sha256:3aa9d43b02a0c681f0bfbc12d476d47b2b2b6a3f9287f11ee42989a268a1833c \
|
||||||
--hash=sha256:6b3d6606d369fc1da4fd8c357d026317fbb9c9b75d36dc16e90e84c26854b088 \
|
--hash=sha256:41f4915e09218744d8bae14759f983e466ab69b178de38066f7579892ff2a555 \
|
||||||
--hash=sha256:748dcd1e3d3d7cd5443ef03ce8685043294ad6bd7c02a38d1bd367cfd968e000 \
|
--hash=sha256:4304d4416ff032ed50ad6bb87416d802e67139e31c0bde4628f36a47a3164bfa \
|
||||||
--hash=sha256:7651c50c8c5ef7bdb41108b7b8c5a83013bfaa8a935590c5d74627c047a583c7 \
|
--hash=sha256:435a22d00ec7d7ea533db494da8581b05977f9c37338c80bc86314bec2619424 \
|
||||||
--hash=sha256:7b78010e7b97fef4bee1e896df8a4bbb6712b7f05b7ef630f9d1da00f6444d2e \
|
--hash=sha256:45f7cd36186db767d803b1473b3c659d57a23b5fa491ad83c6d40f2af58e4dbb \
|
||||||
--hash=sha256:7e61e3e4fa664a8588aa25c883eab612a188c725755afff6289454d6362b9673 \
|
--hash=sha256:48b389b1fd5144603d61d752afd7167dfd205973a43151ae5045b35793232aa2 \
|
||||||
--hash=sha256:80876338e19c951fdfed6198e70bc88f1c9758b94578d5a7c4c91a87af3cf31c \
|
--hash=sha256:4e67d26532bfd8b7f7c05d5a766d6f437b362c1bf203a3a5ce3593a645e870b8 \
|
||||||
--hash=sha256:8895613bcc094d4a1b2dbe179d88d7fb4a15cee43c052e8885783fac397d91fe \
|
--hash=sha256:516a405f174fd3b88829eabfe4bb296ac602d6a0f68e0d64d5ac9456194a5b7e \
|
||||||
--hash=sha256:88e2b3c14bdb32e440be531ade29d3c50a1a59cd4e51b1dd8b0865c54ea5d2e2 \
|
--hash=sha256:5ba5c243f4004c750836f81606a9fcb7841f8874ad8f3bf204ff5e56332b72b9 \
|
||||||
--hash=sha256:8f8e709127c6c77446a8c0a8c8bf3c8ee706a06cd44b1e827c3e6a2ee6b8c098 \
|
--hash=sha256:5bdc0f1f610d067c70aa3737ed06e2726fd9d6f7bfee4a351f4c40b6831f4e82 \
|
||||||
--hash=sha256:9cb4a35b3642fc5c005a6755a5d17c6c8b6bcb6981baf81cea8bfbc8903e8ba8 \
|
--hash=sha256:6107e445faf057c118d5050560695e46d272e5301feffda3c41849641222a828 \
|
||||||
--hash=sha256:9f90389693731ff1f659e55c7d1640e2ec43ff725cc61b04b2f9c6d8d017df6a \
|
--hash=sha256:6327b572f5770293fc062a7ec04160e89741e8552bf1c358d1a23eba68166759 \
|
||||||
--hash=sha256:a09582f178759ee8128d9270cd1344154fd473bb77d94ce0aeb2a93ebf0feaf0 \
|
--hash=sha256:669b29a9eca6146465cc574659058ed949748f0809a2582d1f1a324eb91054dc \
|
||||||
--hash=sha256:a6a14b17d7e17fa0d207ac08642c8820f84f25ce17a442fd15e27ea18d67c59b \
|
--hash=sha256:6ce01337d23884b21c03869d2f68c5523d43174d4fc405490eb0091057943118 \
|
||||||
--hash=sha256:a72e8961a86d19bdb45851d8f1f08b041ea37d2bd8d4fd19903bc3083d80c896 \
|
--hash=sha256:6d872186c1617d143969defeadac5a904e6e374183e07977eedef9c07c8953bf \
|
||||||
--hash=sha256:abd808f9c129ba2beda4cfc53bde801e5bcf9d6e0f22f095e45327c038bfe68e \
|
--hash=sha256:6f76a90c345796c01d85e6332e81cab6d70de83b829cf1d9762d0a3da59c7932 \
|
||||||
--hash=sha256:ac0f5edd2360eea2f1daa9e26a41db02dd4b0451b48f7c318e217ee092a213e9 \
|
--hash=sha256:70d2aa9fb00cf52034feac4b913181a6e10356019b18ef89bc7c12a283bf5f5a \
|
||||||
--hash=sha256:b29ebffcf550f9da55bec9e02ad430c992a87e5f512cd63388abb76f1036d8d2 \
|
--hash=sha256:7cbc78dc018596315d4e7841c8c3a7ae31cc4d638c9b627f87d52e8abaaf2d29 \
|
||||||
--hash=sha256:b2ca4e77f9f47c55c194982e10f058db063937845bb2b7a86c84a6cfe0aefa8b \
|
--hash=sha256:856bf0924d24e7f93b8aee12a3a1095c34085600aa805693fb7f5d1962393206 \
|
||||||
--hash=sha256:b7be2d771cdba2942e13215c4e340bfd76398e9227ad10402a8767ab1865d2e6 \
|
--hash=sha256:8a98748ed1a1df4ee1d6f927e151ed6c1a09d5ec21684de879c7ea6aa96f58f2 \
|
||||||
--hash=sha256:b84834d0cf97e7d27dd5b7f3aca7b6e9263c56308ab9dc8aae9784abb774d404 \
|
--hash=sha256:93a7350f6706b31f457c1457d3a3259ff9071a66f312ae64dc024f049055f72c \
|
||||||
--hash=sha256:b86851a328eedc692acf81fb05444bdf1891747c25af7529e39ddafaf68a4f3f \
|
--hash=sha256:964823b2fc77b55355999ade496c54dde161c621cb1f6eac61dc30ed1b63cd4c \
|
||||||
--hash=sha256:bcb3ef43e58665bbda2fb198698fcae6776483e0c4a631aa5647806c25e02cc0 \
|
--hash=sha256:a003ac9edc22d99ae1286b0875c460351f4e101f8c9d9d2576e78d7e048f64e0 \
|
||||||
--hash=sha256:c0f31130ebc2d37cdd8e44605fb5fa7ad59049298b3f745c74fa74c62fbfcfc4 \
|
--hash=sha256:a0ce71725cacc9ebf839630772b07eeec220cbb5f03be1399e0457a1464f8e1a \
|
||||||
--hash=sha256:c6a164aa47843fb1b01e941d385aab7215563bb8816d80ff3a363a9f8448a8dc \
|
--hash=sha256:a47eef975d2b8b721775a0fa286f50eab535b9d56c70a6e62842134cf7841195 \
|
||||||
--hash=sha256:d8a9d3ebe49f084ad71f9269834ceccbf398253c9fac910c4fd7053ff1386936 \
|
--hash=sha256:a8b5b9712783415695663bd463990e2f00c6750562e6ad1d28e072a611c5f2a6 \
|
||||||
--hash=sha256:db8e577c19c0fda0beb7e0d4e09e0ba74b1e4c092e0e40bfa12fe05b6f6d75ba \
|
--hash=sha256:a9015f5b8af1bb6837a3fcb0cdf3b874fe3385ff6274e8b7925d81ccaec3c5c9 \
|
||||||
--hash=sha256:dc9b18bf40cc75f66f40a7379f6a9513244fe33c0e8aa72e2d56b0196a7ef872 \
|
--hash=sha256:aec510255ce690d240f7cb23d7114f6b351c733a74c279a84def763660a2c3bc \
|
||||||
--hash=sha256:e09f3ff613345df5e8c3667da1d918f9149bd623cd9070c983c013792a9a62eb \
|
--hash=sha256:b00e7bcd71caa0282cbe3c90966f738e2db91e64092a877c3ff7f19a1628fdcb \
|
||||||
--hash=sha256:e4108df7fe9b707191e55f33efbcb2d81928e10cea45527879a4749cbe472614 \
|
--hash=sha256:b50aaac7d05c2c26dfd50c3321199f019ba76bb650e346a6ef3616306eed67b0 \
|
||||||
--hash=sha256:e6024675e67af929088fda399b2094574609396b1decb609c55fa58b028a32a1 \
|
--hash=sha256:b7b6ea9e36d32582cda3465f54c4b454f62f23cb083ebc7a94e2ca6ef011c3a7 \
|
||||||
--hash=sha256:e70f54f1796669ef691ca07d046cd81a29cb4deb1e5f942003f401c0c4a2695d \
|
--hash=sha256:bb9333f58fc3a2296fb1d54576138d4cf5d496a2cc118422bd77835e6ae0b9cb \
|
||||||
--hash=sha256:e715596e683d2ce000574bae5d07bd522c781a822866c20495e52520564f0969 \
|
--hash=sha256:c1c13185b90bbd3f8b5963cd8ce7ad4ff441924c31e23c975cb150e27c2bf67a \
|
||||||
--hash=sha256:e760191dd42581e023a68b758769e2da259b5d52e3103c6060ddc02c9edb8d7b \
|
--hash=sha256:c3b8bd3133cd50f6b637bb4322822c94c5ce4bf0d724ed5ae70afce62187c492 \
|
||||||
--hash=sha256:ed86a35631f7bfbb28e108dd96773b9d5a6ce4811cf6ea468bb6a359b256b1e4 \
|
--hash=sha256:c5d97162c196ce54af6700949ddf9409e9833ef1003b4741c2b39ef46f1d9720 \
|
||||||
--hash=sha256:ee07e47c12890ef248766a6e55bd38ebfb2bb8edd4142d56db91b21ea68b7627 \
|
--hash=sha256:c815270206f983309915a6844fe994b2fa47e5d05c4c4cef267c3b30e34dbe42 \
|
||||||
--hash=sha256:fa3a0128b152627161ce47201262d3140edb5a5c3da88d73a1b790a959126956 \
|
--hash=sha256:cab2eba3830bf4f6d91e2d6718e0e1c14a2f5ad1af68a89d24ace0c6b17cced7 \
|
||||||
--hash=sha256:fcc8eb6d5902bb1cf6dc4f187ee3ea80a1eba0a89aba40a5cb20a5087d961357
|
--hash=sha256:d1df34588123fcc88c872f5acb6f74ae59e9d182a2707097f9e28275ec26a12d \
|
||||||
|
--hash=sha256:d6bdcd415ba87846fd317bee0774e412e8792832e7805938987e4ede1d13046d \
|
||||||
|
--hash=sha256:db9a30ec064129d605d0f1aedc93e00894b9334ec74ba9c6bdd08147434b33eb \
|
||||||
|
--hash=sha256:dbc183e7bef690c9abe5ea67b7b60fdbca81aa8da43468287dae7b5c046107d4 \
|
||||||
|
--hash=sha256:dca802c8db0720ce1c49cce1149ff7b06e91ba15fa84b1d59144fef1a1bc7ac2 \
|
||||||
|
--hash=sha256:dec6b307ce928e8e112a6bb9921a1cb00a0e14979bf28b98e084a4b8a742bd9b \
|
||||||
|
--hash=sha256:df8bb0010fdd0a743b7542589223a2816bdde4d94bb5ad67884348fa2c1c67e8 \
|
||||||
|
--hash=sha256:e4094c7b464cf0a858e75cd14b03509e84789abf7b79f8537e6a72152109c76e \
|
||||||
|
--hash=sha256:e4760a68cab57bfaa628938e9c2971137e05ce48e762a9cb53b76c9b569f1204 \
|
||||||
|
--hash=sha256:eb09b82377233b902d4c3fbeeb7ad731cdab579c6c6fda1f763cd779139e47c3 \
|
||||||
|
--hash=sha256:eb862356ee9391dc5a0b3cbc00f416b48c1b9a52d252d898e5b7696a5f9fe150 \
|
||||||
|
--hash=sha256:ef9528915df81b8f4c7612b19b8628214c65c9b7f74db2e34a646a0a2a0da2d4 \
|
||||||
|
--hash=sha256:f3157624b7558b914cb039fd1af735e5e8049a87c817cc215109ad1c8779df76 \
|
||||||
|
--hash=sha256:f3e0992f23bbb0be00a921eae5363329253c3b86287db27092461c887b791e5e \
|
||||||
|
--hash=sha256:f9338cc05451f1942d0d8203ec2c346c830f8e86469903d5126c1f0a13a2bcbb \
|
||||||
|
--hash=sha256:ffef8fd58a36fb5f1196919638f73dd3ae0db1a878982b27a9a5a176ede4ba91
|
||||||
# via argon2-cffi-bindings
|
# via argon2-cffi-bindings
|
||||||
charset-normalizer==3.3.2 \
|
charset-normalizer==3.3.2 \
|
||||||
--hash=sha256:06435b539f889b1f6f4ac1758871aae42dc3a8c0e24ac9e60c2384973ad73027 \
|
--hash=sha256:06435b539f889b1f6f4ac1758871aae42dc3a8c0e24ac9e60c2384973ad73027 \
|
||||||
|
@ -207,9 +224,9 @@ charset-normalizer==3.3.2 \
|
||||||
--hash=sha256:fd1abc0d89e30cc4e02e4064dc67fcc51bd941eb395c502aac3ec19fab46b519 \
|
--hash=sha256:fd1abc0d89e30cc4e02e4064dc67fcc51bd941eb395c502aac3ec19fab46b519 \
|
||||||
--hash=sha256:ff8fa367d09b717b2a17a052544193ad76cd49979c805768879cb63d9ca50561
|
--hash=sha256:ff8fa367d09b717b2a17a052544193ad76cd49979c805768879cb63d9ca50561
|
||||||
# via requests
|
# via requests
|
||||||
cli-base-utilities==0.8.0 \
|
cli-base-utilities==0.10.3 \
|
||||||
--hash=sha256:1009551eba81b33a0315c4fcfe3b6ef1633a99e303c9562dff39b824bff83ff0 \
|
--hash=sha256:5c54cdd5e5122abf6a86aa6926b4b2dbc6632c113885692c8d95f531bb2b181b \
|
||||||
--hash=sha256:79628db9fc7ca01b5ab18c97c8fa5f3d8b96af9975c608f7fee9a44256edb2ab
|
--hash=sha256:95b1119d9f4bb335974faf655e853f58bdd04af0bac99d22005b6fb79b9e4b14
|
||||||
# via django-fmd_ynh (pyproject.toml)
|
# via django-fmd_ynh (pyproject.toml)
|
||||||
click==8.1.7 \
|
click==8.1.7 \
|
||||||
--hash=sha256:ae74fb96c20a0277a1d615f1e4d73c8414f5a98db8b799a7931d1582f3390c28 \
|
--hash=sha256:ae74fb96c20a0277a1d615f1e4d73c8414f5a98db8b799a7931d1582f3390c28 \
|
||||||
|
@ -222,10 +239,11 @@ colorlog==6.8.2 \
|
||||||
--hash=sha256:4dcbb62368e2800cb3c5abd348da7e53f6c362dda502ec27c560b2e58a66bd33
|
--hash=sha256:4dcbb62368e2800cb3c5abd348da7e53f6c362dda502ec27c560b2e58a66bd33
|
||||||
# via
|
# via
|
||||||
# django-fmd
|
# django-fmd
|
||||||
|
# django-tools
|
||||||
# django-yunohost-integration
|
# django-yunohost-integration
|
||||||
django==5.0.6 \
|
django==5.1 \
|
||||||
--hash=sha256:8363ac062bb4ef7c3f12d078f6fa5d154031d129a15170a1066412af49d30905 \
|
--hash=sha256:848a5980e8efb76eea70872fb0e4bc5e371619c70fffbe48e3e1b50b2c09455d \
|
||||||
--hash=sha256:ff1b61005004e476e0aeea47c7f79b85864c70124030e95146315396f1e7951f
|
--hash=sha256:d3b811bf5371a26def053d7ee42a9df1267ef7622323fe70a601936725aa4557
|
||||||
# via
|
# via
|
||||||
# bx-django-utils
|
# bx-django-utils
|
||||||
# django-axes
|
# django-axes
|
||||||
|
@ -234,13 +252,13 @@ django==5.0.6 \
|
||||||
# django-redis
|
# django-redis
|
||||||
# django-tools
|
# django-tools
|
||||||
# django-yunohost-integration
|
# django-yunohost-integration
|
||||||
django-axes==6.5.0 \
|
django-axes==6.5.1 \
|
||||||
--hash=sha256:bb4d602ef6ab823eb9c41f0957196986ee851756fa38566616f8512cba329661 \
|
--hash=sha256:7435068cc8523bfa3f34faa62bb3a772b76d00925c3ff54aef43e4316e74bf05 \
|
||||||
--hash=sha256:ee6b11b1331bb69a8fb90da9ecfac790ac95f5277ee04f16f55b4a5eb1593691
|
--hash=sha256:d57f0fc95d581a602c642b3fe5bc31488b9401bd7441f3bec1fef0e599028499
|
||||||
# via django-yunohost-integration
|
# via django-yunohost-integration
|
||||||
django-debug-toolbar==4.4.2 \
|
django-debug-toolbar==4.4.6 \
|
||||||
--hash=sha256:5d7afb2ea5f8730241e5b0735396e16cd1fd8c6b53a2f3e1e30bbab9abb23728 \
|
--hash=sha256:36e421cb908c2f0675e07f9f41e3d1d8618dc386392ec82d23bcfcd5d29c7044 \
|
||||||
--hash=sha256:9204050fcb1e4f74216c5b024bc76081451926a6303993d6c513f5e142675927
|
--hash=sha256:3beb671c9ec44ffb817fad2780667f172bd1c067dbcabad6268ce39a81335f45
|
||||||
# via django-fmd
|
# via django-fmd
|
||||||
django-fmd==0.4.1 \
|
django-fmd==0.4.1 \
|
||||||
--hash=sha256:6d73bad1b812d292d0c22a447e987c9addcd94be51f1bdaa84dd9505b1f0f5a8 \
|
--hash=sha256:6d73bad1b812d292d0c22a447e987c9addcd94be51f1bdaa84dd9505b1f0f5a8 \
|
||||||
|
@ -250,27 +268,28 @@ django-redis==5.4.0 \
|
||||||
--hash=sha256:6a02abaa34b0fea8bf9b707d2c363ab6adc7409950b2db93602e6cb292818c42 \
|
--hash=sha256:6a02abaa34b0fea8bf9b707d2c363ab6adc7409950b2db93602e6cb292818c42 \
|
||||||
--hash=sha256:ebc88df7da810732e2af9987f7f426c96204bf89319df4c6da6ca9a2942edd5b
|
--hash=sha256:ebc88df7da810732e2af9987f7f426c96204bf89319df4c6da6ca9a2942edd5b
|
||||||
# via django-yunohost-integration
|
# via django-yunohost-integration
|
||||||
django-tools==0.54.0 \
|
django-tools==0.56.2 \
|
||||||
--hash=sha256:5040a91282be9d1c9d379b0c65da50bcb3691bff03cee54fd4123ace238c3a43 \
|
--hash=sha256:29c25be814d74cd9f554d7d45bc205f5570e5feaa4232cbd09cc913c46b20c07 \
|
||||||
--hash=sha256:a7b7bfa5b9c5a81966454d17dffb2403cee25a806c858ee0486a08798227598f
|
--hash=sha256:88a192f2873f0411b99ee1aba04f2779133284cd18a5c78976e8e4605ba5d7f7
|
||||||
# via django-yunohost-integration
|
# via django-yunohost-integration
|
||||||
django-yunohost-integration[ynh]==0.7.1 \
|
django-yunohost-integration[ynh]==0.8.1 \
|
||||||
--hash=sha256:7dde5ce8cb5ff92a6f6bf7366882652b796d0ce62b8839eda5f800a87b104523 \
|
--hash=sha256:236bc1e427162182ca5efbf773bbad642b20741e7bf42308134887f4b7c27ced \
|
||||||
--hash=sha256:d6dbddd9fae54e3ce4b0fbc6e8a3c0f19ed145c358b8bb8677baddd30ae6a028
|
--hash=sha256:ced40614ba57edb0d80482e6f4f63c614115184695d2f2aaa1aa02b2485b0529
|
||||||
# via django-fmd_ynh (pyproject.toml)
|
# via django-fmd_ynh (pyproject.toml)
|
||||||
gunicorn==22.0.0 \
|
gunicorn==23.0.0 \
|
||||||
--hash=sha256:350679f91b24062c86e386e198a15438d53a7a8207235a78ba1b53df4c4378d9 \
|
--hash=sha256:ec400d38950de4dfd418cff8328b2c8faed0edb0d517d3394e457c317908ca4d \
|
||||||
--hash=sha256:4a0b436239ff76fb33f11c07a16482c521a7e09c1ce3cc293c2330afe01bec63
|
--hash=sha256:f014447a0101dc57e294f6c18ca6b40227a4c90e9bdb586042628030cba004ec
|
||||||
# via
|
# via
|
||||||
# django-fmd
|
# django-fmd
|
||||||
|
# django-tools
|
||||||
# django-yunohost-integration
|
# django-yunohost-integration
|
||||||
icdiff==2.0.7 \
|
icdiff==2.0.7 \
|
||||||
--hash=sha256:f05d1b3623223dd1c70f7848da7d699de3d9a2550b902a8234d9026292fb5762 \
|
--hash=sha256:f05d1b3623223dd1c70f7848da7d699de3d9a2550b902a8234d9026292fb5762 \
|
||||||
--hash=sha256:f79a318891adbf59a45e3a7694f5e1f18c5407065264637072ac8363b759866f
|
--hash=sha256:f79a318891adbf59a45e3a7694f5e1f18c5407065264637072ac8363b759866f
|
||||||
# via django-tools
|
# via django-tools
|
||||||
idna==3.7 \
|
idna==3.8 \
|
||||||
--hash=sha256:028ff3aadf0609c1fd278d8ea3089299412a7a8b9bd005dd08b9f8285bcb5cfc \
|
--hash=sha256:050b4e5baadcd44d760cedbd2b8e639f2ff89bbc7a5730fcc662954303377aac \
|
||||||
--hash=sha256:82fee1fc78add43492d3a1898bfa6d8a904cc97d8427f683ed8e798d07761aa0
|
--hash=sha256:d838c2c0ed6fced7693d5e8ab8e734d5f8fda53a039c0164afb0b82e771e3603
|
||||||
# via requests
|
# via requests
|
||||||
markdown-it-py==3.0.0 \
|
markdown-it-py==3.0.0 \
|
||||||
--hash=sha256:355216845c60bd96232cd8d8c40e8f9765cc86f46880e43a8fd22dc1a1a8cab1 \
|
--hash=sha256:355216845c60bd96232cd8d8c40e8f9765cc86f46880e43a8fd22dc1a1a8cab1 \
|
||||||
|
@ -291,21 +310,65 @@ pprintpp==0.4.0 \
|
||||||
--hash=sha256:b6b4dcdd0c0c0d75e4d7b2f21a9e933e5b2ce62b26e1a54537f9651ae5a5c01d \
|
--hash=sha256:b6b4dcdd0c0c0d75e4d7b2f21a9e933e5b2ce62b26e1a54537f9651ae5a5c01d \
|
||||||
--hash=sha256:ea826108e2c7f49dc6d66c752973c3fc9749142a798d6b254e1e301cfdbc6403
|
--hash=sha256:ea826108e2c7f49dc6d66c752973c3fc9749142a798d6b254e1e301cfdbc6403
|
||||||
# via django-tools
|
# via django-tools
|
||||||
psycopg2==2.9.9 \
|
psycopg[binary]==3.2.1 \
|
||||||
--hash=sha256:121081ea2e76729acfb0673ff33755e8703d45e926e416cb59bae3a86c6a4981 \
|
--hash=sha256:dc8da6dc8729dacacda3cc2f17d2c9397a70a66cf0d2b69c91065d60d5f00cb7 \
|
||||||
--hash=sha256:38a8dcc6856f569068b47de286b472b7c473ac7977243593a288ebce0dc89516 \
|
--hash=sha256:ece385fb413a37db332f97c49208b36cf030ff02b199d7635ed2fbd378724175
|
||||||
--hash=sha256:426f9f29bde126913a20a96ff8ce7d73fd8a216cfb323b1f04da402d452853c3 \
|
|
||||||
--hash=sha256:5e0d98cade4f0e0304d7d6f25bbfbc5bd186e07b38eac65379309c4ca3193efa \
|
|
||||||
--hash=sha256:7e2dacf8b009a1c1e843b5213a87f7c544b2b042476ed7755be813eaf4e8347a \
|
|
||||||
--hash=sha256:a7653d00b732afb6fc597e29c50ad28087dcb4fbfb28e86092277a559ae4e693 \
|
|
||||||
--hash=sha256:ade01303ccf7ae12c356a5e10911c9e1c51136003a9a1d92f7aa9d010fb98372 \
|
|
||||||
--hash=sha256:bac58c024c9922c23550af2a581998624d6e02350f4ae9c5f0bc642c633a2d5e \
|
|
||||||
--hash=sha256:c92811b2d4c9b6ea0285942b2e7cac98a59e166d59c588fe5cfe1eda58e72d59 \
|
|
||||||
--hash=sha256:d1454bde93fb1e224166811694d600e746430c006fbb031ea06ecc2ea41bf156 \
|
|
||||||
--hash=sha256:d735786acc7dd25815e89cc4ad529a43af779db2e25aa7c626de864127e5a024 \
|
|
||||||
--hash=sha256:de80739447af31525feddeb8effd640782cf5998e1a4e9192ebdf829717e3913 \
|
|
||||||
--hash=sha256:ff432630e510709564c01dafdbe996cb552e0b9f3f065eb89bdce5bd31fabf4c
|
|
||||||
# via django-yunohost-integration
|
# via django-yunohost-integration
|
||||||
|
psycopg-binary==3.2.1 \
|
||||||
|
--hash=sha256:059cbd4e6da2337e17707178fe49464ed01de867dc86c677b30751755ec1dc51 \
|
||||||
|
--hash=sha256:06a7aae34edfe179ddc04da005e083ff6c6b0020000399a2cbf0a7121a8a22ea \
|
||||||
|
--hash=sha256:0879b5d76b7d48678d31278242aaf951bc2d69ca4e4d7cef117e4bbf7bfefda9 \
|
||||||
|
--hash=sha256:0ab58213cc976a1666f66bc1cb2e602315cd753b7981a8e17237ac2a185bd4a1 \
|
||||||
|
--hash=sha256:0b018631e5c80ce9bc210b71ea885932f9cca6db131e4df505653d7e3873a938 \
|
||||||
|
--hash=sha256:101472468d59c74bb8565fab603e032803fd533d16be4b2d13da1bab8deb32a3 \
|
||||||
|
--hash=sha256:1d353e028b8f848b9784450fc2abf149d53a738d451eab3ee4c85703438128b9 \
|
||||||
|
--hash=sha256:1d6833f607f3fc7b22226a9e121235d3b84c0eda1d3caab174673ef698f63788 \
|
||||||
|
--hash=sha256:21927f41c4d722ae8eb30d62a6ce732c398eac230509af5ba1749a337f8a63e2 \
|
||||||
|
--hash=sha256:28ada5f610468c57d8a4a055a8ea915d0085a43d794266c4f3b9d02f4288f4db \
|
||||||
|
--hash=sha256:2e8213bf50af073b1aa8dc3cff123bfeedac86332a16c1b7274910bc88a847c7 \
|
||||||
|
--hash=sha256:302b86f92c0d76e99fe1b5c22c492ae519ce8b98b88d37ef74fda4c9e24c6b46 \
|
||||||
|
--hash=sha256:334046a937bb086c36e2c6889fe327f9f29bfc085d678f70fac0b0618949f674 \
|
||||||
|
--hash=sha256:33e6669091d09f8ba36e10ce678a6d9916e110446236a9b92346464a3565635e \
|
||||||
|
--hash=sha256:3c838806eeb99af39f934b7999e35f947a8e577997cc892c12b5053a97a9057f \
|
||||||
|
--hash=sha256:40bb515d042f6a345714ec0403df68ccf13f73b05e567837d80c886c7c9d3805 \
|
||||||
|
--hash=sha256:413977d18412ff83486eeb5875eb00b185a9391c57febac45b8993bf9c0ff489 \
|
||||||
|
--hash=sha256:415c3b72ea32119163255c6504085f374e47ae7345f14bc3f0ef1f6e0976a879 \
|
||||||
|
--hash=sha256:42781ba94e8842ee98bca5a7d0c44cc9d067500fedca2d6a90fa3609b6d16b42 \
|
||||||
|
--hash=sha256:463d55345f73ff391df8177a185ad57b552915ad33f5cc2b31b930500c068b22 \
|
||||||
|
--hash=sha256:4a42b8f9ab39affcd5249b45cac763ac3cf12df962b67e23fd15a2ee2932afe5 \
|
||||||
|
--hash=sha256:4c84fcac8a3a3479ac14673095cc4e1fdba2935499f72c436785ac679bec0d1a \
|
||||||
|
--hash=sha256:592b27d6c46a40f9eeaaeea7c1fef6f3c60b02c634365eb649b2d880669f149f \
|
||||||
|
--hash=sha256:62b1b7b07e00ee490afb39c0a47d8282a9c2822c7cfed9553a04b0058adf7e7f \
|
||||||
|
--hash=sha256:6418712ba63cebb0c88c050b3997185b0ef54173b36568522d5634ac06153040 \
|
||||||
|
--hash=sha256:6f9e13600647087df5928875559f0eb8f496f53e6278b7da9511b4b3d0aff960 \
|
||||||
|
--hash=sha256:7066d3dca196ed0dc6172f9777b2d62e4f138705886be656cccff2d555234d60 \
|
||||||
|
--hash=sha256:73f9c9b984be9c322b5ec1515b12df1ee5896029f5e72d46160eb6517438659c \
|
||||||
|
--hash=sha256:74d623261655a169bc84a9669890975c229f2fa6e19a7f2d10a77675dcf1a707 \
|
||||||
|
--hash=sha256:788ffc43d7517c13e624c83e0e553b7b8823c9655e18296566d36a829bfb373f \
|
||||||
|
--hash=sha256:78c2007caf3c90f08685c5378e3ceb142bafd5636be7495f7d86ec8a977eaeef \
|
||||||
|
--hash=sha256:7a84b5eb194a258116154b2a4ff2962ea60ea52de089508db23a51d3d6b1c7d1 \
|
||||||
|
--hash=sha256:7ce965caf618061817f66c0906f0452aef966c293ae0933d4fa5a16ea6eaf5bb \
|
||||||
|
--hash=sha256:84837e99353d16c6980603b362d0f03302d4b06c71672a6651f38df8a482923d \
|
||||||
|
--hash=sha256:8f28ff0cb9f1defdc4a6f8c958bf6787274247e7dfeca811f6e2f56602695fb1 \
|
||||||
|
--hash=sha256:921f0c7f39590763d64a619de84d1b142587acc70fd11cbb5ba8fa39786f3073 \
|
||||||
|
--hash=sha256:950fd666ec9e9fe6a8eeb2b5a8f17301790e518953730ad44d715b59ffdbc67f \
|
||||||
|
--hash=sha256:9a997efbaadb5e1a294fb5760e2f5643d7b8e4e3fe6cb6f09e6d605fd28e0291 \
|
||||||
|
--hash=sha256:aa3931f308ab4a479d0ee22dc04bea867a6365cac0172e5ddcba359da043854b \
|
||||||
|
--hash=sha256:af0469c00f24c4bec18c3d2ede124bf62688d88d1b8a5f3c3edc2f61046fe0d7 \
|
||||||
|
--hash=sha256:b0104a72a17aa84b3b7dcab6c84826c595355bf54bb6ea6d284dcb06d99c6801 \
|
||||||
|
--hash=sha256:b09e8a576a2ac69d695032ee76f31e03b30781828b5dd6d18c6a009e5a3d1c35 \
|
||||||
|
--hash=sha256:b140182830c76c74d17eba27df3755a46442ce8d4fb299e7f1cf2f74a87c877b \
|
||||||
|
--hash=sha256:b1f087bd84bdcac78bf9f024ebdbfacd07fc0a23ec8191448a50679e2ac4a19e \
|
||||||
|
--hash=sha256:c1d2b6438fb83376f43ebb798bf0ad5e57bc56c03c9c29c85bc15405c8c0ac5a \
|
||||||
|
--hash=sha256:cad2de17804c4cfee8640ae2b279d616bb9e4734ac3c17c13db5e40982bd710d \
|
||||||
|
--hash=sha256:cc304a46be1e291031148d9d95c12451ffe783ff0cc72f18e2cc7ec43cdb8c68 \
|
||||||
|
--hash=sha256:dc314a47d44fe1a8069b075a64abffad347a3a1d8652fed1bab5d3baea37acb2 \
|
||||||
|
--hash=sha256:f092114f10f81fb6bae544a0ec027eb720e2d9c74a4fcdaa9dd3899873136935 \
|
||||||
|
--hash=sha256:f34e369891f77d0738e5d25727c307d06d5344948771e5379ea29c76c6d84555 \
|
||||||
|
--hash=sha256:f8a509aeaac364fa965454e80cd110fe6d48ba2c80f56c9b8563423f0b5c3cfd \
|
||||||
|
--hash=sha256:f8afb07114ea9b924a4a0305ceb15354ccf0ef3c0e14d54b8dbeb03e50182dd7 \
|
||||||
|
--hash=sha256:f99e59f8a5f4dcd9cbdec445f3d8ac950a492fc0e211032384d6992ed3c17eb7
|
||||||
|
# via psycopg
|
||||||
pycparser==2.22 \
|
pycparser==2.22 \
|
||||||
--hash=sha256:491c8be9c040f5390f5bf44a5b07752bd07f56edf992381b05c701439eec10f6 \
|
--hash=sha256:491c8be9c040f5390f5bf44a5b07752bd07f56edf992381b05c701439eec10f6 \
|
||||||
--hash=sha256:c3702b6d3dd8c7abc1afa565d7e63d53a1d0bd86cdc24edd75470f4de499cfcc
|
--hash=sha256:c3702b6d3dd8c7abc1afa565d7e63d53a1d0bd86cdc24edd75470f4de499cfcc
|
||||||
|
@ -348,74 +411,80 @@ pygments==2.18.0 \
|
||||||
--hash=sha256:786ff802f32e91311bff3889f6e9a86e81505fe99f2735bb6d60ae0c5004f199 \
|
--hash=sha256:786ff802f32e91311bff3889f6e9a86e81505fe99f2735bb6d60ae0c5004f199 \
|
||||||
--hash=sha256:b8e6aca0523f3ab76fee51799c488e38782ac06eafcf95e7ba832985c8e7b13a
|
--hash=sha256:b8e6aca0523f3ab76fee51799c488e38782ac06eafcf95e7ba832985c8e7b13a
|
||||||
# via rich
|
# via rich
|
||||||
|
python-dateutil==2.9.0.post0 \
|
||||||
|
--hash=sha256:37dd54208da7e1cd875388217d5e00ebd4179249f90fb72437e91a35459a0ad3 \
|
||||||
|
--hash=sha256:a8b2bc7bffae282281c8140a97d3aa9c14da0b136dfe83f850eea9a5f7470427
|
||||||
|
# via cli-base-utilities
|
||||||
python-stdnum==1.20 \
|
python-stdnum==1.20 \
|
||||||
--hash=sha256:111008e10391d54fb2afad2a10df70d5cb0c6c0a7ec82fec6f022cb8712961d3 \
|
--hash=sha256:111008e10391d54fb2afad2a10df70d5cb0c6c0a7ec82fec6f022cb8712961d3 \
|
||||||
--hash=sha256:ad2a2cf2eb025de408210235f36b4ae31252de3186240ccaa8126e117cb82690
|
--hash=sha256:ad2a2cf2eb025de408210235f36b4ae31252de3186240ccaa8126e117cb82690
|
||||||
# via bx-django-utils
|
# via bx-django-utils
|
||||||
pyyaml==6.0.1 \
|
pyyaml==6.0.2 \
|
||||||
--hash=sha256:04ac92ad1925b2cff1db0cfebffb6ffc43457495c9b3c39d3fcae417d7125dc5 \
|
--hash=sha256:01179a4a8559ab5de078078f37e5c1a30d76bb88519906844fd7bdea1b7729ff \
|
||||||
--hash=sha256:062582fca9fabdd2c8b54a3ef1c978d786e0f6b3a1510e0ac93ef59e0ddae2bc \
|
--hash=sha256:0833f8694549e586547b576dcfaba4a6b55b9e96098b36cdc7ebefe667dfed48 \
|
||||||
--hash=sha256:0d3304d8c0adc42be59c5f8a4d9e3d7379e6955ad754aa9d6ab7a398b59dd1df \
|
--hash=sha256:0a9a2848a5b7feac301353437eb7d5957887edbf81d56e903999a75a3d743086 \
|
||||||
--hash=sha256:1635fd110e8d85d55237ab316b5b011de701ea0f29d07611174a1b42f1444741 \
|
--hash=sha256:0b69e4ce7a131fe56b7e4d770c67429700908fc0752af059838b1cfb41960e4e \
|
||||||
--hash=sha256:184c5108a2aca3c5b3d3bf9395d50893a7ab82a38004c8f61c258d4428e80206 \
|
--hash=sha256:0ffe8360bab4910ef1b9e87fb812d8bc0a308b0d0eef8c8f44e0254ab3b07133 \
|
||||||
--hash=sha256:18aeb1bf9a78867dc38b259769503436b7c72f7a1f1f4c93ff9a17de54319b27 \
|
--hash=sha256:11d8f3dd2b9c1207dcaf2ee0bbbfd5991f571186ec9cc78427ba5bd32afae4b5 \
|
||||||
--hash=sha256:1d4c7e777c441b20e32f52bd377e0c409713e8bb1386e1099c2415f26e479595 \
|
--hash=sha256:17e311b6c678207928d649faa7cb0d7b4c26a0ba73d41e99c4fff6b6c3276484 \
|
||||||
--hash=sha256:1e2722cc9fbb45d9b87631ac70924c11d3a401b2d7f410cc0e3bbf249f2dca62 \
|
--hash=sha256:1e2120ef853f59c7419231f3bf4e7021f1b936f6ebd222406c3b60212205d2ee \
|
||||||
--hash=sha256:1fe35611261b29bd1de0070f0b2f47cb6ff71fa6595c077e42bd0c419fa27b98 \
|
--hash=sha256:1f71ea527786de97d1a0cc0eacd1defc0985dcf6b3f17bb77dcfc8c34bec4dc5 \
|
||||||
--hash=sha256:28c119d996beec18c05208a8bd78cbe4007878c6dd15091efb73a30e90539696 \
|
--hash=sha256:23502f431948090f597378482b4812b0caae32c22213aecf3b55325e049a6c68 \
|
||||||
--hash=sha256:326c013efe8048858a6d312ddd31d56e468118ad4cdeda36c719bf5bb6192290 \
|
--hash=sha256:24471b829b3bf607e04e88d79542a9d48bb037c2267d7927a874e6c205ca7e9a \
|
||||||
--hash=sha256:40df9b996c2b73138957fe23a16a4f0ba614f4c0efce1e9406a184b6d07fa3a9 \
|
--hash=sha256:29717114e51c84ddfba879543fb232a6ed60086602313ca38cce623c1d62cfbf \
|
||||||
--hash=sha256:42f8152b8dbc4fe7d96729ec2b99c7097d656dc1213a3229ca5383f973a5ed6d \
|
--hash=sha256:2e99c6826ffa974fe6e27cdb5ed0021786b03fc98e5ee3c5bfe1fd5015f42b99 \
|
||||||
--hash=sha256:49a183be227561de579b4a36efbb21b3eab9651dd81b1858589f796549873dd6 \
|
--hash=sha256:39693e1f8320ae4f43943590b49779ffb98acb81f788220ea932a6b6c51004d8 \
|
||||||
--hash=sha256:4fb147e7a67ef577a588a0e2c17b6db51dda102c71de36f8549b6816a96e1867 \
|
--hash=sha256:3ad2a3decf9aaba3d29c8f537ac4b243e36bef957511b4766cb0057d32b0be85 \
|
||||||
--hash=sha256:50550eb667afee136e9a77d6dc71ae76a44df8b3e51e41b77f6de2932bfe0f47 \
|
--hash=sha256:3b1fdb9dc17f5a7677423d508ab4f243a726dea51fa5e70992e59a7411c89d19 \
|
||||||
--hash=sha256:510c9deebc5c0225e8c96813043e62b680ba2f9c50a08d3724c7f28a747d1486 \
|
--hash=sha256:41e4e3953a79407c794916fa277a82531dd93aad34e29c2a514c2c0c5fe971cc \
|
||||||
--hash=sha256:5773183b6446b2c99bb77e77595dd486303b4faab2b086e7b17bc6bef28865f6 \
|
--hash=sha256:43fa96a3ca0d6b1812e01ced1044a003533c47f6ee8aca31724f78e93ccc089a \
|
||||||
--hash=sha256:596106435fa6ad000c2991a98fa58eeb8656ef2325d7e158344fb33864ed87e3 \
|
--hash=sha256:50187695423ffe49e2deacb8cd10510bc361faac997de9efef88badc3bb9e2d1 \
|
||||||
--hash=sha256:6965a7bc3cf88e5a1c3bd2e0b5c22f8d677dc88a455344035f03399034eb3007 \
|
--hash=sha256:5ac9328ec4831237bec75defaf839f7d4564be1e6b25ac710bd1a96321cc8317 \
|
||||||
--hash=sha256:69b023b2b4daa7548bcfbd4aa3da05b3a74b772db9e23b982788168117739938 \
|
--hash=sha256:5d225db5a45f21e78dd9358e58a98702a0302f2659a3c6cd320564b75b86f47c \
|
||||||
--hash=sha256:6c22bec3fbe2524cde73d7ada88f6566758a8f7227bfbf93a408a9d86bcc12a0 \
|
--hash=sha256:6395c297d42274772abc367baaa79683958044e5d3835486c16da75d2a694631 \
|
||||||
--hash=sha256:704219a11b772aea0d8ecd7058d0082713c3562b4e271b849ad7dc4a5c90c13c \
|
--hash=sha256:688ba32a1cffef67fd2e9398a2efebaea461578b0923624778664cc1c914db5d \
|
||||||
--hash=sha256:7e07cbde391ba96ab58e532ff4803f79c4129397514e1413a7dc761ccd755735 \
|
--hash=sha256:68ccc6023a3400877818152ad9a1033e3db8625d899c72eacb5a668902e4d652 \
|
||||||
--hash=sha256:81e0b275a9ecc9c0c0c07b4b90ba548307583c125f54d5b6946cfee6360c733d \
|
--hash=sha256:70b189594dbe54f75ab3a1acec5f1e3faa7e8cf2f1e08d9b561cb41b845f69d5 \
|
||||||
--hash=sha256:855fb52b0dc35af121542a76b9a84f8d1cd886ea97c84703eaa6d88e37a2ad28 \
|
--hash=sha256:797b4f722ffa07cc8d62053e4cff1486fa6dc094105d13fea7b1de7d8bf71c9e \
|
||||||
--hash=sha256:8d4e9c88387b0f5c7d5f281e55304de64cf7f9c0021a3525bd3b1c542da3b0e4 \
|
--hash=sha256:7c36280e6fb8385e520936c3cb3b8042851904eba0e58d277dca80a5cfed590b \
|
||||||
--hash=sha256:9046c58c4395dff28dd494285c82ba00b546adfc7ef001486fbf0324bc174fba \
|
--hash=sha256:7e7401d0de89a9a855c839bc697c079a4af81cf878373abd7dc625847d25cbd8 \
|
||||||
--hash=sha256:9eb6caa9a297fc2c2fb8862bc5370d0303ddba53ba97e71f08023b6cd73d16a8 \
|
--hash=sha256:80bab7bfc629882493af4aa31a4cfa43a4c57c83813253626916b8c7ada83476 \
|
||||||
--hash=sha256:a08c6f0fe150303c1c6b71ebcd7213c2858041a7e01975da3a99aed1e7a378ef \
|
--hash=sha256:82d09873e40955485746739bcb8b4586983670466c23382c19cffecbf1fd8706 \
|
||||||
--hash=sha256:a0cd17c15d3bb3fa06978b4e8958dcdc6e0174ccea823003a106c7d4d7899ac5 \
|
--hash=sha256:8388ee1976c416731879ac16da0aff3f63b286ffdd57cdeb95f3f2e085687563 \
|
||||||
--hash=sha256:afd7e57eddb1a54f0f1a974bc4391af8bcce0b444685d936840f125cf046d5bd \
|
--hash=sha256:8824b5a04a04a047e72eea5cec3bc266db09e35de6bdfe34c9436ac5ee27d237 \
|
||||||
--hash=sha256:b1275ad35a5d18c62a7220633c913e1b42d44b46ee12554e5fd39c70a243d6a3 \
|
--hash=sha256:8b9c7197f7cb2738065c481a0461e50ad02f18c78cd75775628afb4d7137fb3b \
|
||||||
--hash=sha256:b786eecbdf8499b9ca1d697215862083bd6d2a99965554781d0d8d1ad31e13a0 \
|
--hash=sha256:9056c1ecd25795207ad294bcf39f2db3d845767be0ea6e6a34d856f006006083 \
|
||||||
--hash=sha256:ba336e390cd8e4d1739f42dfe9bb83a3cc2e80f567d8805e11b46f4a943f5515 \
|
--hash=sha256:936d68689298c36b53b29f23c6dbb74de12b4ac12ca6cfe0e047bedceea56180 \
|
||||||
--hash=sha256:baa90d3f661d43131ca170712d903e6295d1f7a0f595074f151c0aed377c9b9c \
|
--hash=sha256:9b22676e8097e9e22e36d6b7bda33190d0d400f345f23d4065d48f4ca7ae0425 \
|
||||||
--hash=sha256:bc1bf2925a1ecd43da378f4db9e4f799775d6367bdb94671027b73b393a7c42c \
|
--hash=sha256:a4d3091415f010369ae4ed1fc6b79def9416358877534caf6a0fdd2146c87a3e \
|
||||||
--hash=sha256:bd4af7373a854424dabd882decdc5579653d7868b8fb26dc7d0e99f823aa5924 \
|
--hash=sha256:a8786accb172bd8afb8be14490a16625cbc387036876ab6ba70912730faf8e1f \
|
||||||
--hash=sha256:bf07ee2fef7014951eeb99f56f39c9bb4af143d8aa3c21b1677805985307da34 \
|
--hash=sha256:a9f8c2e67970f13b16084e04f134610fd1d374bf477b17ec1599185cf611d725 \
|
||||||
--hash=sha256:bfdf460b1736c775f2ba9f6a92bca30bc2095067b8a9d77876d1fad6cc3b4a43 \
|
--hash=sha256:bc2fa7c6b47d6bc618dd7fb02ef6fdedb1090ec036abab80d4681424b84c1183 \
|
||||||
--hash=sha256:c8098ddcc2a85b61647b2590f825f3db38891662cfc2fc776415143f599bb859 \
|
--hash=sha256:c70c95198c015b85feafc136515252a261a84561b7b1d51e3384e0655ddf25ab \
|
||||||
--hash=sha256:d2b04aac4d386b172d5b9692e2d2da8de7bfb6c387fa4f801fbf6fb2e6ba4673 \
|
--hash=sha256:cc1c1159b3d456576af7a3e4d1ba7e6924cb39de8f67111c735f6fc832082774 \
|
||||||
--hash=sha256:d483d2cdf104e7c9fa60c544d92981f12ad66a457afae824d146093b8c294c54 \
|
--hash=sha256:ce826d6ef20b1bc864f0a68340c8b3287705cae2f8b4b1d932177dcc76721725 \
|
||||||
--hash=sha256:d858aa552c999bc8a8d57426ed01e40bef403cd8ccdd0fc5f6f04a00414cac2a \
|
--hash=sha256:d584d9ec91ad65861cc08d42e834324ef890a082e591037abe114850ff7bbc3e \
|
||||||
--hash=sha256:e7d73685e87afe9f3b36c799222440d6cf362062f78be1013661b00c5c6f678b \
|
--hash=sha256:d7fded462629cfa4b685c5416b949ebad6cec74af5e2d42905d41e257e0869f5 \
|
||||||
--hash=sha256:f003ed9ad21d6a4713f0a9b5a7a0a79e08dd0f221aff4525a2be4c346ee60aab \
|
--hash=sha256:d84a1718ee396f54f3a086ea0a66d8e552b2ab2017ef8b420e92edbc841c352d \
|
||||||
--hash=sha256:f22ac1c3cac4dbc50079e965eba2c1058622631e526bd9afd45fedd49ba781fa \
|
--hash=sha256:d8e03406cac8513435335dbab54c0d385e4a49e4945d2909a581c83647ca0290 \
|
||||||
--hash=sha256:faca3bdcf85b2fc05d06ff3fbc1f83e1391b3e724afa3feba7d13eeab355484c \
|
--hash=sha256:e10ce637b18caea04431ce14fabcf5c64a1c61ec9c56b071a4b7ca131ca52d44 \
|
||||||
--hash=sha256:fca0e3a251908a499833aa292323f32437106001d436eca0e6e7833256674585 \
|
--hash=sha256:ec031d5d2feb36d1d1a24380e4db6d43695f3748343d99434e6f5f9156aaa2ed \
|
||||||
--hash=sha256:fd1592b3fdf65fff2ad0004b5e363300ef59ced41c2e6b3a99d4089fa8c5435d \
|
--hash=sha256:ef6107725bd54b262d6dedcc2af448a266975032bc85ef0172c5f059da6325b4 \
|
||||||
--hash=sha256:fd66fc5d0da6d9815ba2cebeb4205f95818ff4b79c3ebe268e75d961704af52f
|
--hash=sha256:efdca5630322a10774e8e98e1af481aad470dd62c3170801852d752aa7a783ba \
|
||||||
|
--hash=sha256:f753120cb8181e736c57ef7636e83f31b9c0d1722c516f7e86cf15b7aa57ff12 \
|
||||||
|
--hash=sha256:ff3824dc5261f50c9b0dfb3be22b4567a6f938ccce4587b38952d85fd9e9afe4
|
||||||
# via django-yunohost-integration
|
# via django-yunohost-integration
|
||||||
redis==5.0.6 \
|
redis==5.0.8 \
|
||||||
--hash=sha256:38473cd7c6389ad3e44a91f4c3eaf6bcb8a9f746007f29bf4fb20824ff0b2197 \
|
--hash=sha256:0c5b10d387568dfe0698c6fad6615750c24170e548ca2deac10c649d463e9870 \
|
||||||
--hash=sha256:c0d6d990850c627bbf7be01c5c4cbaadf67b48593e913bb71c9819c30df37eee
|
--hash=sha256:56134ee08ea909106090934adc36f65c9bcbbaecea5b21ba704ba6fb561f8eb4
|
||||||
# via django-redis
|
# via django-redis
|
||||||
requests==2.32.3 \
|
requests==2.32.3 \
|
||||||
--hash=sha256:55365417734eb18255590a9ff9eb97e9e1da868d4ccd6402399eaf68af20a760 \
|
--hash=sha256:55365417734eb18255590a9ff9eb97e9e1da868d4ccd6402399eaf68af20a760 \
|
||||||
--hash=sha256:70761cfe03c773ceb22aa2f671b4757976145175cdfca038c02654d061d6dcc6
|
--hash=sha256:70761cfe03c773ceb22aa2f671b4757976145175cdfca038c02654d061d6dcc6
|
||||||
# via django-fmd
|
# via django-fmd
|
||||||
rich==13.7.1 \
|
rich==13.8.0 \
|
||||||
--hash=sha256:4edbae314f59eb482f54e9e30bf00d33350aaa94f4bfcd4e9e3110e64d0d7222 \
|
--hash=sha256:2e85306a063b9492dffc86278197a60cbece75bcb766022f3436f567cae11bdc \
|
||||||
--hash=sha256:9be308cb1fe2f1f57d67ce99e95af38a1e2bc71ad9813b0e247cf7ffbcc3a432
|
--hash=sha256:a5ac1f1cd448ade0d59cc3356f7db7a7ccda2c8cbae9c7a90c28ff463d3e91f4
|
||||||
# via
|
# via
|
||||||
# cli-base-utilities
|
# cli-base-utilities
|
||||||
# rich-click
|
# rich-click
|
||||||
|
@ -426,10 +495,12 @@ rich-click==1.8.3 \
|
||||||
six==1.16.0 \
|
six==1.16.0 \
|
||||||
--hash=sha256:1e61c37477a1626458e36f7b1d82aa5c9b094fa4802892072e49de9c60c4c926 \
|
--hash=sha256:1e61c37477a1626458e36f7b1d82aa5c9b094fa4802892072e49de9c60c4c926 \
|
||||||
--hash=sha256:8abb2f1d86890a2dfb989f9a77cfcfd3e47c2a354b01111771326f8aa26e0254
|
--hash=sha256:8abb2f1d86890a2dfb989f9a77cfcfd3e47c2a354b01111771326f8aa26e0254
|
||||||
# via bleach
|
# via
|
||||||
sqlparse==0.5.0 \
|
# bleach
|
||||||
--hash=sha256:714d0a4932c059d16189f58ef5411ec2287a4360f17cdd0edd2d09d4c5087c93 \
|
# python-dateutil
|
||||||
--hash=sha256:c204494cd97479d0e39f28c93d46c0b2d5959c7b9ab904762ea6c7af211c8663
|
sqlparse==0.5.1 \
|
||||||
|
--hash=sha256:773dcbf9a5ab44a090f3441e2180efe2560220203dc2f8c0b0fa141e18b505e4 \
|
||||||
|
--hash=sha256:bb6b4df465655ef332548e24f08e205afc81b9ab86cb1c45657a7ff173a3a00e
|
||||||
# via
|
# via
|
||||||
# django
|
# django
|
||||||
# django-debug-toolbar
|
# django-debug-toolbar
|
||||||
|
@ -437,14 +508,16 @@ tomli==2.0.1 \
|
||||||
--hash=sha256:939de3e7a6161af0c887ef91b7d41a53e7c5a1ca976325f429cb46ea9bc30ecc \
|
--hash=sha256:939de3e7a6161af0c887ef91b7d41a53e7c5a1ca976325f429cb46ea9bc30ecc \
|
||||||
--hash=sha256:de526c12914f0c550d15924c62d72abc48d6fe7364aa87328337a31007fe8a4f
|
--hash=sha256:de526c12914f0c550d15924c62d72abc48d6fe7364aa87328337a31007fe8a4f
|
||||||
# via cli-base-utilities
|
# via cli-base-utilities
|
||||||
tomlkit==0.12.5 \
|
tomlkit==0.13.2 \
|
||||||
--hash=sha256:af914f5a9c59ed9d0762c7b64d3b5d5df007448eb9cd2edc8a46b1eafead172f \
|
--hash=sha256:7a974427f6e119197f670fbbbeae7bef749a6c14e793db934baefc1b5f03efde \
|
||||||
--hash=sha256:eef34fba39834d4d6b73c9ba7f3e4d1c417a4e56f89a7e96e090dd0d24b8fb3c
|
--hash=sha256:fff5fe59a87295b278abd31bec92c15d9bc4a06885ab12bcea52c71119392e79
|
||||||
# via cli-base-utilities
|
# via cli-base-utilities
|
||||||
typing-extensions==4.12.2 \
|
typing-extensions==4.12.2 \
|
||||||
--hash=sha256:04e5ca0351e0f3f85c6853954072df659d0d13fac324d0072316b67d7794700d \
|
--hash=sha256:04e5ca0351e0f3f85c6853954072df659d0d13fac324d0072316b67d7794700d \
|
||||||
--hash=sha256:1a7ead55c7e559dd4dee8856e3a88b41225abfe1ce8df57b7c13915fe121ffb8
|
--hash=sha256:1a7ead55c7e559dd4dee8856e3a88b41225abfe1ce8df57b7c13915fe121ffb8
|
||||||
# via rich-click
|
# via
|
||||||
|
# psycopg
|
||||||
|
# rich-click
|
||||||
urllib3==2.2.2 \
|
urllib3==2.2.2 \
|
||||||
--hash=sha256:a448b2f64d686155468037e1ace9f2d2199776e17f0a46610480d311f73e3472 \
|
--hash=sha256:a448b2f64d686155468037e1ace9f2d2199776e17f0a46610480d311f73e3472 \
|
||||||
--hash=sha256:dd505485549a7a552833da5e6063639d0d177c04f23bc3864e41e5dc5f612168
|
--hash=sha256:dd505485549a7a552833da5e6063639d0d177c04f23bc3864e41e5dc5f612168
|
||||||
|
|
|
@ -31,7 +31,7 @@ services = ["__APP__"]
|
||||||
type = "boolean"
|
type = "boolean"
|
||||||
yes = "1"
|
yes = "1"
|
||||||
no = "0"
|
no = "0"
|
||||||
help = "Should be never enabled in production!"
|
help = "Enable DEBUG mode? (Should be never enabled in production!)"
|
||||||
bind = "debug_enabled:/home/yunohost.app/__APP__/settings.py"
|
bind = "debug_enabled:/home/yunohost.app/__APP__/settings.py"
|
||||||
|
|
||||||
[main.config.log_level]
|
[main.config.log_level]
|
||||||
|
|
10
dev-cli.py
10
dev-cli.py
|
@ -33,7 +33,7 @@ else:
|
||||||
sys.exit(-1)
|
sys.exit(-1)
|
||||||
|
|
||||||
|
|
||||||
assert sys.version_info >= (3, 10), f'Python version {sys.version_info} is too old!'
|
assert sys.version_info >= (3, 11), f'Python version {sys.version_info} is too old!'
|
||||||
|
|
||||||
|
|
||||||
if sys.platform == 'win32': # wtf
|
if sys.platform == 'win32': # wtf
|
||||||
|
@ -48,7 +48,7 @@ else:
|
||||||
BASE_PATH = Path(__file__).parent
|
BASE_PATH = Path(__file__).parent
|
||||||
VENV_PATH = BASE_PATH / '.venv'
|
VENV_PATH = BASE_PATH / '.venv'
|
||||||
BIN_PATH = VENV_PATH / BIN_NAME
|
BIN_PATH = VENV_PATH / BIN_NAME
|
||||||
PYTHON_PATH = BIN_PATH / f'python{FILE_EXT}'
|
PYTHON_PATH = BIN_PATH / f'python3{FILE_EXT}'
|
||||||
PIP_PATH = BIN_PATH / f'pip{FILE_EXT}'
|
PIP_PATH = BIN_PATH / f'pip{FILE_EXT}'
|
||||||
PIP_SYNC_PATH = BIN_PATH / f'pip-sync{FILE_EXT}'
|
PIP_SYNC_PATH = BIN_PATH / f'pip-sync{FILE_EXT}'
|
||||||
|
|
||||||
|
@ -87,17 +87,17 @@ def main(argv):
|
||||||
|
|
||||||
# Create virtual env in ".venv/":
|
# Create virtual env in ".venv/":
|
||||||
if not PYTHON_PATH.is_file():
|
if not PYTHON_PATH.is_file():
|
||||||
print('Create virtual env here:', VENV_PATH.absolute())
|
print(f'Create virtual env here: {VENV_PATH.absolute()}')
|
||||||
builder = venv.EnvBuilder(symlinks=True, upgrade=True, with_pip=True)
|
builder = venv.EnvBuilder(symlinks=True, upgrade=True, with_pip=True)
|
||||||
builder.create(env_dir=VENV_PATH)
|
builder.create(env_dir=VENV_PATH)
|
||||||
|
|
||||||
|
if not PROJECT_SHELL_SCRIPT.is_file() or not venv_up2date():
|
||||||
# Update pip
|
# Update pip
|
||||||
verbose_check_call(PYTHON_PATH, '-m', 'pip', 'install', '-U', 'pip')
|
verbose_check_call(PYTHON_PATH, '-m', 'pip', 'install', '-U', 'pip')
|
||||||
|
|
||||||
if not PIP_SYNC_PATH.is_file():
|
|
||||||
# Install pip-tools
|
# Install pip-tools
|
||||||
verbose_check_call(PYTHON_PATH, '-m', 'pip', 'install', '-U', 'pip-tools')
|
verbose_check_call(PYTHON_PATH, '-m', 'pip', 'install', '-U', 'pip-tools')
|
||||||
|
|
||||||
if not PROJECT_SHELL_SCRIPT.is_file() or not venv_up2date():
|
|
||||||
# install requirements via "pip-sync"
|
# install requirements via "pip-sync"
|
||||||
verbose_check_call(PIP_SYNC_PATH, str(DEP_LOCK_PATH))
|
verbose_check_call(PIP_SYNC_PATH, str(DEP_LOCK_PATH))
|
||||||
|
|
||||||
|
|
|
@ -9,13 +9,15 @@ from pathlib import Path
|
||||||
|
|
||||||
import rich_click as click
|
import rich_click as click
|
||||||
from cli_base.cli_tools import code_style
|
from cli_base.cli_tools import code_style
|
||||||
from cli_base.cli_tools.dev_tools import run_tox
|
from cli_base.cli_tools.dev_tools import run_coverage, run_tox
|
||||||
from cli_base.cli_tools.subprocess_utils import verbose_check_call
|
from cli_base.cli_tools.subprocess_utils import verbose_check_call
|
||||||
from cli_base.cli_tools.test_utils.snapshot import UpdateTestSnapshotFiles
|
from cli_base.cli_tools.test_utils.snapshot import UpdateTestSnapshotFiles
|
||||||
from cli_base.cli_tools.verbosity import OPTION_KWARGS_VERBOSE
|
from cli_base.cli_tools.verbosity import OPTION_KWARGS_VERBOSE
|
||||||
from cli_base.cli_tools.version_info import print_version
|
from cli_base.cli_tools.version_info import print_version
|
||||||
|
from cli_base.run_pip_audit import run_pip_audit
|
||||||
from django.core.management.commands.test import Command as DjangoTestCommand
|
from django.core.management.commands.test import Command as DjangoTestCommand
|
||||||
from django_yunohost_integration.local_test import create_local_test
|
from django_yunohost_integration.local_test import create_local_test
|
||||||
|
from django_yunohost_integration.path_utils import get_project_root
|
||||||
from manageprojects.utilities.publish import publish_package
|
from manageprojects.utilities.publish import publish_package
|
||||||
from rich import print
|
from rich import print
|
||||||
from rich.console import Console
|
from rich.console import Console
|
||||||
|
@ -24,7 +26,6 @@ from rich_click import RichGroup
|
||||||
|
|
||||||
import django_fmd_ynh
|
import django_fmd_ynh
|
||||||
from django_fmd_ynh import constants
|
from django_fmd_ynh import constants
|
||||||
from django_fmd_ynh.constants import PACKAGE_ROOT
|
|
||||||
from django_fmd_ynh.tests import setup_ynh_tests
|
from django_fmd_ynh.tests import setup_ynh_tests
|
||||||
|
|
||||||
|
|
||||||
|
@ -69,7 +70,7 @@ def cli():
|
||||||
@click.option('-v', '--verbosity', **OPTION_KWARGS_VERBOSE)
|
@click.option('-v', '--verbosity', **OPTION_KWARGS_VERBOSE)
|
||||||
def mypy(verbosity: int):
|
def mypy(verbosity: int):
|
||||||
"""Run Mypy (configured in pyproject.toml)"""
|
"""Run Mypy (configured in pyproject.toml)"""
|
||||||
verbose_check_call('mypy', '.', cwd=PACKAGE_ROOT, verbose=verbosity > 0, exit_on_error=True)
|
verbose_check_call('mypy', '.', cwd=get_project_root(), verbose=verbosity > 0, exit_on_error=True)
|
||||||
|
|
||||||
|
|
||||||
@cli.command()
|
@cli.command()
|
||||||
|
@ -77,29 +78,17 @@ def install():
|
||||||
"""
|
"""
|
||||||
Run pip-sync and install 'django_fmd_ynh' via pip as editable.
|
Run pip-sync and install 'django_fmd_ynh' via pip as editable.
|
||||||
"""
|
"""
|
||||||
verbose_check_call('pip-sync', PACKAGE_ROOT / 'requirements.dev.txt')
|
verbose_check_call('pip-sync', get_project_root() / 'requirements.dev.txt')
|
||||||
verbose_check_call('pip', 'install', '--no-deps', '-e', '.')
|
verbose_check_call('pip', 'install', '--no-deps', '-e', '.')
|
||||||
|
|
||||||
|
|
||||||
def _run_safety():
|
|
||||||
verbose_check_call(
|
|
||||||
'safety',
|
|
||||||
'check',
|
|
||||||
'-r',
|
|
||||||
'requirements.dev.txt',
|
|
||||||
'--ignore',
|
|
||||||
'67599', # Ignore CVE-2018-20225: We do not use the `--extra-index-url` option
|
|
||||||
'--ignore',
|
|
||||||
'70612', # Ignore CVE-2019-8341: We don't use Jinja2 directly
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
@cli.command()
|
@cli.command()
|
||||||
def safety():
|
@click.option('-v', '--verbosity', **OPTION_KWARGS_VERBOSE)
|
||||||
|
def pip_audit(verbosity: int):
|
||||||
"""
|
"""
|
||||||
Run safety check against current requirements files
|
Run pip-audit check against current requirements files
|
||||||
"""
|
"""
|
||||||
_run_safety()
|
run_pip_audit(base_path=get_project_root(), verbosity=verbosity)
|
||||||
|
|
||||||
|
|
||||||
@cli.command()
|
@cli.command()
|
||||||
|
@ -144,7 +133,7 @@ def update():
|
||||||
extra_env=extra_env,
|
extra_env=extra_env,
|
||||||
)
|
)
|
||||||
|
|
||||||
_run_safety()
|
run_pip_audit(base_path=get_project_root())
|
||||||
|
|
||||||
# Install new dependencies in current .venv:
|
# Install new dependencies in current .venv:
|
||||||
verbose_check_call(bin_path / 'pip-sync', 'requirements.dev.txt')
|
verbose_check_call(bin_path / 'pip-sync', 'requirements.dev.txt')
|
||||||
|
@ -162,7 +151,7 @@ def publish():
|
||||||
|
|
||||||
publish_package(
|
publish_package(
|
||||||
module=django_fmd_ynh,
|
module=django_fmd_ynh,
|
||||||
package_path=PACKAGE_ROOT,
|
package_path=get_project_root(),
|
||||||
distribution_name='django_fmd_ynh',
|
distribution_name='django_fmd_ynh',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -174,7 +163,7 @@ def fix_code_style(color: bool, verbosity: int):
|
||||||
"""
|
"""
|
||||||
Fix code style of all your_cool_package source code files via darker
|
Fix code style of all your_cool_package source code files via darker
|
||||||
"""
|
"""
|
||||||
code_style.fix(package_root=PACKAGE_ROOT, darker_color=color, darker_verbose=verbosity > 0)
|
code_style.fix(package_root=get_project_root(), darker_color=color, darker_verbose=verbosity > 0)
|
||||||
|
|
||||||
|
|
||||||
@cli.command()
|
@cli.command()
|
||||||
|
@ -184,7 +173,7 @@ def check_code_style(color: bool, verbosity: int):
|
||||||
"""
|
"""
|
||||||
Check code style by calling darker + flake8
|
Check code style by calling darker + flake8
|
||||||
"""
|
"""
|
||||||
code_style.check(package_root=PACKAGE_ROOT, darker_color=color, darker_verbose=verbosity > 0)
|
code_style.check(package_root=get_project_root(), darker_color=color, darker_verbose=verbosity > 0)
|
||||||
|
|
||||||
|
|
||||||
@cli.command()
|
@cli.command()
|
||||||
|
@ -192,7 +181,7 @@ def update_test_snapshot_files():
|
||||||
"""
|
"""
|
||||||
Update all test snapshot files (by remove and recreate all snapshot files)
|
Update all test snapshot files (by remove and recreate all snapshot files)
|
||||||
"""
|
"""
|
||||||
with UpdateTestSnapshotFiles(root_path=PACKAGE_ROOT, verbose=True):
|
with UpdateTestSnapshotFiles(root_path=get_project_root(), verbose=True):
|
||||||
# Just recreate them by running tests:
|
# Just recreate them by running tests:
|
||||||
_run_django_test_cli(argv=sys.argv, exit_after_run=False)
|
_run_django_test_cli(argv=sys.argv, exit_after_run=False)
|
||||||
|
|
||||||
|
@ -211,6 +200,7 @@ def _run_django_test_cli(argv, exit_after_run=True):
|
||||||
print()
|
print()
|
||||||
|
|
||||||
test_command = DjangoTestCommand()
|
test_command = DjangoTestCommand()
|
||||||
|
|
||||||
test_command.run_from_argv(argv)
|
test_command.run_from_argv(argv)
|
||||||
if exit_after_run:
|
if exit_after_run:
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
|
@ -224,6 +214,14 @@ def test():
|
||||||
_run_django_test_cli(argv=sys.argv, exit_after_run=True)
|
_run_django_test_cli(argv=sys.argv, exit_after_run=True)
|
||||||
|
|
||||||
|
|
||||||
|
@cli.command() # Dummy command
|
||||||
|
def coverage():
|
||||||
|
"""
|
||||||
|
Run tests and show coverage report.
|
||||||
|
"""
|
||||||
|
run_coverage()
|
||||||
|
|
||||||
|
|
||||||
@cli.command() # Dummy "tox" command
|
@cli.command() # Dummy "tox" command
|
||||||
def tox():
|
def tox():
|
||||||
"""
|
"""
|
||||||
|
@ -245,8 +243,8 @@ def local_test():
|
||||||
Build a "local_test" YunoHost installation and start the Django dev. server against it.
|
Build a "local_test" YunoHost installation and start the Django dev. server against it.
|
||||||
"""
|
"""
|
||||||
create_local_test(
|
create_local_test(
|
||||||
django_settings_path=PACKAGE_ROOT / 'conf' / 'settings.py',
|
django_settings_path=get_project_root() / 'conf' / 'settings.py',
|
||||||
destination=PACKAGE_ROOT / 'local_test',
|
destination=get_project_root() / 'local_test',
|
||||||
runserver=True,
|
runserver=True,
|
||||||
extra_replacements={
|
extra_replacements={
|
||||||
'__DEBUG_ENABLED__': '1',
|
'__DEBUG_ENABLED__': '1',
|
||||||
|
@ -259,9 +257,9 @@ def diffsettings():
|
||||||
"""
|
"""
|
||||||
Run "diffsettings" manage command against a "local_test" YunoHost installation.
|
Run "diffsettings" manage command against a "local_test" YunoHost installation.
|
||||||
"""
|
"""
|
||||||
destination = PACKAGE_ROOT / 'local_test'
|
destination = get_project_root() / 'local_test'
|
||||||
create_local_test(
|
create_local_test(
|
||||||
django_settings_path=PACKAGE_ROOT / 'conf' / 'settings.py',
|
django_settings_path=get_project_root() / 'conf' / 'settings.py',
|
||||||
destination=destination,
|
destination=destination,
|
||||||
runserver=False,
|
runserver=False,
|
||||||
extra_replacements={
|
extra_replacements={
|
||||||
|
@ -286,6 +284,7 @@ def main():
|
||||||
command_map = {
|
command_map = {
|
||||||
'test': _run_django_test_cli,
|
'test': _run_django_test_cli,
|
||||||
'tox': run_tox,
|
'tox': run_tox,
|
||||||
|
'coverage': run_coverage,
|
||||||
}
|
}
|
||||||
if real_func := command_map.get(command):
|
if real_func := command_map.get(command):
|
||||||
real_func(argv=sys.argv, exit_after_run=True)
|
real_func(argv=sys.argv, exit_after_run=True)
|
||||||
|
|
|
@ -4,12 +4,16 @@ import unittest.util
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
||||||
import django
|
import django
|
||||||
import django_fmd_ynh
|
|
||||||
from bx_py_utils.test_utils.deny_requests import deny_any_real_request
|
from bx_py_utils.test_utils.deny_requests import deny_any_real_request
|
||||||
from cli_base.cli_tools.verbosity import MAX_LOG_LEVEL, setup_logging
|
from cli_base.cli_tools.verbosity import MAX_LOG_LEVEL, setup_logging
|
||||||
from django_fmd_ynh.constants import PACKAGE_ROOT
|
|
||||||
from django_yunohost_integration.local_test import CreateResults, create_local_test
|
from django_yunohost_integration.local_test import CreateResults, create_local_test
|
||||||
|
from django_yunohost_integration.path_utils import get_project_root
|
||||||
from rich import print # noqa
|
from rich import print # noqa
|
||||||
|
from typeguard import install_import_hook
|
||||||
|
|
||||||
|
|
||||||
|
# Check type annotations via typeguard in all tests:
|
||||||
|
install_import_hook(packages=('django_fmd_ynh',))
|
||||||
|
|
||||||
|
|
||||||
def pre_configure_tests() -> None:
|
def pre_configure_tests() -> None:
|
||||||
|
@ -28,12 +32,15 @@ def pre_configure_tests() -> None:
|
||||||
|
|
||||||
|
|
||||||
def setup_ynh_tests() -> None:
|
def setup_ynh_tests() -> None:
|
||||||
|
# Import after "install_import_hook" to check type annotations:
|
||||||
|
import django_fmd_ynh
|
||||||
|
|
||||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'settings'
|
os.environ['DJANGO_SETTINGS_MODULE'] = 'settings'
|
||||||
|
|
||||||
print('Compile YunoHost files...')
|
print('Compile YunoHost files...')
|
||||||
result: CreateResults = create_local_test(
|
result: CreateResults = create_local_test(
|
||||||
django_settings_path=PACKAGE_ROOT / 'conf' / 'settings.py',
|
django_settings_path=get_project_root() / 'conf' / 'settings.py',
|
||||||
destination=PACKAGE_ROOT / 'local_test',
|
destination=get_project_root() / 'local_test',
|
||||||
runserver=False,
|
runserver=False,
|
||||||
extra_replacements={
|
extra_replacements={
|
||||||
'__DEBUG_ENABLED__': '0', # "1" or "0" string
|
'__DEBUG_ENABLED__': '0', # "1" or "0" string
|
||||||
|
|
|
@ -1,18 +1,12 @@
|
||||||
|
import tomllib
|
||||||
from django_fmd_ynh.cli.dev import PACKAGE_ROOT
|
|
||||||
|
|
||||||
|
|
||||||
try:
|
|
||||||
import tomllib # New in Python 3.11
|
|
||||||
except ImportError:
|
|
||||||
import tomli as tomllib
|
|
||||||
|
|
||||||
from bx_django_utils.filename import clean_filename
|
from bx_django_utils.filename import clean_filename
|
||||||
from bx_py_utils.path import assert_is_dir, assert_is_file
|
from bx_py_utils.path import assert_is_dir, assert_is_file
|
||||||
from django.test.testcases import TestCase
|
from django.test.testcases import TestCase
|
||||||
from django_tools.unittest_utils.project_setup import check_editor_config
|
from django_tools.unittest_utils.project_setup import check_editor_config
|
||||||
|
from django_yunohost_integration.path_utils import get_project_root
|
||||||
from findmydevice import __version__ as upstream_version
|
from findmydevice import __version__ as upstream_version
|
||||||
|
|
||||||
from django_fmd_ynh import __version__ as ynh_pkg_version
|
from django_fmd_ynh import __version__ as ynh_pkg_version
|
||||||
|
|
||||||
|
|
||||||
|
@ -29,7 +23,7 @@ class ProjectSetupTestCase(TestCase):
|
||||||
def setUpClass(cls):
|
def setUpClass(cls):
|
||||||
super().setUpClass()
|
super().setUpClass()
|
||||||
|
|
||||||
manifest_path = PACKAGE_ROOT / 'manifest.toml'
|
manifest_path = get_project_root() / 'manifest.toml'
|
||||||
assert_is_file(manifest_path)
|
assert_is_file(manifest_path)
|
||||||
|
|
||||||
cls.manifest_cfg = tomllib.loads(manifest_path.read_text(encoding='UTF-8'))
|
cls.manifest_cfg = tomllib.loads(manifest_path.read_text(encoding='UTF-8'))
|
||||||
|
@ -49,7 +43,7 @@ class ProjectSetupTestCase(TestCase):
|
||||||
"""
|
"""
|
||||||
https://forum.yunohost.org/t/yunohost-bot-cant-handle-spaces-in-screenshots/19483
|
https://forum.yunohost.org/t/yunohost-bot-cant-handle-spaces-in-screenshots/19483
|
||||||
"""
|
"""
|
||||||
screenshot_path = PACKAGE_ROOT / 'doc' / 'screenshots'
|
screenshot_path = get_project_root() / 'doc' / 'screenshots'
|
||||||
assert_is_dir(screenshot_path)
|
assert_is_dir(screenshot_path)
|
||||||
renamed = []
|
renamed = []
|
||||||
for file_path in screenshot_path.iterdir():
|
for file_path in screenshot_path.iterdir():
|
||||||
|
@ -64,7 +58,7 @@ class ProjectSetupTestCase(TestCase):
|
||||||
assert not renamed, f'Bad screenshots file names found: {", ".join(renamed)}'
|
assert not renamed, f'Bad screenshots file names found: {", ".join(renamed)}'
|
||||||
|
|
||||||
def test_check_editor_config(self):
|
def test_check_editor_config(self):
|
||||||
check_editor_config(package_root=PACKAGE_ROOT)
|
check_editor_config(package_root=get_project_root())
|
||||||
|
|
||||||
def test_manifest_toml(self):
|
def test_manifest_toml(self):
|
||||||
self.assertEqual(self.manifest_cfg['packaging_format'], 2)
|
self.assertEqual(self.manifest_cfg['packaging_format'], 2)
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
||||||
from bx_py_utils.auto_doc import assert_readme_block
|
from bx_py_utils.auto_doc import assert_readme_block
|
||||||
from django_fmd_ynh.cli.dev import PACKAGE_ROOT, cli
|
from django_yunohost_integration.path_utils import get_project_root
|
||||||
from django_fmd_ynh.constants import CLI_EPILOG
|
|
||||||
from manageprojects.test_utils.click_cli_utils import invoke_click
|
from manageprojects.test_utils.click_cli_utils import invoke_click
|
||||||
from manageprojects.tests.base import BaseTestCase
|
from manageprojects.tests.base import BaseTestCase
|
||||||
|
|
||||||
|
from django_fmd_ynh.cli.dev import cli
|
||||||
|
from django_fmd_ynh.constants import CLI_EPILOG
|
||||||
|
|
||||||
|
|
||||||
def assert_cli_help_in_readme(text_block: str, marker: str, readme_path: Path):
|
def assert_cli_help_in_readme(text_block: str, marker: str, readme_path: Path):
|
||||||
text_block = text_block.replace(CLI_EPILOG, '')
|
text_block = text_block.replace(CLI_EPILOG, '')
|
||||||
|
@ -32,5 +34,5 @@ class ReadmeTestCase(BaseTestCase):
|
||||||
assert_cli_help_in_readme(
|
assert_cli_help_in_readme(
|
||||||
text_block=stdout,
|
text_block=stdout,
|
||||||
marker='help',
|
marker='help',
|
||||||
readme_path=PACKAGE_ROOT / 'doc' / 'ADMIN.md',
|
readme_path=get_project_root() / 'doc' / 'ADMIN.md',
|
||||||
)
|
)
|
||||||
|
|
|
@ -45,6 +45,7 @@ Usage: ./dev-cli.py [OPTIONS] COMMAND [ARGS]...
|
||||||
╰──────────────────────────────────────────────────────────────────────────────────────────────────╯
|
╰──────────────────────────────────────────────────────────────────────────────────────────────────╯
|
||||||
╭─ Commands ───────────────────────────────────────────────────────────────────────────────────────╮
|
╭─ Commands ───────────────────────────────────────────────────────────────────────────────────────╮
|
||||||
│ check-code-style Check code style by calling darker + flake8 │
|
│ check-code-style Check code style by calling darker + flake8 │
|
||||||
|
│ coverage Run tests and show coverage report. │
|
||||||
│ diffsettings Run "diffsettings" manage command against a "local_test" YunoHost │
|
│ diffsettings Run "diffsettings" manage command against a "local_test" YunoHost │
|
||||||
│ installation. │
|
│ installation. │
|
||||||
│ fix-code-style Fix code style of all your_cool_package source code files via darker │
|
│ fix-code-style Fix code style of all your_cool_package source code files via darker │
|
||||||
|
@ -52,8 +53,8 @@ Usage: ./dev-cli.py [OPTIONS] COMMAND [ARGS]...
|
||||||
│ local-test Build a "local_test" YunoHost installation and start the Django dev. │
|
│ local-test Build a "local_test" YunoHost installation and start the Django dev. │
|
||||||
│ server against it. │
|
│ server against it. │
|
||||||
│ mypy Run Mypy (configured in pyproject.toml) │
|
│ mypy Run Mypy (configured in pyproject.toml) │
|
||||||
|
│ pip-audit Run pip-audit check against current requirements files │
|
||||||
│ publish Build and upload this project to PyPi │
|
│ publish Build and upload this project to PyPi │
|
||||||
│ safety Run safety check against current requirements files │
|
|
||||||
│ test Compile YunoHost files and run Django unittests │
|
│ test Compile YunoHost files and run Django unittests │
|
||||||
│ tox Run tox │
|
│ tox Run tox │
|
||||||
│ update Update "requirements*.txt" dependencies files │
|
│ update Update "requirements*.txt" dependencies files │
|
||||||
|
|
11
manage_local_test.py
Normal file
11
manage_local_test.py
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
#!.venv/bin/python3
|
||||||
|
|
||||||
|
"""
|
||||||
|
Call the "manage.py" from the local test environment.
|
||||||
|
"""
|
||||||
|
|
||||||
|
from django_yunohost_integration.local_test import run_local_test_manage
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
run_local_test_manage()
|
|
@ -20,7 +20,7 @@ code = "https://github.com/YunoHost-Apps/django-fmd_ynh"
|
||||||
|
|
||||||
[integration]
|
[integration]
|
||||||
# https://yunohost.org/en/packaging_manifest#integration-section
|
# https://yunohost.org/en/packaging_manifest#integration-section
|
||||||
yunohost = ">= 11.2.12"
|
yunohost = ">=11.2"
|
||||||
architectures = "all"
|
architectures = "all"
|
||||||
multi_instance = false
|
multi_instance = false
|
||||||
ldap = true
|
ldap = true
|
||||||
|
@ -101,7 +101,7 @@ ram.runtime = "50M" # **estimate** minimum ram requirement. e.g. 50M, 400M, 1G,
|
||||||
[resources.apt]
|
[resources.apt]
|
||||||
# https://yunohost.org/en/packaging_apps_resources#apt
|
# https://yunohost.org/en/packaging_apps_resources#apt
|
||||||
# This will automatically install/uninstall the following apt packages
|
# This will automatically install/uninstall the following apt packages
|
||||||
packages = "build-essential, libssl-dev, libnss3-dev, libffi-dev, git, libpq-dev, postgresql, postgresql-contrib, redis-server"
|
packages = "build-essential, python3-dev, python3-pip, python3-venv, git, libffi-dev, libpq-dev, postgresql, postgresql-contrib, redis-server, checkinstall, pkg-config, libssl-dev, openssl"
|
||||||
|
|
||||||
[resources.database]
|
[resources.database]
|
||||||
# https://yunohost.org/en/packaging_apps_resources#database
|
# https://yunohost.org/en/packaging_apps_resources#database
|
||||||
|
|
|
@ -7,7 +7,7 @@ readme = "README.md"
|
||||||
authors = [
|
authors = [
|
||||||
{name = 'Jens Diemer', email = 'git@jensdiemer.de'}
|
{name = 'Jens Diemer', email = 'git@jensdiemer.de'}
|
||||||
]
|
]
|
||||||
requires-python = ">=3.9" # Stay with 3.9 until YunoHost used >=Debian 11 (Bullseye)
|
requires-python = ">=3.11"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"django-fmd>=0.4.1", # https://gitlab.com/jedie/django-find-my-device
|
"django-fmd>=0.4.1", # https://gitlab.com/jedie/django-find-my-device
|
||||||
#
|
#
|
||||||
|
@ -33,8 +33,9 @@ dev = [
|
||||||
"pyflakes", # https://github.com/PyCQA/pyflakes
|
"pyflakes", # https://github.com/PyCQA/pyflakes
|
||||||
"codespell", # https://github.com/codespell-project/codespell
|
"codespell", # https://github.com/codespell-project/codespell
|
||||||
"EditorConfig", # https://github.com/editorconfig/editorconfig-core-py
|
"EditorConfig", # https://github.com/editorconfig/editorconfig-core-py
|
||||||
"safety", # https://github.com/pyupio/safety
|
"pip-audit", # https://github.com/pypa/pip-audit
|
||||||
"mypy", # https://github.com/python/mypy
|
"mypy", # https://github.com/python/mypy
|
||||||
|
"typeguard", # https://github.com/agronholm/typeguard/
|
||||||
"twine", # https://github.com/pypa/twine
|
"twine", # https://github.com/pypa/twine
|
||||||
|
|
||||||
# https://github.com/akaihola/darker
|
# https://github.com/akaihola/darker
|
||||||
|
@ -43,11 +44,9 @@ dev = [
|
||||||
# https://github.com/pygments/pygments
|
# https://github.com/pygments/pygments
|
||||||
"darker[flynt, isort, color]",
|
"darker[flynt, isort, color]",
|
||||||
|
|
||||||
# indirect depencies added because of bug:
|
# indirect depencies for Python <=3.11
|
||||||
# https://github.com/pypa/pip/issues/9644 / https://github.com/jazzband/pip-tools/issues/1866
|
# Work-a-round for: https://github.com/jazzband/pip-tools/issues/1326
|
||||||
# to avoid errors like:
|
"backports.tarfile",
|
||||||
# In --require-hashes mode, all requirements must have their versions pinned with ==. These do not: ...
|
|
||||||
"tomli", # Only needed for Python <3.11
|
|
||||||
]
|
]
|
||||||
|
|
||||||
[project.urls]
|
[project.urls]
|
||||||
|
@ -74,6 +73,14 @@ include = ["django_fmd_ynh*"]
|
||||||
version = {attr = "django_fmd_ynh.__version__"}
|
version = {attr = "django_fmd_ynh.__version__"}
|
||||||
|
|
||||||
|
|
||||||
|
[tool.cli_base.pip_audit]
|
||||||
|
# https://github.com/jedie/cli-base-utilities/blob/main/docs/pip_audit.md
|
||||||
|
requirements=["requirements.dev.txt"]
|
||||||
|
strict=true
|
||||||
|
require_hashes=true
|
||||||
|
ignore-vuln=[]
|
||||||
|
|
||||||
|
|
||||||
[tool.darker]
|
[tool.darker]
|
||||||
src = ['.']
|
src = ['.']
|
||||||
# YunoHost apps still use "master" istead of "main", isn't it?
|
# YunoHost apps still use "master" istead of "main", isn't it?
|
||||||
|
@ -157,6 +164,9 @@ initial_revision = "1f3a70e"
|
||||||
initial_date = 2024-05-21T21:22:39+02:00
|
initial_date = 2024-05-21T21:22:39+02:00
|
||||||
cookiecutter_template = "https://github.com/jedie/cookiecutter_templates/"
|
cookiecutter_template = "https://github.com/jedie/cookiecutter_templates/"
|
||||||
cookiecutter_directory = "yunohost_django_package"
|
cookiecutter_directory = "yunohost_django_package"
|
||||||
|
applied_migrations = [
|
||||||
|
"2cdc1d8", # 2024-08-25T19:00:41+02:00
|
||||||
|
]
|
||||||
|
|
||||||
[manageprojects.cookiecutter_context.cookiecutter]
|
[manageprojects.cookiecutter_context.cookiecutter]
|
||||||
project_name = "django-fmd"
|
project_name = "django-fmd"
|
||||||
|
|
1223
requirements.dev.txt
1223
requirements.dev.txt
File diff suppressed because it is too large
Load diff
|
@ -86,13 +86,11 @@ myynh_install_python() {
|
||||||
if $(dpkg --compare-versions $py_built_version ge $python)
|
if $(dpkg --compare-versions $py_built_version ge $python)
|
||||||
then
|
then
|
||||||
# Built >= Required
|
# Built >= Required
|
||||||
ynh_print_info --message="Using already used python3 built version..."
|
|
||||||
|
|
||||||
py_app_version="/usr/local/bin/python${py_built_version%.*}"
|
py_app_version="/usr/local/bin/python${py_built_version%.*}"
|
||||||
|
ynh_print_info --message="Using already used python3 built version: $py_app_version"
|
||||||
else
|
else
|
||||||
# APT < Minimal & Actual < Minimal => Build & install Python into /usr/local/bin
|
# APT < Minimal & Actual < Minimal => Build & install Python into /usr/local/bin
|
||||||
ynh_print_info --message="Building python (may take a while)..."
|
ynh_print_info --message="Building $python (may take a while)..."
|
||||||
|
|
||||||
# Store current direcotry
|
# Store current direcotry
|
||||||
local MY_DIR=$(pwd)
|
local MY_DIR=$(pwd)
|
||||||
|
@ -126,21 +124,25 @@ myynh_install_python() {
|
||||||
fi
|
fi
|
||||||
# Save python version in settings
|
# Save python version in settings
|
||||||
ynh_app_setting_set --app=$app --key=python --value="$python"
|
ynh_app_setting_set --app=$app --key=python --value="$python"
|
||||||
|
|
||||||
|
# Print some version information:
|
||||||
|
ynh_print_info --message="Python version: $($py_app_version -VV)"
|
||||||
|
ynh_print_info --message="Pip version: $($py_app_version -m pip -V)"
|
||||||
}
|
}
|
||||||
#==================================================================================
|
#==================================================================================
|
||||||
#==================================================================================
|
#==================================================================================
|
||||||
|
|
||||||
myynh_setup_python_venv() {
|
myynh_setup_python_venv() {
|
||||||
# Always recreate everything fresh with current python version
|
# Install Python if needed:
|
||||||
ynh_secure_remove "$data_dir/venv"
|
|
||||||
|
|
||||||
myynh_install_python --python="$py_required_version"
|
myynh_install_python --python="$py_required_version"
|
||||||
|
|
||||||
# Create a virtualenv with python installed by myynh_install_python():
|
# Create a virtualenv with python installed by myynh_install_python():
|
||||||
# Skip pip because of: https://github.com/YunoHost/issues/issues/1960
|
# Skip pip because of: https://github.com/YunoHost/issues/issues/1960
|
||||||
$py_app_version -m venv --without-pip "$data_dir/venv"
|
ynh_exec_as $app $py_app_version -m venv --clear --upgrade-deps "$data_dir/venv"
|
||||||
|
|
||||||
chown -c -R "$app:" "$data_dir"
|
# Print some version information:
|
||||||
|
ynh_print_info --message="venv Python version: $($data_dir/venv/bin/python3 -VV)"
|
||||||
|
ynh_print_info --message="venv Pip version: $($data_dir/venv/bin/python3 -m pip -V)"
|
||||||
|
|
||||||
# run source in a 'sub shell'
|
# run source in a 'sub shell'
|
||||||
(
|
(
|
||||||
|
@ -148,8 +150,7 @@ myynh_setup_python_venv() {
|
||||||
source "$data_dir/venv/bin/activate"
|
source "$data_dir/venv/bin/activate"
|
||||||
set -o nounset
|
set -o nounset
|
||||||
set -x
|
set -x
|
||||||
ynh_exec_as $app $data_dir/venv/bin/python3 -m ensurepip
|
ynh_exec_as $app $data_dir/venv/bin/pip3 install --upgrade pip wheel setuptools
|
||||||
ynh_exec_as $app $data_dir/venv/bin/pip3 install --upgrade wheel pip setuptools
|
|
||||||
ynh_exec_as $app $data_dir/venv/bin/pip3 install --no-deps -r "$data_dir/requirements.txt"
|
ynh_exec_as $app $data_dir/venv/bin/pip3 install --no-deps -r "$data_dir/requirements.txt"
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -179,46 +180,3 @@ myynh_fix_file_permissions() {
|
||||||
chmod -c o-rwx "$data_dir"
|
chmod -c o-rwx "$data_dir"
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# Redis HELPERS
|
|
||||||
#=================================================
|
|
||||||
|
|
||||||
# get the first available redis database
|
|
||||||
#
|
|
||||||
# usage: ynh_redis_get_free_db
|
|
||||||
# | returns: the database number to use
|
|
||||||
ynh_redis_get_free_db() {
|
|
||||||
local result max db
|
|
||||||
result=$(redis-cli INFO keyspace)
|
|
||||||
|
|
||||||
# get the num
|
|
||||||
max=$(cat /etc/redis/redis.conf | grep ^databases | grep -Eow "[0-9]+")
|
|
||||||
|
|
||||||
db=0
|
|
||||||
# default Debian setting is 15 databases
|
|
||||||
for i in $(seq 0 "$max")
|
|
||||||
do
|
|
||||||
if ! echo "$result" | grep -q "db$i"
|
|
||||||
then
|
|
||||||
db=$i
|
|
||||||
break 1
|
|
||||||
fi
|
|
||||||
db=-1
|
|
||||||
done
|
|
||||||
|
|
||||||
test "$db" -eq -1 && ynh_die "No available Redis databases..."
|
|
||||||
|
|
||||||
echo "$db"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Create a master password and set up global settings
|
|
||||||
# Please always call this script in install and restore scripts
|
|
||||||
#
|
|
||||||
# usage: ynh_redis_remove_db database
|
|
||||||
# | arg: database - the database to erase
|
|
||||||
ynh_redis_remove_db() {
|
|
||||||
local db=$1
|
|
||||||
redis-cli -n "$db" flushall
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -113,7 +113,7 @@ cd "$data_dir" || exit
|
||||||
#=================================================
|
#=================================================
|
||||||
ynh_script_progression --message="Integrating service in YunoHost..."
|
ynh_script_progression --message="Integrating service in YunoHost..."
|
||||||
|
|
||||||
yunohost service add $app
|
yunohost service add --description $app $app
|
||||||
|
|
||||||
#=================================================
|
#=================================================
|
||||||
# GENERIC FINALIZATION
|
# GENERIC FINALIZATION
|
||||||
|
|
|
@ -26,6 +26,9 @@ ynh_script_progression --message="Restoring $app main directory..."
|
||||||
ynh_restore_file --origin_path="$install_dir"
|
ynh_restore_file --origin_path="$install_dir"
|
||||||
ynh_restore_file --origin_path="$data_dir"
|
ynh_restore_file --origin_path="$data_dir"
|
||||||
|
|
||||||
|
ynh_script_progression --message="Set file permissions..."
|
||||||
|
myynh_fix_file_permissions
|
||||||
|
|
||||||
#=================================================
|
#=================================================
|
||||||
# PYTHON VIRTUALENV
|
# PYTHON VIRTUALENV
|
||||||
# Maybe the backup contains a other Python version
|
# Maybe the backup contains a other Python version
|
||||||
|
@ -34,13 +37,6 @@ ynh_script_progression --message="Create and setup Python virtualenv..." --weigh
|
||||||
|
|
||||||
myynh_setup_python_venv
|
myynh_setup_python_venv
|
||||||
|
|
||||||
#=================================================
|
|
||||||
# Fix file permissions
|
|
||||||
#=================================================
|
|
||||||
ynh_script_progression --message="Set file permissions..."
|
|
||||||
|
|
||||||
myynh_fix_file_permissions
|
|
||||||
|
|
||||||
#=================================================
|
#=================================================
|
||||||
# RESTORE THE PostgreSQL DATABASE
|
# RESTORE THE PostgreSQL DATABASE
|
||||||
#=================================================
|
#=================================================
|
||||||
|
@ -61,7 +57,7 @@ systemctl enable $app.service --quiet
|
||||||
#=================================================
|
#=================================================
|
||||||
ynh_script_progression --message="Integrating service in YunoHost..."
|
ynh_script_progression --message="Integrating service in YunoHost..."
|
||||||
|
|
||||||
yunohost service add $app
|
yunohost service add --description $app $app
|
||||||
|
|
||||||
#=================================================
|
#=================================================
|
||||||
# RESTORE THE LOGROTATE CONFIGURATION
|
# RESTORE THE LOGROTATE CONFIGURATION
|
||||||
|
|
|
@ -111,7 +111,7 @@ myynh_fix_file_permissions
|
||||||
#=================================================
|
#=================================================
|
||||||
ynh_script_progression --message="Starting systemd service '$app'..." --weight=5
|
ynh_script_progression --message="Starting systemd service '$app'..." --weight=5
|
||||||
|
|
||||||
yunohost service add $app
|
yunohost service add --description $app $app
|
||||||
ynh_systemd_action --service_name=$app --action="start" --log_path="$log_file"
|
ynh_systemd_action --service_name=$app --action="start" --log_path="$log_file"
|
||||||
|
|
||||||
#=================================================
|
#=================================================
|
||||||
|
|
Loading…
Reference in a new issue