src/Module/Api/Method/Api4/Artists4Method.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\Api4;
use Ampache\Repository\Model\User;
use Ampache\Module\Api\Api;
use Ampache\Module\Api\Json4_Data;
use Ampache\Module\Api\Xml4_Data;
/**
* Class Artists4Method
*/
final class Artists4Method
{
public const ACTION = 'artists';
/**
* artists
* MINIMUM_API_VERSION=380001
*
* This takes a collection of inputs and returns
* artist objects. This function is deprecated!
*
* 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
* include = (array) 'albums'|'songs' //optional
*/
public static function artists(array $input, User $user): void
{
$browse = Api::getBrowse();
$browse->set_type('artist');
$browse->set_sort('name', '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'] ?? '');
$results = $browse->get_objects();
$include = [];
if (array_key_exists('include', $input)) {
$include = (is_array($input['include'])) ? $input['include'] : explode(',', html_entity_decode((string)($input['include'])));
}
ob_end_clean();
switch ($input['api_format']) {
case 'json':
Json4_Data::set_offset($input['offset'] ?? 0);
Json4_Data::set_limit($input['limit'] ?? 0);
echo Json4_Data::artists($results, $include, $user);
break;
default:
Xml4_Data::set_offset($input['offset'] ?? 0);
Xml4_Data::set_limit($input['limit'] ?? 0);
echo Xml4_Data::artists($results, $include, $user);
}
}
}