protected function getRelatedHtmlUrl($subject)
 {
     /** @var Response $response */
     $response = GitHub::connection()->getHttpClient()->get($subject['latest_comment_url']);
     $subjectData = ResponseMediator::getContent($response);
     return $subjectData['html_url'];
 }
Esempio n. 2
0
 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]);
 }
Esempio n. 3
0
 /**
  * @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];
 }
Esempio n. 4
0
 /**
  * @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];
 }
Esempio n. 5
0
 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]);
 }
Esempio n. 6
0
 /**
  * @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;
     }
 }
Esempio n. 7
0
 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()]);
 }