CVE-2019-13161 - NULL Pointer Dereference

Severity

35%

Complexity

68%

Confidentiality

48%

An issue was discovered in Asterisk Open Source through 13.27.0, 14.x and 15.x through 15.7.2, and 16.x through 16.4.0, and Certified Asterisk through 13.21-cert3. A pointer dereference in chan_sip while handling SDP negotiation allows an attacker to crash Asterisk when handling an SDP answer to an outgoing T.38 re-invite. To exploit this vulnerability an attacker must cause the chan_sip module to send a T.38 re-invite request to them. Upon receipt, the attacker must send an SDP answer containing both a T.38 UDPTL stream and another media stream containing only a codec (which is not permitted according to the chan_sip configuration).

An issue was discovered in Asterisk Open Source through 13.27.0, 14.x and 15.x through 15.7.2, and 16.x through 16.4.0, and Certified Asterisk through 13.21-cert3. A pointer dereference in chan_sip while handling SDP negotiation allows an attacker to crash Asterisk when handling an SDP answer to an outgoing T.38 re-invite. To exploit this vulnerability an attacker must cause the chan_sip module to send a T.38 re-invite request to them. Upon receipt, the attacker must send an SDP answer containing both a T.38 UDPTL stream and another media stream containing only a codec (which is not permitted according to the chan_sip configuration).

CVSS 3.0 Base Score 5.3. CVSS Attack Vector: network. CVSS Attack Complexity: high. CVSS Vector: (CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:U/C:N/I:N/A:H).

CVSS 2.0 Base Score 3.5. CVSS Attack Vector: network. CVSS Attack Complexity: medium. CVSS Vector: (AV:N/AC:M/Au:S/C:N/I:N/A:P).

Demo Examples

NULL Pointer Dereference

CWE-476

While there are no complete fixes aside from conscientious programming, the following steps will go a long way to ensure that NULL pointer dereferences do not occur.


               
}
/* make use of pointer1 *//* ... */

If you are working with a multithreaded or otherwise asynchronous environment, ensure that proper locking APIs are used to lock before the if statement; and unlock when it has finished.

NULL Pointer Dereference

CWE-476

This example takes an IP address from a user, verifies that it is well formed and then looks up the hostname and copies it into a buffer.


               
}
strcpy(hostname, hp->h_name);/*routine that ensures user_supplied_addr is in the right format for conversion */

If an attacker provides an address that appears to be well-formed, but the address does not resolve to a hostname, then the call to gethostbyaddr() will return NULL. Since the code does not check the return value from gethostbyaddr (CWE-252), a NULL pointer dereference would then occur in the call to strcpy().

Note that this example is also vulnerable to a buffer overflow (see CWE-119).

NULL Pointer Dereference

CWE-476

In the following code, the programmer assumes that the system always has a property named "cmd" defined. If an attacker can control the program's environment so that "cmd" is not defined, the program throws a NULL pointer exception when it attempts to call the trim() method.


               
cmd = cmd.trim();

NULL Pointer Dereference

CWE-476

This application has registered to handle a URL when sent an intent:


               
}......
}
}
int length = URL.length();
...

The application assumes the URL will always be included in the intent. When the URL is not present, the call to getStringExtra() will return null, thus causing a null pointer exception when length() is called.

Overview

First reported 5 years ago

2019-07-12 20:15:00

Last updated 5 years ago

2019-11-30 23:15:00

Affected Software

Digium Certified Asterisk 1.8.0.0

1.8.0.0

Digium Certified Asterisk 1.8.0.0 beta1

1.8.0.0

Digium Certified Asterisk 1.8.0.0 beta2

1.8.0.0

Digium Certified Asterisk 1.8.0.0 beta3

1.8.0.0

Digium Certified Asterisk 1.8.0.0 beta4

1.8.0.0

Digium Certified Asterisk 1.8.0.0 beta5

1.8.0.0

Digium Certified Asterisk 1.8.0.0 release candidate 1

1.8.0.0

