2023-02-01 13:31:36 +03:00
|
|
|
#! /bin/bash
|
|
|
|
|
2023-03-11 22:20:57 +03:00
|
|
|
# DESCRIPTION:
|
|
|
|
# Converting JPEG collection to MP4.
|
|
|
|
# This is only a local "proof of conept" for testing and debugging.
|
2023-02-01 13:31:36 +03:00
|
|
|
#
|
2023-03-11 22:20:57 +03:00
|
|
|
# DEPENDENCIES:
|
|
|
|
# - ffmpeg
|
2023-02-01 13:31:36 +03:00
|
|
|
#
|
2023-03-11 22:20:57 +03:00
|
|
|
# PARAMETERS:
|
|
|
|
# 1: "qn" - execution without pauses
|
|
|
|
# 2: custom configuration file path
|
|
|
|
# 3: periods: '' - today | '-d' - yesterday | '-w' - last week | '-m' - last month | '-y' - last year
|
2023-02-01 13:31:36 +03:00
|
|
|
#
|
2023-03-11 22:20:57 +03:00
|
|
|
# FUNCTIONS:
|
2023-02-01 13:31:36 +03:00
|
|
|
#
|
|
|
|
|
2023-03-11 22:20:57 +03:00
|
|
|
#######################################
|
|
|
|
# Print message and add to log.
|
|
|
|
# Globals:
|
|
|
|
# logs
|
|
|
|
# Arguments:
|
|
|
|
# 1: message to print and logging
|
|
|
|
#######################################
|
2023-02-01 13:31:36 +03:00
|
|
|
addtologs() {
|
2023-03-11 22:20:57 +03:00
|
|
|
echo "$(date +'%Y.%m.%d-%H:%M:%S') $1" | tee -a "${logs}"
|
2023-02-01 13:31:36 +03:00
|
|
|
}
|
2023-03-11 22:20:57 +03:00
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Waiting for press [ENTER].
|
|
|
|
# Globals:
|
|
|
|
# None
|
|
|
|
# Arguments:
|
|
|
|
# None
|
|
|
|
#######################################
|
2023-02-01 13:31:36 +03:00
|
|
|
execpause() {
|
2023-03-11 22:20:57 +03:00
|
|
|
read -r -p "Press [ENTER] to continue... "
|
2023-02-01 13:31:36 +03:00
|
|
|
}
|
2023-03-11 22:20:57 +03:00
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Exit procedure.
|
|
|
|
# Globals:
|
|
|
|
# show
|
|
|
|
# Arguments:
|
|
|
|
# None
|
|
|
|
#######################################
|
2023-02-01 13:31:36 +03:00
|
|
|
execquite() {
|
2023-03-11 22:20:57 +03:00
|
|
|
addtologs "execution time is $(($(date +%s)-time)) seconds, exit"
|
|
|
|
if [ "${show}" != "qn" ]; then
|
|
|
|
execpause
|
|
|
|
fi
|
|
|
|
exit
|
2023-02-01 13:31:36 +03:00
|
|
|
}
|
2023-03-11 22:20:57 +03:00
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Error exit procedure with Telegram notification.
|
|
|
|
# Globals:
|
|
|
|
# telegramapiurl
|
|
|
|
# telegramchatid
|
|
|
|
# Arguments:
|
|
|
|
# 1: message to print and logging
|
|
|
|
#######################################
|
2023-02-01 13:31:36 +03:00
|
|
|
execerror() {
|
2023-03-11 22:20:57 +03:00
|
|
|
addtologs "error: $1"
|
|
|
|
curl -s -X POST "${telegramapiurl}/sendMessage" \
|
|
|
|
-d "chat_id=${telegramchatid}" \
|
|
|
|
-d "text=$(basename -s .sh "$0") error: $1" \
|
|
|
|
>> /dev/null 2>&1
|
|
|
|
execquite
|
2023-02-01 13:31:36 +03:00
|
|
|
}
|
2023-03-11 22:20:57 +03:00
|
|
|
|
|
|
|
#######################################
|
|
|
|
# Parsing config file and creating global vars.
|
|
|
|
# Globals:
|
|
|
|
# None
|
|
|
|
# Arguments:
|
|
|
|
# None
|
|
|
|
#######################################
|
2023-02-01 13:31:36 +03:00
|
|
|
getconfig() {
|
2023-03-11 22:20:57 +03:00
|
|
|
logs=$(grep "logs=" "${conf}" | cut -d= -f2)
|
|
|
|
list=$(grep "list=" "${conf}" | cut -d= -f2)
|
|
|
|
imgroot=$(grep "imgroot=" "${conf}" | cut -d= -f2)
|
|
|
|
IFS=" " read -r -a imgnames <<< "$(grep "imgnames=" "${conf}" | cut -d= -f2)"
|
|
|
|
xscale=$(grep "xscale=" "${conf}" | cut -d= -f2)
|
|
|
|
yscale=$(grep "yscale=" "${conf}" | cut -d= -f2)
|
|
|
|
mp4fps=$(grep "mp4fps=" "${conf}" | cut -d= -f2)
|
|
|
|
telegramapiurl=$(grep "telegramapiurl=" "${conf}" | cut -d= -f2)
|
|
|
|
telegramchatid=$(grep "telegramchatid=" "${conf}" | cut -d= -f2)
|
2023-02-01 13:31:36 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
#
|
2023-03-15 15:17:48 +03:00
|
|
|
# VARIABLES:
|
2023-02-01 13:31:36 +03:00
|
|
|
#
|
|
|
|
|
2023-03-11 22:20:57 +03:00
|
|
|
show=$1
|
|
|
|
conf=$2
|
|
|
|
if [ -z "${conf}" ] || [ "${conf}" == "-" ]; then
|
|
|
|
conf="$(dirname "$(realpath "$0")")/$(basename -s .sh "$0").conf"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
2023-03-11 22:20:57 +03:00
|
|
|
when=$3
|
|
|
|
if [ -z "${when}" ]; then
|
|
|
|
d=$(date +"%d")
|
|
|
|
w=$(date +"%V")
|
|
|
|
m=$(date +"%m")
|
|
|
|
y=$(date +"%Y")
|
|
|
|
duration=1
|
|
|
|
imgpath="${y}/${m}/${w}/${d}"
|
|
|
|
imgname="${y}.${m}.${d}"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
2023-03-11 22:20:57 +03:00
|
|
|
if [ "${when}" == "-d" ]; then
|
|
|
|
d=$(date -d "-1 day" +"%d")
|
|
|
|
m=$(date +"%m")
|
|
|
|
if [ "$(date -d '-1 day' +'%m')" != "$(date +'%m')" ]; then
|
|
|
|
m=$(date -d '-1 day' +'%m')
|
|
|
|
fi
|
|
|
|
y=$(date +"%Y")
|
|
|
|
if [ "$(date -d '-1 day' +'%Y')" != "$(date +'%Y')" ]; then
|
|
|
|
y=$(date -d '-1 day' +'%Y')
|
|
|
|
fi
|
|
|
|
w=$(date +"%V")
|
|
|
|
if [ "$(date +'%w')" == "1" ]; then
|
|
|
|
w=$(date -d "-1 week" +"%V")
|
|
|
|
fi
|
|
|
|
duration=1
|
|
|
|
imgpath="${y}/${m}/${w}/${d}"
|
|
|
|
imgname="${y}.${m}.${d}"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
2023-03-11 22:20:57 +03:00
|
|
|
if [ "${when}" == "-w" ]; then
|
|
|
|
w=$(date -d "-1 week" +"%V")
|
|
|
|
m=$(date +"%m")
|
|
|
|
if [ "$(date -d '-1 week' +'%m')" != "$(date +'%m')" ]; then
|
|
|
|
m=$(date -d '-1 week' +'%m')
|
|
|
|
fi
|
|
|
|
y=$(date +"%Y")
|
|
|
|
if [ "$(date -d '-1 week' +'%Y')" != "$(date +'%Y')" ]; then
|
|
|
|
y=$(date -d '-1 week' +'%Y')
|
|
|
|
fi
|
|
|
|
duration=7
|
|
|
|
imgpath="${y}/*/${w}"
|
|
|
|
imgname="${y}-w${w}"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
2023-03-11 22:20:57 +03:00
|
|
|
if [ "${when}" == "-m" ]; then
|
|
|
|
m=$(date -d "-1 month" +"%m")
|
|
|
|
y=$(date +"%Y")
|
|
|
|
if [ "$(date -d '-1 month' +'%Y')" != "$(date +'%Y')" ]; then
|
|
|
|
y=$(date -d '-1 month' +'%Y')
|
|
|
|
fi
|
|
|
|
duration=30
|
|
|
|
imgpath="${y}/${m}"
|
|
|
|
imgname="${y}.${m}"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
2023-03-11 22:20:57 +03:00
|
|
|
if [ "${when}" == "-y" ]; then
|
|
|
|
y=$(date -d "-1 year" +"%Y")
|
|
|
|
duration=360
|
|
|
|
imgpath="${y}"
|
|
|
|
imgname="${y}"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
|
|
|
|
|
|
|
time=$(date +%s)
|
2023-03-11 22:20:57 +03:00
|
|
|
cd "$(dirname "$(realpath "$0")")" || execerror
|
|
|
|
if [ ! -e "${conf}" ]; then
|
|
|
|
execerror "Not found config file: ${conf}"
|
2023-02-01 13:31:36 +03:00
|
|
|
else
|
2023-03-11 22:20:57 +03:00
|
|
|
getconfig
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
|
|
|
if [ -z "${logs}" ];then
|
2023-03-11 22:20:57 +03:00
|
|
|
logs=/dev/null
|
|
|
|
elif [ ! -e "${logs}" ];then
|
|
|
|
touch "${logs}"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
|
|
|
if [ -z "${list}" ];then
|
2023-03-11 22:20:57 +03:00
|
|
|
list="$(dirname "$(realpath "$0")")/$(basename -s .sh "$0").list"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
2023-03-11 22:20:57 +03:00
|
|
|
if [ ! -e "${list}" ];then
|
|
|
|
touch "${list}"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
|
|
|
if ! command -v ffmpeg &> /dev/null; then
|
2023-03-11 22:20:57 +03:00
|
|
|
execerror "Not found dependencies"
|
2023-02-01 13:31:36 +03:00
|
|
|
fi
|
|
|
|
|
|
|
|
#
|
2023-03-11 22:20:57 +03:00
|
|
|
# MAIN:
|
2023-02-01 13:31:36 +03:00
|
|
|
#
|
|
|
|
|
2023-03-11 22:20:57 +03:00
|
|
|
for name in "${imgnames[@]}"; do
|
|
|
|
imgmatch="*${name}*.jpeg"
|
|
|
|
imgarray=()
|
|
|
|
while read -r FILE; do
|
|
|
|
imgarray+=("${FILE}")
|
|
|
|
done < <(find "${imgroot}/${imgpath}" -name "${imgmatch}" | sort)
|
|
|
|
imgcount=${#imgarray[*]}
|
2023-02-01 13:31:36 +03:00
|
|
|
|
2023-03-11 22:20:57 +03:00
|
|
|
echo '' > "${list}"
|
|
|
|
for item in "${imgarray[@]}"; do
|
|
|
|
echo file \'"${item}"\' >> "${list}"
|
|
|
|
done
|
2023-02-01 13:31:36 +03:00
|
|
|
|
2023-03-11 22:20:57 +03:00
|
|
|
imgdest="${imgroot}/${name}_${imgname}.mp4"
|
|
|
|
echo "${imgdest}"
|
|
|
|
if ffmpeg -r "${imgcount}/${duration}" -f concat -safe 0 -i "${list}" \
|
|
|
|
-c:v libx264 -vf "scale=${xscale}:${yscale},fps=${mp4fps},format=yuv420p" \
|
|
|
|
"${imgdest}" -y; then
|
|
|
|
addtologs "converted ${imgcount} images to ${imgdest} with duration ${duration}"
|
|
|
|
else
|
|
|
|
execerror "converted ${imgcount} images to ${imgdest} with duration ${duration}"
|
|
|
|
fi
|
2023-02-01 13:31:36 +03:00
|
|
|
done
|
|
|
|
execquite
|