private function getAdminMassUpdateMirrorPresenters() { $mirrors = $this->mirror_data_mapper->fetchAllForProject($this->project); $mirror_presenters = array(); foreach ($mirrors as $mirror) { $mirror_presenters[] = new GitPresenters_MirrorPresenter($mirror, false); } return $mirror_presenters; }
private function getMirrorPresentersForGitAdmin() { $mirrors = $this->mirror_data_mapper->fetchAllForProject($this->project); $default_mirror_ids = $this->mirror_data_mapper->getDefaultMirrorIdsForProject($this->project); $mirror_presenters = array(); foreach ($mirrors as $mirror) { $is_used = in_array($mirror->id, $default_mirror_ids); $mirror_presenters[] = new GitPresenters_MirrorPresenter($mirror, $is_used); } return $mirror_presenters; }
/** * @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 moveProjectFiles($old_name, $new_name, Git_Gitolite_GitModifications $git_modifications, Project $project) { $old_file = 'conf/projects/' . $old_name . '.conf'; $new_file = 'conf/projects/' . $new_name . '.conf'; $this->proceedToFileMove($old_file, $new_file, $git_modifications); if (!$this->gitoliterc_reader->getHostname()) { return; } $mirrors = $this->mirror_data_mapper->fetchAllForProject($project); foreach ($mirrors as $mirror) { $this->moveProjectFileForMirror($old_name, $new_name, $git_modifications, $mirror); } }
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); } }
private function areMirrorsEnabledForProject() { return count($this->mirror_data_mapper->fetchAllForProject($this->project)) > 0; }
private function isAdminMassChangeAllowed() { return count($this->mirror_data_mapper->fetchAllForProject($this->project)) > 0; }