2014-04-15 16:07:27 +02:00
|
|
|
<?php
|
2016-02-08 15:41:00 +01:00
|
|
|
/* Icinga Web 2 | (c) 2014 Icinga Development Team | GPLv2+ */
|
2014-04-15 16:07:27 +02:00
|
|
|
|
|
|
|
namespace Icinga\Data;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface for sorting a result set
|
|
|
|
*/
|
|
|
|
interface Sortable
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Sort ascending
|
|
|
|
*/
|
|
|
|
const SORT_ASC = 'ASC';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sort descending
|
|
|
|
*/
|
|
|
|
const SORT_DESC = 'DESC';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sort result set by the given field (and direction)
|
|
|
|
*
|
|
|
|
* Preferred usage:
|
|
|
|
* <code>
|
|
|
|
* $query->order('field, 'ASC')
|
|
|
|
* </code>
|
|
|
|
*
|
|
|
|
* @param string $field
|
2014-05-07 10:00:41 +02:00
|
|
|
* @param string $direction
|
2014-04-15 16:07:27 +02:00
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function order($field, $direction = null);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether an order is set
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
2015-06-26 15:13:46 +02:00
|
|
|
public function hasOrder();
|
2014-04-15 16:07:27 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the order if any
|
|
|
|
*
|
|
|
|
* @return array|null
|
|
|
|
*/
|
|
|
|
public function getOrder();
|
|
|
|
}
|