1
0
mirror of https://github.com/dg/dibi.git synced 2025-10-26 03:07:09 +01:00

Connection: added option [result][formatJson] that sets json column decoding (text|object|array) (#335)

This commit is contained in:
Pavel Janda
2019-09-09 19:48:01 +02:00
committed by David Grudl
parent 0535d57e6b
commit a2afac80f2
2 changed files with 13 additions and 2 deletions

View File

@@ -43,6 +43,11 @@ class Connection implements IConnection
* - lazy (bool) => if true, connection will be established only when required * - lazy (bool) => if true, connection will be established only when required
* - result (array) => result set options * - result (array) => result set options
* - formatDateTime => date-time format (if empty, DateTime objects will be returned) * - formatDateTime => date-time format (if empty, DateTime objects will be returned)
* - formatJson => json format (
* "string" for leaving value as is,
* "object" for decoding json as \stdClass,
* "array" for decoding json as an array - default
* )
* - profiler (array) * - profiler (array)
* - run (bool) => enable profiler? * - run (bool) => enable profiler?
* - file => file to log * - file => file to log
@@ -59,6 +64,7 @@ class Connection implements IConnection
Helpers::alias($config, 'result|formatDateTime', 'resultDateTime'); Helpers::alias($config, 'result|formatDateTime', 'resultDateTime');
$config['driver'] = $config['driver'] ?? 'mysqli'; $config['driver'] = $config['driver'] ?? 'mysqli';
$config['name'] = $name; $config['name'] = $name;
$config['result']['formatJson'] = $config['result']['formatJson'] ?? 'array';
$this->config = $config; $this->config = $config;
// profiler // profiler
@@ -395,7 +401,8 @@ class Connection implements IConnection
{ {
$res = new Result($resultDriver); $res = new Result($resultDriver);
return $res->setFormat(Type::DATE, $this->config['result']['formatDate']) return $res->setFormat(Type::DATE, $this->config['result']['formatDate'])
->setFormat(Type::DATETIME, $this->config['result']['formatDateTime']); ->setFormat(Type::DATETIME, $this->config['result']['formatDateTime'])
->setFormat(Type::JSON, $this->config['result']['formatJson']);
} }

View File

@@ -496,7 +496,11 @@ class Result implements IDataSource
$row[$key] = is_string($value) ? $this->getResultDriver()->unescapeBinary($value) : $value; $row[$key] = is_string($value) ? $this->getResultDriver()->unescapeBinary($value) : $value;
} elseif ($type === Type::JSON) { } elseif ($type === Type::JSON) {
$row[$key] = json_decode($value, true); if ($this->formats[$type] === 'string') {
$row[$key] = $value;
} else {
$row[$key] = json_decode($value, $this->formats[$type] === 'array');
}
} }
} }
} }