И так, понадобилось мне воткнуть в сеть железяку, которая лет ндцать была уже в нашей сети и у неё статический адрес….
на этой железяке выписан мак, и по маку я должен был найти её ip адрес.
Сегодня я расскажу вам необычную историю, попросили меня проследить за голосованием на одном из сайтов.
т.к. бывает за ночь один из кандидатов как прибавить 1-2 тыщи голосов, а потом весь день тишина…
что б доказать явный косяк делаем просто. снимаем скриншот сайта каждую минуту и смотрим что голоса не постепенно копятся, а бах и всё.
В тырнете куча мануалов как сделать это на атвомате но если у нас установлен Х-сервер.
но у меня вот так сложилась что ни на одном сервере его нету.
Но не беда есть есть Fake Xserver завётся он xvfb
Устанавливаем
[cc lang=”bash”]aptitude install xvfb[/cc]
при тестовом запуске
[cc lang=”bash”]Xvfb :99 -ac[/cc]
он будет ругаться на кучу всего
[cc lang=”bash”]
[dix] Could not init font path element /usr/share/fonts/X11/misc, removing from list!
[dix] Could not init font path element /usr/share/fonts/X11/cyrillic, removing from list!
[dix] Could not init font path element /usr/share/fonts/X11/100dpi/:unscaled, removing from list!
[dix] Could not init font path element /usr/share/fonts/X11/75dpi/:unscaled, removing from list![/cc]
Создаём каталог временный где угодно (/home/username/CutyCapt например), в нём выполняют команды
[cc lang=”bash”]
svn co https://cutycapt.svn.sourceforge.net/svnroot/cutycapt
cd cutycapt/CutyCapt
qmake
make[/cc]
всё теперь у нас есть CutyCapt.
можно пробовать 🙂
создаём файл
touch screenner.sh
в него кидаем вот такой код
[cc lang=”bash”]#!/bin/bash
xvfb-run –server-args=”-screen 0, 1024x768x24″ /home/developer/scr/cutycapt/CutyCapt/CutyCapt –url=http://www.google.com –out=/var/exchange/screensite/`date +%F-%H-%M`.png
[/cc]
Мы запускаем виртуальный сервер с параметрами (0 скрин) указываем разрешение (если сайт длинный можно указать хоть 2000 во втором параметре)
/home/developer/scr/cutycapt/CutyCapt/ – это путь до CutyCap там мы делали qmake и make
Ну и куда сохранить, мне нужно было дату + время ставить.
Вот и всё готово.
Мог что-то упустить из виду т.к. по факту ставил пакетов больше, но пригодились ли они, не уверен.
Сегодня Django снова порадовала, мне требовалось отобразить список категорий с под категориями
не важно можно с ul-li.
мне надо было завернуть всё это в красивый селект, ну вот что-то вроде этого.
в хтмл это примерно вот так
[cc lang=”html”]
[/cc]
Допустим у меня есть 2 вот таких модели в вакууме.
Одна: категория – Firefox (как в примере выше.)
[cc lang=”python”]
class Category(models.Model):
name = models.CharField(max_length=100)
def __unicode__(self):
return self.name[/cc]
И вторая не посредственно список, где есть поле указывающее на связь с родителем
[cc lang=”python”]
class SubCategory(models.Model):
category_name = models.ForeignKey(Category)
name = models.CharField(max_length=200)
def __unicode__(self):
return self.name[/cc]
Едем дальше.
в PHP, я бы в цикле прорисовки категорий поставил бы ещё один цикл выбирающий всех детей для данной категории. (хаха – много запросов ну и ладно)
Но тут у нас всё интереснее, в притом намного.
Мы во views должны сформировать что-то и отправить в шаблон уже как-то почти готовое для отображения.
Хочется городить велосипед, но тут Документация Django какбэ подсказывает
что есть такая хреновая, которая мне поможет.
Суть её в том, что тот массив что придёт к нам она может пересортироватьперегруппировать по любому полю, и поможет нам красиво его отобразить.
В итоге во views.py я делаю выборку того, что мне нужно.
Например вот так:
[cc lang=”python”]sub_category_list = SubCategory.objects.all()[/cc]
И всё вот это мы отправляем тихо мирно в шаблон.
А в шаблоне нас встретит уже магический regroup
Вот с такой конструкцией
[cc lang=”python”]
{% regroup sub_category_list by category_name as categ_list %}
[/cc]
Теперь по порядку.
[cc lang=”python”]{% regroup sub_category_list by category_name as categ_list %}[/cc]
Группируем sub_category_list по полю category_name и называем результат categ_list
Дальше создаём html элемент, тут я думаю всё понятно.
и начинаем разбирать то, что у нас в categ_list
[cc lang=”python”]{% for ca in categ_list %}[/cc]
Тут рассказывать ничего не надо, перебираем элементы по порядку
[cc lang=”python”]
{% endfor %}
[/cc]
Вот и завершили все наши дела.
и получили нечто похожее на селект рутреккера тот, что в самом верху.