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.
205 lines
4.9 KiB
205 lines
4.9 KiB
<?php |
|
|
|
|
|
|
|
// 0 - none |
|
define( 'GEDEBUG_NONE', 0 ); |
|
|
|
// 1 - call logging only |
|
define( 'GEDEBUG_CALL', 1 ); |
|
|
|
// 2 - calls, and responses |
|
define( 'GEDEBUG_RESP', 2 ); |
|
|
|
// Selected debug level |
|
define( 'GITHUB_API_LEVEL', GEDEBUG_NONE ); |
|
|
|
|
|
/** |
|
* This class contains all the functions that actually retrieve information from the GitHub API |
|
*/ |
|
class github_api { |
|
|
|
|
|
private $client_id = null; |
|
private $client_secret = null; |
|
|
|
|
|
|
|
/** |
|
* Allow the client ID / secret to be set, and used for subsequent calls |
|
*/ |
|
function __construct() { |
|
|
|
add_action( 'plugins_loaded', array( $this, 'set_credentials' ) ); |
|
add_filter( 'http_request_timeout', array( $this, 'http_request_timeout' ) ); |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
* Extend the timeout since API calls can easily exceed 5 seconds |
|
* @param int $seconds The current timeout setting |
|
* @return int The revised timeout setting |
|
*/ |
|
function http_request_timeout( $seconds ) { |
|
return $seconds < 25 ? 25 : $seconds; |
|
} |
|
|
|
|
|
|
|
/** |
|
* If you find yourself hitting rate limits, then you can register an application |
|
* with GitHub(http://developer.github.com/v3/oauth/) use the filters here to |
|
* provide the credentials. |
|
*/ |
|
public function set_credentials() { |
|
|
|
$this->client_id = apply_filters( 'github-embed-client-id', $this->client_id ); |
|
$this->client_secret = apply_filters( 'github-embed-client-secret', $this->client_secret ); |
|
|
|
} |
|
|
|
|
|
|
|
private function call_api( $url ) { |
|
|
|
// Allow users to supply auth details to enable a higher rate limit |
|
if ( ! empty( $this->client_id ) && ! empty( $this->client_secret ) ) { |
|
$url = add_query_arg( |
|
array( |
|
'client_id' => $this->client_id, |
|
'client_secret' => $this->client_secret ), |
|
$url |
|
); |
|
} |
|
|
|
$args = array( 'user-agent' => 'WordPress Github oEmbed plugin - https://github.com/leewillis77/wp-github-oembed'); |
|
|
|
$this->log( __FUNCTION__." : $url", GEDEBUG_CALL ); |
|
|
|
$results = wp_remote_get( $url, $args ); |
|
|
|
$this->log( __FUNCTION__ . " : " . print_r( $results,1 ), GEDEBUG_RESP ); |
|
|
|
if( is_wp_error( $results ) || |
|
! isset( $results['response']['code'] ) || |
|
$results['response']['code'] != '200' ) { |
|
header( 'HTTP/1.0 404 Not Found' ); |
|
die( 'Octocat is lost, and afraid' ); |
|
} |
|
|
|
return $results; |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
* Get a repository from the GitHub API |
|
* @param string $owner The repository's owner |
|
* @param string $repository The respository name |
|
* @return object The response from the GitHub API |
|
*/ |
|
public function get_repo( $owner, $repository ) { |
|
|
|
$this->log( "get_repo( $owner, $repository )", GEDEBUG_CALL ); |
|
|
|
$owner = trim( $owner, '/' ); |
|
$repository = trim( $repository, '/' ); |
|
|
|
$results = $this->call_api( "https://api.github.com/repos/$owner/$repository" ); |
|
|
|
return json_decode( $results['body'] ); |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
* Get commit information for a repository from the GitHub API |
|
* @param string $owner The repository's owner |
|
* @param string $repository The respository name |
|
* @return object The response from the GitHub API |
|
*/ |
|
public function get_repo_commits( $owner, $repository ) { |
|
|
|
$this->log( "get_repo_commits( $owner, $repository )", GEDEBUG_CALL ); |
|
|
|
$owner = trim( $owner, '/' ); |
|
$repository = trim( $repository, '/' ); |
|
|
|
$results = $this->call_api( "https://api.github.com/repos/$owner/$repository/commits" ); |
|
|
|
return json_decode( $results['body'] ); |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
* Get a milestone summary from the GitHub API |
|
* @param string $owner The repository's owner |
|
* @param string $repository The respository name |
|
* @param string $milestone The milestone ID |
|
* @return object The response from the GitHub API |
|
*/ |
|
public function get_repo_milestone_summary( $owner, $repository, $milestone ) { |
|
|
|
$this->log( "get_repo_milestone_summary( $owner, $repository, $milestone )", GEDEBUG_CALL ); |
|
|
|
$owner = trim( $owner, '/' ); |
|
$repo = trim( $repository, '/' ); |
|
|
|
$results = $this->call_api( "https://api.github.com/repos/$owner/$repository/milestones/$milestone" ); |
|
|
|
return json_decode( $results['body'] ); |
|
|
|
} |
|
|
|
|
|
|
|
public function get_repo_contributors( $owner, $repository ) { |
|
|
|
$this->log( "get_repo_contributors( $owner, $repository )", GEDEBUG_CALL ); |
|
|
|
$owner = trim( $owner, '/' ); |
|
$repo = trim( $repository, '/' ); |
|
|
|
$results = $this->call_api( "https://api.github.com/repos/$owner/$repository/stats/contributors" ); |
|
|
|
return json_decode( $results['body'] ); |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
* Get a user from the GitHub API |
|
* @param string $user The username |
|
* @return object The response from the GitHub API |
|
*/ |
|
public function get_user( $user ) { |
|
|
|
$this->log( "get_user( $user )", GEDEBUG_CALL ); |
|
|
|
$user = trim( $user, '/' ); |
|
|
|
$results = $this->call_api( "https://api.github.com/users/$user" ); |
|
|
|
return json_decode( $results['body'] ); |
|
|
|
} |
|
|
|
|
|
|
|
private function log( $msg, $level ) { |
|
if ( GITHUB_API_LEVEL >= $level ) { |
|
error_log( "[GE$level]: ".$msg ); |
|
} |
|
} |
|
|
|
|
|
|
|
}
|
|
|