diff --git a/article/models.py b/article/models.py index 5a0da916..aa252baf 100644 --- a/article/models.py +++ b/article/models.py @@ -123,7 +123,7 @@ class Article(TranslatableModel): files = generic.GenericRelation('file.FileModel', content_type_field='content_type', object_id_field='object_id') class Meta: - ordering = ['-created'] + ordering = ['-publish_date'] def __unicode__(self): return self.lazy_translation_getter('main_title', self.pk) diff --git a/city/management/commands/update_hotels_currency.py b/city/management/commands/update_hotels_currency.py new file mode 100644 index 00000000..f28365d4 --- /dev/null +++ b/city/management/commands/update_hotels_currency.py @@ -0,0 +1,51 @@ +import urllib2, base64 +import json +from django.core.management.base import BaseCommand, CommandError +from city.models import Hotel + +HOTEL_URL = 'https://distribution-xml.booking.com/json/bookings.getHotels?' +username = 'expomap' +password = '33xp00m33p' + + +def handle_hotels(hotel_ids): + good_hotels = [] + hotel_ids_str = ','.join(hotel_ids) + new_url = HOTEL_URL + 'hotel_ids=%s'%hotel_ids_str + request = urllib2.Request(new_url) + base64string = base64.encodestring('%s:%s' % (username, password)).replace('\n', '') + request.add_header("Authorization", "Basic %s" % base64string) + try: + response = urllib2.urlopen(request) + code = response.getcode() + except urllib2.HTTPError, e: + code = e.code + except urllib2.URLError, e: + code = e.code + + json_hotels = response.read() + hotels = json.loads(json_hotels) + for item in hotels: + id = item['hotel_id'] + currency = item['currencycode'] + Hotel.objects.filter(id=id).update(currency=currency) + good_hotels.append(id) + bad_hotels = list(set(hotel_ids) - set(good_hotels)) + + Hotel.objects.filter(id__in=bad_hotels).delete() + print('success update currency in %d hotels'%len(good_hotels)) + + +def main(): + hotels_todo = Hotel.objects.filter(currency__isnull=True)[:100].count() + while hotels_todo > 0: + hotel_ids = [str(item.id) for item in list(Hotel.objects.filter(currency__isnull=True)[:100])] + handle_hotels(hotel_ids) + hotels_todo =Hotel.objects.filter(currency__isnull=True)[:100].count() + + + + +class Command(BaseCommand): + def handle(self, *args, **options): + main() diff --git a/city/management/commands/update_hotels_price.py b/city/management/commands/update_hotels_price.py new file mode 100644 index 00000000..38243658 --- /dev/null +++ b/city/management/commands/update_hotels_price.py @@ -0,0 +1,68 @@ +import urllib2, base64 +import json +from django.core.management.base import BaseCommand, CommandError +from city.models import Hotel + +URL = 'https://distribution-xml.booking.com/json/bookings.getRooms?' +username = 'expomap' +password = '33xp00m33p' +test_id = '298239' + +def get_prices(rooms): + min_price = None + max_price = None + for room in rooms: + try: + cur_min = float(room.get('min_price')) + except TypeError: + cur_min = None + try: + cur_max = float(room.get('max_price')) + except TypeError: + cur_max = None + + if cur_min > min_price: + min_price = cur_min + if cur_max > max_price: + max_price = cur_max + + return min_price, max_price + +def handle_hotels(hotel_id): + hotel_ids_str = hotel_id + new_url = URL + 'hotel_ids=%s'%hotel_ids_str + request = urllib2.Request(new_url) + base64string = base64.encodestring('%s:%s' % (username, password)).replace('\n', '') + request.add_header("Authorization", "Basic %s" % base64string) + try: + response = urllib2.urlopen(request) + code = response.getcode() + except urllib2.HTTPError, e: + code = e.code + except urllib2.URLError, e: + code = e.code + + json_rooms = response.read() + rooms = json.loads(json_rooms) + min_price, max_price = get_prices(rooms) + Hotel.objects.filter(id=hotel_id).update(min_price=min_price, max_price=max_price) + print('success') + +def main(): + hotel_id = test_id + for hotel in Hotel.objects.all(): + try: + handle_hotels(str(hotel.id)) + except: + continue + + #hotels_todo = Hotel.objects.filter(currency__isnull=True)[:100].count() + #while hotels_todo > 0: + #hotel_ids = [str(item.id) for item in list(Hotel.objects.filter(currency__isnull=True)[:100])] + #handle_hotels(hotel_ids) + #hotels_todo = Hotel.objects.filter(currency__isnull=True)[:100].count() + + +class Command(BaseCommand): + def handle(self, *args, **options): + main() \ No newline at end of file diff --git a/city/models.py b/city/models.py index aa4f4ead..8ec29ea9 100644 --- a/city/models.py +++ b/city/models.py @@ -136,6 +136,10 @@ class Hotel(TranslatableModel): latitude = models.FloatField(blank=True, null=True) longitude = models.FloatField(blank=True, null=True) photo = ImageField(upload_to='hotels') + currency = models.CharField(max_length=10) + min_price = models.FloatField(blank=True, null=True) + max_price = models.FloatField(blank=True, null=True) + checked = models.NullBooleanField(blank=True, null=True) translations = TranslatedFields( name = models.CharField(max_length=255, blank=True), diff --git a/templates/client/article/article.html b/templates/client/article/article.html index 71f5d860..e36596ee 100644 --- a/templates/client/article/article.html +++ b/templates/client/article/article.html @@ -19,7 +19,7 @@ {% include 'client/includes/article/article_logo.html' with obj=object %}