Digium Certified Asterisk 1.8.0.0 release candidate 2

1.8.0.0

Digium Certified Asterisk 1.8.0.0 release candidate 3

1.8.0.0

Digium Certified Asterisk 1.8.0.0 release candidate 4

1.8.0.0

Digium Certified Asterisk 1.8.0.0 release candidate 5

1.8.0.0

Digium Certified Asterisk 1.8.1.0

1.8.1.0

Digium Certified Asterisk 1.8.1.0 release candidate 1

1.8.1.0

Digium Certified Asterisk 1.8.2.0

1.8.2.0

Digium Certified Asterisk 1.8.2.0 release candidate 1

1.8.2.0

Digium Certified Asterisk 1.8.3.0

1.8.3.0

Digium Certified Asterisk 1.8.3.0 release candidate 1

1.8.3.0

Digium Certified Asterisk 1.8.3.0 release candidate 2

1.8.3.0

Digium Certified Asterisk 1.8.3.0 release candidate 3

1.8.3.0

Digium Certified Asterisk 1.8.4.0

1.8.4.0

Digium Certified Asterisk 1.8.4.0 release candidate 1

1.8.4.0

Digium Certified Asterisk 1.8.4.0 release candidate 2

1.8.4.0

Digium Certified Asterisk 1.8.4.0 release candidate 3

1.8.4.0

Digium Certified Asterisk 1.8.5.0

1.8.5.0

Digium Certified Asterisk 1.8.5.0 release candidate 1

1.8.5.0

Digium Certified Asterisk 1.8.6.0

1.8.6.0

Digium Certified Asterisk 1.8.6.0 release candidate 1

1.8.6.0

Digium Certified Asterisk 1.8.6.0 release candidate 2

1.8.6.0

Digium Certified Asterisk 1.8.6.0 release candidate 3

1.8.6.0

Digium Certified Asterisk 1.8.7.0

1.8.7.0

Digium Certified Asterisk 1.8.7.0 release candidate 1

1.8.7.0

Digium Certified Asterisk 1.8.7.0 release candidate 2

1.8.7.0

Digium Certified Asterisk 1.8.8.0

1.8.8.0

Digium Certified Asterisk 1.8.8.0 release candidate 1

1.8.8.0

Digium Certified Asterisk 1.8.8.0 release candidate 2

1.8.8.0

Digium Certified Asterisk 1.8.8.0 release candidate 3

1.8.8.0

Digium Certified Asterisk 1.8.8.0 release candidate 4

1.8.8.0

Digium Certified Asterisk 1.8.8.0 release candidate 5

1.8.8.0

Digium Certified Asterisk 1.8.9.0

1.8.9.0

Digium Certified Asterisk 1.8.9.0 release candidate 1

1.8.9.0

Digium Certified Asterisk 1.8.9.0 release candidate 2

1.8.9.0

Digium Certified Asterisk 1.8.9.0 release candidate 3

1.8.9.0

Digium Certified Asterisk 1.8.10.0

1.8.10.0

Digium Certified Asterisk 1.8.10.0 release candidate 1

1.8.10.0

Digium Certified Asterisk 1.8.10.0 release candidate 2

1.8.10.0

Digium Certified Asterisk 1.8.10.0 release candidate 3

1.8.10.0

Digium Certified Asterisk 1.8.10.0 release candidate 4

1.8.10.0

Asterisk Certified Asterisk 1.8.11-cert

1.8.11

Asterisk Certified Asterisk 1.8.11-cert1

1.8.11

Asterisk Certified Asterisk 1.8.11-cert10

1.8.11

Asterisk Certified Asterisk 1.8.11-cert2

1.8.11

Asterisk Certified Asterisk 1.8.11-cert3

1.8.11

Digium Certified Asterisk 1.8.11 Cert3-Release Candidate 1

1.8.11

Digium Certified Asterisk 1.8.11 Cert3-Release Candidate 2

1.8.11

Asterisk Certified Asterisk 1.8.11-cert4

