BackendInterface.php 2.75 KB
Newer Older
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
1
<?php
Thomas Maroschik's avatar
Thomas Maroschik committed
2
3
namespace TYPO3\CMS\Extbase\Persistence\Generic\Storage;

Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
4
/***************************************************************
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
 *  Copyright notice
 *
 *  (c) 2009 Jochen Rau <jochen.rau@typoplanet.de>
 *  All rights reserved
 *
 *  This class is a backport of the corresponding class of FLOW3.
 *  All credits go to the v5 team.
 *
 *  This script is part of the TYPO3 project. The TYPO3 project is
 *  free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  The GNU General Public License can be found at
 *  http://www.gnu.org/copyleft/gpl.html.
 *
 *  This script is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  This copyright notice MUST APPEAR in all copies of the script!
 ***************************************************************/
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
29
30
31
/**
 * Storage backend interface
 */
Thomas Maroschik's avatar
Thomas Maroschik committed
32
interface BackendInterface
33
{
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
34
35
36
37
38
	/**
	 * Adds a row to the storage
	 *
	 * @param string $tableName The database table name
	 * @param array $row The row to insert
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
39
	 * @param boolean $isRelation TRUE if we are currently inserting into a relation table, FALSE by default
40
	 * @return mixed|void
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
41
	 */
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
42
	public function addRow($tableName, array $row, $isRelation = FALSE);
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
43
44
45
46
47
48

	/**
	 * Updates a row in the storage
	 *
	 * @param string $tableName The database table name
	 * @param array $row The row to update
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
49
	 * @param boolean $isRelation TRUE if we are currently inserting into a relation table, FALSE by default
50
	 * @return mixed|void
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
51
	 */
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
52
	public function updateRow($tableName, array $row, $isRelation = FALSE);
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
53
54
55
56
57

	/**
	 * Deletes a row in the storage
	 *
	 * @param string $tableName The database table name
58
	 * @param array $identifier An array of identifier array('fieldname' => value). This array will be transformed to a WHERE clause
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
59
	 * @param boolean $isRelation TRUE if we are currently inserting into a relation table, FALSE by default
60
	 * @return mixed|void
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
61
	 */
62
	public function removeRow($tableName, array $identifier, $isRelation = FALSE);
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
63
64

	/**
65
	 * Returns the number of items matching the query.
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
66
	 *
Thomas Maroschik's avatar
Thomas Maroschik committed
67
	 * @param \TYPO3\CMS\Extbase\Persistence\QueryInterface $query
68
69
	 * @return integer
	 * @api
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
70
	 */
Thomas Maroschik's avatar
Thomas Maroschik committed
71
	public function getObjectCountByQuery(\TYPO3\CMS\Extbase\Persistence\QueryInterface $query);
Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
72

73
	/**
74
	 * Returns the object data matching the $query.
75
	 *
Thomas Maroschik's avatar
Thomas Maroschik committed
76
	 * @param \TYPO3\CMS\Extbase\Persistence\QueryInterface $query
77
78
	 * @return array
	 * @api
79
	 */
Thomas Maroschik's avatar
Thomas Maroschik committed
80
	public function getObjectDataByQuery(\TYPO3\CMS\Extbase\Persistence\QueryInterface $query);
81

Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
82
}
Thomas Maroschik's avatar
Thomas Maroschik committed
83

Sebastian Kurfürst's avatar
Sebastian Kurfürst committed
84
?>