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.1: asterisk.rc6 asterisk-1.6.1.1-resolve-peer-not-section-header.patch
Date: Tue, 30 Jun 2009 16:01:19
Message-Id: E1MLfll-00019X-OW@stork.gentoo.org
1 chainsaw 09/06/30 16:01:17
2
3 Added: asterisk.rc6
4 asterisk-1.6.1.1-resolve-peer-not-section-header.patch
5 Log:
6 Revision bump. Patch by Federico Santulli to resolve the SIP peer instead of a random section header nearby, closes bug #275394. Also updates the init script to call the new-style graceful shutdown command.
7 (Portage version: 2.1.6.13/cvs/Linux x86_64)
8
9 Revision Changes Path
10 1.1 net-misc/asterisk/files/1.6.1/asterisk.rc6
11
12 file : http://sources.gentoo.org/viewcvs.py/gentoo-x86/net-misc/asterisk/files/1.6.1/asterisk.rc6?rev=1.1&view=markup
13 plain: http://sources.gentoo.org/viewcvs.py/gentoo-x86/net-misc/asterisk/files/1.6.1/asterisk.rc6?rev=1.1&content-type=text/plain
14
15 Index: asterisk.rc6
16 ===================================================================
17 #!/sbin/runscript
18 # Copyright 1999-2009 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.1/asterisk.rc6,v 1.1 2009/06/30 16:01:17 chainsaw Exp $
21
22 opts="${opts} forcestop reload"
23
24 depend() {
25 need net
26 use nscd dns zaptel 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 local OPTS ARGS MSG NICE=""
46 local result=0 signal=0
47
48 # default options
49 OPTS="-f" # don't fork / detach breaks wrapper script...
50
51 # filter (redundant) arguments
52 ARGS="$(echo "${@}" | sed -e "s:-c\|-f::g")"
53
54 # mangle yes/no options
55 ASTERISK_CONSOLE="$(echo ${ASTERISK_CONSOLE} | tr '[:lower:]' '[:upper:]')"
56
57 if [ -n "${ASTERISK_CORE_SIZE}" ] &&
58 [ "${ASTERISK_CORE_SIZE}" != "0" ]; then
59 ulimit -c ${ASTERISK_CORE_SIZE}
60
61 if [ -n "${ASTERISK_CORE_DIR}" ] && \
62 [ ! -d "${ASTERISK_CORE_DIR}" ]
63 then
64 mkdir -m750 -p "${ASTERISK_CORE_DIR}"
65
66 if [ -n "${ASTERISK_USER}" ]; then
67 chown -R "${ASTERISK_USER}" "${ASTERISK_CORE_DIR}"
68 fi
69 fi
70 ASTERISK_CORE_DIR="${ASTERISK_CORE_DIR:-/tmp}"
71
72 cd "${ASTERISK_CORE_DIR}"
73 echo " Core dump size : ${ASTERISK_CORE_SIZE}"
74 echo " Core dump location : ${ASTERISK_CORE_DIR}"
75 fi
76
77 if [ -n "${ASTERISK_MAX_FD}" ]; then
78 ulimit -n ${ASTERISK_MAX_FD}
79 echo " Max open filedescriptors : ${ASTERISK_MAX_FD}"
80 fi
81
82 if [ -n "${ASTERISK_NICE}" ]; then
83 echo " Nice level : ${ASTERISK_NICE}"
84 NICE="nice -n ${ASTERISK_NICE} --"
85 fi
86
87 if [ -n "${ASTERISK_NOTIFY_EMAIL}" ]; then
88 if [ -x /usr/sbin/sendmail ]; then
89 echo " Email notifications go to : ${ASTERISK_NOTIFY_EMAIL}"
90 else
91 echo " Notifications disabled, /usr/sbin/sendmail doesn't exist or is not executable!"
92 unset ASTERISK_NOTIFY_EMAIL
93 fi
94 fi
95
96 if [ -n "${ASTERISK_TTY}" ]; then
97 for x in ${ASTERISK_TTY} \
98 /dev/tty${ASTERISK_TTY} \
99 /dev/vc/${ASTERISK_TTY}
100 do
101 if [ -c "${x}" ]; then
102 TTY="${x}"
103 fi
104 done
105 [ -n "${TTY}" ] && \
106 echo " Messages are sent to : ${TTY}"
107 fi
108
109 if [ "${ASTERISK_CONSOLE}" = "YES" ] && [ -n "${TTY}" ]; then
110 echo " Starting Asterisk console : ${ASTERISK_CONSOLE}"
111 OPTS="${OPTS} -c"
112 fi
113
114 OPTS="${OPTS} ${ARGS}"
115
116 while :; do
117
118 if [ -n "${TTY}" ]; then
119 /usr/bin/stty -F ${TTY} sane
120 ${NICE} /usr/sbin/asterisk ${OPTS} >${TTY} 2>&1 <${TTY}
121 result=$?
122 else
123 ${NICE} /usr/sbin/asterisk ${OPTS} &>/dev/null
124 result=$?
125 fi
126
127 if [ $result -eq 0 ]; then
128 echo "Asterisk terminated normally"
129 break
130 else
131 if [ $result -gt 128 ]; then
132 signal=$((result - 128))
133 MSG="Asterisk terminated with Signal: $signal"
134
135 CORE_TARGET="core-$(date "+%Y%m%d-%h%M%s")"
136
137 local CORE_DUMPED=0
138 if [ -f "${ASTERISK_CORE_DIR}/core" ]; then
139 mv "${ASTERISK_CORE_DIR}/core" \
140 "${ASTERISK_CORE_DIR}/${CORE_TARGET}"
141 CORE_DUMPED=1
142
143 elif [ -f "${ASTERISK_CORE_DIR}/core.${PID}" ]; then
144 mv "${ASTERISK_CORE_DIR}/core.${PID}" \
145 "${ASTERISK_CORE_DIR}/${CORE_TARGET}"
146 CORE_DUMPED=1
147
148 fi
149
150 [ $CORE_DUMPED -eq 1 ] && \
151 MSG="${MSG}\n\rCore dumped: ${ASTERISK_CORE_DIR}/${CORE_TARGET}"
152 else
153 MSG="Asterisk terminated with return code: $result"
154 fi
155
156 # kill left-over tasks
157 for X in ${ASTERISK_CLEANUP_ON_CRASH}; do
158 kill -9 $(pidof ${X});
159 done
160 fi
161
162 [ -n "${TTY}" ] \
163 && echo "${MSG}" >${TTY} \
164 || echo "${MSG}"
165
166
167 if [ -n "${ASTERISK_NOTIFY_EMAIL}" ] && \
168 [ -x /usr/sbin/sendmail ]; then
169 echo -e -n "Subject: Asterisk crashed\n\r${MSG}\n\r" |\
170 /usr/sbin/sendmail "${ASTERISK_NOTIFY_EMAIL}"
171 fi
172 sleep 5
173 echo "Restarting Asterisk..."
174 done
175 return 0
176 }
177
178 start() {
179 local OPTS USER GROUP PID
180 local tmp x
181
182 if [ -n "${ASTERISK_NICE}" ]; then
183 if [ ${ASTERISK_NICE} -ge -20 ] && \
184 [ ${ASTERISK_NICE} -le 19 ]; then
185 OPTS="--nicelevel ${ASTERISK_NICE}"
186 else
187 eerror "Nice value must be between -20 and 19"
188 return 1
189 fi
190 fi
191
192 if [ -n "${ASTERISK_USER}" ]; then
193 USER=$(echo $ASTERISK_USER | sed 's/:.*//')
194 GROUP=$(echo $ASTERISK_USER | awk -F: '/.*:.*/ { print $2 }')
195 if [ -n "${USER}" ]; then
196 ASTERISK_OPTS="${ASTERISK_OPTS} -U ${USER}"
197 fi
198 if [ -n "${GROUP}" ]; then
199 ASTERISK_OPTS="${ASTERISK_OPTS} -G ${GROUP}"
200 GROUP=":${GROUP}" # make it look nice...
201 fi
202 ebegin "Starting asterisk PBX (as ${USER}${GROUP})"
203 else
204 ebegin "Starting asterisk PBX (as root)"
205 fi
206
207 if [ "$(echo ${ASTERISK_WRAPPER} | tr '[:upper:]' '[:lower:]')" != "yes" ]; then
208 start-stop-daemon --start --exec /usr/sbin/asterisk \
209 ${OPTS} -- ${ASTERISK_OPTS}
210 result=$?
211 else
212 asterisk_run_loop ${ASTERISK_OPTS} 2>/dev/null &
213 result=$?
214 fi
215
216 if [ $result -eq 0 ]; then
217 # 2 seconds should be enough for asterisk to start
218 sleep 2
219 is_running
220 result=$?
221 fi
222
223 eend $result
224 }
225
226 forcestop() {
227 ebegin "Stopping asterisk PBX"
228 start-stop-daemon --stop --pidfile /var/run/asterisk/asterisk.pid
229 eend $?
230 }
231
232 stop() {
233 if ! is_running; then
234 eerror "Asterisk is not running!"
235 return 0
236 fi
237
238 ebegin "Stopping asterisk PBX gracefully"
239 /usr/sbin/asterisk -r -x "core stop gracefully" &>/dev/null
240 # Now we have to wait until asterisk has _really_ stopped.
241 sleep 1
242 if is_running; then
243 einfon "Waiting for asterisk to shutdown ."
244 local cnt=0
245 while is_running; do
246 cnt=`expr $cnt + 1`
247 if [ $cnt -gt 60 ] ; then
248 # Waited 120 seconds now. Fail.
249 echo
250 eend 1 "Failed."
251 return
252 fi
253 sleep 2
254 echo -n "."
255 done
256 echo
257 fi
258 eend 0
259 }
260
261 reload() {
262 if is_running; then
263 ebegin "Forcing asterisk to reload configuration"
264 /usr/sbin/asterisk -r -x "reload" &>/dev/null
265 eend $?
266 else
267 eerror "Asterisk is not running!"
268 fi
269 }
270
271
272
273 1.1 net-misc/asterisk/files/1.6.1/asterisk-1.6.1.1-resolve-peer-not-section-header.patch
274
275 file : http://sources.gentoo.org/viewcvs.py/gentoo-x86/net-misc/asterisk/files/1.6.1/asterisk-1.6.1.1-resolve-peer-not-section-header.patch?rev=1.1&view=markup
276 plain: http://sources.gentoo.org/viewcvs.py/gentoo-x86/net-misc/asterisk/files/1.6.1/asterisk-1.6.1.1-resolve-peer-not-section-header.patch?rev=1.1&content-type=text/plain
277
278 Index: asterisk-1.6.1.1-resolve-peer-not-section-header.patch
279 ===================================================================
280 --- ./asterisk-1.6.1.1.orig/channels/chan_sip.c 2009-04-20 19:08:26.000000000 +0200
281 +++ ./asterisk-1.6.1.1/channels/chan_sip.c 2009-06-30 17:00:46.713621713 +0200
282 @@ -9969,6 +9969,7 @@
283 char tmp[80];
284 char addr[80];
285 struct sip_pvt *p;
286 + struct sip_peer *peer;
287 int res;
288 char *fromdomain;
289
290 @@ -9982,8 +9983,12 @@
291
292 if (r->dnsmgr == NULL) {
293 char transport[MAXHOSTNAMELEN];
294 + peer = find_peer(r->hostname, NULL, TRUE, FINDPEERS, FALSE);
295 snprintf(transport, sizeof(transport), "_sip._%s", get_transport(r->transport)); /* have to use static get_transport function */
296 - ast_dnsmgr_lookup(r->hostname, &r->us, &r->dnsmgr, global_srvlookup ? transport : NULL);
297 + ast_dnsmgr_lookup(peer ? peer->tohost : r->hostname, &r->us, &r->dnsmgr, global_srvlookup ? transport : NULL);
298 + if (peer) {
299 + unref_peer(peer, "removing peer ref for dnsmgr_lookup");
300 + }
301 }
302
303 if (r->call) { /* We have a registration */