channels/chan_sip: Fix RealTime error during SIP unregistration with MariaDB
authorMatthew Jordan <mjordan@digium.com>
Wed, 11 Feb 2015 17:13:28 +0000 (17:13 +0000)
committerMatthew Jordan <mjordan@digium.com>
Wed, 11 Feb 2015 17:13:28 +0000 (17:13 +0000)
commit5a17ed7a38c6539fe335c8d1eda0ed866729c22a
tree385017bb8cae6bb464cd1fd6b5a138da9b3d152a
parent8cc50b1ebc3fe6eacd2a03a8c8bc4800bdddfbe9
channels/chan_sip: Fix RealTime error during SIP unregistration with MariaDB

When a SIP device that has its registration stored in RealTime unregisters,
the entry for that device is updated with blank values, i.e., "", indicating
that it is no longer registered. Unfortunately, one of those values that is
'blanked' is the device's port. If the column type for the port is not a
string datatype (the recommended type is integer), an ODBC or database error
will be thrown. MariaDB does not coerce empty strings to a valid integer value.

This patch updates the query run from chan_sip such that it replaces the port
value with a value of '0', as opposed to a blank value. This is the value that
other database backends coerce the empty string ("") to already, and the
handling of reading a RealTime registration value from a backend already
anticipates receiving a port of '0' from the backends.

ASTERISK-24772 #close
Reported by: Richard Miller
patches:
  chan_sip.diff uploaded by Richard Miller (License 5685)
........

Merged revisions 431673 from http://svn.asterisk.org/svn/asterisk/branches/11
........

Merged revisions 431674 from http://svn.asterisk.org/svn/asterisk/branches/13

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@431675 65c4cc65-6c06-0410-ace0-fbb531ad65f3
channels/chan_sip.c