Merge branch 'origin/feature/migration' into origin/feature/migrate-etablishment
# Conflicts: # apps/transfer/management/commands/transfer.py
This commit is contained in:
commit
490fae3c00
24
apps/account/migrations/0016_auto_20191024_0833.py
Normal file
24
apps/account/migrations/0016_auto_20191024_0833.py
Normal file
|
|
@ -0,0 +1,24 @@
|
||||||
|
# Generated by Django 2.2.4 on 2019-10-24 08:33
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
import django.db.models.deletion
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('account', '0015_merge_20191023_1317'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='role',
|
||||||
|
name='role',
|
||||||
|
field=models.PositiveIntegerField(choices=[(1, 'Standard user'), (2, 'Comments moderator'), (3, 'Country admin'), (4, 'Content page manager'), (5, 'Establishment manager'), (6, 'Reviewer manager'), (7, 'Restaurant reviewer')], verbose_name='Role'),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='userrole',
|
||||||
|
name='establishment',
|
||||||
|
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='establishment.Establishment', verbose_name='Establishment'),
|
||||||
|
),
|
||||||
|
]
|
||||||
14
apps/account/migrations/0017_merge_20191024_1233.py
Normal file
14
apps/account/migrations/0017_merge_20191024_1233.py
Normal file
|
|
@ -0,0 +1,14 @@
|
||||||
|
# Generated by Django 2.2.4 on 2019-10-24 12:33
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('account', '0016_auto_20191024_0830'),
|
||||||
|
('account', '0016_auto_20191024_0833'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
]
|
||||||
18
apps/advertisement/migrations/0004_auto_20191025_0903.py
Normal file
18
apps/advertisement/migrations/0004_auto_20191025_0903.py
Normal file
|
|
@ -0,0 +1,18 @@
|
||||||
|
# Generated by Django 2.2.4 on 2019-10-25 09:03
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('advertisement', '0003_auto_20190919_1344'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='advertisement',
|
||||||
|
name='block_level',
|
||||||
|
field=models.CharField(blank=True, max_length=10, null=True, verbose_name='Block level'),
|
||||||
|
),
|
||||||
|
]
|
||||||
|
|
@ -15,7 +15,7 @@ class Advertisement(ImageMixin, ProjectBaseMixin, PlatformMixin):
|
||||||
url = models.URLField(verbose_name=_('Ad URL'))
|
url = models.URLField(verbose_name=_('Ad URL'))
|
||||||
width = models.PositiveIntegerField(verbose_name=_('Block width'))
|
width = models.PositiveIntegerField(verbose_name=_('Block width'))
|
||||||
height = models.PositiveIntegerField(verbose_name=_('Block height'))
|
height = models.PositiveIntegerField(verbose_name=_('Block height'))
|
||||||
block_level = models.CharField(verbose_name=_('Block level'), max_length=10)
|
block_level = models.CharField(verbose_name=_('Block level'), max_length=10, blank=True, null=True)
|
||||||
target_languages = models.ManyToManyField(Language)
|
target_languages = models.ManyToManyField(Language)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
|
||||||
20
apps/advertisement/transfer_data.py
Normal file
20
apps/advertisement/transfer_data.py
Normal file
|
|
@ -0,0 +1,20 @@
|
||||||
|
from pprint import pprint
|
||||||
|
from django.db.models import Value, IntegerField, F
|
||||||
|
from transfer.models import Ads
|
||||||
|
from transfer.serializers.advertisement import AdvertisementSerializer
|
||||||
|
|
||||||
|
|
||||||
|
def transfer_advertisement():
|
||||||
|
queryset = Ads.objects.filter(href__isnull=False)
|
||||||
|
|
||||||
|
serialized_data = AdvertisementSerializer(data=list(queryset.values()), many=True)
|
||||||
|
|
||||||
|
if serialized_data.is_valid():
|
||||||
|
serialized_data.save()
|
||||||
|
else:
|
||||||
|
pprint(f"News serializer errors: {serialized_data.errors}")
|
||||||
|
|
||||||
|
|
||||||
|
data_types = {
|
||||||
|
"commercial": [transfer_advertisement]
|
||||||
|
}
|
||||||
19
apps/collection/migrations/0016_auto_20191024_1334.py
Normal file
19
apps/collection/migrations/0016_auto_20191024_1334.py
Normal file
|
|
@ -0,0 +1,19 @@
|
||||||
|
# Generated by Django 2.2.4 on 2019-10-24 13:34
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
import django.db.models.deletion
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('collection', '0015_auto_20191023_0715'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='guide',
|
||||||
|
name='collection',
|
||||||
|
field=models.ForeignKey(blank=True, default=None, null=True, on_delete=django.db.models.deletion.CASCADE, to='collection.Collection', verbose_name='collection'),
|
||||||
|
),
|
||||||
|
]
|
||||||
|
|
@ -101,8 +101,9 @@ class Guide(ProjectBaseMixin, CollectionNameMixin, CollectionDateMixin):
|
||||||
advertorials = JSONField(
|
advertorials = JSONField(
|
||||||
_('advertorials'), null=True, blank=True,
|
_('advertorials'), null=True, blank=True,
|
||||||
default=None, help_text='{"key":"value"}')
|
default=None, help_text='{"key":"value"}')
|
||||||
collection = models.ForeignKey(
|
collection = models.ForeignKey(Collection, on_delete=models.CASCADE,
|
||||||
Collection, verbose_name=_('collection'), on_delete=models.CASCADE)
|
null=True, blank=True, default=None,
|
||||||
|
verbose_name=_('collection'))
|
||||||
|
|
||||||
objects = GuideQuerySet.as_manager()
|
objects = GuideQuerySet.as_manager()
|
||||||
|
|
||||||
|
|
|
||||||
20
apps/establishment/migrations/0043_establishment_currency.py
Normal file
20
apps/establishment/migrations/0043_establishment_currency.py
Normal file
|
|
@ -0,0 +1,20 @@
|
||||||
|
# Generated by Django 2.2.4 on 2019-10-24 13:13
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
import django.db.models.deletion
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('main', '0022_auto_20191023_1113'),
|
||||||
|
('establishment', '0042_establishment_tz'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='establishment',
|
||||||
|
name='currency',
|
||||||
|
field=models.ForeignKey(blank=True, default=None, null=True, on_delete=django.db.models.deletion.PROTECT, to='main.Currency', verbose_name='currency'),
|
||||||
|
),
|
||||||
|
]
|
||||||
|
|
@ -17,7 +17,7 @@ from phonenumber_field.modelfields import PhoneNumberField
|
||||||
|
|
||||||
from collection.models import Collection
|
from collection.models import Collection
|
||||||
from location.models import Address
|
from location.models import Address
|
||||||
from main.models import Award
|
from main.models import Award, Currency
|
||||||
from review.models import Review
|
from review.models import Review
|
||||||
from utils.models import (ProjectBaseMixin, TJSONField, URLImageMixin,
|
from utils.models import (ProjectBaseMixin, TJSONField, URLImageMixin,
|
||||||
TranslatedFieldsMixin, BaseAttributes)
|
TranslatedFieldsMixin, BaseAttributes)
|
||||||
|
|
@ -362,6 +362,9 @@ class Establishment(ProjectBaseMixin, URLImageMixin, TranslatedFieldsMixin):
|
||||||
reviews = generic.GenericRelation(to='review.Review')
|
reviews = generic.GenericRelation(to='review.Review')
|
||||||
comments = generic.GenericRelation(to='comment.Comment')
|
comments = generic.GenericRelation(to='comment.Comment')
|
||||||
favorites = generic.GenericRelation(to='favorites.Favorites')
|
favorites = generic.GenericRelation(to='favorites.Favorites')
|
||||||
|
currency = models.ForeignKey(Currency, blank=True, null=True, default=None,
|
||||||
|
on_delete=models.PROTECT,
|
||||||
|
verbose_name=_('currency'))
|
||||||
|
|
||||||
objects = EstablishmentQuerySet.as_manager()
|
objects = EstablishmentQuerySet.as_manager()
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -7,6 +7,7 @@ from establishment.serializers import (
|
||||||
EstablishmentTypeBaseSerializer)
|
EstablishmentTypeBaseSerializer)
|
||||||
from main.models import Currency
|
from main.models import Currency
|
||||||
from utils.decorators import with_base_attributes
|
from utils.decorators import with_base_attributes
|
||||||
|
from utils.serializers import TimeZoneChoiceField
|
||||||
|
|
||||||
|
|
||||||
class EstablishmentListCreateSerializer(EstablishmentBaseSerializer):
|
class EstablishmentListCreateSerializer(EstablishmentBaseSerializer):
|
||||||
|
|
@ -19,8 +20,8 @@ class EstablishmentListCreateSerializer(EstablishmentBaseSerializer):
|
||||||
phones = ContactPhonesSerializer(read_only=True, many=True, )
|
phones = ContactPhonesSerializer(read_only=True, many=True, )
|
||||||
emails = ContactEmailsSerializer(read_only=True, many=True, )
|
emails = ContactEmailsSerializer(read_only=True, many=True, )
|
||||||
socials = SocialNetworkRelatedSerializers(read_only=True, many=True, )
|
socials = SocialNetworkRelatedSerializers(read_only=True, many=True, )
|
||||||
slug = serializers.SlugField(required=True, allow_blank=False, max_length=50)
|
|
||||||
type = EstablishmentTypeBaseSerializer(source='establishment_type', read_only=True)
|
type = EstablishmentTypeBaseSerializer(source='establishment_type', read_only=True)
|
||||||
|
tz = TimeZoneChoiceField()
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.Establishment
|
model = models.Establishment
|
||||||
|
|
|
||||||
|
|
@ -159,10 +159,10 @@ class EstablishmentBaseSerializer(ProjectModelSerializer):
|
||||||
"""Base serializer for Establishment model."""
|
"""Base serializer for Establishment model."""
|
||||||
|
|
||||||
preview_image = serializers.URLField(source='preview_image_url')
|
preview_image = serializers.URLField(source='preview_image_url')
|
||||||
slug = serializers.SlugField(allow_blank=False, required=True, max_length=50)
|
|
||||||
address = AddressBaseSerializer()
|
address = AddressBaseSerializer()
|
||||||
in_favorites = serializers.BooleanField(allow_null=True)
|
in_favorites = serializers.BooleanField(allow_null=True)
|
||||||
tags = TagBaseSerializer(read_only=True, many=True)
|
tags = TagBaseSerializer(read_only=True, many=True)
|
||||||
|
currency = CurrencySerializer()
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
"""Meta class."""
|
"""Meta class."""
|
||||||
|
|
@ -180,6 +180,7 @@ class EstablishmentBaseSerializer(ProjectModelSerializer):
|
||||||
'in_favorites',
|
'in_favorites',
|
||||||
'address',
|
'address',
|
||||||
'tags',
|
'tags',
|
||||||
|
'currency'
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -9,6 +9,7 @@ from establishment.models import Establishment, EstablishmentType, Menu
|
||||||
from translation.models import Language
|
from translation.models import Language
|
||||||
from account.models import Role, UserRole
|
from account.models import Role, UserRole
|
||||||
from location.models import Country, Address, City, Region
|
from location.models import Country, Address, City, Region
|
||||||
|
from pytz import timezone as py_tz
|
||||||
|
|
||||||
|
|
||||||
class BaseTestCase(APITestCase):
|
class BaseTestCase(APITestCase):
|
||||||
|
|
@ -77,7 +78,8 @@ class EstablishmentBTests(BaseTestCase):
|
||||||
'name': 'Test establishment',
|
'name': 'Test establishment',
|
||||||
'type_id': self.establishment_type.id,
|
'type_id': self.establishment_type.id,
|
||||||
'is_publish': True,
|
'is_publish': True,
|
||||||
'slug': 'test-establishment-slug'
|
'slug': 'test-establishment-slug',
|
||||||
|
'tz': py_tz('Europe/Moscow').zone
|
||||||
}
|
}
|
||||||
|
|
||||||
response = self.client.post('/api/back/establishments/', data=data, format='json')
|
response = self.client.post('/api/back/establishments/', data=data, format='json')
|
||||||
|
|
|
||||||
|
|
@ -1,14 +1,16 @@
|
||||||
# Create your tests here.
|
# Create your tests here.
|
||||||
from http.cookies import SimpleCookie
|
from http.cookies import SimpleCookie
|
||||||
from django.contrib.contenttypes.models import ContentType
|
|
||||||
|
|
||||||
from rest_framework.test import APITestCase
|
from django.contrib.contenttypes.models import ContentType
|
||||||
|
from django.urls import reverse
|
||||||
from rest_framework import status
|
from rest_framework import status
|
||||||
|
from rest_framework.test import APITestCase
|
||||||
|
|
||||||
from account.models import User
|
from account.models import User
|
||||||
|
from establishment.models import Establishment, EstablishmentType
|
||||||
from favorites.models import Favorites
|
from favorites.models import Favorites
|
||||||
from establishment.models import Establishment, EstablishmentType, EstablishmentSubType
|
|
||||||
from news.models import NewsType, News
|
from news.models import NewsType, News
|
||||||
|
from datetime import datetime
|
||||||
|
|
||||||
|
|
||||||
class BaseTestCase(APITestCase):
|
class BaseTestCase(APITestCase):
|
||||||
|
|
@ -17,38 +19,57 @@ class BaseTestCase(APITestCase):
|
||||||
self.username = 'sedragurda'
|
self.username = 'sedragurda'
|
||||||
self.password = 'sedragurdaredips19'
|
self.password = 'sedragurdaredips19'
|
||||||
self.email = 'sedragurda@desoz.com'
|
self.email = 'sedragurda@desoz.com'
|
||||||
self.user = User.objects.create_user(username=self.username, email=self.email, password=self.password)
|
self.user = User.objects.create_user(
|
||||||
tokkens = User.create_jwt_tokens(self.user)
|
username=self.username,
|
||||||
self.client.cookies = SimpleCookie({'access_token': tokkens.get('access_token'),
|
email=self.email,
|
||||||
'refresh_token': tokkens.get('refresh_token')})
|
password=self.password
|
||||||
|
)
|
||||||
|
|
||||||
self.test_news_type = NewsType.objects.create(name="Test news type")
|
tokens = User.create_jwt_tokens(self.user)
|
||||||
self.test_news = News.objects.create(created_by=self.user, modified_by=self.user, title={"en-GB": "Test news"},
|
self.client.cookies = SimpleCookie(
|
||||||
news_type=self.test_news_type,
|
{'access_token': tokens.get('access_token'),
|
||||||
description={"en-GB": "Description test news"},
|
'refresh_token': tokens.get('refresh_token')})
|
||||||
start="2020-12-03 12:00:00", end="2020-12-13 12:00:00",
|
|
||||||
state=News.PUBLISHED, slug='test-news')
|
|
||||||
|
|
||||||
self.test_content_type = ContentType.objects.get(app_label="news", model="news")
|
self.test_news_type = NewsType.objects.create(
|
||||||
|
name="Test news type",
|
||||||
|
)
|
||||||
|
self.test_news = News.objects.create(
|
||||||
|
created_by=self.user,
|
||||||
|
modified_by=self.user,
|
||||||
|
title={"en-GB": "Test news"},
|
||||||
|
news_type=self.test_news_type,
|
||||||
|
description={"en-GB": "Description test news"},
|
||||||
|
start=datetime.fromisoformat("2020-12-03 12:00:00"),
|
||||||
|
end=datetime.fromisoformat("2020-12-03 12:00:00"),
|
||||||
|
state=News.PUBLISHED,
|
||||||
|
slug='test-news'
|
||||||
|
)
|
||||||
|
|
||||||
self.test_favorites = Favorites.objects.create(user=self.user, content_type=self.test_content_type,
|
self.test_content_type = ContentType.objects.get(
|
||||||
object_id=self.test_news.id)
|
app_label="news", model="news")
|
||||||
|
|
||||||
self.test_establishment_type = EstablishmentType.objects.create(name={"en-GB": "test establishment type"},
|
self.test_favorites = Favorites.objects.create(
|
||||||
use_subtypes=False)
|
user=self.user, content_type=self.test_content_type,
|
||||||
|
object_id=self.test_news.id)
|
||||||
|
|
||||||
self.test_establishment = Establishment.objects.create(name="test establishment",
|
self.test_establishment_type = EstablishmentType.objects.create(
|
||||||
description={"en-GB": "description of test establishment"},
|
name={"en-GB": "test establishment type"},
|
||||||
establishment_type=self.test_establishment_type,
|
use_subtypes=False)
|
||||||
is_publish=True)
|
|
||||||
|
self.test_establishment = Establishment.objects.create(
|
||||||
|
name="test establishment",
|
||||||
|
description={"en-GB": "description of test establishment"},
|
||||||
|
establishment_type=self.test_establishment_type,
|
||||||
|
is_publish=True)
|
||||||
# value for GenericRelation(reverse side) field must be iterable
|
# value for GenericRelation(reverse side) field must be iterable
|
||||||
# value for GenericRelation(reverse side) field must be assigned through "set" method of field
|
# value for GenericRelation(reverse side) field must be assigned through
|
||||||
|
# "set" method of field
|
||||||
self.test_establishment.favorites.set([self.test_favorites])
|
self.test_establishment.favorites.set([self.test_favorites])
|
||||||
|
|
||||||
|
|
||||||
class FavoritesTestCase(BaseTestCase):
|
class FavoritesTestCase(BaseTestCase):
|
||||||
|
|
||||||
def test_func(self):
|
def test_func(self):
|
||||||
response = self.client.get("/api/web/favorites/establishments/")
|
url = reverse('web:favorites:establishment-list')
|
||||||
print(response.json())
|
response = self.client.get(url)
|
||||||
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
||||||
14
apps/gallery/migrations/0004_merge_20191025_0906.py
Normal file
14
apps/gallery/migrations/0004_merge_20191025_0906.py
Normal file
|
|
@ -0,0 +1,14 @@
|
||||||
|
# Generated by Django 2.2.4 on 2019-10-25 09:06
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('gallery', '0002_auto_20191023_1207'),
|
||||||
|
('gallery', '0003_auto_20191003_1228'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
]
|
||||||
|
|
@ -4,7 +4,7 @@ from rest_framework import serializers
|
||||||
from advertisement.serializers.web import AdvertisementSerializer
|
from advertisement.serializers.web import AdvertisementSerializer
|
||||||
from location.serializers import CountrySerializer
|
from location.serializers import CountrySerializer
|
||||||
from main import models
|
from main import models
|
||||||
from utils.serializers import ProjectModelSerializer
|
from utils.serializers import ProjectModelSerializer, TranslatedField
|
||||||
|
|
||||||
|
|
||||||
class FeatureSerializer(serializers.ModelSerializer):
|
class FeatureSerializer(serializers.ModelSerializer):
|
||||||
|
|
@ -41,7 +41,9 @@ class SiteFeatureSerializer(serializers.ModelSerializer):
|
||||||
|
|
||||||
|
|
||||||
class CurrencySerializer(ProjectModelSerializer):
|
class CurrencySerializer(ProjectModelSerializer):
|
||||||
"""Currency serializer"""
|
"""Currency serializer."""
|
||||||
|
|
||||||
|
name_translated = TranslatedField()
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.Currency
|
model = models.Currency
|
||||||
|
|
|
||||||
28
apps/news/migrations/0028_auto_20191024_1649.py
Normal file
28
apps/news/migrations/0028_auto_20191024_1649.py
Normal file
|
|
@ -0,0 +1,28 @@
|
||||||
|
# Generated by Django 2.2.4 on 2019-10-24 16:49
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
import django.db.models.deletion
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('news', '0027_remove_news_playlist'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='newsgallery',
|
||||||
|
name='image',
|
||||||
|
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='news_gallery', to='gallery.Image', verbose_name='gallery'),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='newsgallery',
|
||||||
|
name='news',
|
||||||
|
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='news_gallery', to='news.News', verbose_name='news'),
|
||||||
|
),
|
||||||
|
migrations.AlterUniqueTogether(
|
||||||
|
name='newsgallery',
|
||||||
|
unique_together={('news', 'is_main')},
|
||||||
|
),
|
||||||
|
]
|
||||||
14
apps/news/migrations/0029_merge_20191025_0906.py
Normal file
14
apps/news/migrations/0029_merge_20191025_0906.py
Normal file
|
|
@ -0,0 +1,14 @@
|
||||||
|
# Generated by Django 2.2.4 on 2019-10-25 09:06
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('news', '0028_auto_20191024_1649'),
|
||||||
|
('news', '0021_auto_20191021_1120'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
]
|
||||||
|
|
@ -194,13 +194,24 @@ class News(BaseAttributes, TranslatedFieldsMixin):
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def main_image(self):
|
def main_image(self):
|
||||||
return self.news_gallery.main_images().first().image
|
qs = self.news_gallery.main_image()
|
||||||
|
if qs.exists():
|
||||||
|
return qs.first().image
|
||||||
|
|
||||||
|
@property
|
||||||
|
def image_url(self):
|
||||||
|
return self.main_image.image.url if self.main_image else None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def preview_image_url(self):
|
||||||
|
if self.main_image:
|
||||||
|
return self.main_image.get_image_url(thumbnail_key='news_preview')
|
||||||
|
|
||||||
|
|
||||||
class NewsGalleryQuerySet(models.QuerySet):
|
class NewsGalleryQuerySet(models.QuerySet):
|
||||||
"""QuerySet for model News"""
|
"""QuerySet for model News"""
|
||||||
|
|
||||||
def main_images(self):
|
def main_image(self):
|
||||||
"""Return objects with flag is_main is True"""
|
"""Return objects with flag is_main is True"""
|
||||||
return self.filter(is_main=True)
|
return self.filter(is_main=True)
|
||||||
|
|
||||||
|
|
@ -209,11 +220,11 @@ class NewsGallery(models.Model):
|
||||||
|
|
||||||
news = models.ForeignKey(News, null=True,
|
news = models.ForeignKey(News, null=True,
|
||||||
related_name='news_gallery',
|
related_name='news_gallery',
|
||||||
on_delete=models.SET_NULL,
|
on_delete=models.CASCADE,
|
||||||
verbose_name=_('news'))
|
verbose_name=_('news'))
|
||||||
image = models.ForeignKey('gallery.Image', null=True,
|
image = models.ForeignKey('gallery.Image', null=True,
|
||||||
related_name='news_gallery',
|
related_name='news_gallery',
|
||||||
on_delete=models.SET_NULL,
|
on_delete=models.CASCADE,
|
||||||
verbose_name=_('gallery'))
|
verbose_name=_('gallery'))
|
||||||
is_main = models.BooleanField(default=False,
|
is_main = models.BooleanField(default=False,
|
||||||
verbose_name=_('Is the main image'))
|
verbose_name=_('Is the main image'))
|
||||||
|
|
@ -224,3 +235,4 @@ class NewsGallery(models.Model):
|
||||||
"""NewsGallery meta class."""
|
"""NewsGallery meta class."""
|
||||||
verbose_name = _('news gallery')
|
verbose_name = _('news gallery')
|
||||||
verbose_name_plural = _('news galleries')
|
verbose_name_plural = _('news galleries')
|
||||||
|
unique_together = ('news', 'is_main')
|
||||||
|
|
|
||||||
|
|
@ -281,7 +281,7 @@ class NewsBackOfficeGallerySerializer(serializers.ModelSerializer):
|
||||||
if news.news_gallery.filter(image=image).exists():
|
if news.news_gallery.filter(image=image).exists():
|
||||||
raise serializers.ValidationError({'detail': _('Image is already added')})
|
raise serializers.ValidationError({'detail': _('Image is already added')})
|
||||||
|
|
||||||
if is_main and news.news_gallery.main_images().exists():
|
if is_main and news.news_gallery.main_image().exists():
|
||||||
raise serializers.ValidationError({'detail': _('Main image is already added')})
|
raise serializers.ValidationError({'detail': _('Main image is already added')})
|
||||||
|
|
||||||
attrs['news'] = news
|
attrs['news'] = news
|
||||||
|
|
|
||||||
|
|
@ -18,11 +18,14 @@ class BaseTestCase(APITestCase):
|
||||||
self.username = 'sedragurda'
|
self.username = 'sedragurda'
|
||||||
self.password = 'sedragurdaredips19'
|
self.password = 'sedragurdaredips19'
|
||||||
self.email = 'sedragurda@desoz.com'
|
self.email = 'sedragurda@desoz.com'
|
||||||
self.user = User.objects.create_user(username=self.username, email=self.email, password=self.password)
|
self.user = User.objects.create_user(
|
||||||
#get tokkens
|
username=self.username, email=self.email, password=self.password)
|
||||||
tokkens = User.create_jwt_tokens(self.user)
|
|
||||||
self.client.cookies = SimpleCookie({'access_token': tokkens.get('access_token'),
|
# get tokens
|
||||||
'refresh_token': tokkens.get('refresh_token')})
|
tokens = User.create_jwt_tokens(self.user)
|
||||||
|
self.client.cookies = SimpleCookie(
|
||||||
|
{'access_token': tokens.get('access_token'),
|
||||||
|
'refresh_token': tokens.get('refresh_token')})
|
||||||
self.test_news_type = NewsType.objects.create(name="Test news type")
|
self.test_news_type = NewsType.objects.create(name="Test news type")
|
||||||
|
|
||||||
self.lang = Language.objects.get(
|
self.lang = Language.objects.get(
|
||||||
|
|
@ -46,21 +49,25 @@ class BaseTestCase(APITestCase):
|
||||||
)
|
)
|
||||||
user_role.save()
|
user_role.save()
|
||||||
|
|
||||||
self.test_news = News.objects.create(created_by=self.user, modified_by=self.user,
|
self.test_news = News.objects.create(
|
||||||
title={"en-GB": "Test news"},
|
created_by=self.user, modified_by=self.user,
|
||||||
news_type=self.test_news_type,
|
title={"en-GB": "Test news"},
|
||||||
description={"en-GB": "Description test news"},
|
news_type=self.test_news_type,
|
||||||
start=datetime.now() + timedelta(hours=-2),
|
description={"en-GB": "Description test news"},
|
||||||
end=datetime.now() + timedelta(hours=2),
|
start=datetime.now() + timedelta(hours=-2),
|
||||||
state=News.PUBLISHED, slug='test-news-slug',
|
end=datetime.now() + timedelta(hours=2),
|
||||||
country=self.country_ru)
|
state=News.PUBLISHED,
|
||||||
|
slug='test-news-slug',
|
||||||
|
country=self.country_ru,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class NewsTestCase(BaseTestCase):
|
class NewsTestCase(BaseTestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super().setUp()
|
super().setUp()
|
||||||
|
|
||||||
def test_web_news(self):
|
def test_web_news(self):
|
||||||
response = self.client.get("/api/web/news/")
|
response = self.client.get(reverse('web:news:list'))
|
||||||
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
||||||
|
|
||||||
response = self.client.get(f"/api/web/news/slug/{self.test_news.slug}/")
|
response = self.client.get(f"/api/web/news/slug/{self.test_news.slug}/")
|
||||||
|
|
|
||||||
|
|
@ -8,7 +8,7 @@ app_name = 'news'
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
path('', views.NewsBackOfficeLCView.as_view(), name='list-create'),
|
path('', views.NewsBackOfficeLCView.as_view(), name='list-create'),
|
||||||
path('<int:pk>/', views.NewsBackOfficeRUDView.as_view(),
|
path('<int:pk>/', views.NewsBackOfficeRUDView.as_view(),
|
||||||
name='gallery-retrieve-update-destroy'),
|
name='retrieve-update-destroy'),
|
||||||
path('<int:pk>/gallery/', views.NewsBackOfficeGalleryListView.as_view(),
|
path('<int:pk>/gallery/', views.NewsBackOfficeGalleryListView.as_view(),
|
||||||
name='gallery-list'),
|
name='gallery-list'),
|
||||||
path('<int:pk>/gallery/<int:image_id>/', views.NewsBackOfficeGalleryCreateDestroyView.as_view(),
|
path('<int:pk>/gallery/<int:image_id>/', views.NewsBackOfficeGalleryCreateDestroyView.as_view(),
|
||||||
|
|
|
||||||
|
|
@ -14,14 +14,33 @@ from utils.permissions import IsCountryAdmin, IsContentPageManager
|
||||||
class NewsMixinView:
|
class NewsMixinView:
|
||||||
"""News mixin."""
|
"""News mixin."""
|
||||||
|
|
||||||
permission_classes = (permissions.AllowAny, )
|
permission_classes = (permissions.AllowAny,)
|
||||||
|
serializer_class = serializers.NewsBaseSerializer
|
||||||
|
|
||||||
def get_queryset(self, *args, **kwargs):
|
def get_queryset(self, *args, **kwargs):
|
||||||
|
from django.conf import settings
|
||||||
"""Override get_queryset method."""
|
"""Override get_queryset method."""
|
||||||
qs = models.News.objects.published().with_base_related()\
|
|
||||||
|
qs = models.News.objects.published().with_base_related() \
|
||||||
.order_by('-is_highlighted', '-created')
|
.order_by('-is_highlighted', '-created')
|
||||||
if self.request.country_code:
|
country_code = self.request.country_code
|
||||||
qs = qs.by_country_code(self.request.country_code)
|
if country_code:
|
||||||
|
|
||||||
|
# temp code
|
||||||
|
# Temporary stub for international news logic
|
||||||
|
# (по договорённости с заказчиком на демонстрации 4 ноября
|
||||||
|
# здесь будет 6 фиксированных новостей)
|
||||||
|
# TODO replace this stub with actual logic
|
||||||
|
if hasattr(settings, 'HARDCODED_INTERNATIONAL_NEWS_IDS'):
|
||||||
|
if country_code and country_code != 'www' and country_code != 'main':
|
||||||
|
qs = qs.by_country_code(country_code)
|
||||||
|
else:
|
||||||
|
qs = models.News.objects.filter(
|
||||||
|
id__in=settings.HARDCODED_INTERNATIONAL_NEWS_IDS)
|
||||||
|
return qs
|
||||||
|
# temp code
|
||||||
|
|
||||||
|
qs = qs.by_country_code(country_code)
|
||||||
return qs
|
return qs
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -24,6 +24,8 @@ class NewsDocument(Document):
|
||||||
country = fields.ObjectField(properties={'id': fields.IntegerField(),
|
country = fields.ObjectField(properties={'id': fields.IntegerField(),
|
||||||
'code': fields.KeywordField()})
|
'code': fields.KeywordField()})
|
||||||
web_url = fields.KeywordField(attr='web_url')
|
web_url = fields.KeywordField(attr='web_url')
|
||||||
|
image_url = fields.KeywordField(attr='image_url')
|
||||||
|
preview_image_url = fields.KeywordField(attr='preview_image_url')
|
||||||
tags = fields.ObjectField(
|
tags = fields.ObjectField(
|
||||||
properties={
|
properties={
|
||||||
'id': fields.IntegerField(attr='id'),
|
'id': fields.IntegerField(attr='id'),
|
||||||
|
|
|
||||||
|
|
@ -102,28 +102,3 @@ class EstablishmentDocumentSerializer(DocumentSerializer):
|
||||||
# 'establishment_type',
|
# 'establishment_type',
|
||||||
# 'establishment_subtypes',
|
# 'establishment_subtypes',
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
# def to_representation(self, instance):
|
|
||||||
# ret = super().to_representation(instance)
|
|
||||||
# dict_merge = lambda a, b: a.update(b) or a
|
|
||||||
#
|
|
||||||
# ret['tags'] = map(lambda tag: dict_merge(tag, {'label_translated': get_translated_value(tag.pop('label'))}),
|
|
||||||
# ret['tags'])
|
|
||||||
# ret['establishment_subtypes'] = map(
|
|
||||||
# lambda subtype: dict_merge(subtype, {'name_translated': get_translated_value(subtype.pop('name'))}),
|
|
||||||
# ret['establishment_subtypes'])
|
|
||||||
# if ret.get('establishment_type'):
|
|
||||||
# ret['establishment_type']['name_translated'] = get_translated_value(ret['establishment_type'].pop('name'))
|
|
||||||
# if ret.get('address'):
|
|
||||||
# ret['address']['city']['country']['name_translated'] = get_translated_value(
|
|
||||||
# ret['address']['city']['country'].pop('name'))
|
|
||||||
# location = ret['address'].pop('location')
|
|
||||||
# if location:
|
|
||||||
# ret['address']['geo_lon'] = location['lon']
|
|
||||||
# ret['address']['geo_lat'] = location['lat']
|
|
||||||
#
|
|
||||||
# ret['type'] = ret.pop('establishment_type')
|
|
||||||
# ret['subtypes'] = ret.pop('establishment_subtypes')
|
|
||||||
#
|
|
||||||
# return ret
|
|
||||||
|
|
@ -15,8 +15,9 @@ class Command(BaseCommand):
|
||||||
'subscriber',
|
'subscriber',
|
||||||
'recipe',
|
'recipe',
|
||||||
'partner',
|
'partner',
|
||||||
'gallery',
|
|
||||||
'establishment',
|
'establishment',
|
||||||
|
'gallery',
|
||||||
|
'commercial'
|
||||||
]
|
]
|
||||||
|
|
||||||
def handle(self, *args, **options):
|
def handle(self, *args, **options):
|
||||||
|
|
|
||||||
|
|
@ -788,3 +788,23 @@ class PageMetadata(MigrateMixin):
|
||||||
class Meta:
|
class Meta:
|
||||||
managed = False
|
managed = False
|
||||||
db_table = 'page_metadata'
|
db_table = 'page_metadata'
|
||||||
|
|
||||||
|
|
||||||
|
class Ads(MigrateMixin):
|
||||||
|
using = 'legacy'
|
||||||
|
|
||||||
|
site_id = models.IntegerField(blank=True, null=True)
|
||||||
|
href = models.CharField(max_length=255, blank=True, null=True)
|
||||||
|
start_at = models.DateTimeField(blank=True, null=True)
|
||||||
|
expire_at = models.DateTimeField(blank=True, null=True)
|
||||||
|
attachment_file_name = models.CharField(max_length=255, blank=True, null=True)
|
||||||
|
attachment_content_type = models.CharField(max_length=255, blank=True, null=True)
|
||||||
|
attachment_file_size = models.IntegerField(blank=True, null=True)
|
||||||
|
attachment_updated_at = models.DateTimeField(blank=True, null=True)
|
||||||
|
geometries = models.CharField(max_length=1024, blank=True, null=True)
|
||||||
|
created_at = models.DateTimeField()
|
||||||
|
updated_at = models.DateTimeField()
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
managed = False
|
||||||
|
db_table = 'ads'
|
||||||
39
apps/transfer/serializers/advertisement.py
Normal file
39
apps/transfer/serializers/advertisement.py
Normal file
|
|
@ -0,0 +1,39 @@
|
||||||
|
from rest_framework import serializers
|
||||||
|
from advertisement.models import Advertisement
|
||||||
|
import yaml
|
||||||
|
|
||||||
|
|
||||||
|
class AdvertisementSerializer(serializers.ModelSerializer):
|
||||||
|
href = serializers.CharField()
|
||||||
|
geometries = serializers.CharField(max_length=1024)
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = Advertisement
|
||||||
|
fields = (
|
||||||
|
"href",
|
||||||
|
"geometries"
|
||||||
|
)
|
||||||
|
|
||||||
|
def validate(self, data):
|
||||||
|
data["url"] = data["href"]
|
||||||
|
data["width"] = self.get_width(data["geometries"])
|
||||||
|
data["height"] = self.get_height(data["geometries"])
|
||||||
|
data.pop("href")
|
||||||
|
data.pop("geometries")
|
||||||
|
return data
|
||||||
|
|
||||||
|
def create(self, validated_data):
|
||||||
|
return Advertisement.objects.create(**validated_data)
|
||||||
|
|
||||||
|
def get_width(self, data):
|
||||||
|
data = self.parse_geometries(data)
|
||||||
|
return int(float(data["width"]))
|
||||||
|
|
||||||
|
def get_height(self, data):
|
||||||
|
data = self.parse_geometries(data)
|
||||||
|
return int(float(data["height"]))
|
||||||
|
|
||||||
|
def parse_geometries(self, geo_str):
|
||||||
|
clear_str = "!ruby/object:Paperclip::Geometry"
|
||||||
|
content_dict = yaml.safe_load(geo_str.replace(clear_str, ''))
|
||||||
|
return content_dict[':original']
|
||||||
|
|
@ -1,8 +1,10 @@
|
||||||
from rest_framework import serializers
|
from rest_framework import serializers
|
||||||
from recipe.models import Recipe
|
from recipe.models import Recipe
|
||||||
|
from utils.legacy_parser import parse_legacy_content
|
||||||
|
|
||||||
|
|
||||||
class RecipeSerializer(serializers.ModelSerializer):
|
class RecipeSerializer(serializers.ModelSerializer):
|
||||||
|
locale = serializers.CharField()
|
||||||
body = serializers.CharField(allow_null=True)
|
body = serializers.CharField(allow_null=True)
|
||||||
title = serializers.CharField()
|
title = serializers.CharField()
|
||||||
state = serializers.CharField()
|
state = serializers.CharField()
|
||||||
|
|
@ -14,7 +16,8 @@ class RecipeSerializer(serializers.ModelSerializer):
|
||||||
"body",
|
"body",
|
||||||
"title",
|
"title",
|
||||||
"state",
|
"state",
|
||||||
"created_at"
|
"created_at",
|
||||||
|
'locale',
|
||||||
)
|
)
|
||||||
|
|
||||||
def validate(self, data):
|
def validate(self, data):
|
||||||
|
|
@ -22,6 +25,7 @@ class RecipeSerializer(serializers.ModelSerializer):
|
||||||
data["title"] = self.get_title(data)
|
data["title"] = self.get_title(data)
|
||||||
data["description"] = self.get_description(data)
|
data["description"] = self.get_description(data)
|
||||||
data.pop("body")
|
data.pop("body")
|
||||||
|
data.pop("locale")
|
||||||
return data
|
return data
|
||||||
|
|
||||||
def create(self, validated_data):
|
def create(self, validated_data):
|
||||||
|
|
@ -38,9 +42,14 @@ class RecipeSerializer(serializers.ModelSerializer):
|
||||||
return Recipe.WAITING
|
return Recipe.WAITING
|
||||||
|
|
||||||
def get_title(self, obj):
|
def get_title(self, obj):
|
||||||
tit = obj.get("title")
|
# tit = obj.get("title")
|
||||||
return {"en-GB": tit}
|
# return {"en-GB": tit}
|
||||||
|
return {obj['locale']: obj['title']}
|
||||||
|
|
||||||
def get_description(self, obj):
|
def get_description(self, obj):
|
||||||
desc = obj.get("body")
|
# desc = obj.get("body")
|
||||||
return {"en-GB": desc}
|
# return {"en-GB": desc}
|
||||||
|
content = None
|
||||||
|
if obj['body']:
|
||||||
|
content = parse_legacy_content(obj['body'])
|
||||||
|
return {obj['locale']: content}
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,5 @@
|
||||||
"""Utils app serializer."""
|
"""Utils app serializer."""
|
||||||
|
import pytz
|
||||||
from django.core import exceptions
|
from django.core import exceptions
|
||||||
from rest_framework import serializers
|
from rest_framework import serializers
|
||||||
from utils import models
|
from utils import models
|
||||||
|
|
@ -48,6 +49,25 @@ class TJSONField(serializers.JSONField):
|
||||||
validators = [validate_tjson]
|
validators = [validate_tjson]
|
||||||
|
|
||||||
|
|
||||||
|
class TimeZoneChoiceField(serializers.ChoiceField):
|
||||||
|
"""Take the timezone object and make it JSON serializable."""
|
||||||
|
|
||||||
|
def __init__(self, choices=None, **kwargs):
|
||||||
|
if choices is None:
|
||||||
|
choices = pytz.all_timezones
|
||||||
|
super().__init__(choices=choices, **kwargs)
|
||||||
|
|
||||||
|
def to_representation(self, value):
|
||||||
|
if isinstance(value, str):
|
||||||
|
return value
|
||||||
|
elif isinstance(value, pytz.tzinfo.BaseTzInfo):
|
||||||
|
return value.zone
|
||||||
|
return None
|
||||||
|
|
||||||
|
def to_internal_value(self, data):
|
||||||
|
return pytz.timezone(data)
|
||||||
|
|
||||||
|
|
||||||
class ProjectModelSerializer(serializers.ModelSerializer):
|
class ProjectModelSerializer(serializers.ModelSerializer):
|
||||||
"""Overrided ModelSerializer."""
|
"""Overrided ModelSerializer."""
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -27,7 +27,7 @@ class BaseTestCase(APITestCase):
|
||||||
self.client.cookies = SimpleCookie(
|
self.client.cookies = SimpleCookie(
|
||||||
{'access_token': tokkens.get('access_token'),
|
{'access_token': tokkens.get('access_token'),
|
||||||
'refresh_token': tokkens.get('refresh_token'),
|
'refresh_token': tokkens.get('refresh_token'),
|
||||||
'locale': "en"
|
'locale': "en-GB"
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -58,12 +58,11 @@ class TranslateFieldTests(BaseTestCase):
|
||||||
def test_model_field(self):
|
def test_model_field(self):
|
||||||
self.assertTrue(hasattr(self.news_item, "title_translated"))
|
self.assertTrue(hasattr(self.news_item, "title_translated"))
|
||||||
|
|
||||||
|
|
||||||
def test_read_locale(self):
|
def test_read_locale(self):
|
||||||
response = self.client.get(f"/api/web/news/slug/{self.news_item.slug}/", format='json')
|
response = self.client.get(f"/api/web/news/slug/{self.news_item.slug}/", format='json')
|
||||||
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
self.assertEqual(response.status_code, status.HTTP_200_OK)
|
||||||
news_data = response.json()
|
news_data = response.json()
|
||||||
|
print(news_data)
|
||||||
self.assertIn("title_translated", news_data)
|
self.assertIn("title_translated", news_data)
|
||||||
|
|
||||||
self.assertIn("Test news item", news_data['title_translated'])
|
self.assertIn("Test news item", news_data['title_translated'])
|
||||||
|
|
|
||||||
|
|
@ -31,14 +31,6 @@ services:
|
||||||
# Redis
|
# Redis
|
||||||
redis:
|
redis:
|
||||||
image: redis:2.8.23
|
image: redis:2.8.23
|
||||||
ports:
|
|
||||||
- "6379:6379"
|
|
||||||
|
|
||||||
# RabbitMQ
|
|
||||||
#rabbitmq:
|
|
||||||
# image: rabbitmq:latest
|
|
||||||
# ports:
|
|
||||||
# - "5672:5672"
|
|
||||||
|
|
||||||
# Celery
|
# Celery
|
||||||
worker:
|
worker:
|
||||||
|
|
|
||||||
|
|
@ -159,8 +159,9 @@ DATABASES = {
|
||||||
},
|
},
|
||||||
'legacy': {
|
'legacy': {
|
||||||
'ENGINE': 'django.db.backends.mysql',
|
'ENGINE': 'django.db.backends.mysql',
|
||||||
|
'HOST': '172.17.0.1',
|
||||||
# 'HOST': '172.23.0.1',
|
# 'HOST': '172.23.0.1',
|
||||||
'HOST': 'mysql_db',
|
# 'HOST': 'mysql_db',
|
||||||
'PORT': 3306,
|
'PORT': 3306,
|
||||||
'NAME': 'dev',
|
'NAME': 'dev',
|
||||||
'USER': 'dev',
|
'USER': 'dev',
|
||||||
|
|
@ -482,4 +483,4 @@ STATICFILES_DIRS = (
|
||||||
|
|
||||||
|
|
||||||
# MEDIA
|
# MEDIA
|
||||||
MEDIA_LOCATION = 'media'
|
MEDIA_LOCATION = 'media'
|
||||||
|
|
|
||||||
|
|
@ -19,7 +19,8 @@ DOMAIN_URI = 'gm.id-east.ru'
|
||||||
# ELASTICSEARCH SETTINGS
|
# ELASTICSEARCH SETTINGS
|
||||||
ELASTICSEARCH_DSL = {
|
ELASTICSEARCH_DSL = {
|
||||||
'default': {
|
'default': {
|
||||||
'hosts': 'elasticsearch:9200'
|
'hosts': 'localhost:9200'
|
||||||
|
# 'hosts': 'elasticsearch:9200'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -34,3 +35,7 @@ sentry_sdk.init(
|
||||||
dsn="https://35d9bb789677410ab84a822831c6314f@sentry.io/1729093",
|
dsn="https://35d9bb789677410ab84a822831c6314f@sentry.io/1729093",
|
||||||
integrations=[DjangoIntegration()]
|
integrations=[DjangoIntegration()]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# TMP ( TODO remove it later)
|
||||||
|
# Временный хардкод для демонстрации 4 ноября, потом удалить!
|
||||||
|
HARDCODED_INTERNATIONAL_NEWS_IDS = [8, 9, 10, 11, 15, 17]
|
||||||
|
|
|
||||||
|
|
@ -26,3 +26,8 @@ ELASTICSEARCH_INDEX_NAMES = {
|
||||||
# 'search_indexes.documents.news': 'stage_news', #temporarily disabled
|
# 'search_indexes.documents.news': 'stage_news', #temporarily disabled
|
||||||
'search_indexes.documents.establishment': 'stage_establishment',
|
'search_indexes.documents.establishment': 'stage_establishment',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# TMP ( TODO remove it later)
|
||||||
|
# Временный хардкод для демонстрации 4 ноября, потом удалить!
|
||||||
|
HARDCODED_INTERNATIONAL_NEWS_IDS = [8, 9, 10, 11, 15, 17]
|
||||||
Loading…
Reference in New Issue
Block a user