public function triggerUpdateFollowingAGitPush(GitRepository $repository) { $repository_mirrors = $this->data_mapper->fetchAllRepositoryMirrors($repository); foreach ($repository_mirrors as $mirror) { $this->generator->updateCurrentTimeOfRepository($mirror, $repository); } }
private function getCloneUrl() { $mirrors = $this->mirror_data_mapper->fetchAllRepositoryMirrors($this->repository); $presenter = new RepositoryClonePresenter($this->repository, $this->getAccessURLs(), $mirrors, $this->controller->isAPermittedAction('repo_management'), $this->getMasterLocationName()); $renderer = TemplateRendererFactory::build()->getRenderer(GIT_TEMPLATE_DIR); return $renderer->renderToString($presenter->getTemplateName(), $presenter); }
private function getMirrorUserNames(GitRepository $repository) { $names = array(); foreach ($this->data_mapper->fetchAllRepositoryMirrors($repository) as $mirror) { $names[] = $mirror->owner->getUserName(); } return $names; }
/** * @return array */ private function buildPanes(GitRepository $repository) { $panes = array(new GitViews_RepoManagement_Pane_GeneralSettings($repository, $this->request)); if ($repository->getBackendType() == GitDao::BACKEND_GITOLITE) { $panes[] = new GitViews_RepoManagement_Pane_Gerrit($repository, $this->request, $this->driver_factory, $this->gerrit_servers, $this->gerrit_config_templates); } $panes[] = new GitViews_RepoManagement_Pane_AccessControl($repository, $this->request); $mirrors = $this->mirror_data_mapper->fetchAllForProject($repository->getProject()); if (count($mirrors) > 0) { $repository_mirrors = $this->mirror_data_mapper->fetchAllRepositoryMirrors($repository); $panes[] = new GitViews_RepoManagement_Pane_Mirroring($repository, $this->request, $mirrors, $repository_mirrors); } $panes[] = new GitViews_RepoManagement_Pane_Notification($repository, $this->request); $panes[] = new GitViews_RepoManagement_Pane_Delete($repository, $this->request); $indexed_panes = array(); foreach ($panes as $pane) { if ($pane->canBeDisplayed()) { $indexed_panes[$pane->getIdentifier()] = $pane; } } return $indexed_panes; }
private function getWaitingForRepositoryCreationInfo() { $html = '<div class="alert alert-info wait_creation">'; $html .= $GLOBALS['Language']->getText('plugin_git', 'waiting_for_repo_creation'); $default_mirrors = $this->mirror_data_mapper->fetchAllRepositoryMirrors($this->repository); if ($default_mirrors) { $default_mirrors_names = array_map(array($this, 'extractMirrorName'), $default_mirrors); $html .= '<br/>'; $html .= $GLOBALS['Language']->getText('plugin_git', 'waiting_for_repo_creation_default_mirrors', implode(', ', $default_mirrors_names)); } $html .= '</div>'; return $html; }
private function mirrorForkedRepository(GitRepository $forked_repository, GitRepository $base_repository) { $base_repository_mirrors = $this->mirror_data_mapper->fetchAllRepositoryMirrors($base_repository); $project_destination = $forked_repository->getProject(); $allowed_mirrors_forked_repository = $this->mirror_data_mapper->fetchAllForProject($project_destination); $repository_mirrors_ids = array(); foreach ($base_repository_mirrors as $mirror) { if (in_array($mirror, $allowed_mirrors_forked_repository)) { $repository_mirrors_ids[] = $mirror->id; } } if ($repository_mirrors_ids) { $this->mirror_updater->updateRepositoryMirrors($forked_repository, $repository_mirrors_ids); $this->git_system_event_manager->queueRepositoryUpdate($forked_repository); } }