You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

ResultAdapter.php 1.9KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?php
  2. /*
  3. * @copyright 2021 Christoph Wurst <christoph@winzerhof-wurst.at>
  4. *
  5. * @author 2021 Christoph Wurst <christoph@winzerhof-wurst.at>
  6. *
  7. * @license GNU AGPL version 3 or any later version
  8. *
  9. * This program is free software: you can redistribute it and/or modify
  10. * it under the terms of the GNU Affero General Public License as
  11. * published by the Free Software Foundation, either version 3 of the
  12. * License, or (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU Affero General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU Affero General Public License
  20. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  21. */
  22. declare(strict_types=1);
  23. namespace OC\DB;
  24. use Doctrine\DBAL\Result;
  25. use OCP\DB\IResult;
  26. use PDO;
  27. /**
  28. * Adapts DBAL 2.6 API for DBAL 3.x for backwards compatibility of a leaked type
  29. */
  30. class ResultAdapter implements IResult {
  31. /** @var Result */
  32. private $inner;
  33. public function __construct(Result $inner) {
  34. $this->inner = $inner;
  35. }
  36. public function closeCursor(): bool {
  37. $this->inner->free();
  38. return true;
  39. }
  40. public function fetch(int $fetchMode = PDO::FETCH_ASSOC) {
  41. return $this->inner->fetch($fetchMode);
  42. }
  43. public function fetchAll(int $fetchMode = PDO::FETCH_ASSOC): array {
  44. if ($fetchMode !== PDO::FETCH_ASSOC && $fetchMode !== PDO::FETCH_NUM && $fetchMode !== PDO::FETCH_COLUMN) {
  45. throw new \Exception('Fetch mode needs to be assoc, num or column.');
  46. }
  47. return $this->inner->fetchAll($fetchMode);
  48. }
  49. public function fetchColumn($columnIndex = 0) {
  50. return $this->inner->fetchOne();
  51. }
  52. public function fetchOne() {
  53. return $this->inner->fetchOne();
  54. }
  55. public function rowCount(): int {
  56. return $this->inner->rowCount();
  57. }
  58. }