src/Zendesk/API/Resources/Core/SatisfactionRatings.php
<?php
namespace Zendesk\API\Resources\Core;
use Zendesk\API\Resources\ResourceAbstract;
use Zendesk\API\Exceptions\MissingParametersException;
use Zendesk\API\Traits\Resource\Create;
use Zendesk\API\Traits\Resource\Find;
use Zendesk\API\Traits\Resource\FindAll;
/**
* Class Satisfaction Ratings
* https://developer.zendesk.com/rest_api/docs/core/satisfaction_ratings
*/
class SatisfactionRatings extends ResourceAbstract
{
use Create {
create as traitCreate;
}
use Find;
use FindAll;
/**
* Declares routes to be used by this resource.
*/
protected function setUpRoutes()
{
parent::setUpRoutes();
$this->setRoutes([
'create' => 'tickets/{ticket_id}/satisfaction_rating.json'
]);
}
/**
* Creates a Satisfaction Rating
* https://developer.zendesk.com/rest_api/docs/core/satisfaction_ratings#create-a-satisfaction-rating
*
* @param array $queryParams
*
* @throws MissingParametersException
* @throws \Exception
*
* @return \stdClass | null
*/
public function create(array $queryParams = [])
{
$queryParams = $this->addChainedParametersToParams($queryParams, ['ticket_id' => Tickets::class]);
if (! $this->hasKeys($queryParams, ['ticket_id'])) {
throw new MissingParametersException(__METHOD__, ['ticket_id']);
}
return $this->traitCreate($queryParams);
}
}