-
Notifications
You must be signed in to change notification settings - Fork 61
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into update_django
- Loading branch information
Showing
55 changed files
with
7,532 additions
and
117 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
version: '3' | ||
version: '3.8' | ||
volumes: | ||
backups-data: | ||
static-data: | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -12,7 +12,7 @@ | |
"last_login": "2010-11-24 07:56:12", | ||
"groups": [], | ||
"user_permissions": [], | ||
"password": "sha1$d6c11$4f3f04e104dc8bbe7950234f0cd8406a65df0bdf", | ||
"password": "pbkdf2_sha256$150000$foQAQGi54z25$AQelhq+oBE3TOBJRT9F9UsEP5K1PSWQnQeozkmyc3fs=", | ||
"email": "", | ||
"date_joined": "2010-11-24 07:56:12" | ||
} | ||
|
@@ -30,7 +30,7 @@ | |
"last_login": "2010-11-25 07:35:07", | ||
"groups": [], | ||
"user_permissions": [], | ||
"password": "sha1$9ba9f$6088ef8abc2243a55e777e937159c8f2fd4920bb", | ||
"password": "pbkdf2_sha256$150000$BBba4NloaWZO$XN4lzpxcvFSrLl1QqiwQz/0ZLiEH/JTgEJE/uRRXWto=", | ||
"email": "[email protected]", | ||
"date_joined": "2009-10-06 18:04:20" | ||
} | ||
|
@@ -48,7 +48,7 @@ | |
"last_login": "2010-11-25 07:35:20", | ||
"groups": [], | ||
"user_permissions": [], | ||
"password": "sha1$cb97a$221727796b3f551e342dca9d00112f072e399182", | ||
"password": "pbkdf2_sha256$150000$GJga5YEinaWz$zJAjCXccvWHNPGmoZEjvBNgm1DGkjZGA3BmTVaNAxP4=", | ||
"email": "", | ||
"date_joined": "2010-11-25 07:35:20" | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
from functools import wraps | ||
from django.http import HttpResponseForbidden | ||
from rest_framework_simplejwt.authentication import JWTAuthentication | ||
from plugins.models import Plugin, PluginOutstandingToken | ||
from rest_framework_simplejwt.exceptions import InvalidToken, TokenError | ||
from rest_framework_simplejwt.token_blacklist.models import BlacklistedToken, OutstandingToken | ||
import datetime | ||
|
||
def has_valid_token(function): | ||
@wraps(function) | ||
def wrap(request, *args, **kwargs): | ||
auth_token = request.META.get("HTTP_AUTHORIZATION") | ||
package_name = kwargs.get('package_name') | ||
if not str(auth_token).startswith('Bearer'): | ||
raise InvalidToken("Invalid token") | ||
|
||
# Validate JWT token | ||
authentication = JWTAuthentication() | ||
try: | ||
validated_token = authentication.get_validated_token(auth_token[7:]) | ||
plugin_id = validated_token.payload.get('plugin_id') | ||
jti = validated_token.payload.get('refresh_jti') | ||
token_id = OutstandingToken.objects.get(jti=jti).pk | ||
is_blacklisted = BlacklistedToken.objects.filter(token_id=token_id).exists() | ||
if not plugin_id or is_blacklisted: | ||
raise InvalidToken("Invalid token") | ||
|
||
plugin = Plugin.objects.get(pk=plugin_id) | ||
if not plugin or plugin.package_name != package_name: | ||
raise InvalidToken("Invalid token") | ||
plugin_token = PluginOutstandingToken.objects.get(token__pk=token_id, plugin=plugin) | ||
plugin_token.last_used_on = datetime.datetime.now() | ||
plugin_token.save() | ||
request.plugin_token = plugin_token | ||
return function(request, *args, **kwargs) | ||
except (InvalidToken, TokenError) as e: | ||
return HttpResponseForbidden(str(e)) | ||
|
||
return wrap |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
import os | ||
from shutil import rmtree | ||
from django.conf import settings | ||
from django.core.management import call_command | ||
from django.core.management.base import BaseCommand | ||
|
||
class Command(BaseCommand): | ||
help = 'Run collectstatic and delete folders from media that exist in static' | ||
|
||
def handle(self, *args, **options): | ||
confirm = input("Do you want to run 'collectstatic' first? (yes/no): ") | ||
if confirm.lower() == 'yes': | ||
# Run collectstatic command | ||
call_command('collectstatic', interactive=False) | ||
|
||
# Get the paths of static and media folders | ||
static_root = settings.STATIC_ROOT | ||
media_root = settings.MEDIA_ROOT | ||
|
||
# Iterate over each directory in the static folder | ||
for static_dir in os.listdir(static_root): | ||
static_path = os.path.join(static_root, static_dir) | ||
|
||
# Check if the path is a directory and exists in the media folder | ||
if os.path.isdir(static_path) and os.path.exists(os.path.join(media_root, static_dir)): | ||
confirm = input(f"Are you sure you want to delete '{static_dir}' from the media folder? (yes/no): ") | ||
|
||
if confirm.lower() == 'yes': | ||
try: | ||
# Delete the corresponding folder in the media folder | ||
rmtree(os.path.join(media_root, static_dir)) | ||
self.stdout.write(self.style.SUCCESS(f'Deleted {static_dir} from media folder.')) | ||
except Exception as e: | ||
self.stderr.write(self.style.ERROR(f'Error deleting {static_dir}: {str(e)}')) | ||
else: | ||
self.stdout.write(self.style.WARNING(f'Skipped deletion of {static_dir}.')) | ||
|
||
self.stdout.write(self.style.SUCCESS('The media folder has been cleaned.')) |
40 changes: 40 additions & 0 deletions
40
qgis-app/plugins/management/commands/organize_old_package.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
# myapp/management/commands/organize_packages.py | ||
import os | ||
import shutil | ||
from django.core.management.base import BaseCommand | ||
from django.conf import settings | ||
from plugins.models import PluginVersion | ||
|
||
PLUGINS_STORAGE_PATH = getattr(settings, "PLUGINS_STORAGE_PATH", "packages") | ||
class Command(BaseCommand): | ||
help = 'Organize packages created before 2014 into folders by year' | ||
|
||
def handle(self, *args, **options): | ||
packages_dir = os.path.join(settings.MEDIA_ROOT, PLUGINS_STORAGE_PATH) | ||
|
||
# Some of the packages created on 2014 also need to be organized | ||
versions = PluginVersion.objects.filter(created_on__lt='2014-12-31').exclude(package__icontains='2014/') | ||
self.stdout.write(self.style.NOTICE(f'{versions.count()} packages will be organized.')) | ||
|
||
for version in versions: | ||
year_folder = os.path.join(packages_dir, str(version.created_on.year)) | ||
|
||
# Create the year folder if it doesn't exist | ||
os.makedirs(year_folder, exist_ok=True) | ||
|
||
# Copy the package file to the year folder | ||
old_path = version.package.path | ||
if os.path.exists(old_path): | ||
new_path = os.path.join(year_folder, os.path.basename(old_path)) | ||
if not os.path.exists(new_path): | ||
shutil.copy(old_path, year_folder) | ||
|
||
# Update the model with the new package path | ||
version.package.name = os.path.relpath(new_path, settings.MEDIA_ROOT) | ||
version.save() | ||
else: | ||
self.stdout.write(self.style.WARNING(f'Plugin version id {version.pk} ignored: {new_path} already exists.')) | ||
else: | ||
self.stdout.write(self.style.WARNING(f'Plugin version id {version.pk} ignored: {old_path} is not found.')) | ||
|
||
self.stdout.write(self.style.SUCCESS('Packages organized successfully')) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
# Generated by Django 2.2.25 on 2023-11-30 05:13 | ||
|
||
from django.db import migrations | ||
|
||
|
||
class Migration(migrations.Migration): | ||
|
||
dependencies = [ | ||
('plugins', '0002_plugins_feedback'), | ||
('plugins', '0003_plugin_allow_update_name'), | ||
] | ||
|
||
operations = [ | ||
] |
Oops, something went wrong.