mirror of
https://github.com/RSS-Bridge/rss-bridge.git
synced 2025-10-24 04:56:17 +02:00
50 lines
1.4 KiB
PHP
50 lines
1.4 KiB
PHP
<?php
|
|
|
|
/* Generate the "Contributors" list for README.md automatically utilizing the GitHub API */
|
|
|
|
require __DIR__ . '/../../lib/bootstrap.php';
|
|
|
|
$url = 'https://api.github.com/repos/rss-bridge/rss-bridge/contributors';
|
|
$contributors = [];
|
|
$next = true;
|
|
|
|
while ($next) { /* Collect all contributors */
|
|
$headers = [
|
|
'Accept' => 'application/json',
|
|
'Content-Type' => 'application/json',
|
|
'User-Agent' => 'RSS-Bridge',
|
|
];
|
|
$result = _http_request($url, ['headers' => $headers]);
|
|
|
|
foreach (json_decode($result['body']) as $contributor) {
|
|
$contributors[] = $contributor;
|
|
}
|
|
|
|
// Extract links to "next", "last", etc...
|
|
$links = explode(',', $result['headers']['link'][0]);
|
|
$next = false;
|
|
|
|
// Check if there is a link with 'rel="next"'
|
|
foreach ($links as $link) {
|
|
[$url, $type] = explode(';', $link, 2);
|
|
|
|
if (trim($type) === 'rel="next"') {
|
|
$url = trim(preg_replace('/([<>])/', '', $url));
|
|
$next = true;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* Example JSON data: https://api.github.com/repos/rss-bridge/rss-bridge/contributors */
|
|
|
|
// We want contributors sorted by name
|
|
usort($contributors, function ($a, $b) {
|
|
return strcasecmp($a->login, $b->login);
|
|
});
|
|
|
|
// Export as Markdown list
|
|
foreach ($contributors as $contributor) {
|
|
echo " * [{$contributor->login}]({$contributor->html_url})\n";
|
|
}
|