Gentoo Archives: gentoo-commits

From: "Tony Vroon (chainsaw)" <chainsaw@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] gentoo-x86 commit in net-misc/asterisk/files/1.6.2: asterisk.initd2 asterisk-1.6.2.11-strip-noapi.patch asterisk.logrotate
Date: Fri, 20 Aug 2010 23:12:57
Message-Id: 20100820231254.07B4E2004C@flycatcher.gentoo.org
1 chainsaw 10/08/20 23:12:54
2
3 Added: asterisk.initd2 asterisk-1.6.2.11-strip-noapi.patch
4 asterisk.logrotate
5 Log:
6 Tweak nm call to avoid binary deletion as requested by Alexey McSakoff in bug #302736. Bashims removed from init script by Kerin Millar & Federico Santulli, closes bug #309277. Stock audio prompts now split out to separate ebuilds and logrotate support thanks to Jaco Kroon, closes bug #328513 & #329281 respectively.
7 (Portage version: 2.2_rc67/cvs/Linux x86_64)
8
9 Revision Changes Path
10 1.1 net-misc/asterisk/files/1.6.2/asterisk.initd2
11
12 file : http://sources.gentoo.org/viewvc.cgi/gentoo-x86/net-misc/asterisk/files/1.6.2/asterisk.initd2?rev=1.1&view=markup
13 plain: http://sources.gentoo.org/viewvc.cgi/gentoo-x86/net-misc/asterisk/files/1.6.2/asterisk.initd2?rev=1.1&content-type=text/plain
14
15 Index: asterisk.initd2
16 ===================================================================
17 #!/sbin/runscript
18 # Copyright 1999-2010 Gentoo Foundation
19 # Distributed under the terms of the GNU General Public License v2
20 # $Header: /var/cvsroot/gentoo-x86/net-misc/asterisk/files/1.6.2/asterisk.initd2,v 1.1 2010/08/20 23:12:53 chainsaw Exp $
21
22 opts="${opts} forcestop reload"
23
24 depend() {
25 need net
26 use nscd dns dahdi mysql postgresql slapd capi
27 }
28
29 is_running() {
30 if [ -z "`pidof asterisk`" ]; then
31 return 1
32 else
33 PID="`cat /var/run/asterisk/asterisk.pid`"
34 for x in `pidof asterisk`; do
35 if [ "${x}" = "${PID}" ]; then
36 return 0
37 fi
38 done
39 fi
40
41 return 1
42 }
43
44 asterisk_run_loop() {
45 logger -t asterisk_wrapper "Initializing asterisk wrapper"
46
47 local OPTS ARGS MSG NICE=""
48 local result=0 signal=0
49
50 # default options
51 OPTS="-f" # don't fork / detach breaks wrapper script...
52
53 # filter (redundant) arguments
54 ARGS="`echo "${@}" | sed -e "s:-c\|-f::g"`"
55
56 # mangle yes/no options
57 ASTERISK_CONSOLE="`echo ${ASTERISK_CONSOLE} | tr '[:lower:]' '[:upper:]'`"
58
59 if [ -n "${ASTERISK_CORE_SIZE}" ] &&
60 [ "${ASTERISK_CORE_SIZE}" != "0" ]; then
61 ulimit -c ${ASTERISK_CORE_SIZE}
62
63 if [ -n "${ASTERISK_CORE_DIR}" ] && \
64 [ ! -d "${ASTERISK_CORE_DIR}" ]
65 then
66 mkdir -m750 -p "${ASTERISK_CORE_DIR}"
67
68 if [ -n "${ASTERISK_USER}" ]; then
69 chown -R "${ASTERISK_USER}" "${ASTERISK_CORE_DIR}"
70 fi
71 fi
72 ASTERISK_CORE_DIR="${ASTERISK_CORE_DIR:-/tmp}"
73
74 cd "${ASTERISK_CORE_DIR}"
75 echo " Core dump size : ${ASTERISK_CORE_SIZE}"
76 echo " Core dump location : ${ASTERISK_CORE_DIR}"
77 fi
78
79 if [ -n "${ASTERISK_MAX_FD}" ]; then
80 ulimit -n ${ASTERISK_MAX_FD}
81 echo " Max open filedescriptors : ${ASTERISK_MAX_FD}"
82 fi
83
84 if [ -n "${ASTERISK_NICE}" ]; then
85 echo " Nice level : ${ASTERISK_NICE}"
86 NICE="nice -n ${ASTERISK_NICE} --"
87 fi
88
89 if [ -n "${ASTERISK_NOTIFY_EMAIL}" ]; then
90 if [ -x /usr/sbin/sendmail ]; then
91 echo " Email notifications go to : ${ASTERISK_NOTIFY_EMAIL}"
92 else
93 echo " Notifications disabled, /usr/sbin/sendmail doesn't exist or is not executable!"
94 unset ASTERISK_NOTIFY_EMAIL
95 fi
96 fi
97
98 if [ -n "${ASTERISK_TTY}" ]; then
99 for x in ${ASTERISK_TTY} \
100 /dev/tty${ASTERISK_TTY} \
101 /dev/vc/${ASTERISK_TTY}
102 do
103 if [ -c "${x}" ]; then
104 TTY="${x}"
105 fi
106 done
107 [ -n "${TTY}" ] && \
108 echo " Messages are sent to : ${TTY}"
109 fi
110
111 if [ "${ASTERISK_CONSOLE}" = "YES" ] && [ -n "${TTY}" ]; then
112 echo " Starting Asterisk console : ${ASTERISK_CONSOLE}"
113 OPTS="${OPTS} -c"
114 fi
115
116 OPTS="${OPTS} ${ARGS}"
117
118 trap "rm /var/run/asterisk/wrapper_loop.pid" EXIT
119 cut -f4 -d' ' < /proc/self/stat > /var/run/asterisk/wrapper_loop.pid
120
121 while :; do
122 if [ -n "${TTY}" ]; then
123 /usr/bin/stty -F ${TTY} sane
124 ${NICE} /usr/sbin/asterisk ${OPTS} >${TTY} 2>&1 <${TTY}
125 result=$?
126 else
127 set -o pipefail
128 ${NICE} /usr/sbin/asterisk ${OPTS} 2>&1 >/dev/null | logger -t asterisk_wrapper
129 set +o pipefail
130 result=$?
131 fi
132
133 if [ $result -eq 0 ]; then
134 logger -t asterisk_wrapper "Asterisk terminated normally"
135 break
136 else
137 if [ $result -gt 128 ]; then
138 signal=`expr $signal - 128`
139 MSG="Asterisk terminated with Signal: $signal"
140
141 CORE_TARGET="core-`date +%Y%m%d-%H%M%S`"
142
143 local CORE_DUMPED=0
144 if [ -f "${ASTERISK_CORE_DIR}/core" ]; then
145 mv "${ASTERISK_CORE_DIR}/core" \
146 "${ASTERISK_CORE_DIR}/${CORE_TARGET}"
147 CORE_DUMPED=1
148
149 elif [ -f "${ASTERISK_CORE_DIR}/core.${PID}" ]; then
150 mv "${ASTERISK_CORE_DIR}/core.${PID}" \
151 "${ASTERISK_CORE_DIR}/${CORE_TARGET}"
152 CORE_DUMPED=1
153
154 fi
155
156 [ $CORE_DUMPED -eq 1 ] && \
157 MSG="${MSG}\n\rCore dumped: ${ASTERISK_CORE_DIR}/${CORE_TARGET}"
158 else
159 MSG="Asterisk terminated with return code: $result"
160 fi
161
162 # kill left-over tasks
163 for X in ${ASTERISK_CLEANUP_ON_CRASH}; do
164 kill -9 `pidof ${X}`;
165 done
166 fi
167
168 [ -n "${TTY}" ] \
169 && echo "${MSG}" >${TTY} \
170 || logger -t asterisk_wrapper "${MSG}"
171
172
173 if [ -n "${ASTERISK_NOTIFY_EMAIL}" ] && \
174 [ -x /usr/sbin/sendmail ]; then
175 echo -e -n "Subject: Asterisk crashed\n\r${MSG}\n\r" |\
176 /usr/sbin/sendmail "${ASTERISK_NOTIFY_EMAIL}"
177 fi
178 sleep 5
179 logger -t asterisk_wrapper "Restarting Asterisk..."
180 done
181 return 0
182 }
183
184 start() {
185 local OPTS USER GROUP PID
186 local tmp x
187
188 if [ -n "${ASTERISK_NICE}" ]; then
189 if [ ${ASTERISK_NICE} -ge -20 ] && \
190 [ ${ASTERISK_NICE} -le 19 ]; then
191 OPTS="--nicelevel ${ASTERISK_NICE}"
192 else
193 eerror "Nice value must be between -20 and 19"
194 return 1
195 fi
196 fi
197
198 if [ -n "${ASTERISK_USER}" ]; then
199 USER=`echo $ASTERISK_USER | sed 's/:.*//'`
200 GROUP=`echo $ASTERISK_USER | awk -F: '/.*:.*/ { print $2 }'`
201 if [ -n "${USER}" ]; then
202 ASTERISK_OPTS="${ASTERISK_OPTS} -U ${USER}"
203 fi
204 if [ -n "${GROUP}" ]; then
205 ASTERISK_OPTS="${ASTERISK_OPTS} -G ${GROUP}"
206 GROUP=":${GROUP}" # make it look nice...
207 fi
208 for element in `find /var/{log,run}/asterisk`; do
209 if [ `stat -c %U $element` != "${USER}" ]; then
210 ewarn "${USER} is not the owner of $element, fixing."
211 chown -R ${USER} /var/{log,run}/asterisk
212 chmod -R u+r /var/{log,run}/asterisk
213 chmod u+x /var/{log,run}/asterisk
214 fi;
215 done;
216 ebegin "Starting asterisk PBX (as ${USER}${GROUP})"
217 else
218 ebegin "Starting asterisk PBX (as root)"
219 fi
220
221 if [ "`echo ${ASTERISK_WRAPPER} | tr '[:upper:]' '[:lower:]'`" != "yes" ]; then
222 start-stop-daemon --start --exec /usr/sbin/asterisk \
223 ${OPTS} -- ${ASTERISK_OPTS}
224 result=$?
225 else
226 asterisk_run_loop ${ASTERISK_OPTS} 2>/dev/null &
227 result=$?
228 fi
229
230 if [ $result -eq 0 ]; then
231 # 2 seconds should be enough for asterisk to start
232 sleep 2
233 is_running
234 result=$?
235 fi
236
237 eend $result
238 }
239
240 forcestop() {
241 ebegin "Stopping asterisk PBX"
242 start-stop-daemon --stop --pidfile /var/run/asterisk/asterisk.pid
243 eend $?
244 }
245
246 stop() {
247 if ! is_running; then
248 eerror "Asterisk is not running!"
249 return 0
250 fi
251
252 if [ -r /var/run/asterisk/wrapper_loop.pid ]; then
253 ebegin "Killing wrapper script"
254 kill `cat /var/run/asterisk/wrapper_loop.pid`
255 eend $?
256 fi
257
258 ebegin "Stopping asterisk PBX gracefully"
259 /usr/sbin/asterisk -r -x "core stop gracefully" &>/dev/null
260 # Now we have to wait until asterisk has _really_ stopped.
261 sleep 1
262 if is_running; then
263 einfon "Waiting for asterisk to shutdown ."
264 local cnt=0
265 while is_running; do
266 cnt=`expr $cnt + 1`
267 if [ $cnt -gt 60 ] ; then
268 # Waited 120 seconds now. Fail.
269 echo
270 eend 1 "Failed."
271 return
272 fi
273 sleep 2
274 echo -n "."
275 done
276 echo
277 fi
278 eend 0
279 }
280
281 reload() {
282 if is_running; then
283 ebegin "Forcing asterisk to reload configuration"
284 /usr/sbin/asterisk -r -x "reload" &>/dev/null
285 eend $?
286 else
287 eerror "Asterisk is not running!"
288 fi
289 }
290
291
292
293 1.1 net-misc/asterisk/files/1.6.2/asterisk-1.6.2.11-strip-noapi.patch
294
295 file : http://sources.gentoo.org/viewvc.cgi/gentoo-x86/net-misc/asterisk/files/1.6.2/asterisk-1.6.2.11-strip-noapi.patch?rev=1.1&view=markup
296 plain: http://sources.gentoo.org/viewvc.cgi/gentoo-x86/net-misc/asterisk/files/1.6.2/asterisk-1.6.2.11-strip-noapi.patch?rev=1.1&content-type=text/plain
297
298 Index: asterisk-1.6.2.11-strip-noapi.patch
299 ===================================================================
300 diff -uNr asterisk-1.6.2.2.ORIG/build_tools/strip_nonapi asterisk-1.6.2.2/build_tools/strip_nonapi
301 --- asterisk-1.6.2.2.ORIG/build_tools/strip_nonapi 2008-06-19 21:26:50.000000000 +0500
302 +++ asterisk-1.6.2.2/build_tools/strip_nonapi 2010-02-10 20:15:13.000000000 +0400
303 @@ -29,10 +29,15 @@
304
305 case "${OSARCH}" in
306 linux-gnu|FreeBSD)
307 - nm ${1} | ${GREP} -e "$TEXTSYM" | cut -d" " -f3 | ${FILTER} > striplist
308 - sed -e "s/^/-N /" striplist | xargs -n 40 ${STRIP} ${1}
309 - rm -f striplist
310 - ;;
311 + nm ${1} > symlist
312 + if [ -s symlist ]
313 + then
314 + ${GREP} -e "$TEXTSYM" symlist | cut -d" " -f3 | ${FILTER} > striplist
315 + sed -e "s/^/-N /" striplist | xargs -n 40 ${STRIP} ${1}
316 + rm -f striplist
317 + fi
318 + rm -f symlist
319 + ;;
320 *)
321 ;;
322 esac
323
324
325
326 1.1 net-misc/asterisk/files/1.6.2/asterisk.logrotate
327
328 file : http://sources.gentoo.org/viewvc.cgi/gentoo-x86/net-misc/asterisk/files/1.6.2/asterisk.logrotate?rev=1.1&view=markup
329 plain: http://sources.gentoo.org/viewvc.cgi/gentoo-x86/net-misc/asterisk/files/1.6.2/asterisk.logrotate?rev=1.1&content-type=text/plain
330
331 Index: asterisk.logrotate
332 ===================================================================
333 /var/log/asterisk/messages /var/log/asterisk/queue_log {
334 missingok
335 notifempty
336
337 postrotate
338 /usr/sbin/asterisk -rx "logger reload"
339 endscript
340 }
341
342 /var/log/asterisk/debug /var/log/asterisk/full {
343 missingok
344 notifempty
345 daily
346
347 postrotate
348 /usr/sbin/asterisk -rx "logger reload"
349 endscript
350 }
351
352 /var/log/asterisk/cdr-csv/*.csv /var/log/asterisk/cdr-custom/*.csv {
353 missingok
354 notifempty
355 weekly
356 rotations 52
357
358 postrotate
359 /usr/sbin/asterisk -rx "logger reload"
360 endscript
361 }