1.8.11

Asterisk Certified Asterisk 1.8.11-cert5

1.8.11

Digium Certified Asterisk 1.8.11 Cert5-Release Candidate 1

1.8.11

Digium Certified Asterisk 1.8.11 Cert5-Release Candidate 2

1.8.11

Asterisk Certified Asterisk 1.8.11-cert6

1.8.11

Asterisk Certified Asterisk 1.8.11-cert7

1.8.11

Asterisk Certified Asterisk 1.8.11-cert8

1.8.11

Asterisk Certified Asterisk 1.8.11-cert9

1.8.11

Digium Certified Asterisk 1.8.11 Cert9-Release Candidate 1

1.8.11

Digium Certified Asterisk 1.8.11.0

1.8.11.0

Digium Certified Asterisk 1.8.11.0 release candidate 1

1.8.11.0

Digium Certified Asterisk 1.8.11.0 release candidate 2

1.8.11.0

Digium Certified Asterisk 1.8.11.0 release candidate 3

1.8.11.0

Digium Certified Asterisk 1.8.12.0

1.8.12.0

Digium Certified Asterisk 1.8.12.0 release candidate 1

1.8.12.0

Digium Certified Asterisk 1.8.12.0 release candidate 2

1.8.12.0

Digium Certified Asterisk 1.8.12.0 release candidate 3

1.8.12.0

Digium Certified Asterisk 1.8.13.0

1.8.13.0

Digium Certified Asterisk 1.8.13.0 release candidate 1

1.8.13.0

Digium Certified Asterisk 1.8.13.0 release candidate 2

1.8.13.0

Digium Certified Asterisk 1.8.14.0 release candidate 1

1.8.14.0

Digium Certified Asterisk 1.8.14.0 release candidate 2

1.8.14.0

Digium Certified Asterisk 1.8.15

1.8.15

Digium Certified Asterisk 1.8.15-cert1

1.8.15

Digium Certified Asterisk 1.8.15 Cert1-Release Candidate 1

1.8.15

Digium Certified Asterisk 1.8.15 Cert1-Release Candidate 2

1.8.15

Digium Certified Asterisk 1.8.15 Cert1-Release Candidate 3

1.8.15

Digium Certified Asterisk 1.8.15-cert1 release candidate 1

1.8.15

Digium Certified Asterisk 1.8.15-cert1 release candidate 2

1.8.15

Digium Certified Asterisk 1.8.15-cert1 release candidate 3

1.8.15

Digium Certified Asterisk 1.8.15-cert2

1.8.15

Digium Certified Asterisk 1.8.15-cert3

1.8.15

Digium Certified Asterisk 1.8.15-cert4

1.8.15

Digium Certified Asterisk 1.8.15-cert5

1.8.15

Digium Certified Asterisk 1.8.15-cert6

1.8.15

Digium Certified Asterisk 1.8.15 Cert7

1.8.15

Digium Certified Asterisk 1.8.28

1.8.28

Digium Certified Asterisk 1.8.28 cert 1 LTS

1.8.28

Digium Certified Asterisk 1.8.28 Cert1-Release Candidate 1

1.8.28

Digium Certified Asterisk 1.8.28 Cert2

1.8.28

Digium Certified Asterisk 1.8.28-cert2 LTS

1.8.28

Digium Certified Asterisk 1.8.28 Cert3

1.8.28

Digium Certified Asterisk 1.8.28 Cert4

1.8.28

Digium Certified Asterisk 1.8.28 Cert5

1.8.28

Digium Certified Asterisk 1.8.28.0 LTS

1.8.28.0

Digium Certified Asterisk 11.0.0

11.0.0

Digium Certified Asterisk 11.0.0 Release Candidate 1

11.0.0

Digium Certified Asterisk 11.0.0 Release Candidate 2

11.0.0

Digium Certified Asterisk 11.1.0

11.1.0

Digium Certified Asterisk 11.1.0 Release Candidate 1

11.1.0

