[asterisk-bugs] [JIRA] (ASTERISK-21765) [patch] - FILE function's length argument counts from beginning of file rather than the offset

Richard Mudgett (JIRA) noreply at issues.asterisk.org
Fri Jun 7 13:55:03 CDT 2013


    [ https://issues.asterisk.org/jira/browse/ASTERISK-21765?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=207076#comment-207076 ] 

Richard Mudgett edited comment on ASTERISK-21765 at 6/7/13 1:53 PM:
--------------------------------------------------------------------

The doc should be fine. But the implementation has problems.

funcs/func_env.c
{code}
if (off_i + toappend > offset + length) {
    toappend = length - off_i;
}
{code}

should be

{code}
if (off_i + toappend > offset + length) {
    toappend = offset + length - off_i;
}
{code}

It should fix the offset and length issue.
                
      was (Author: homesick):
    The doc should be fine. But the implementation has problems.

funcs/func_env.c

if (off_i + toappend > offset + length) {
    toappend = length - off_i;
}

should be

if (off_i + toappend > offset + length) {
    toappend = offset + length - off_i;
}

It should fix the offset and length issue.
                  
> [patch] - FILE function's length argument counts from beginning of file rather than the offset
> ----------------------------------------------------------------------------------------------
>
>                 Key: ASTERISK-21765
>                 URL: https://issues.asterisk.org/jira/browse/ASTERISK-21765
>             Project: Asterisk
>          Issue Type: Bug
>      Security Level: None
>          Components: Functions/func_dialplan
>    Affects Versions: 11.2.1, 11.3.0
>         Environment: AsteriskNow64 3.0.0
> Asterisk 11.2.1 and Asterisk 11.3.0
>            Reporter: John Zhong
>         Attachments: file_read_390821.patch
>
>
> AsteriskNow64 3.0.0 running under VMWare workstation.
> There are two issues have been found while I am testing our HiTPM with AsteriskNow64 3.0.0 integration.
> Reproduce steps:
>   1) Install netcat
>   2) Create two test files as:
>      echo 0123456789 >/tmp/0123456789.txt
>      base64 -w 0 /var/lib/asterisk/sounds/en/vm-login.ulaw > /tmp/vm-login.ulaw.b64
>   3) Run: ifconfig;nc -l 4573
>   4) Add a peer for SIP client into sip.conf
>   5) Create an extension for an AGI(agi://[the_ip_address_of_nc_listen_on]) 
>   6) Call the AGI extension
>   7) If setup is correct, the nc windows should have AGI headers
>   8) Send following commands by nc:
> {noformat}
>      GET VARIABLE FILE("/tmp/0123456789.txt,2,5")
>      and 
>      GET VARIABLE FILE("/tmp/vm-login.ulaw.b64,4080,5100")
> {noformat}
>   9) Verify the result:
> {noformat}
>      GET VARIABLE FILE("/tmp/0123456789.txt,2,5")
>      200 result=1 (234)
> {noformat}
>      Base on previous version Asterisk and current document, it should
>      return (23456), the first argument is offset and the second argument
>      should be length, but it is the 1 before the end position now. 
> [Edit by Rusty Newton - removed secondary issue as you shouldn't file two bugs in one report. Filing a new issue report.]

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: https://issues.asterisk.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira



More information about the asterisk-bugs mailing list