[asterisk-bugs] [Asterisk 0017893]: [patch] 'dialplan save' crash when '|' (pipe) is used. Patch included.
Asterisk Bug Tracker
noreply at bugs.digium.com
Mon Aug 23 01:52:01 CDT 2010
The following issue has been UPDATED.
======================================================================
https://issues.asterisk.org/view.php?id=17893
======================================================================
Reported By: knutant
Assigned To:
======================================================================
Project: Asterisk
Issue ID: 17893
Category: PBX/pbx_config
Reproducibility: always
Severity: crash
Priority: normal
Status: new
Asterisk Version: 1.4.35
JIRA:
Regression: No
Reviewboard Link:
SVN Branch (only for SVN checkouts, not tarball releases): N/A
SVN Revision (number only!):
Request Review:
======================================================================
Date Submitted: 2010-08-20 07:39 CDT
Last Modified: 2010-08-23 01:52 CDT
======================================================================
Summary: [patch] 'dialplan save' crash when '|' (pipe) is
used. Patch included.
Description:
I was trying out the 'dialplan save' call from the asterisk CLI and it
crashed when trying to write out this line (which it had already read from
extensions.conf on startup):
exten => 1234,1,RTPPage(basic|224.0.0.1:7000|ulaw|ef)
By looking at the code I noticed that it tries to replace '|' with ',' but
the buffer it writes to is only allocated to 1 byte, so it crashes. It
might be worth noting that I ran Asterisk on a blackfin processor under
uClinux, but looking at the code I do not thing that matters.
The problem is located at line 1370 in pbx/pbx_config.c where the char
pointer to tempdata is allocated. It takes strlen(tempdata) instead of
strlen(s) and because tempdata is set to an empty string a few lines up,
this will always allocate a single byte.
I've looked at the latest revision of pbx_config.c in the 1.4 branch, and
the problem is still there. I've added a patch in the addition information
field. By using this patch, the crash is avoided and the writeout seems to
work correctly.
======================================================================
Issue History
Date Modified Username Field Change
======================================================================
2010-08-23 01:52 knutant Summary 'dialplan save' crash
when '|' (pipe) is used. Patch included. => [patch] 'dialplan save' crash when
'|' (pipe) is used. Patch included.
======================================================================
More information about the asterisk-bugs
mailing list