lilalo
annotate l3bashrc @ 155:8ee5e59f1bd3
Локальное хранение и анализ данных с помощью SQlite
Очень много изменений, касающихся работы с sqlite
и локального использования результатов записи.
Подробнее:
README.l3text
Очень много изменений, касающихся работы с sqlite
и локального использования результатов записи.
Подробнее:
README.l3text
author | Igor Chubin <igor@chub.in> |
---|---|
date | Tue Mar 16 20:05:30 2010 +0200 (2010-03-16) |
parents | 40d843395547 |
children | a0daf0c3fa52 |
rev | line source |
---|---|
devi@70 | 1 #!/bin/sh |
devi@70 | 2 |
devi@105 | 3 # (c) Igor Chubin, igor@chub.in, 2004-2006 |
devi@70 | 4 |
devi@76 | 5 # Environment variables set by the script: |
devi@76 | 6 # |
devi@76 | 7 # L3_SESSION_ID - uniq id of the LiLaLo-session |
devi@76 | 8 # L3_PARENT_TTY - name of tty on which script is running |
devi@76 | 9 # PS1 - intercative shell prompt in which LiLaLo hides |
devi@76 | 10 # various information about the command |
devi@76 | 11 # L3_TAMPERED_EDITORS - list of editors which are tampered with functions |
devi@76 | 12 |
devi@76 | 13 |
devi@76 | 14 # Functions with the names starting _l3_ are internal. |
devi@76 | 15 # Such functions are unset before this rc script exits |
devi@76 | 16 |
devi@76 | 17 _l3_editors_to_tamper='/bin/vi /usr/bin/vi /usr/bin/vim /bin/ee /usr/bin/ee /usr/bin/pico /usr/bin/nano /usr/local/bin/vim' |
devi@76 | 18 |
devi@70 | 19 _l3_start() |
devi@70 | 20 { |
devi@80 | 21 echo $- | grep -q i || return 0 |
devi@79 | 22 if _l3_is_running_here |
devi@76 | 23 then |
devi@76 | 24 _l3_env |
devi@76 | 25 _l3_init_prompt |
devi@76 | 26 l3_fix_prompt |
devi@76 | 27 _l3_tamper_editors |
devi@76 | 28 _l3_tamper_commands |
devi@76 | 29 _l3_unset_internal |
devi@79 | 30 else |
devi@79 | 31 _l3_start_session |
devi@79 | 32 _l3_run_script |
devi@76 | 33 fi |
devi@76 | 34 } |
devi@76 | 35 |
devi@76 | 36 # ===================== STAGE 1 ============================ |
devi@76 | 37 |
devi@79 | 38 _l3_is_running_here() |
devi@76 | 39 { |
devi@79 | 40 ps waux | awk '{print $2" "$11 }' | grep -q ^$PPID" "script |
devi@79 | 41 return $? |
devi@79 | 42 |
devi@79 | 43 # Check if ^^^^ run on Linux |
devi@79 | 44 # and del vvvv this if it does |
devi@79 | 45 |
devi@76 | 46 export L3_TTY=`/usr/bin/tty` |
devi@79 | 47 uname -a | grep -qi bsd && bsd=yes |
devi@70 | 48 proc_on_the_term=`w | grep "${L3_TTY##/dev/}" | awk '{print $8;}'` |
devi@70 | 49 # freeBSD: |
devi@70 | 50 [ -n "$bsd" ] && \ |
devi@70 | 51 proc_on_the_term=`w | grep "${L3_TTY##/dev/tty}" | awk '{print $6;}'` |
devi@70 | 52 |
devi@79 | 53 [ -n "$proc_on_the_term" ] && echo $proc_on_the_term | grep -q script |
devi@70 | 54 } |
devi@70 | 55 |
devi@70 | 56 _l3_start_session() |
devi@70 | 57 { |
devi@79 | 58 export L3_SESSION_ID=${RANDOM}${RANDOM}${RANDOM}${RANDOM}-`date +%s` |
devi@71 | 59 export L3_HOME=~/.lilalo/ |
igor@155 | 60 L3_SQLITE=$L3_HOME/report.sqlite |
devi@70 | 61 mkdir -p $L3_HOME |
devi@70 | 62 |
devi@79 | 63 tty=`/usr/bin/tty` |
devi@70 | 64 uname -a | grep -qi bsd && bsd=yes |
devi@70 | 65 parent=`cat /proc/$PPID/cmdline 2> /dev/null` |
devi@79 | 66 [ -z "$parent" ] && parent="`ps waux | awk '{if ($2 == '$PPID') print $11; }'`" |
devi@70 | 67 system=`uname -rs` |
devi@79 | 68 login_from=`who | grep "${tty##/dev/}" | awk '{print $6;}' | tr -d '()'` |
devi@70 | 69 #[ -n "$bsd" ] && login_from="" #FIXME! |
devi@70 | 70 start_time=`date +%s` |
devi@70 | 71 hostname=`hostname -f 2> /dev/null` |
devi@70 | 72 [ -n "$bsd" ] && hostname=`hostname` |
devi@70 | 73 |
igor@155 | 74 cat <<INFO | perl |
igor@155 | 75 use DBI; |
igor@155 | 76 use strict; |
igor@155 | 77 my \$db = DBI->connect("dbi:SQLite:$L3_SQLITE", "", "", |
igor@155 | 78 {RaiseError => 1, AutoCommit => 1}); |
igor@155 | 79 |
igor@155 | 80 \$db->do("CREATE TABLE IF NOT EXISTS sessions (id INTEGER PRIMARY KEY, |
igor@155 | 81 session TEXT, hostname TEXT, user TEXT, uid TEXT, login_from TEXT, |
igor@155 | 82 tty TEXT, system TEXT, parent TEXT, ppid TEXT, pid TEXT, start_time TEXT, lang TEXT)"); |
igor@155 | 83 \$db->do("INSERT INTO sessions VALUES (NULL, '$L3_SESSION_ID', '$hostname', '$USER', '$UID', '$login_from', |
igor@155 | 84 '$tty', '$system', '$parent', '$PPID', '$$', |
igor@155 | 85 '$start_time', '$LANG')"); |
igor@155 | 86 INFO |
igor@155 | 87 #perl $temp_l3_name #; rm $temp_l3_name; unset temp_l3_name |
igor@155 | 88 |
devi@70 | 89 cat <<INFO > $L3_HOME/$L3_SESSION_ID.info |
devi@70 | 90 <session> |
devi@70 | 91 <local_session_id>$L3_SESSION_ID</local_session_id> |
devi@70 | 92 <hostname>$hostname</hostname> |
devi@70 | 93 <user>$USER</user> |
devi@70 | 94 <uid>$UID</uid> |
devi@70 | 95 <login_from>$login_from</login_from> |
devi@79 | 96 <tty>$tty</tty> |
devi@70 | 97 <system>$system</system> |
devi@70 | 98 <parent>$parent</parent> |
devi@70 | 99 <ppid>$PPID</ppid> |
devi@70 | 100 <pid>$$</pid> |
devi@70 | 101 <start_time>$start_time</start_time> |
devi@76 | 102 <lang>$LANG</lang> |
devi@70 | 103 </session> |
devi@70 | 104 INFO |
devi@70 | 105 |
devi@79 | 106 unset parent system login_from start_time hostname tty |
devi@70 | 107 } |
devi@70 | 108 |
devi@70 | 109 _l3_run_script() |
devi@70 | 110 { |
devi@70 | 111 uname -a | grep -qi bsd && bsd=yes |
devi@70 | 112 flush="-f" #linux |
devi@70 | 113 [ -n "$bsd" ] && flush="-t 0" #freebsd |
devi@76 | 114 export L3_PARENT_TTY=`/usr/bin/tty` |
igor@149 | 115 exec script $flush -c ${0#-} -q $L3_HOME/${L3_SESSION_ID}.script |
devi@70 | 116 } |
devi@70 | 117 |
devi@76 | 118 # ===================== STAGE 2 ============================ |
devi@76 | 119 |
devi@76 | 120 _l3_env() |
devi@76 | 121 { |
devi@76 | 122 trap l3_close_session 2 |
devi@76 | 123 trap l3_close_session EXIT |
devi@76 | 124 true |
devi@76 | 125 } |
devi@76 | 126 |
devi@76 | 127 l3_close_session() |
devi@70 | 128 { |
devi@71 | 129 ( |
devi@71 | 130 echo '<history>' |
devi@71 | 131 history | sed 's/&/\&/; s/</\</g; s/>/\>/g' |
devi@71 | 132 echo '</history>' |
devi@71 | 133 ) >> $L3_HOME/$L3_SESSION_ID.info |
devi@70 | 134 } |
devi@70 | 135 |
devi@76 | 136 _l3_init_prompt() |
devi@76 | 137 { |
devi@76 | 138 PS1='[\u@\h:\W]\$ ' |
devi@77 | 139 [ $UID = 0 ] \ |
devi@77 | 140 && PS1='\[\033[0;31m\]'$PS1'\[\033[0m\]' \ |
devi@77 | 141 || PS1='\[\033[0;32m\]'$PS1'\[\033[0m\]' \ |
devi@76 | 142 export PS1 |
devi@76 | 143 } |
devi@76 | 144 |
devi@76 | 145 l3_fix_prompt() |
devi@76 | 146 { |
igor@119 | 147 export PS1='\[$($L3_HOME/l3prompt "v3#\!#$?#$UID#$$#$(/bin/date +%s)#$PWD#$RANDOM#")$(l3_save_last_line >& /dev/null)\]'$PS1 |
devi@76 | 148 } |
devi@76 | 149 |
devi@76 | 150 _l3_tamper_editors() |
devi@76 | 151 { |
devi@76 | 152 for editor_file in $_l3_editors_to_tamper |
devi@76 | 153 do |
devi@76 | 154 [ -x $editor_file ] || continue |
devi@76 | 155 editor_name=${editor_file##*/} |
devi@76 | 156 eval " |
devi@76 | 157 $editor_name() { |
devi@76 | 158 if [ -d \"\$1\" ] |
devi@76 | 159 then |
devi@76 | 160 $editor_file \"\$1\" |
devi@76 | 161 return \$? |
devi@76 | 162 else |
devi@76 | 163 TIME=\"\`date +%s\`\" |
devi@76 | 164 DIR=\"\" |
devi@76 | 165 [ \"\${1#/}\" = \"\$1\" ] && DIR=\"\$PWD/\" |
devi@80 | 166 DIFFNAME=\"\${L3_SESSION_ID}_\${TIME}\`echo \$DIR\$1| sed s@_@__@ | sed 's@/@_@g'\`.diff\" |
devi@76 | 167 old_file=\"/tmp/l3-saved-\$\$.\$RANDOM.\$RANDOM\" |
devi@76 | 168 /bin/cp -- \"\$1\" \"\$old_file\" 2> /dev/null |
devi@76 | 169 $editor_file \"\$@\" || ERR=\$? |
igor@112 | 170 if [ -e \"\$old_file\" ] |
igor@112 | 171 then |
igor@112 | 172 diff -u \"\$old_file\" \"\$1\" > \"\$L3_HOME/\$DIFFNAME\" 2> /dev/null |
igor@112 | 173 else |
igor@112 | 174 diff -u /dev/null \"\$1\" > \"\$L3_HOME/\$DIFFNAME\" 2> /dev/null |
igor@112 | 175 fi |
devi@76 | 176 /bin/rm \"\$old_file\" 2> /dev/null |
devi@76 | 177 return \$ERR |
devi@76 | 178 fi |
devi@76 | 179 } |
devi@76 | 180 " |
devi@76 | 181 L3_TAMPERED_EDITORS="$L3_TAMPERED_EDITORS $editor_name" |
devi@76 | 182 done |
devi@76 | 183 [ -n "$L3_TAMPERED_EDITORS" ] && export L3_TAMPERED_EDITORS |
devi@76 | 184 } |
devi@76 | 185 |
devi@76 | 186 _l3_tamper_commands() |
devi@76 | 187 { |
devi@76 | 188 tty() |
devi@76 | 189 { |
devi@76 | 190 [ -n "$L3_PARENT_TTY" ] && echo $L3_PARENT_TTY || /usr/bin/tty |
devi@76 | 191 } |
devi@76 | 192 } |
devi@76 | 193 |
devi@76 | 194 _l3_unset_internal() |
devi@76 | 195 { |
devi@76 | 196 unset `set | grep '^_l3_.*()' | sed 's/()//'` |
devi@76 | 197 unset `set | grep '^_l3_.*=' | sed 's/=.*//'` |
devi@76 | 198 } |
devi@78 | 199 |
devi@78 | 200 l3shot() |
devi@78 | 201 { |
devi@78 | 202 if [ -x "`which xwd`" ] |
devi@78 | 203 then |
devi@78 | 204 _l3_home=${L3_HOME:-~/.lilalo} |
devi@78 | 205 shot_name="${L3_SESSION_ID}_`date +%s`".xwd |
devi@78 | 206 echo -n Choose window to be shoot ... >&2 |
devi@78 | 207 [ -d ${_l3_home} ] || mkdir -p ${_l3_home} |
devi@78 | 208 xwd -out "$_l3_home/$shot_name" \ |
devi@78 | 209 && echo Screenshot is written to ${_l3_home}/${shot_name} \ |
igor@115 | 210 && curl -s -F photo=@$_l3_home/$shot_name http://`l3-config backend_address`/l3-upload |
devi@78 | 211 else |
devi@78 | 212 { |
devi@78 | 213 echo |
devi@78 | 214 echo "Can't make screenshot :(" |
devi@78 | 215 echo |
devi@78 | 216 echo I must use program xwd to make screenshot, |
devi@78 | 217 echo but it seems not to be installed |
devi@78 | 218 echo Try to find the program in the \"xbase-clients\" package |
devi@78 | 219 echo |
devi@78 | 220 } >&2 |
devi@78 | 221 fi |
devi@78 | 222 } |
devi@97 | 223 |
igor@111 | 224 l3upload() |
igor@111 | 225 { |
igor@111 | 226 if [ $# -lt 1 ] |
igor@111 | 227 then |
igor@111 | 228 echo Usage: |
igor@111 | 229 echo |
igor@144 | 230 echo l3upload "<filename> [<time>]" |
igor@111 | 231 echo |
igor@111 | 232 echo "<filename>" - name of the file to upload |
igor@111 | 233 return 1 |
igor@111 | 234 else |
igor@111 | 235 source=$1 |
igor@144 | 236 time=`date +%s` |
igor@144 | 237 [ -n "$2" ] && time="$2" |
igor@144 | 238 target="${L3_SESSION_ID}_$time"_"$(echo $source|sed s@.*/@@)" |
igor@111 | 239 if echo $source | grep -q http:// |
igor@111 | 240 then |
igor@111 | 241 curl -s "$source" > /tmp/$target |
igor@111 | 242 else |
igor@111 | 243 [ -r "$source" ] || { echo "l3upload: Can't open $source for reading" > /dev/stderr; return 1; } |
igor@111 | 244 cp $source /tmp/$target |
igor@111 | 245 fi |
igor@111 | 246 echo Uploaded file name is ${target} |
igor@115 | 247 curl -s -F photo=@/tmp/$target http://`l3-config backend_address`/l3-upload && rm -f /tmp/$target |
igor@111 | 248 fi |
igor@111 | 249 } |
igor@111 | 250 |
igor@144 | 251 l3mass_upload() |
igor@144 | 252 { |
igor@144 | 253 for i in "$@" |
igor@144 | 254 do |
igor@144 | 255 l3upload $i `perl -e 'print (((stat("$i"))[9])."\n")'` |
igor@144 | 256 done |
igor@144 | 257 } |
igor@144 | 258 |
devi@97 | 259 # Append lines from "$@" files to the end of the shell history |
igor@111 | 260 hist_append () |
igor@111 | 261 { |
igor@111 | 262 eval $(cat "$@" | sed 's/"/\\\\"/g' | while read line; do echo history -s \"$line\"\;; done); |
devi@97 | 263 } |
devi@97 | 264 |
devi@97 | 265 l3_save_last_line () |
devi@97 | 266 { |
devi@97 | 267 ( |
devi@97 | 268 echo '<cline>' |
devi@97 | 269 history 1 | sed 's/&/&/; s/</\</g; s/>/\>/g' |
devi@97 | 270 echo '</cline>' |
devi@97 | 271 ) >> $L3_HOME/$L3_SESSION_ID.info |
devi@97 | 272 } |
devi@97 | 273 |
devi@107 | 274 l3 () |
devi@107 | 275 { |
devi@107 | 276 case "$1" in |
igor@155 | 277 context) |
igor@155 | 278 if [ -z "$2" ] |
igor@155 | 279 then |
igor@155 | 280 echo "$L3_CONTEXT" |
igor@155 | 281 else |
igor@155 | 282 echo $2 | grep -q ^/ && L3_CONTEXT="$2" || L3_CONTEXT="$L3_CONTEXT/$2" |
igor@155 | 283 export L3_CONTEXT="`echo $L3_CONTEXT | perl -e '$_=<>; 1 while s@/[^/]*/\.\.@@; print;'`" |
igor@155 | 284 fi |
devi@107 | 285 ;; |
devi@107 | 286 cd) |
devi@107 | 287 echo l3cd="$2" > ~/.l3rc |
devi@107 | 288 ;; |
devi@107 | 289 pwd) |
devi@107 | 290 grep ^l3cd= ~/.l3rc | sed s/[^=]*=// |
devi@107 | 291 ;; |
devi@107 | 292 *) |
igor@155 | 293 l3text "$@" |
devi@107 | 294 ;; |
devi@107 | 295 esac |
devi@107 | 296 } |
devi@97 | 297 |
igor@109 | 298 |
igor@109 | 299 |