Digium Certified Asterisk 11.1.0 Release Candidate 2

11.1.0

Digium Certified Asterisk 11.1.0 Release Candidate 3

11.1.0

Digium Certified Asterisk 11.2 Cert1

11.2

Digium Certified Asterisk 11.2 Cert1-Release Candidate 2

11.2

Digium Certified Asterisk 11.2 Cert2

11.2

Digium Certified Asterisk 11.2 Cert3

11.2

Digium Certified Asterisk 11.3.0

11.3.0

Digium Certified Asterisk 11.3.0 Release Candidate 1

11.3.0

Digium Certified Asterisk 11.3.0 Release Candidate 2

11.3.0

Digium Certified Asterisk 11.4.0

11.4.0

Digium Certified Asterisk 11.4.0 Release Candidate 1

11.4.0

Digium Certified Asterisk 11.4.0 Release Candidate 2

11.4.0

Digium Certified Asterisk 11.4.0 Release Candidate 3

11.4.0

Digium Certified Asterisk 11.5.0

11.5.0

Digium Certified Asterisk 11.5.0 Release Candidate 1

11.5.0

Digium Certified Asterisk 11.5.0 Release Candidate 2

11.5.0

Digium Certified Asterisk 11.6-cert1

11.6

Digium Certified Asterisk 11.6 cert 1 LTS

11.6

Digium Certified Asterisk 11.6 Cert1-Release Candidate 1

11.6

Digium Certified Asterisk 11.6 Cert1-Release Candidate 2

11.6

Digium Certified Asterisk 11.6 Cert10

11.6

Digium Certified Asterisk 11.6 Cert11

11.6

Digium Certified Asterisk 11.6 Cert12

11.6

Digium Certified Asterisk 11.6 Cert12 Long Term Support

11.6

Digium Certified Asterisk 11.6 Cert13

11.6

Digium Certified Asterisk 11.6 Cert13 Long Term Support

11.6

Digium Certified Asterisk 11.6 Cert14

11.6

Digium Certified Asterisk 11.6 Cert14 Long Term Support

11.6

Digium Certified Asterisk 11.6 Cert14-Release Candidate 1

11.6

Digium Certified Asterisk 11.6 Cert14-Release Candidate 2

11.6

Digium Certified Asterisk 11.6 Cert15

11.6

Digium Certified Asterisk 11.6 Cert15 Long Term Support

11.6

Digium Certified Asterisk 11.6 Cert16

11.6

Digium Certified Asterisk 11.6 Cert17

11.6

Digium Certified Asterisk 11.6 Cert18

11.6

Digium Certified Asterisk 11.6-cert1 release candidate 1

11.6

Digium Certified Asterisk 11.6-cert1 release candidate 2

11.6

Digium Certified Asterisk 11.6-cert2

11.6

Digium Certified Asterisk 11.6 cert 2 LTS

11.6

Digium Certified Asterisk 11.6-cert3

11.6

Digium Certified Asterisk 11.6 cert 3 LTS

11.6

Digium Certified Asterisk 11.6 Cert4

11.6

Digium Certified Asterisk 11.6 cert 4 LTS

11.6

Digium Certified Asterisk 11.6 Cert5

11.6

Digium Certified Asterisk 11.6 cert 5 LTS

11.6

Digium Certified Asterisk 11.6 Cert6

11.6

Digium Certified Asterisk 11.6 cert 6 LTS

11.6

Digium Certified Asterisk 11.6 Cert7

11.6

Digium Certified Asterisk 11.6 cert 7 LTS

11.6

Digium Certified Asterisk 11.6 Cert8

11.6

Digium Certified Asterisk 11.6 cert8 LTS

11.6

Digium Certified Asterisk 11.6 Cert9

11.6

Digium Certified Asterisk 11.6.0 LTS

11.6.0

Digium Certified Asterisk 11.6.0

11.6.0

Digium Certified Asterisk 11.6.0 release candidate 1

11.6.0

Digium Certified Asterisk 11.6.0 release candidate 2