{{ object.main_title }}

- {{ object.created|date:"d E Y" }}{% if object.theme.all.exists %}{% include 'includes/article_theme.html' with obj=object %}{% endif %} + {{ object.publish_date|date:"d E Y" }}{% if object.theme.all.exists %}{% include 'includes/article_theme.html' with obj=object %}{% endif %} {% if request.user.is_admin %} {% trans 'изменить' %} {% endif %} diff --git a/templates/client/includes/article/blog_list.html b/templates/client/includes/article/blog_list.html index afd7969d..64b68bad 100644 --- a/templates/client/includes/article/blog_list.html +++ b/templates/client/includes/article/blog_list.html @@ -7,7 +7,7 @@ {% include 'includes/article/article_preview.html' with obj=blog %}

{{ blog.main_title }}

{{ blog.preview|safe }} - {{ blog.created|date:"d E Y" }}{% if blog.tag.all.exists %}{% include 'includes/article_tags.html' with obj=blog %}{% endif %} + {{ blog.publish_date|date:"d E Y" }}{% if blog.tag.all.exists %}{% include 'includes/article_tags.html' with obj=blog %}{% endif %} {% if forloop.counter == 5 or objects|length < 5 %} diff --git a/templates/client/includes/booking_block.html b/templates/client/includes/booking_block.html index 8de59a1a..4f686236 100644 --- a/templates/client/includes/booking_block.html +++ b/templates/client/includes/booking_block.html @@ -25,8 +25,10 @@ {{ hotel.name }} - - Забронировать + {% if hotel.min_price %} +
{{ hotel.min_price|floatformat:0 }} {{ hotel.currency }}/{% trans 'ночь' %}
+ {% endif %} + {% trans 'Забронировать' %} {% endfor %} @@ -40,11 +42,13 @@ {% endthumbnail %} - {{ hotel.name }} + {{ hotel.name }} -
 
- - Забронировать + + {% if hotel.min_price %} +
{{ hotel.min_price|floatformat:0 }} {{ hotel.currency }}/{% trans 'ночь' %}
+ {% endif %} + {% trans 'Забронировать' %} {% endfor %} diff --git a/templates/client/includes/conference/conference_object.html b/templates/client/includes/conference/conference_object.html index bc3d16bb..25af9df2 100644 --- a/templates/client/includes/conference/conference_object.html +++ b/templates/client/includes/conference/conference_object.html @@ -91,7 +91,7 @@ {% trans 'изменить' %} {% endif %} -
{% trans 'Найти отель' %}
+
{% trans 'Найти отель' %}

diff --git a/templates/client/includes/exposition/exposition_object.html b/templates/client/includes/exposition/exposition_object.html index 48034fe6..a24da278 100644 --- a/templates/client/includes/exposition/exposition_object.html +++ b/templates/client/includes/exposition/exposition_object.html @@ -95,7 +95,7 @@ {% trans 'изменить' %} {% endif %}
-
{% trans 'Найти отель' %}
+
{% trans 'Найти отель' %}