src/Module/Api/Method/Api5/Songs5Method.php
<?php
declare(strict_types=0);
/**
* vim:set softtabstop=4 shiftwidth=4 expandtab:
*
* LICENSE: GNU Affero General Public License, version 3 (AGPL-3.0-or-later)
* Copyright Ampache.org, 2001-2023
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
*/
namespace Ampache\Module\Api\Method\Api5;
use Ampache\Repository\Model\User;
use Ampache\Module\Api\Api;
use Ampache\Module\Api\Api5;
use Ampache\Module\Api\Json5_Data;
use Ampache\Module\Api\Xml5_Data;
/**
* Class Songs5Method
*/
final class Songs5Method
{
public const ACTION = 'songs';
/**
* songs
* MINIMUM_API_VERSION=380001
* CHANGED_IN_API_VERSION=420000
*
* Returns songs based on the specified filter
* All calls that return songs now include <playlisttrack> which can be used to identify track order.
*
* filter = (string) Alpha-numeric search term //optional
* exact = (integer) 0,1, if true filter is exact rather then fuzzy //optional
* add = $browse->set_api_filter(date) //optional
* update = $browse->set_api_filter(date) //optional
* offset = (integer) //optional
* limit = (integer) //optional
*/
public static function songs(array $input, User $user): bool
{
$browse = Api::getBrowse();
$browse->set_type('song');
$browse->set_sort('title', 'ASC');
$method = (array_key_exists('exact', $input) && (int)$input['exact'] == 1) ? 'exact_match' : 'alpha_match';
$browse->set_api_filter($method, $input['filter'] ?? '');
$browse->set_api_filter('add', $input['add'] ?? '');
$browse->set_api_filter('update', $input['update'] ?? '');
// Filter out disabled songs
$browse->set_filter('enabled', 1);
$results = $browse->get_objects();
if (empty($results)) {
Api5::empty('song', $input['api_format']);
return false;
}
ob_end_clean();
switch ($input['api_format']) {
case 'json':
Json5_Data::set_offset($input['offset'] ?? 0);
Json5_Data::set_limit($input['limit'] ?? 0);
echo Json5_Data::songs($results, $user);
break;
default:
Xml5_Data::set_offset($input['offset'] ?? 0);
Xml5_Data::set_limit($input['limit'] ?? 0);
echo Xml5_Data::songs($results, $user);
}
return true;
}
}