11.6.0

Digium Certified Asterisk 13.1 Cert1

13.1

Digium Certified Asterisk 13.1 Cert1-Release Candidate 1

13.1

Digium Certified Asterisk 13.1 Cert1-Release Candidate 3

13.1

Digium Certified Asterisk 13.1 Cert2

13.1

Digium Certified Asterisk 13.1 Cert3

13.1

Digium Certified Asterisk 13.1 Cert3-Release Candidate 1

13.1

Digium Certified Asterisk 13.1 Cert4

13.1

Digium Certified Asterisk 13.1 Cert5

13.1

Digium Certified Asterisk 13.1 Cert6

13.1

Digium Certified Asterisk 13.1 Cert7

13.1

Digium Certified Asterisk 13.1 Cert8

13.1

Digium Certified Asterisk 13.1.0

13.1.0

Digium Certified Asterisk 13.1.0 Release Candidate 1

13.1.0

Digium Certified Asterisk 13.1.0 Release Candidate 2

13.1.0

Digium Certified Asterisk 13.8 Cert1

13.8

Digium Certified Asterisk 13.8 Cert1-Release Candidate 2

13.8

Digium Certified Asterisk 13.8 Cert1-Release Candidate 3

13.8

Digium Certified Asterisk 13.8 Cert1 Release Candidate 1

13.8

Digium Certified Asterisk 13.8 Cert1 Release Candidate 2

13.8

Digium Certified Asterisk 13.8 Cert1 Release Candidate 3

13.8

Digium Certified Asterisk 13.8 Cert2

13.8

Digium Certified Asterisk 13.8 Cert2-Release Candidate 1

13.8

Digium Certified Asterisk 13.8 Cert2 Release Candidate 1

13.8

Digium Certified Asterisk 13.8 Cert3

13.8

Digium Certified Asterisk 13.8 Cert4

13.8

Digium Certified Asterisk 13.8.0

13.8.0

Digium Certified Asterisk 13.8.0 Release Candidate 1

13.8.0

Digium Certified Asterisk 13.13 Cert1-Release Candidate 1

13.13

Digium Certified Asterisk 13.13 Cert1-Release Candidate 2

13.13

Digium Certified Asterisk 13.13 Cert1-Release Candidate 3

13.13

Digium Certified Asterisk 13.13 Cert1-Release Candidate 4

13.13

Digium Certified Asterisk 13.13 Cert2

13.13

Digium Certified Asterisk 13.13 Cert3

13.13

Digium Certified Asterisk 13.13 Cert4

13.13

Digium Certified Asterisk 13.13 Cert5

13.13

Digium Certified Asterisk 13.13 Cert6

13.13

Digium Certified Asterisk 13.13 Cert7

13.13

Digium Certified Asterisk 13.13 Cert8

13.13

Digium Certified Asterisk 13.13 Cert9

13.13

Digium Certified Asterisk 13.13-cert2

13.13-cert2

Digium Certified Asterisk 13.18 Cert1

13.18

Digium Certified Asterisk 13.18 Cert1-Release Candidate 1

13.18

Digium Certified Asterisk 13.18 Cert1-Release Candidate 2

13.18

Digium Certified Asterisk 13.18 Cert1-Release Candidate 3

13.18

Digium Certified Asterisk 13.18 Cert2

13.18

Digium Certified Asterisk 13.18 Cert3

13.18

Digium Certified Asterisk 13.18 Cert4

13.18

Digium Certified Asterisk 13.21 Cert1

13.21

Digium Certified Asterisk 13.21 Cert1-Release Candidate 1

13.21

Digium Certified Asterisk 13.21 Cert1-Release Candidate 2

13.21

Digium Certified Asterisk 13.21 Cert2

13.21

Stay updated

ExploitPedia is constantly evolving. Sign up to receive a notification when we release additional functionality.

Get in touch

If you'd like to report a bug or have any suggestions for improvements then please do get in touch with us using this form. We will get back to you as soon as we can.