Как сохранять историю Skype
Мне сильно не нравится, когда собеседник удаляет в «Скайпе» свои сообщения. Бывает, что я их не успеваю прочитать, это печально. Я подумал, что было бы неплохо научиться их куда-то логировать, попробовал несколько модулей для «Пайтона», все они на «Маке» падают.
К счастью, «Скайп» хранит свою историю в SQLite, а там, как оказалось, есть триггеры. В общем, простой способ сохранять историю — создать ещё одну таблицу и триггер, который будет висеть на операции INSERT и копировать все новые сообщения в нашу таблицу:
CREATE TABLE Messages_backup (timestamp int, author text, body_xml text); -- таблица, где будут храниться сообщения
-- А вот и наш триггер, причём посмотрите, после WHEN у меня идёт условие, я сохраняю только сообщения
-- от пользователя megadestroyer, это условие можно убрать (вместе с WHEN)
-- или написать туда через OR несколько логинов
CREATE TRIGGER Messages_insert INSERT ON Messages WHEN new.author='megadestroyer'
BEGIN
INSERT INTO Messages_backup VALUES(new.timestamp, new.author, new.body_xml);
END;
Создать таблицу и тригер очень просто, база SQLite — это просто файл (вам нужен файл «main.db»), который лежит где-то у вас на диске (можно в интренете поискать, гуглится элементарно), у меня на «Маке» он лежит в папке «~/Library/Application Support/Skype/bolknote.#». Его надо открыть утилитой sqlite3 (на «Маке» она уже есть) и выполнить эти команды.
После чего, если захочется прочитать что же удалил собеседник, там же, в sqlite3, можно будет выполнять команду
select * from Messages_backup;
и видеть весь лог сообщений, включая удалённые пользователем.
Первое что пришло в голову: Почему триггер для удаленных записей на поставлен на добавление, а не на удаление записи?
Комментарий для KAndy:
Т. е. чтобы сохранять только удалённые? Мне удобнее видеть остальные сообщения этого диалога, хотя это тоже способ, да.
Комментарий для KAndy:
После обеда и его добавлю тоже.
На «Маке» есть ещё способ без хитрых команд — настроить Skype на показ уведомлений при помощи Growl. В Growl есть своя история уведомлений, из которой Skype уже не сможет удалить сообщение.
Также в Growl есть много способов отображения уведомлений вплоть до отправки сообщения по эл. почте и sms.
Комментарий для http://platosha-ru.livejourna.com:
Для меня мой способ проще :)
Комментарий для KAndy:
Удаления как такового, оказывается, нет. Делается это через UPDATE, а этих апдейтов там куча на всякий чих.
А как догадаться, что сообщения вообще были, но теперь удалены? Скайп об этом пишет?
В Windows7 Skype удаляет новую таблицу после старта.
Комментарий для Vladimir:
Подозреваю стоит попробовать сделать это от администратора.
Комментарий для m-ivanov.livejournal.com:
Да.
Комментарий для Vladimir:
Запуск от админа не поможет, у SQLite нет авторизации. Тогда можно сунуть скрипт создания таблицы и тригера после запуска skype.exe, т. е. сделать батник с запуском в фоне skype, а после — создания таблицы.
Комментарий для Евгения Степанищева:
Забавно. Но зачем заморачиваться с удаленными сообщениями? По моему если человек хотел удалть свое сообщение — ну значит пусть удаляет.
Комментарий для agonych.livejournal.com:
Пусть удаляет, но мне хочется его прочитать :)
Извини что здесь, но — продолжение.
http://www.gazeta.ru/social/2012/10/24/4823121.shtml
Это то, о чем я говорил. Жизнь в Казани — опасна.
Комментарий для Николай:
По сравнению с каким городом опасна?
А с каким городом ты сравнивал Казань пару-тройку постов назад?
Комментарий для Николай:
Ты про Москву что ли? Ты серьёзно сейчас? Я просто поверить не могу. С чего, интересно, ты взял, что в Москве безопаснее? Пару-тройку постов назад, ты, кстати, ничего мне не ответил на мой комментарий тебе: http://bolknote.ru/all/3774#n36695
не ответил, потому что ты спросил очевидную глупость. Вероятность ТАКОГО (тупых идиотов в центре города) в Москве минимальна, в разы меньше чем в Казани.
Я тебе приведу пример — моему брату зам. министра МВД Татарстана под микрофон сказал — «Да, действия сотрудников МВД в отношении вас — незаконный досмотр, фальсификация протокола, и тп — следствие приказа по МВД — требовать выполнения требований любой ценой. За законность требуемых действий рядовые исполнители не отвечают и не могут отвечать, т. к. они получили приказ от своего командира. А что делать... Кстати, раз ты такой законник, иди к нам в штат, нам такие нужны!»
Ты вдумайся — зам министра МВД (!) в открытую (!!) говорит, что рядовые исполнители — сотрудники полиции — не гарантируют законности своих требований (!!!). А полиции в Казани оооочень много. Одна вчерашняя стрельба чего стоит.
Дикость. Что было в 1995 году, то и осталось сейчас. В этом отношении Москва — оплот страны.
ps: думал, писать или нет, но все же напишу. Даже на митингах поведение полиции в Москве и в других городах — да том же Татарстане — отличается в разы. В десятки раз.
Комментарий для Николай:
Ох, Николай, честно сказать, не понимаю вообще ничего из того что ты говоришь. Давай закончим.
Я установил плагин для Pidgin, тоже ведет неудаляемый лог, записывает все модификации сообщений, кроме того, имеется более удобный поиск
Комментарий для werdn666.ya.ru:
Ну он страшненький же (сам клиент).
а почему может так быть что в директории «~/Library/Application Support» нету директории Skype, хотя он установлен.
Комментарий для Михаил:
Вот уж не знаю. Попробуйте найти директорию Skype командой
find / -type d -name Skype 2>&-
Долго, но допендрил, есть две папки Library видимо.
Та которая нужна почему-то скрыта, в нее надо входить через открытый фаиндр с «cmd+shift+G» и дальше ~/Library/ И там будет, то что нужно.
Извините если это слишком очевидная вещь, пишу, вдруг кому-то пригодится. Я недавно OS X использую поэтому на каждом шагу пока натыкаюсь на такие «необъяснимые» штуки.
Комментарий для Михаил:
Я, когда пишу, подразумеваю, что все эти действия в консоли будут делаться :)
Указанный скрипт не работает. Написал свой. Он просто отменяет удаление, добавляет (AntiDeleteMessageTechnology) перед сообщением и оставляет его пометку «отредактировано». Сообщение можно увидеть в базе или после пару перезапусков skype:
CREATE TRIGGER AntiDeleteMessageTechnology AFTER UPDATE ON Messages WHEN new.body_xml=’’ BEGIN
UPDATE Messages SET body_xml = (’(AntiDeleteMessageTechnology)’ || COALESCE(OLD.body_xml, ’’))
WHERE id = NEW.id;
END;
Поправил:
CREATE TRIGGER AntiDeleteMessageTechnology AFTER UPDATE OF body_xml ON Messages WHEN NEW.body_xml=’’
BEGIN
UPDATE Messages
SET body_xml = (’(AntiDeleteMessageTechnology)’ || COALESCE(OLD.body_xml, ’’))
WHERE id = NEW.id;
END;
Сообщение видно либо в базе, либо после написания нескольких следующих и последующего перезапуска skype
При запуске скайпа триггер удаляется, видимо самим скайпом(
Комментарий для Юрий:
За пять лет многое могло измениться.
Комментарий для Юрий:
За пять лет многое могло измениться.