3 # Copyright 2014 Paul Hänsch
5 # This file is part of Confetti.
7 # Confetti is free software: you can redistribute it and/or modify
8 # it under the terms of the GNU Affero General Public License as published by
9 # the Free Software Foundation, either version 3 of the License, or
10 # (at your option) any later version.
12 # Confetti is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU Affero General Public License for more details.
17 # You should have received a copy of the GNU Affero General Public License
18 # along with Confetti. If not, see <http://www.gnu.org/licenses/>.
20 pdflatex="$(where pdflatex |head -n1 || echo false)"
21 course="${_GET[course]}"
22 fromdate=$_GET['fromdate']
23 fromdate=$(date -d "$fromdate" +%s)
24 [ -z "$fromdate" ] && fromdate=$(date +%s)
26 . ${_EXEC}/pages/courses.sh loadfunctions
27 . ${_EXEC}/pages/attendees.sh loadfunctions
29 tex_clean() { #in dire need for improvement
30 echo "$*" |tr -d '{&}\'
34 list_attendee() { #Parameter: Cardfile
36 cardfile="$_DATA/vcard/${id}"
41 vcf_parse "$cardfile" |while read -r line; do
44 value*) eval "$line";;
47 if [ -z "$key" ]; then
50 values[$key]="$(tex_clean "$value")"
51 for t in ${(k)tag}; do
52 tags[${key}_$t]="$tag[$t]"
55 if [ -n "$values[$key]" ]; then
57 while [ -n "$values[$key$n]" ]; do n=$(($n + 1)); done
68 for n in TEL TEL{0..10}; do if (echo "$values[$n]" |grep -Eq '[0-9]'); then
69 [ -n "$tel" ] && tel="$tel\\newline $values[$n]" || tel="$values[$n]"
72 for n in NOTE NOTE{0..10}; do if [ -n "$values[$n]" ]; then
73 [ -n "$note" ] && note="$note\\newline $values[$n]" || note="$values[$n]"
75 echo -E "$values[FN] & $values[BDAY] & $tel & $note"
78 get_dates() { #Parameter: Calendarfile
79 calendarfile="$_DATA/ical/$course"
84 ics_parse "$calendarfile" |while read -r line; do
87 value*) eval "$line";;
90 if [ -z "$key" ]; then
93 values[$key]="$(tex_clean "$value")"
94 for t in ${(k)tag}; do
95 tags[${key}_$t]="$tag[$t]"
98 if [ -n "$values[$key]" ]; then
100 while [ -n "$values[$key$n]" ]; do n=$(($n + 1)); done
110 dtstart="$values[DTSTART]"
111 [ -z "$dtstart" ] && dtstart=$(date +%Y%m%dT%H%M%S)
112 echo "$dtstart" |case "$dtstart" in
113 *Z) sed -rn 's:^([0-9]{4})([0-9]{2})([0-9]{2})T([0-9]{2})([0-9]{2})([0-9]{2})Z$:\1-\2-\3 \4\:\5\:\6 UTC:p';;
114 TZID*) sed -rn 's:^TZID=(.+)\:([0-9]{4})([0-9]{2})([0-9]{2})T([0-9]{2})([0-9]{2})([0-9]{2})$:TZ="\1" \2-\3-\4 \5\:\6\:\7:p';;
115 *) sed -rn 's:^([0-9]{4})([0-9]{2})([0-9]{2})T([0-9]{2})([0-9]{2})([0-9]{2})$:\1-\2-\3 \4\:\5\:\6:p';;
117 rrule="$values[RRULE]"
118 rr_int="$(echo $rrule |sed -rn 's:^.*INTERVAL=([0-9]+)(;.*)?$:\1:p')"
119 rr_freq="$(echo $rrule |sed -rn 's:^.*FREQ=(YEARLY|MONTHLY|WEEKLY|DAILY)(;.*)?$:\1:p')"
121 YEARLY) rec="$rr_int year";;
122 MONTHLY) rec="$rr_int month";;
123 DAILY) rec="$rr_int day";;
124 *) rec="$rr_int week";;
127 next_date="$dts_date"
129 while [ $n -gt 0 ]; do
130 if [ "$(date -d "$next_date" +%s)" -gt "$(date +%s)" ]; then
131 dtlist="$dtlist & $(date -d "$next_date" +"%d. %b.")"
134 next_date="$(date -d "$next_date + $rec" +%Y-%m-%d)"
140 if [ -r "${_DATA}/ical/${course}" ]; then
141 . ${_EXEC}/templates/course_print.sh >"${_DATA}/temp/courselist_${course}.tex"
142 [ -e "${_DATA}/temp/courselist_${course}.pdf" ] && rm "${_DATA}/temp/courselist_${course}.pdf"
143 "$pdflatex" -halt-on-error -output-directory "${_DATA}/temp/" "${_DATA}/temp/courselist_${course}.tex" |debug >/dev/null
144 "$pdflatex" -halt-on-error -output-directory "${_DATA}/temp/" "${_DATA}/temp/courselist_${course}.tex" |debug >/dev/null
146 if [ -r "${_DATA}/temp/courselist_${course}.pdf" ]; then
147 echo 'Content-Type: application/x-pdf\n'
148 cat "${_DATA}/temp/courselist_${course}.pdf"