pdo hacks

This commit is contained in:
zotlabs 2016-10-23 17:05:08 -07:00
parent 04ac04e0ad
commit d30892ea60
2 changed files with 18 additions and 4 deletions

View file

@ -53,7 +53,14 @@ class DBA {
}
else {
if(!($port))
// attempt to use the pdo driver compiled-in mysqli socket
// if using 'localhost' with no port configured.
// If this is wrong you'll need to set the socket path specifically
// using a server name of 'mysql:unix_socket=/socket/path', setting /socket/path
// as needed for your platform
if((!($port)) && ($server !== 'localhost'))
$port = 3306;
}

View file

@ -107,7 +107,7 @@ class dba_pdo extends dba_driver {
return 'string_agg(' . $fld . ',\'' . $sep . '\')';
}
else {
return 'GROUP_CONCAT(DISTINCT '.$fld.' SEPARATOR \''.$sep.'\')';
return 'GROUP_CONCAT(DISTINCT ' . $fld . ' SEPARATOR \'' . $sep . '\')';
}
}
@ -120,9 +120,12 @@ class dba_pdo extends dba_driver {
}
}
// These two functions assume that postgres standard_conforming_strings is set to off;
// which we perform during DB open.
function escapebin($str) {
if($this->driver_dbtype === 'pgsql') {
return str_replace([ chr(92), chr(0), chr(39) ], [ '\\\134', '\\\000', '\\\047' ], $str);
return "\\\\x" . bin2hex($str);
}
else {
return $this->escape($str);
@ -131,7 +134,11 @@ class dba_pdo extends dba_driver {
function unescapebin($str) {
if($this->driver_dbtype === 'pgsql') {
return stripcslashes($str);
// The initial backslash inserted by escapebin above will have been stripped
// by the postgres server, leaving us with '\x{hexdigits}'
return hex2bin(substr($str,2));
}
else {
return $str;