summaryrefslogtreecommitdiffabout
path: root/doc/on-upload-photo.bash
blob: 483b68aa4a6a0dd2a3a5237e3ced64bfe8aaf27d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#!/bin/bash
test -z "$targetroot" && targetroot="$(dirname "$EYEFI_UPLOADED")"

make_vars() {
 echo -n "ttype=$1 "
 sed <<<$etime -e 's,^[^/]\+/,,' -e 's, 0*, hour=,' -e 's,^0*,year=,' -e 's,:0*, month=,' -e 's,:0*, day=,' -e 's,:0*, minute=,' -e 's,:0*, second=,'
}

j_time() {
 local j="$1"
 local etime="$(exiftime -s / -tg "$j" 2>/dev/null)"
 [[ -z "$etime" ]] && etime="$(exiftime -s / -td "$j" 2>/dev/null)"
 [[ -z "$etime" ]] && etime="$(exiftime -s / -tc "$j" 2>/dev/null)"
 [[ -z "$etime" ]] && return 1
 make_vars jpg <<<$etime
}

a_time() {
 local a="$1"
 local etime="$(iii-extract-riff-chunk "$a" '/RIFF.AVI /LIST.ncdt/nctg'|dd bs=1 skip=82 count=19 2>/dev/null)"
 [[ -z "$etime" ]] && return 1
 make_vars avi <<<$etime
}

ul="$EYEFI_UPLOADED"

if ! vars="$(j_time "$ul"||a_time "$ul")" ; then
 report="Timeless $(basename "$ul") uploaded"
else
 eval "$vars"
 stem="$(printf '%04d-%02d-%02d--%02d-%02d-%02d' "$year" "$month" "$day" "$hour" "$minute" "$second")"
 targetdir="$(printf "%s/%04d-%02d" "$targetroot" "$year" "$month")"
 mkdir -p "$targetdir"
 success=false
 for((i=0;i<100;++i)) do
  [[ $i = 0 ]] && tf="$stem.$ttype" || tf="$stem ($i).$ttype"
  tf="$targetdir/$tf"
  if ln -T "$ul" "$tf" &>/dev/null && rm "$ul"  ; then
   success=true
   break
  fi
 done
 if $success ; then
  report="$(basename "$tf") uploaded"
  if [[ -n "$EYEFI_LOG" ]] ; then
   ln -T "$EYEFI_LOG" "${tf}.log" && rm "$EYEFI_LOG" || report="$report, but log..."
  fi
 else
  report="$(basename "$ul") uploaded, but..."
 fi
fi
echo "$report"

type iii_report &>/dev/null && iii_report "$report"