mirror of
				https://gitlab.crans.org/bde/nk20
				synced 2025-10-20 20:19:38 +02:00 
			
		
		
		
	Compare commits
	
		
			17 Commits
		
	
	
		
			food_bugs
			...
			7d6bc364f8
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 7d6bc364f8 | ||
|  | cf4c23d1ac | ||
|  | d71105976f | ||
|  | 89cc03141b | ||
|  | ff812a028c | ||
|  | 5a8acbde00 | ||
|  | f60dc8cfa0 | ||
|  | 067dd6f9d1 | ||
|  | 7b1e32e514 | ||
|  | e88dbfd597 | ||
|  | 3d34270959 | ||
|  | 3bb99671ec | ||
|  | 0d69383dfd | ||
|  | 7b9ff119e8 | ||
|  | 9643d7652b | ||
|  | dde1baa25c | ||
|  | 7a7ee47e0b | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -48,7 +48,6 @@ backups/ | ||||
| env/ | ||||
| venv/ | ||||
| db.sqlite3 | ||||
| shell.nix | ||||
|  | ||||
| # ansibles customs host | ||||
| ansible/host_vars/*.yaml | ||||
|   | ||||
| @@ -63,7 +63,8 @@ class FoodListView(ProtectQuerysetMixin, LoginRequiredMixin, MultiTableMixin, Li | ||||
|             valid_regex = is_regex(pattern) | ||||
|             suffix = '__iregex' if valid_regex else '__istartswith' | ||||
|             prefix = '^' if valid_regex else '' | ||||
|             qs = qs.filter(Q(**{f'name{suffix}': prefix + pattern})) | ||||
|             qs = qs.filter(Q(**{f'name{suffix}': prefix + pattern}) | ||||
|                            | Q(**{f'owner__name{suffix}': prefix + pattern})) | ||||
|         else: | ||||
|             qs = qs.none() | ||||
|         search_table = qs.filter(PermissionBackend.filter_queryset(self.request, Food, 'view')) | ||||
| @@ -263,7 +264,7 @@ class TransformedFoodCreateView(ProtectQuerysetMixin, ProtectedCreateView): | ||||
|         return reverse_lazy('food:transformedfood_view', kwargs={"pk": self.object.pk}) | ||||
|  | ||||
|  | ||||
| MAX_FORMS = 10 | ||||
| MAX_FORMS = 100 | ||||
|  | ||||
|  | ||||
| class ManageIngredientsView(LoginRequiredMixin, UpdateView): | ||||
|   | ||||
							
								
								
									
										46
									
								
								apps/member/migrations/0014_create_bda.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								apps/member/migrations/0014_create_bda.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,46 @@ | ||||
| from django.db import migrations | ||||
|  | ||||
| def create_bda(apps, schema_editor): | ||||
|     """ | ||||
|     The club BDA is now pre-injected. | ||||
|     """ | ||||
|     Club = apps.get_model("member", "club") | ||||
|     NoteClub = apps.get_model("note", "noteclub") | ||||
|     Alias = apps.get_model("note", "alias") | ||||
|     ContentType = apps.get_model('contenttypes', 'ContentType') | ||||
|     polymorphic_ctype_id = ContentType.objects.get_for_model(NoteClub).id | ||||
|      | ||||
|     Club.objects.get_or_create( | ||||
|         id=10, | ||||
|         name="BDA", | ||||
|         email="bda.ensparissaclay@gmail.com", | ||||
|         require_memberships=True, | ||||
|         membership_fee_paid=750, | ||||
|         membership_fee_unpaid=750, | ||||
|         membership_duration=396, | ||||
|         membership_start="2024-08-01", | ||||
|         membership_end="2025-09-30", | ||||
|     ) | ||||
|     NoteClub.objects.get_or_create( | ||||
|         id=1937, | ||||
|         club_id=10, | ||||
|         polymorphic_ctype_id=polymorphic_ctype_id, | ||||
|     ) | ||||
|     Alias.objects.get_or_create( | ||||
|         id=1937, | ||||
|         note_id=1937, | ||||
|         name="BDA", | ||||
|         normalized_name="bda", | ||||
|     ) | ||||
|  | ||||
|  | ||||
| class Migration(migrations.Migration): | ||||
|  | ||||
|     dependencies = [ | ||||
|         ('member', '0013_auto_20240801_1436'), | ||||
|     ] | ||||
|      | ||||
|     operations = [ | ||||
|         migrations.RunPython(create_bda), | ||||
|     ] | ||||
|  | ||||
| @@ -4091,8 +4091,8 @@ | ||||
|                 158, | ||||
|                 159, | ||||
|                 160, | ||||
| 		212, | ||||
| 		222 | ||||
|                 212, | ||||
|                 222 | ||||
|             ] | ||||
|         } | ||||
|     }, | ||||
| @@ -4133,14 +4133,14 @@ | ||||
|                 50, | ||||
|                 141, | ||||
|                 169, | ||||
| 		217, | ||||
| 		218, | ||||
| 		219, | ||||
| 		220, | ||||
| 		221, | ||||
| 		247, | ||||
| 		258, | ||||
| 		259 | ||||
|                 217, | ||||
|                 218, | ||||
|                 219, | ||||
|                 220, | ||||
|                 221, | ||||
|                 247, | ||||
|                 258, | ||||
|                 259 | ||||
|             ] | ||||
|         } | ||||
|     }, | ||||
| @@ -4152,8 +4152,8 @@ | ||||
|             "name": "Pr\u00e9sident\u22c5e de club", | ||||
|             "permissions": [ | ||||
|                 62, | ||||
|                 142, | ||||
|                 135 | ||||
|                 135, | ||||
|                 142 | ||||
|             ] | ||||
|         } | ||||
|     }, | ||||
| @@ -4538,8 +4538,8 @@ | ||||
|             "name": "GC anti-VSS", | ||||
|             "permissions": [ | ||||
|                 42, | ||||
| 		135, | ||||
| 		150, | ||||
|                 135, | ||||
|                 150, | ||||
|                 163, | ||||
|                 164 | ||||
|             ] | ||||
| @@ -4555,10 +4555,137 @@ | ||||
|                 137, | ||||
|                 211, | ||||
|                 212, | ||||
| 		213, | ||||
| 		214, | ||||
| 		215, | ||||
| 		216 | ||||
|                 213, | ||||
|                 214, | ||||
|                 215, | ||||
|                 216 | ||||
|             ] | ||||
|         } | ||||
|     },   | ||||
|     { | ||||
|         "model": "permission.role", | ||||
|         "pk": 23, | ||||
|             "fields": { | ||||
|             "for_club": 2, | ||||
|             "name": "Darbonne", | ||||
|             "permissions": [ | ||||
|                 30, | ||||
|                 31, | ||||
|                 32 | ||||
|             ] | ||||
|         } | ||||
|     },  | ||||
|     { | ||||
|         "model": "permission.role", | ||||
|         "pk": 24, | ||||
|             "fields": { | ||||
|             "for_club": null, | ||||
|             "name": "Staffeur⋅euse (S&L,Respo Tech,...)", | ||||
|             "permissions": [] | ||||
|         } | ||||
|     },  | ||||
|     { | ||||
|         "model": "permission.role", | ||||
|         "pk": 25, | ||||
|             "fields": { | ||||
|             "for_club": null, | ||||
|             "name": "Référent⋅e Bus", | ||||
|             "permissions": [ | ||||
|                 22, | ||||
|                 84, | ||||
|                 115, | ||||
|                 117, | ||||
|                 118, | ||||
|                 119, | ||||
|                 120, | ||||
|                 121, | ||||
|                 122 | ||||
|             ] | ||||
|         } | ||||
|     },  | ||||
|     { | ||||
|         "model": "permission.role", | ||||
|         "pk": 28, | ||||
|             "fields": { | ||||
|             "for_club": 10, | ||||
|             "name": "Trésorièr⸱e BDA", | ||||
|             "permissions": [ | ||||
|                 55, | ||||
|                 56, | ||||
|                 57, | ||||
|                 58, | ||||
|                 135, | ||||
|                 143, | ||||
|                 176, | ||||
|                 177, | ||||
|                 178, | ||||
|                 243, | ||||
|                 260, | ||||
|                 261, | ||||
|                 262, | ||||
|                 263, | ||||
|                 264, | ||||
|                 265, | ||||
|                 266, | ||||
|                 267, | ||||
|                 268, | ||||
|                 269 | ||||
|             ] | ||||
|         } | ||||
|     },  | ||||
|     { | ||||
|         "model": "permission.role", | ||||
|         "pk": 30, | ||||
|             "fields": { | ||||
|             "for_club": 10, | ||||
|             "name": "Respo sorties", | ||||
|             "permissions": [ | ||||
|                 49,  | ||||
|                 62,  | ||||
|                 141,  | ||||
|                 241,  | ||||
|                 242,  | ||||
|                 243 | ||||
|             ] | ||||
|         } | ||||
|     },  | ||||
|     { | ||||
|         "model": "permission.role", | ||||
|         "pk": 31, | ||||
|             "fields": { | ||||
|             "for_club": 1, | ||||
|             "name": "Respo comm", | ||||
|             "permissions": [ | ||||
|                 135, | ||||
|                 244 | ||||
|             ] | ||||
|         } | ||||
|     },  | ||||
|     { | ||||
|         "model": "permission.role", | ||||
|         "pk": 32, | ||||
|             "fields": { | ||||
|             "for_club": 10, | ||||
|             "name": "Respo comm Art", | ||||
|             "permissions": [ | ||||
|                 135, | ||||
|                 245 | ||||
|             ] | ||||
|         } | ||||
|     },  | ||||
|     { | ||||
|         "model": "permission.role", | ||||
|         "pk": 33, | ||||
|             "fields": { | ||||
|             "for_club": 10, | ||||
|             "name": "Respo Jam", | ||||
|             "permissions": [ | ||||
|                 247,  | ||||
|                 250,  | ||||
|                 251,  | ||||
|                 252,  | ||||
|                 253,  | ||||
|                 254 | ||||
|             ] | ||||
|         } | ||||
|     },  | ||||
| @@ -4596,5 +4723,15 @@ | ||||
|         "model": "wei.weirole", | ||||
|         "pk": 18, | ||||
|         "fields": {} | ||||
|     }, | ||||
|     { | ||||
|         "model": "wei.weirole", | ||||
|         "pk": 24, | ||||
|         "fields": {} | ||||
|     }, | ||||
|     { | ||||
|         "model": "wei.weirole", | ||||
|         "pk": 25, | ||||
|         "fields": {} | ||||
|     } | ||||
| ] | ||||
|   | ||||
| @@ -3,6 +3,7 @@ | ||||
| from oauth2_provider.oauth2_validators import OAuth2Validator | ||||
| from oauth2_provider.scopes import BaseScopes | ||||
| from member.models import Club | ||||
| from note.models import Alias | ||||
| from note_kfet.middlewares import get_current_request | ||||
|  | ||||
| from .backends import PermissionBackend | ||||
| @@ -35,7 +36,18 @@ class PermissionScopes(BaseScopes): | ||||
|  | ||||
|  | ||||
| class PermissionOAuth2Validator(OAuth2Validator): | ||||
|     oidc_claim_scope = None  # fix breaking change of django-oauth-toolkit 2.0.0 | ||||
|     oidc_claim_scope = OAuth2Validator.oidc_claim_scope | ||||
|     oidc_claim_scope.update({"name": 'openid', | ||||
|                              "normalized_name": 'openid', | ||||
|                              "email": 'openid', | ||||
|                              }) | ||||
|  | ||||
|     def get_additional_claims(self, request): | ||||
|         return { | ||||
|             "name": request.user.username, | ||||
|             "normalized_name": Alias.normalize(request.user.username), | ||||
|             "email": request.user.email, | ||||
|         } | ||||
|  | ||||
|     def validate_scopes(self, client_id, scopes, client, request, *args, **kwargs): | ||||
|         """ | ||||
|   | ||||
							
								
								
									
										34
									
								
								shell-static.nix
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										34
									
								
								shell-static.nix
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| # This is a workaround meant for use with the nix package manager. If you don't know what it is or don't use it, please ignore this file. | ||||
| #  | ||||
| # The nk20 javascript static location are hardcoded for imperative system. | ||||
| # This make ./manage.py collectstatic hard to use with nixos. | ||||
| #  | ||||
| # A workaround is to enter a FHSUserEnv with the static placed under /share/javascript/<static>. | ||||
| # This emulate a debian like system and enable collecting static normally with ./manage.py collectstatics. | ||||
| # The regular shell.nix should be enough for other configurations. | ||||
| # | ||||
| # Warning, you are still supposed to use pip package with a venv ! | ||||
| { pkgs ? import <nixpkgs> {} }: | ||||
| (pkgs.buildFHSUserEnv { | ||||
|   name = "pipzone"; | ||||
|   targetPkgs = pkgs: (with pkgs; | ||||
|   let | ||||
|     fhs-static = stdenv.mkDerivation { | ||||
|       name = "fhs-static"; | ||||
|       buildCommand = '' | ||||
|       mkdir -p $out/share/javascript/bootstrap4 | ||||
|       mkdir -p $out/share/javascript/jquery | ||||
|       ln -s ${python39Packages.xstatic-bootstrap}/lib/python3.9/site-packages/xstatic/pkg/bootstrap/data/* $out/share/javascript/bootstrap4 | ||||
|       ln -s ${python39Packages.xstatic-jquery}/lib/python3.9/site-packages/xstatic/pkg/jquery/data/* $out/share/javascript/jquery | ||||
|     ''; | ||||
|     }; | ||||
|   in [ | ||||
|     fhs-static | ||||
|     python39 | ||||
|     gettext | ||||
|     python39Packages.pip | ||||
|     python39Packages.virtualenv | ||||
|     python39Packages.setuptools | ||||
|   ]); | ||||
|   runScript = "bash"; | ||||
| }).env | ||||
							
								
								
									
										23
									
								
								shell.nix
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										23
									
								
								shell.nix
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| # This is meant for use with the nix package manager. If you don't know what it is or don't use it, please ignore this file. | ||||
| # | ||||
| # This shell.nix contains all dependencies require to create a venv and pip install -r requirements.txt. | ||||
| # | ||||
| # Please check shell-static.nix for running ./manage.py collectstatics. | ||||
| { pkgs ? import <nixpkgs> {} }: | ||||
| pkgs.mkShell { | ||||
|   buildInputs = with pkgs; [ | ||||
|     python39 | ||||
|     python39Packages.pip | ||||
|     python39Packages.setuptools | ||||
|     gettext | ||||
|  | ||||
|   ]; | ||||
|   shellHook = '' | ||||
|     # Tells pip to put packages into $PIP_PREFIX instead of the usual locations. | ||||
|     # See https://pip.pypa.io/en/stable/user_guide/#environment-variables. | ||||
|     export PIP_PREFIX=$(pwd)/_build/pip_packages | ||||
|     export PYTHONPATH="$PIP_PREFIX/${pkgs.python39.sitePackages}:$PYTHONPATH" | ||||
|     export PATH="$PIP_PREFIX/bin:$PATH" | ||||
|     unset SOURCE_DATE_EPOCH | ||||
|   ''; | ||||
| } | ||||
		Reference in New Issue
	
	Block a user