nginxsonarrradarrplexorganizrdashboardbookmarkapplication-dashboardmuximuxlandingpagestartpagelandinghtpcserverhomepagesabnzbdheimdallembycouchpotatonzbget
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
136 lines
3.7 KiB
136 lines
3.7 KiB
6 years ago
|
<?php
|
||
|
|
||
|
namespace Github\Api\Issue;
|
||
|
|
||
|
use Github\Api\AbstractApi;
|
||
|
use Github\Api\AcceptHeaderTrait;
|
||
|
use Github\Exception\MissingArgumentException;
|
||
|
|
||
|
/**
|
||
|
* @link http://developer.github.com/v3/issues/comments/
|
||
|
*
|
||
|
* @author Joseph Bielawski <stloyd@gmail.com>
|
||
|
* @author Tobias Nyholm <tobias.nyholm@gmail.com>
|
||
|
*/
|
||
|
class Comments extends AbstractApi
|
||
|
{
|
||
|
use AcceptHeaderTrait;
|
||
|
|
||
|
/**
|
||
|
* Configure the body type.
|
||
|
*
|
||
|
* @link https://developer.github.com/v3/issues/comments/#custom-media-types
|
||
|
*
|
||
|
* @param string|null $bodyType
|
||
|
*
|
||
|
* @return self
|
||
|
*/
|
||
|
public function configure($bodyType = null)
|
||
|
{
|
||
|
if (!in_array($bodyType, ['raw', 'text', 'html'])) {
|
||
|
$bodyType = 'full';
|
||
|
}
|
||
|
|
||
|
$this->acceptHeaderValue = sprintf('application/vnd.github.%s.%s+json', $this->client->getApiVersion(), $bodyType);
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get all comments for an issue.
|
||
|
*
|
||
|
* @link https://developer.github.com/v3/issues/comments/#list-comments-on-an-issue
|
||
|
*
|
||
|
* @param string $username
|
||
|
* @param string $repository
|
||
|
* @param int $issue
|
||
|
* @param int $page
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function all($username, $repository, $issue, $page = 1)
|
||
|
{
|
||
|
return $this->get('/repos/'.rawurlencode($username).'/'.rawurlencode($repository).'/issues/'.rawurlencode($issue).'/comments', [
|
||
|
'page' => $page,
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get a comment for an issue.
|
||
|
*
|
||
|
* @link https://developer.github.com/v3/issues/comments/#get-a-single-comment
|
||
|
*
|
||
|
* @param string $username
|
||
|
* @param string $repository
|
||
|
* @param int $comment
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function show($username, $repository, $comment)
|
||
|
{
|
||
|
return $this->get('/repos/'.rawurlencode($username).'/'.rawurlencode($repository).'/issues/comments/'.rawurlencode($comment));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Create a comment for an issue.
|
||
|
*
|
||
|
* @link https://developer.github.com/v3/issues/comments/#create-a-comment
|
||
|
*
|
||
|
* @param string $username
|
||
|
* @param string $repository
|
||
|
* @param int $issue
|
||
|
* @param array $params
|
||
|
*
|
||
|
* @throws \Github\Exception\MissingArgumentException
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function create($username, $repository, $issue, array $params)
|
||
|
{
|
||
|
if (!isset($params['body'])) {
|
||
|
throw new MissingArgumentException('body');
|
||
|
}
|
||
|
|
||
|
return $this->post('/repos/'.rawurlencode($username).'/'.rawurlencode($repository).'/issues/'.rawurlencode($issue).'/comments', $params);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Update a comment for an issue.
|
||
|
*
|
||
|
* @link https://developer.github.com/v3/issues/comments/#edit-a-comment
|
||
|
*
|
||
|
* @param string $username
|
||
|
* @param string $repository
|
||
|
* @param int $comment
|
||
|
* @param array $params
|
||
|
*
|
||
|
* @throws \Github\Exception\MissingArgumentException
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function update($username, $repository, $comment, array $params)
|
||
|
{
|
||
|
if (!isset($params['body'])) {
|
||
|
throw new MissingArgumentException('body');
|
||
|
}
|
||
|
|
||
|
return $this->patch('/repos/'.rawurlencode($username).'/'.rawurlencode($repository).'/issues/comments/'.rawurlencode($comment), $params);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Delete a comment for an issue.
|
||
|
*
|
||
|
* @link https://developer.github.com/v3/issues/comments/#delete-a-comment
|
||
|
*
|
||
|
* @param string $username
|
||
|
* @param string $repository
|
||
|
* @param int $comment
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function remove($username, $repository, $comment)
|
||
|
{
|
||
|
return $this->delete('/repos/'.rawurlencode($username).'/'.rawurlencode($repository).'/issues/comments/'.rawurlencode($comment));
|
||
|
}
|
||
|
}
|