/l3/users/Ive/asterisk/linux4.unix.nt/root :1 :2 :3 :4 :5 :6 :7 :8 :9 :10 :11 :12 :13 :14 :15 |
|
#cp -a /root/out.call /var/spool/asterisk/outgoing/
|
#asterisk -rvvv
Asterisk 1.4.21.2~dfsg-3+lenny1, Copyright (C) 1999 - 2008 Digium, Inc. and others. Created by Mark Spencer <markster@digium.com> Asterisk comes with ABSOLUTELY NO WARRANTY; type 'core show warranty' for details. This is free software, with components licensed under the GNU General Public License version 2 and other licenses; you are welcome to redistribute it under certain conditions. Type 'core show license' for details. ========================================================================= This package has been modified for the Debian GNU/Linux distribution Please report all bugs to http://bugs.debian.org/asterisk ========================================================================= ... linux4*CLI> linux4*CLI> linux4*CLI> linux4*CLI> linux4*CLI> linux4*CLI> linux4*CLI> restart No such command 'restart ' (type 'help restart' for other possible commands) linux4*CLI> quit Executing last minute cleanups |
#ls -la /root/out.call
-rw-r--r-- 1 asterisk asterisk 101 2010-05-29 10:53 /root/out.call |
#cp -a /root/out.call /var/spool/asterisk/outgoing/
|
#ls -la /var/spool/asterisk/outgoing/
total 12 drwxr-x--- 2 asterisk asterisk 4096 2010-05-29 10:52 . drwxr-x--- 9 asterisk asterisk 4096 2010-05-26 09:48 .. -rw-r--r-- 1 asterisk asterisk 101 2010-05-29 10:53 out.call |
#ls -la /var/spool/asterisk/outgoing/
total 12 drwxr-x--- 2 asterisk asterisk 4096 2010-05-29 10:52 . drwxr-x--- 9 asterisk asterisk 4096 2010-05-26 09:48 .. -rw-r--r-- 1 asterisk asterisk 101 2010-05-29 10:53 out.call |
#ls -la /var/spool/asterisk/outgoing/
|
#vim /root/out.call
--- /tmp/l3-saved-3891.16024.30621 2010-05-29 10:53:59.000000000 +0300 +++ /root/out.call 2010-05-29 10:54:07.000000000 +0300 @@ -5,5 +5,5 @@ Context: menu -Extension: 1 +Extension: s Priority: 1 |
#~
total 12 drwxr-x--- 2 asterisk asterisk 4096 2010-05-29 10:52 . drwxr-x--- 9 asterisk asterisk 4096 2010-05-26 09:48 .. -rw-r--r-- 1 asterisk asterisk 101 2010-05-29 10:54 out.call |
#vim /root/out.call
|
#/etc/init.d/asterisk restart
Stopping Asterisk PBX: asterisk. Starting Asterisk PBX: asterisk. |
#ls -al --sort=t | more
|
#ls
adsi.conf esel.conf manager.conf say.conf adtranvofr.conf extconfig.conf manager.d sip.conf agents.conf extensions.ael meetme.conf sip.conf.bak alarmreceiver.conf extensions.conf mgcp.conf sip.conf.SAVE alsa.conf extensions.conf.bak misdn.conf sip_notify.conf amd.conf extensions.conf.SAVE modules.conf skinny.conf asterisk.adsi features.conf musiconhold.conf sla.conf asterisk.conf festival.conf muted.conf smdi.conf cdr.conf followme.conf osp.conf telcordia-1.adsi cdr_custom.conf func_odbc.conf oss.conf udptl.conf cdr_manager.conf gtalk.conf phone.conf users.conf cdr_odbc.conf h323.conf privacy.conf voicemail.conf cdr_pgsql.conf http.conf queues.conf vpb.conf cdr_tds.conf iax.conf res_odbc.conf watchdog.conf codecs.conf iaxprov.conf res_pgsql.conf zapata-channels.conf dnsmgr.conf indications.conf res_snmp.conf zapata-channels.conf.bak dundi.conf jabber.conf rpt.conf zapata.conf enum.conf logger.conf rtp.conf |
#vim sip.conf.SAVE
|
#:q
total 332 drwxr-xr-x 3 asterisk asterisk 4096 2010-05-29 11:00 . drwxr-xr-x 72 root root 5120 2010-05-29 10:05 .. -rw-r----- 1 asterisk asterisk 140 2009-12-14 21:08 adsi.conf -rw-r----- 1 asterisk asterisk 840 2009-12-14 21:08 adtranvofr.conf -rw-r----- 1 asterisk asterisk 2724 2009-12-14 21:08 agents.conf -rw-r----- 1 asterisk asterisk 2227 2009-12-14 21:08 alarmreceiver.conf -rw-r----- 1 asterisk asterisk 2675 2009-12-14 21:08 alsa.conf -rw-r----- 1 asterisk asterisk 767 2009-12-14 21:08 amd.conf -rw-r----- 1 asterisk asterisk 3260 2009-12-14 21:08 asterisk.adsi ... -rw-r----- 1 asterisk asterisk 2665 2009-12-14 21:08 smdi.conf -rw-r----- 1 asterisk asterisk 1384 2009-12-14 21:08 telcordia-1.adsi -rw-r----- 1 asterisk asterisk 598 2009-12-14 21:08 udptl.conf -rw-r----- 1 asterisk asterisk 1804 2009-12-14 21:08 users.conf -rw-r----- 1 asterisk asterisk 11729 2010-05-27 12:29 voicemail.conf -rw-r----- 1 asterisk asterisk 2772 2009-12-14 21:08 vpb.conf -rw-r----- 1 asterisk asterisk 393 2009-12-14 21:08 watchdog.conf -rw-r--r-- 1 root root 465 2010-05-28 16:16 zapata-channels.conf -rw-r--r-- 1 root root 459 2010-05-28 16:02 zapata-channels.conf.bak -rw-r----- 1 asterisk asterisk 24252 2010-05-29 10:13 zapata.conf |
#mv sip.conf sip.conf.pri
|
#cat /tmp/outcall.call
Channel: Sip/701 Data:/var/tmp/vybor Application: Playback context: submenu Extension: s Priority: 1 |
#mv extensions.conf extensions.
extensions.ael extensions.conf extensions.conf.bak extensions.conf.SAVE |
#mv extensions.conf extensions.pri
|
#vim extensions.conf
|
#vim extensions.conf
--- /tmp/l3-saved-3891.31465.12237 2010-05-29 11:03:15.000000000 +0300 +++ extensions.conf 2010-05-29 11:05:02.000000000 +0300 @@ -82,6 +82,7 @@ [default] + [local] include => parkedcalls @@ -122,6 +123,11 @@ ;exten => _5XX,1,Dial(SIP/${EXTEN}) + +exten => 569,1,Dial(Zap/G2,10,tT) +exten => _57X,1,Dial(Zap/G1/${EXTEN:2}) +exten => _56X,1,Dial(SIP/${EXTEN},,Tt) + exten => _4XX,1,Macro(call_in) [corp] |
#exten => t,n,Playback(/var/tmp/vybor)
; "zapata.conf" 686L, 24252C ; ; Zapata telephony interface ; ; Configuration file ; ; You need to restart Asterisk to re-configure the Zap channel ; CLI> reload chan_zap.so [trunkgroups] ... ; ; local "zapata.conf" 686L, 24250C written [channels] ; ; Default language ; ;language=en ; |
#/etc/init.d/asterisk restart
Stopping Asterisk PBX: asterisk. Starting Asterisk PBX: asterisk. |
#asterisk -rvvv
Asterisk 1.4.21.2~dfsg-3+lenny1, Copyright (C) 1999 - 2008 Digium, Inc. and others. Created by Mark Spencer <markster@digium.com> Asterisk comes with ABSOLUTELY NO WARRANTY; type 'core show warranty' for details. This is free software, with components licensed under the GNU General Public License version 2 and other licenses; you are welcome to redistribute it under certain conditions. Type 'core show license' for details. ========================================================================= This package has been modified for the Debian GNU/Linux distribution Please report all bugs to http://bugs.debian.org/asterisk ========================================================================= ... -- B-channel 0/8 restarted on span 1 -- B-channel 0/8 successfully restarted on span 1 -- B-channel 0/9 restarted on span 1 -- B-channel 0/9 successfully restarted on span 1 -- B-channel 0/10 restarted on span 1 -- B-channel 0/10 successfully restarted on span 1 linux4*CLI> linux4*CLI> linux4*CLI> quit Executing last minute cleanups |
#ssh 192.168.1.1
root@192.168.1.1's password: Linux linux1.unix.nt 2.6.26-2-686 #1 SMP Wed May 12 21:56:10 UTC 2010 i686 The programs included with the Debian GNU/Linux system are free software; the exact distribution terms for each program are described in the individual files in /usr/share/doc/*/copyright. Debian GNU/Linux comes with ABSOLUTELY NO WARRANTY, to the extent permitted by applicable law. Last login: Sat May 29 12:32:54 2010 from 192.168.2.1 l3-agent is already running: pid=2558; pidfile=/root/.lilalo/l3-agent.pid |
#sh /tmp/vsem.sh
chown: невозможно получить доступ к `/tmp/call701': Нет такого файла или каталога mv: невозможно выполнить stat для `/tmp/call701': Нет такого файла или каталога chown: невозможно получить доступ к `/tmp/call702': Нет такого файла или каталога mv: невозможно выполнить stat для `/tmp/call702': Нет такого файла или каталога /tmp/vsem.sh: line 5: /tmp/callodessa/301.call: Нет такого файла или каталога chown: невозможно получить доступ к `/tmp/callodessa_301': Нет такого файла или каталога mv: невозможно выполнить stat для `/tmp/callodessa_301': Нет такого файла или каталога /tmp/vsem.sh: line 5: /tmp/callodessa/302.call: Нет такого файла или каталога chown: невозможно получить доступ к `/tmp/callodessa_302': Нет такого файла или каталога mv: невозможно выполнить stat для `/tmp/callodessa_302': Нет такого файла или каталога ... mv: невозможно выполнить stat для `/tmp/callkiev_201': Нет такого файла или каталога /tmp/vsem.sh: line 5: /tmp/callkiev/202.call: Нет такого файла или каталога chown: невозможно получить доступ к `/tmp/callkiev_202': Нет такого файла или каталога mv: невозможно выполнить stat для `/tmp/callkiev_202': Нет такого файла или каталога /tmp/vsem.sh: line 5: /tmp/callcrimea/501.call: Нет такого файла или каталога chown: невозможно получить доступ к `/tmp/callcrimea_501': Нет такого файла или каталога mv: невозможно выполнить stat для `/tmp/callcrimea_501': Нет такого файла или каталога /tmp/vsem.sh: line 5: /tmp/callcrimea/502.call: Нет такого файла или каталога chown: невозможно получить доступ к `/tmp/callcrimea_502': Нет такого файла или каталога mv: невозможно выполнить stat для `/tmp/callcrimea_502': Нет такого файла или каталога |
#vi /tmp/vsem.sh
|
#sh /tmp/vsem.sh
|
#ls /var/spool/asterisk/outgoing/
|
#ls /tmp/
example3.call lost+found/ outcall.call .X11-unix/ .ICE-unix/ mc-root/ vsem.sh |
#ls /tmp/example3.call
/tmp/example3.call |
#cat /tmp/example3.call
Channel: SIP/bt101 MaxRetries: 1 RetryTime: 60 WaitTime: 30 # # Assuming that your outgoing call logic is kept in the # context called [outgoing] # Context: outgoing Extension: 14109850123 Priority: 1 |
#vi /etc/asterisk/extensions.conf
|
#vi /usr/local/bin/callback.sh
|
#chmod +x /usr/local/bin/callback.sh
|
#vi /etc/asterisk/extensions.conf
|
#asterisk -rvvv
Asterisk 1.4.21.2~dfsg-3+lenny1, Copyright (C) 1999 - 2008 Digium, Inc. and others. Created by Mark Spencer <markster@digium.com> Asterisk comes with ABSOLUTELY NO WARRANTY; type 'core show warranty' for details. This is free software, with components licensed under the GNU General Public License version 2 and other licenses; you are welcome to redistribute it under certain conditions. Type 'core show license' for details. ========================================================================= This package has been modified for the Debian GNU/Linux distribution Please report all bugs to http://bugs.debian.org/asterisk ========================================================================= ... Connected to Asterisk 1.4.21.2~dfsg-3+lenny1 currently running on linux1 (pid = 7193) Verbosity is at least 4 linux1*CLI> -- Executing [852@gr2:1] Hangup("SIP/701-081deea8", "") in new stack == Spawn extension (gr2, 852, 1) exited non-zero on 'SIP/701-081deea8' [May 29 12:23:45] NOTICE[7215]: chan_sip.c:15500 handle_request_subscribe: Received SIP subscribe for peer without mailbox: 702 linux1*CLI> linux1*CLI> linux1*CLI> quit Executing last minute cleanups |
#vim /etc/asterisk/extensions.conf
|
#vim /etc/asterisk/extensions.conf
|
#cd /etc/asterisk/
|
#ls
adsi.conf features.conf privacy.conf adtranvofr.conf festival.conf queues.conf agents.conf followme.conf res_odbc.conf alarmreceiver.conf func_odbc.conf res_pgsql.conf alsa.conf gtalk.conf res_snmp.conf amd.conf h323.conf rpt.conf asterisk.adsi http.conf rtp.conf asterisk.conf iax.conf Russian-Tamara-2.0.2-ulaw cdr.conf iaxprov.conf say.conf cdr_custom.conf indications.conf sip.conf ... cdr_tds.conf manager.d sla.conf codecs.conf meetme.conf smdi.conf dnsmgr.conf mgcp.conf telcordia-1.adsi dundi.conf misdn.conf udptl.conf enum.conf modules.conf users.conf esel.conf musiconhold.conf voicemail.conf extconfig.conf muted.conf vpb.conf extensions.ael osp.conf watchdog.conf extensions.conf oss.conf zapata.conf extensions.conf.save phone.conf |
#vim extensions.conf
|
#vi /usr/local/bin/callback.sh
|
#vi /usr/local/bin/callback.sh
|
#include => corp
|
#fg
bash: fg: current: no such job |
#asterisk -rx 'dialplan reload'
Dialplan reloaded. |
#ls /var/spool/asterisk/
dictate meetme monitor outgoing system tmp voicemail |
#ls /var/spool/asterisk/dictate/
|
#ls
adsi.conf features.conf privacy.conf adtranvofr.conf festival.conf queues.conf agents.conf followme.conf res_odbc.conf alarmreceiver.conf func_odbc.conf res_pgsql.conf alsa.conf gtalk.conf res_snmp.conf amd.conf h323.conf rpt.conf asterisk.adsi http.conf rtp.conf asterisk.conf iax.conf Russian-Tamara-2.0.2-ulaw cdr.conf iaxprov.conf say.conf cdr_custom.conf indications.conf sip.conf ... cdr_tds.conf manager.d sla.conf codecs.conf meetme.conf smdi.conf dnsmgr.conf mgcp.conf telcordia-1.adsi dundi.conf misdn.conf udptl.conf enum.conf modules.conf users.conf esel.conf musiconhold.conf voicemail.conf extconfig.conf muted.conf vpb.conf extensions.ael osp.conf watchdog.conf extensions.conf oss.conf zapata.conf extensions.conf.save phone.conf |
#ld d
dnsmgr.conf dundi.conf |
#ls /var/spool/asterisk/
dictate meetme monitor outgoing system tmp voicemail |
#ls
adsi.conf esel.conf manager.conf say.conf adtranvofr.conf extconfig.conf manager.d sip.conf agents.conf extensions.ael meetme.conf sip.conf.bak alarmreceiver.conf extensions.conf mgcp.conf sip.conf.pri alsa.conf extensions.conf.bak misdn.conf sip_notify.conf amd.conf extensions.pri modules.conf skinny.conf asterisk.adsi features.conf musiconhold.conf sla.conf asterisk.conf festival.conf muted.conf smdi.conf cdr.conf followme.conf osp.conf telcordia-1.adsi cdr_custom.conf func_odbc.conf oss.conf udptl.conf cdr_manager.conf gtalk.conf phone.conf users.conf cdr_odbc.conf h323.conf privacy.conf voicemail.conf cdr_pgsql.conf http.conf queues.conf vpb.conf cdr_tds.conf iax.conf res_odbc.conf watchdog.conf codecs.conf iaxprov.conf res_pgsql.conf zapata-channels.conf dnsmgr.conf indications.conf res_snmp.conf zapata-channels.conf.bak dundi.conf jabber.conf rpt.conf zapata.conf enum.conf logger.conf rtp.conf |
#vim extensions.conf
|
#vim extensions.conf
--- /tmp/l3-saved-6503.22899.29174 2010-05-29 14:23:28.000000000 +0300 +++ extensions.conf 2010-05-29 14:24:05.000000000 +0300 @@ -113,6 +113,7 @@ exten => 815,1,Set(CALLFILENAME=${EXTEN-record-${EPOCH}}) exten => 815,n,Monitor(wav,${CALLFILEMANE},m) exten => 815,n,Dial(SIP/401) +exten => 816,1,Dictate() exten => 820,1,Record(/var/tmp/menu:gsm) exten => 821,1,Record(/var/tmp/goaway-stranger:gsm) |
#vi /tmp/call-queue/702
|
#cat /usr/local/bin/
callback.sh l3-agent l3-config l3script |
#cat /usr/local/bin/callback.sh
#!/bin/sh CALLERID=$1 EXTENSION=$2 TEMP=`mktemp /tmp/callXXXXXXXXXXXX`.call cat <<EOF > $TEMP Channel: Sip/$EXTENSION Extension: $CALLERID Context: local Priority: 1 EOF chown asterisk:asterisk $TEMP mv $TEMP /var/spool/asterisk/outgoing/ |
#cp /usr/local/bin/callback.sh /usr/local/bin/queue.sh
|
#vi /usr/local/bin/queue.sh
|
#chmod +x /usr/local/bin/queue.sh
|
#cat /tmp/call-queue/701
301 302 201 |
#/usr/local/bin/queue.sh 701
|
#fi
302 201 |
#vi /usr/local/bin/queue.sh
|
#vi /tmp/call-queue/701
|
#/usr/local/bin/queue.sh 701
Channel: Sip/701 Extension: 3302 Context: gr3 Priority: 1 |
#vi extensions.conf
|
#asterisk -rx 'dialplan reload'
Dialplan reloaded. |
#cat /tmp/call-queue/701
2201 |
#vi /tmp/call-queue/701
|
#cat /tmp/call-queue/701
3301 2201 |
#/usr/local/bin/queue.sh 701
Channel: Sip/701 Extension: 3301 Context: gr3 Priority: 1 |
#/usr/local/bin/queue.sh 701
Channel: Sip/701 Extension: 2201 Context: gr3 Priority: 1 |
3301 2201
Channel: SIP/bt101 MaxRetries: 1 RetryTime: 60 WaitTime: 30 # # Assuming that your outgoing call logic is kept in the # context called [outgoing] # Context: outgoing Extension: 14109850123 Priority: 1
Channel: Sip/701 Data:/var/tmp/vybor Application: Playback context: submenu Extension: s Priority: 1
#!/bin/sh CALLERID=$1 EXTENSION=$2 TEMP=`mktemp /tmp/callXXXXXXXXXXXX`.call cat <<EOF > $TEMP Channel: Sip/$EXTENSION Extension: $CALLERID Context: local Priority: 1 EOF chown asterisk:asterisk $TEMP mv $TEMP /var/spool/asterisk/outgoing/
Время первой команды журнала | 09:52:54 2010- 5-29 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Время последней команды журнала | 13:38:07 2010- 5-29 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в журнале | 101 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Процент команд с ненулевым кодом завершения, % | 5.94 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Процент синтаксически неверно набранных команд, % | 0.00 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Суммарное время работы с терминалом *, час | 2.18 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Количество командных строк в единицу времени, команда/мин | 0.77 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Частота использования команд |
|
В журнал автоматически попадают все команды, данные в любом терминале системы.
Для того чтобы убедиться, что журнал на текущем терминале ведётся, и команды записываются, дайте команду w. В поле WHAT, соответствующем текущему терминалу, должна быть указана программа script.
Команды, при наборе которых были допущены синтаксические ошибки, выводятся перечёркнутым текстом:
$ l s-l bash: l: command not found |
Если код завершения команды равен нулю, команда была выполнена без ошибок. Команды, код завершения которых отличен от нуля, выделяются цветом.
$ test 5 -lt 4 |
Команды, ход выполнения которых был прерван пользователем, выделяются цветом.
$ find / -name abc find: /home/devi-orig/.gnome2: Keine Berechtigung find: /home/devi-orig/.gnome2_private: Keine Berechtigung find: /home/devi-orig/.nautilus/metafiles: Keine Berechtigung find: /home/devi-orig/.metacity: Keine Berechtigung find: /home/devi-orig/.inkscape: Keine Berechtigung ^C |
Команды, выполненные с привилегиями суперпользователя, выделяются слева красной чертой.
# id uid=0(root) gid=0(root) Gruppen=0(root) |
Изменения, внесённые в текстовый файл с помощью редактора, запоминаются и показываются в журнале в формате ed. Строки, начинающиеся символом "<", удалены, а строки, начинающиеся символом ">" -- добавлены.
$ vi ~/.bashrc
|
Для того чтобы изменить файл в соответствии с показанными в диффшоте изменениями, можно воспользоваться командой patch. Нужно скопировать изменения, запустить программу patch, указав в качестве её аргумента файл, к которому применяются изменения, и всавить скопированный текст:
$ patch ~/.bashrc |
Для того чтобы получить краткую справочную информацию о команде, нужно подвести к ней мышь. Во всплывающей подсказке появится краткое описание команды.
Если справочная информация о команде есть, команда выделяется голубым фоном, например: vi. Если справочная информация отсутствует, команда выделяется розовым фоном, например: notepad.exe. Справочная информация может отсутствовать в том случае, если (1) команда введена неверно; (2) если распознавание команды LiLaLo выполнено неверно; (3) если информация о команде неизвестна LiLaLo. Последнее возможно для редких команд.
Большие, в особенности многострочные, всплывающие подсказки лучше всего показываются браузерами KDE Konqueror, Apple Safari и Microsoft Internet Explorer. В браузерах Mozilla и Firefox они отображаются не полностью, а вместо перевода строки выводится специальный символ.
Время ввода команды, показанное в журнале, соответствует времени начала ввода командной строки, которое равно тому моменту, когда на терминале появилось приглашение интерпретатора
Имя терминала, на котором была введена команда, показано в специальном блоке. Этот блок показывается только в том случае, если терминал текущей команды отличается от терминала предыдущей.
Вывод не интересующих вас в настоящий момент элементов журнала, таких как время, имя терминала и других, можно отключить. Для этого нужно воспользоваться формой управления журналом вверху страницы.
Небольшие комментарии к командам можно вставлять прямо из командной строки. Комментарий вводится прямо в командную строку, после символов #^ или #v. Символы ^ и v показывают направление выбора команды, к которой относится комментарий: ^ - к предыдущей, v - к следующей. Например, если в командной строке было введено:
$ whoami
user
$ #^ Интересно, кто я?в журнале это будет выглядеть так:
$ whoami
user
Интересно, кто я? |
Если комментарий содержит несколько строк, его можно вставить в журнал следующим образом:
$ whoami
user
$ cat > /dev/null #^ Интересно, кто я?
Программа whoami выводит имя пользователя, под которым мы зарегистрировались в системе. - Она не может ответить на вопрос о нашем назначении в этом мире.В журнале это будет выглядеть так:
$ whoami user
|
Комментарии, не относящиеся непосредственно ни к какой из команд, добавляются точно таким же способом, только вместо симолов #^ или #v нужно использовать символы #=
1 2 3 4Группы команд, выполненных на разных терминалах, разделяются специальной линией. Под этой линией в правом углу показано имя терминала, на котором выполнялись команды. Для того чтобы посмотреть команды только одного сенса, нужно щёкнуть по этому названию.
LiLaLo (L3) расшифровывается как Live Lab Log.
Программа разработана для повышения эффективности обучения Unix/Linux-системам.
(c) Игорь Чубин, 2004-2008