2014-04-15 16:07:27 +02:00
|
|
|
<?php
|
2015-02-03 16:16:10 +01:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
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
|
|
|
|
*/
|
|
|
|
public function hasOrder();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the order if any
|
|
|
|
*
|
|
|
|
* @return array|null
|
|
|
|
*/
|
|
|
|
public function getOrder();
|
|
|
|
}
|