最近因為 上級要知道 OpenKM(簡稱 OKM) 內容的更動狀況 , 需要每週 report 一次 !!
主要是看看這星期 OKM 內容有哪些人更動!!
Google 一下 有關 OKM 的 auto report , 發現需要會 java script , 我不會 @@ !!
想說 , OKM 的 dashboard 可以看到 log 內容 , 應該 找一下 log file , 也會有吧 !!
找了半天 , 發現 /openkm-6.2.2-community/tomcat/repository/okmdb.log 內有我要的訊息 , 好吧 , 山不轉 人轉 , 寫一個 shell script + crontab 來執行 auto report 吧 !!
首先寫一個 shell , 由 okmdb.log 內容取出 document create/delete & check in 的項目
到一個 temp file , shell 如下:
#!/bin/sh
#
# vi:set ts=4:
#############################
## ===== defind echo color
#############################
COLOR_ECHO="echo -e" ## in Fedora the color echo need have -e argument.
COLOR_NORMAL="\033[0m"
COLOR_BOLD="\033[1m"
COLOR_RED="\033[31m"
COLOR_GREEN="\033[32m"
COLOR_YELLOW="\033[33m"
COLOR_BLUE="\033[34m"
#############################
## ==== check log file exist.
#############################
OKMDB_LOG="/home/jeff/openkm-6.2.2-community/tomcat/repository/okmdb.log"
TEMP_FILE="/home/jeff/okm_report.txt"
if [ ! -e ${OKMDB_LOG} ];then
${COLOR_ECHO} "${COLOR_BOLD}""${COLOR_RED}" \
"The log file \"${OKMDB_LOG}\" not exist !! " \
"${COLOR_NORMAL}"
exit
fi
#############################
## ==== Crate title
#############################
echo -e "ITEM\t\t\tDATE\t\t\tFILES\t\t\tUSER" > ${TEMP_FILE}
echo >> ${TEMP_FILE}
#############################
## ==== get document create event log.
#############################
DOC_CREATE=`cat ${OKMDB_LOG} | grep "CREATE_DOCUMENT" | sed 's/\ /:/g'`
IFS="
"
for list in ${DOC_CREATE} ; do
IFS=','
_date=`echo ${list} | awk '{print $3}' | sed 's/\..*//g' | sed 's/'\''//g' `
_file=`echo ${list} | awk '{print $7}' | sed 's/'\''//g' | sed 's/\/okm\:root\///g' `
_user=`echo ${list} | awk '{print $8}' | sed 's/'\''//g' | sed 's/)//g'`
echo -e "CREATE\t\t${_date}\t\t${_file}\t\t${_user}" >> ${TEMP_FILE}
done
echo >> ${TEMP_FILE}
#############################
## ==== get document delete event log.
#############################
DOC_DELETE=`cat ${OKMDB_LOG} | grep "DELETE_DOCUMENT" | sed 's/\ /:/g'`
IFS="
"
for list in ${DOC_DELETE} ; do
IFS=','
_date=`echo ${list} | awk '{print $3}' | sed 's/\..*//g' | sed 's/'\''//g' `
_file=`echo ${list} | awk '{print $6}' | sed 's/'\''//g' | sed 's/\/okm\:root\///g' `
_user=`echo ${list} | awk '{print $7}' | sed 's/'\''//g' | sed 's/)//g'`
echo -e "DELETE\t\t${_date}\t\t${_file}\t\t${_user}" >> ${TEMP_FILE}
done
echo >> ${TEMP_FILE}
#############################
## ==== get document modify event log.
#############################
DOC_CHECKIN=`cat ${OKMDB_LOG} | grep "CHECKIN_DOCUMENT" | sed 's/\ /:/g'`
IFS="
"
for list in ${DOC_CHECKIN} ; do
IFS=','
_date=`echo ${list} | awk '{print $3}' | sed 's/\..*//g' | sed 's/'\''//g' `
_file=`echo ${list} | awk '{print $7}' | sed 's/'\''//g' | sed 's/\/okm\:root\///g' `
_user=`echo ${list} | awk '{print $8}' | sed 's/'\''//g' | sed 's/)//g'`
echo -e "CHECKIN\t\t${_date}\t\t${_file}\t\t${_user}" >> ${TEMP_FILE}
done
echo >> ${TEMP_FILE}
##############################
## ==== send notify mail
#############################
NOTIFY_MAIL="jeff@xxxxxxx.com.tw,ch@xxxxxxx.com.tw,emiliehuang@xxxxxxx.com.tw,alvin@xxxxxxx.com.tw,pp@xxxxxxx.com.tw"
#NOTIFY_MAIL="jeff@xxxxxxx.com.tw"
mail -s "Content report" ${NOTIFY_MAIL} < ${TEMP_FILE}
rm -rf ${TEMP_FILE}
## ==== remove log file ??
if [ ! -z "$1" ] && [ "$1" == "-d" ];then
echo > ${OKMDB_LOG}
fi
#############################
接著 , 我不想每天(星期)都去檢查 report file , 就將這個 file 內容直接mail 給上級吧^^ !!
要讓 fedora 發 mail 其實蠻簡單的 用 "mail -s "Content report" ${NOTIFY_MAIL} < ${TEMP_FILE}"
就可以了!!
不過要先設定 smtp 的內容 , google 一下 其實也不難 , 只要建立 /home/jeff/.mailrc 檔案, 且.mailrc 內容填入下列即可:
set from=Server_AUTO<jeff@xxxxxx.com.tw> smtp=xxxx.com.tw
set smtp-auth-user=jeff@xxxx.com.tw smtp-auth-password=*******
set smtp-auth=login
上面有些個人訊息 , 就用 xxxx 和 **** 代替 !!
收到 mail 的內容就會如下:
ITEM DATE FILES USER
CREATE 2013-02-06:10:28:40 share/data_sip_image_ec510/sip/Image/English/Lower/btn_backspace_press.png alvin
CREATE 2013-02-06:10:29:18 share/data_sip_image_ec510/sip/Image/English/Upper/btn_backspace_press.png alvin..........
沒有留言:
張貼留言