protected function getRelatedHtmlUrl($subject) { /** @var Response $response */ $response = GitHub::connection()->getHttpClient()->get($subject['latest_comment_url']); $subjectData = ResponseMediator::getContent($response); return $subjectData['html_url']; }
public function showIndex($login, $repo) { $repoInfo = GitHub::repos()->show($login, $repo); if ($repoInfo['fork']) { $pullFrom = $repoInfo['parent']['owner']['login']; $defaultBranch = $repoInfo['parent']['default_branch']; } else { $pullFrom = $login; $defaultBranch = $repoInfo['default_branch']; } if ($pullFrom != $login) { // Get pulls requests from issue list $pulls = []; $paginator = new ResultPager(GitHub::connection()); $issues = $paginator->fetchAll(GitHub::issues(), 'all', [$pullFrom, $repo, ['creator' => $repoInfo['owner']['login']]]); foreach ($issues as $issue) { if (isset($issue['pull_request'])) { $pull = GitHub::pullRequest()->show($pullFrom, $repo, $issue['number']); $pulls[$pull['head']['ref']][] = $pull; } } } // Get branches for this repo $branches = GitHub::gitData()->references()->branches($login, $repo); foreach ($branches as &$branch) { $branch['name'] = str_replace('refs/heads/', '', $branch['ref']); if ($pullFrom == $login) { $branch['pulls'] = GitHub::pullRequests()->all($pullFrom, $repo, ['base' => $branch['name']]); } else { $branch['pulls'] = isset($pulls[$branch['name']]) ? $pulls[$branch['name']] : []; } } return view('branches.index', ['login' => $login, 'repo' => $repo, 'branches' => $branches, 'rateLimits' => $this->getRateLimit(), 'defaultBranch' => $defaultBranch]); }
/** * @param $login * @param $lastEventId * @param int $page * * @return array */ private function findNewActivity($login, $lastEventId, $page = 1) { /** @var Response $response */ $response = GitHub::connection()->getHttpClient()->get(sprintf('/users/%s/received_events?page=%s', $login, (int) $page)); // Get the interval Github allows for polling $interval = $response->hasHeader('X-Poll-Interval') ? (string) $response->getHeader('X-Poll-Interval') : 60; $activity = ResponseMediator::getContent($response); $pagination = ResponseMediator::getPagination($response); $isLastPage = empty($pagination['next']); $caughtUp = false; $newActivity = []; foreach ($activity as $event) { if ($event['id'] == $lastEventId) { $caughtUp = true; break; } $newActivity[] = $event; } if (!$caughtUp && !$isLastPage) { // Try the next page list($interval, $activity) = $this->findNewActivity($login, $lastEventId, $page + 1); $newActivity += $activity; } return [$interval, $newActivity]; }
/** * @param $login * @param $lastEventId * @param int $page * * @return array */ private function findNewActivity($login, $lastEventId, $page = 1) { /** @var Response $response */ $response = GitHub::connection()->getHttpClient()->get(sprintf('/notifications?page=%s', $login, (int) $page)); // Get the interval Github allows for polling $interval = $response->hasHeader('X-Poll-Interval') ? (string) $response->getHeader('X-Poll-Interval') : 60; $activity = ResponseMediator::getContent($response); $newActivity = []; foreach ($activity as $event) { if ($event['id'] == $lastEventId) { break; } $newActivity[] = $event; } return [$interval, $newActivity]; }
public function showIndex(Request $request, $page = 1) { $me = GitHub::me()->show(); /** @var Response $response */ $response = GitHub::connection()->getHttpClient()->get(sprintf('/users/%s/received_events?page=%s', $me['login'], (int) $page)); $activity = ResponseMediator::getContent($response); $pagination = $this->getPagination($response); $pending = Input::get('pending', 0); // Save the latest activity ID for live fetching if (count($activity)) { $request->session()->put('last_event_id', $activity[0]['id']); $this->parseActivity($activity, $me, $pending); } // Get the interval Github allows for polling $interval = $response->hasHeader('X-Poll-Interval') ? (string) $response->getHeader('X-Poll-Interval') : 60; return view('activity.index', ['me' => $me, 'activity' => $activity, 'pagination' => $pagination, 'page' => $page, 'interval' => (int) $interval * 1000, 'pending' => $pending]); }
/** * @param $repositories * @param $org * @param $me */ private function getIssuesAndPRs(&$repositories, $org, $me) { foreach ($repositories as &$repo) { // Get pulls requests from issue list $pulls = []; $issues = []; $paginator = new ResultPager(GitHub::connection()); $allIssues = $paginator->fetchAll(GitHub::issues(), 'all', [$org['login'], $repo['name'], ['creator' => $me['login']]]); foreach ($allIssues as $issue) { if (isset($issue['pull_request'])) { $pulls[] = $issue; } else { $issues[] = $issue; } } $repo['issues'] = $issues; $repo['pulls'] = $pulls; } }
public function showIndex(Request $request, $page = 1) { $me = GitHub::me()->show(); /** @var Response $response */ $activity = GitHub::notification()->all(); // Save the latest activity ID for live fetching if (count($activity)) { $request->session()->put('last_notification_id', $activity[0]['id']); // Mark as read try { GitHub::notification()->markRead(); } catch (\Exception $e) { // Github returns empty string for this endpoint but the API library tries to parse it as json } foreach ($activity as &$notice) { $notice['html_url'] = $this->getRelatedHtmlUrl($notice['subject']); } } // Get the interval Github allows for polling $response = GitHub::connection()->getHttpClient()->getLastResponse(); $interval = $response->hasHeader('X-Poll-Interval') ? (string) $response->getHeader('X-Poll-Interval') : 60; return view('notifications.index', ['me' => $me, 'activity' => $activity, 'page' => $page, 'interval' => (int) $interval * 1000]); }
public function generate($login, $repo, $milestone) { // Find the milestone number by fetching all milestones $paginator = new ResultPager(GitHub::connection()); $milestones = $paginator->fetchAll(GitHub::issues()->milestones(), 'all', [$login, $repo]); // Fetch the issues for this milestone $milestoneIssues = []; foreach ($milestones as $result) { if ($milestone == $result['title']) { $milestoneIssues = $paginator->fetchAll(GitHub::issues(), 'all', [$login, $repo, ['milestone' => $result['number'], 'state' => 'all']]); break; } } $pullRequests = []; $issues = []; $acknowledgements = []; $labels = []; $hideAuthors = explode(',', $_SERVER['GITHUB_HIDE_AUTHORS']); $labelGroups = explode(',', $_SERVER['GITHUB_LABELS']); foreach ($labelGroups as &$label) { list($labelName, $groupName) = explode('|', $label); $labels[$labelName] = $groupName; } $defaultGroup = $labels[$_SERVER['GITHUB_DEFAULT_GROUP']]; foreach ($milestoneIssues as $k => $issue) { $issue['submitter'] = in_array($issue['user']['login'], $hideAuthors) ? '' : $issue['user']['login']; if (!empty($issue['submitter']) && !in_array('@' . $issue['submitter'], $acknowledgements)) { $acknowledgements[] = '@' . $issue['submitter']; } if (isset($issue['pull_request'])) { $labelFound = false; foreach ($issue['labels'] as $label) { if (array_key_exists($label['name'], $labels)) { $pullRequests[$labels[$label['name']]][] = $issue; $labelFound = true; break; } } if (!$labelFound) { $pullRequests[$defaultGroup][] = $issue; } } else { $labelFound = false; foreach ($issue['labels'] as $label) { if (array_key_exists($label['name'], $labels)) { $issues[$labels[$label['name']]][] = $issue; $labelFound = true; break; } } if (!$labelFound) { $issues[$defaultGroup][] = $issue; } } } // Sort by label order $pullRequests = array_merge(array_flip($labels), $pullRequests); $issues = array_merge(array_flip($labels), $issues); // Set acknowledgements natcasesort($acknowledgements); $acknowledgements = implode(', ', $acknowledgements); return view('milestones.changelog', ['login' => $login, 'repo' => $repo, 'milestone' => $milestone, 'pullRequests' => $pullRequests, 'issues' => $issues, 'acknowledgements' => $acknowledgements, 'rateLimits' => $this->getRateLimit()]); }
public function generate($login, $repo, $milestone) { // Find the milestone number by fetching all milestones $paginator = new ResultPager(GitHub::connection()); $milestones = $paginator->fetchAll(GitHub::issues()->milestones(), 'all', [$login, $repo]); // Fetch the issues for this milestone $milestoneIssues = []; foreach ($milestones as $result) { if ($milestone == $result['title']) { $milestoneIssues = $paginator->fetchAll(GitHub::issues(), 'all', [$login, $repo, ['milestone' => $result['number'], 'state' => 'all']]); $milestone = $result; break; } } $prs = []; $team = explode(',', $_SERVER['GITHUB_HIDE_AUTHORS']); foreach ($milestoneIssues as $k => $issue) { if (isset($issue['pull_request']) && $issue['state'] !== 'closed') { $needsDocumentation = false; $hasConflicts = false; $status = false; foreach ($issue['labels'] as $label) { switch (true) { case 'Pending Test Confirmation' == $label['name']: $status = 'Pending Test Confirmation'; break; case 'Code Review' == $label['name']: $status = 'Code Review'; break; case 'Pending Feedback' == $label['name']: $status = 'Pending Feedback'; break; case 'Ready To Commit' == $label['name']: $status = "Ready To Commit"; break; } if ('Needs Documentation' == $label['name']) { $needsDocumentation = true; } if ($status) { break; } } if (!$status) { $status = 'Needs Testing'; } $pull = GitHub::pullRequest()->show($login, $repo, $issue['number']); if (empty($pull['mergeable'])) { $hasConflicts = true; } $plusOne = []; $feedBackBy = []; $comments = $event['comments'] = GitHub::issue()->comments()->all($login, $repo, $issue['number']); foreach ($comments as $comment) { if (in_array($comment['user']['login'], $team)) { if (strpos($comment['body'], '+1') !== false) { $plusOne[] = $comment['user']['login']; } $feedBackBy[$comment['user']['login']] = $comment['user']['login']; } } $prs[$issue['number']] = ['author' => $issue['user']['login'], 'name' => $issue['title'], 'link' => $issue['html_url'], 'status' => $status, 'hasConflicts' => $hasConflicts, 'needsDocs' => $needsDocumentation, 'plusOne' => $plusOne, 'feedbackBy' => $feedBackBy]; } } uasort($prs, function ($a, $b) { return strnatcasecmp($a['author'], $b['author']); }); return view('milestones.analyasis', ['login' => $login, 'repo' => $repo, 'milestone' => $milestone, 'pullRequests' => $prs, 'rateLimits' => $this->getRateLimit()]); }