-
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' of github.com:Xpirix/QGIS-Django into token_bas…
…ed_authentication
- Loading branch information
Showing
21 changed files
with
5,969 additions
and
39 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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -61,3 +61,4 @@ pyjwt==1.7.1 | |
djangorestframework-simplejwt==4.4 | ||
django-rest-auth==0.9.5 | ||
drf-yasg | ||
django-matomo==0.1.6 |
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 |
---|---|---|
|
@@ -56,3 +56,4 @@ django-rest-multiple-models==2.1.3 | |
|
||
django-preferences==1.0.0 | ||
PyWavefront==1.3.3 | ||
django-matomo==0.1.6 |
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,29 @@ | ||
# Generated by Django 2.2.25 on 2023-11-29 22:45 | ||
|
||
from django.conf import settings | ||
from django.db import migrations, models | ||
import django.db.models.deletion | ||
|
||
def populate_maintainer(apps, schema_editor): | ||
Plugin = apps.get_model('plugins', 'Plugin') | ||
|
||
# Set the maintainer as the plugin creator by default | ||
for obj in Plugin.objects.all(): | ||
obj.maintainer = obj.created_by | ||
obj.save() | ||
|
||
class Migration(migrations.Migration): | ||
|
||
dependencies = [ | ||
migrations.swappable_dependency(settings.AUTH_USER_MODEL), | ||
('plugins', '0004_merge_20231122_0223'), | ||
] | ||
|
||
operations = [ | ||
migrations.AddField( | ||
model_name='plugin', | ||
name='maintainer', | ||
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='plugins_maintainer', to=settings.AUTH_USER_MODEL, verbose_name='Maintainer'), | ||
), | ||
migrations.RunPython(populate_maintainer), | ||
] |
18 changes: 18 additions & 0 deletions
18
qgis-app/plugins/migrations/0006_plugin_display_created_by.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,18 @@ | ||
# Generated by Django 2.2.25 on 2023-11-29 23:22 | ||
|
||
from django.db import migrations, models | ||
|
||
|
||
class Migration(migrations.Migration): | ||
|
||
dependencies = [ | ||
('plugins', '0005_plugin_maintainer'), | ||
] | ||
|
||
operations = [ | ||
migrations.AddField( | ||
model_name='plugin', | ||
name='display_created_by', | ||
field=models.BooleanField(default=False, verbose_name='Display "Created by" in plugin details'), | ||
), | ||
] |
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
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,101 @@ | ||
import os | ||
from unittest.mock import patch | ||
|
||
from django.urls import reverse | ||
from django.test import Client, TestCase, override_settings | ||
from django.contrib.auth.models import User | ||
from django.core.files.uploadedfile import SimpleUploadedFile | ||
from plugins.models import Plugin, PluginVersion | ||
from plugins.forms import PluginForm | ||
|
||
def do_nothing(*args, **kwargs): | ||
pass | ||
|
||
TESTFILE_DIR = os.path.abspath(os.path.join(os.path.dirname(__file__), "testfiles")) | ||
|
||
class PluginRenameTestCase(TestCase): | ||
fixtures = [ | ||
"fixtures/styles.json", | ||
"fixtures/auth.json", | ||
"fixtures/simplemenu.json", | ||
] | ||
|
||
@override_settings(MEDIA_ROOT="api/tests") | ||
def setUp(self): | ||
self.client = Client() | ||
self.url_upload = reverse('plugin_upload') | ||
|
||
# Create a test user | ||
self.user = User.objects.create_user( | ||
username='testuser', | ||
password='testpassword', | ||
email='[email protected]' | ||
) | ||
|
||
# Log in the test user | ||
self.client.login(username='testuser', password='testpassword') | ||
|
||
# Upload a plugin for renaming test. | ||
# This process is already tested in test_plugin_upload | ||
valid_plugin = os.path.join(TESTFILE_DIR, "valid_plugin.zip_") | ||
with open(valid_plugin, "rb") as file: | ||
uploaded_file = SimpleUploadedFile( | ||
"valid_plugin.zip_", file.read(), | ||
content_type="application/zip") | ||
|
||
self.client.post(self.url_upload, { | ||
'package': uploaded_file, | ||
}) | ||
|
||
self.plugin = Plugin.objects.get(name='Test Plugin') | ||
self.plugin.save() | ||
|
||
@patch("plugins.tasks.generate_plugins_xml.delay", new=do_nothing) | ||
@patch("plugins.validator._check_url_link", new=do_nothing) | ||
def test_change_maintainer(self): | ||
""" | ||
Test change maintainer for plugin update | ||
""" | ||
package_name = self.plugin.package_name | ||
self.url_plugin_update = reverse('plugin_update', args=[package_name]) | ||
self.url_add_version = reverse('version_create', args=[package_name]) | ||
|
||
# Test GET request | ||
response = self.client.get(self.url_plugin_update) | ||
self.assertEqual(response.status_code, 200) | ||
self.assertIsInstance(response.context['form'], PluginForm) | ||
self.assertEqual(response.context['form']['maintainer'].value(), self.user.pk) | ||
|
||
|
||
# Test POST request to change maintainer | ||
|
||
response = self.client.post(self.url_plugin_update, { | ||
'description': self.plugin.description, | ||
'about': self.plugin.about, | ||
'author': self.plugin.author, | ||
'email': self.plugin.email, | ||
'tracker': self.plugin.tracker, | ||
'repository': self.plugin.repository, | ||
'maintainer': 1, | ||
}) | ||
self.assertEqual(response.status_code, 302) | ||
self.assertEqual(Plugin.objects.get(name='Test Plugin').maintainer.pk, 1) | ||
|
||
# Test POST request with new version | ||
|
||
valid_plugin = os.path.join(TESTFILE_DIR, "valid_plugin_0.0.2.zip_") | ||
with open(valid_plugin, "rb") as file: | ||
uploaded_file = SimpleUploadedFile( | ||
"valid_plugin_0.0.2.zip_", file.read(), | ||
content_type="application/zip_") | ||
|
||
response = self.client.post(self.url_add_version, { | ||
'package': uploaded_file, | ||
'experimental': False, | ||
'changelog': '' | ||
}) | ||
self.assertEqual(response.status_code, 302) | ||
self.assertEqual(Plugin.objects.get(name='Test Plugin').maintainer.pk, 1) | ||
|
||
def tearDown(self): | ||
self.client.logout() |
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 |
---|---|---|
@@ -0,0 +1,40 @@ | ||
// Replace the date with local timezone | ||
|
||
$(".user-timezone").each(function (i) { | ||
let localDate = toUserTimeZone($(this).text()); | ||
$(this).text(localDate); | ||
}) | ||
|
||
$(".user-timezone-short").each(function (i) { | ||
let localDate = toUserTimeZone($(this).text(), withTime=false); | ||
$(this).text(localDate); | ||
}) | ||
|
||
$(".user-timezone-short-naturalday").each(function (i) { | ||
let localDate = toUserTimeZone($(this).text(), withTime=false, isNaturalDay=true); | ||
$(this).text(localDate); | ||
}) | ||
|
||
function toUserTimeZone(date, withTime=true, isNaturalDay=false) { | ||
try { | ||
date = new Date(date); | ||
let options = { | ||
year: 'numeric', month: 'short', day: 'numeric' | ||
} | ||
if (withTime) { | ||
options['hour'] = '2-digit' | ||
options['minute'] = '2-digit' | ||
options['timeZoneName'] = 'short' | ||
} | ||
const diffInDays = moment().diff(moment(date), 'days'); | ||
|
||
if (diffInDays <= 1 && isNaturalDay) { | ||
const distance = moment(date).fromNow(); | ||
return distance | ||
} | ||
return date.toLocaleDateString([], options); | ||
} catch (e) { | ||
return date; | ||
} | ||
} | ||
|
Oops, something went wrong.