X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=app%2FController%2FGithub%2FRepo.php;h=f194d8e726b91ac52294e1651a542b95d0d8ea4e;hb=930d06a96fa24317f053fecb8569aacaa69a0778;hp=0c33a016c4cbc643bfeeaf7a049c47df5ee0627d;hpb=ebc0d017c8a24bd16ca1f4347b39b07ba4349135;p=pharext%2Fpharext.org diff --git a/app/Controller/Github/Repo.php b/app/Controller/Github/Repo.php index 0c33a01..f194d8e 100644 --- a/app/Controller/Github/Repo.php +++ b/app/Controller/Github/Repo.php @@ -17,15 +17,28 @@ class Repo extends Github } catch (\app\Github\Exception $exception) { $this->app->getView()->addData(compact("exception", "owner", "name")); } + + if (($modal = $this->app->getRequest()->getQuery("modal"))) { + $this->app->getView()->addData(compact("modal") + [ + "action" => $this->app->getRequest()->getQuery($modal) + ]); + } + $this->app->display("github/repo"); } } function repoCallback($repo, $links) { - $this->app->getView()->addData(compact("repo")); + $this->app->getView()->addData(compact("repo") + [ + "title" => "Github: {$repo->name}" + ]); settype($repo->tags, "object"); + $this->github->fetchHooks($repo->full_name, function($hooks) use($repo) { + $repo->hooks = $hooks; + }); $this->github->fetchTags($repo->full_name, 1, $this->createTagsCallback($repo)); $this->github->fetchReleases($repo->full_name, 1, $this->createReleasesCallback($repo)); + $this->github->fetchContents($repo->full_name, null, $this->createContentsCallback($repo)); } function createReleasesCallback($repo) { @@ -47,4 +60,21 @@ class Repo extends Github } }; } + + function createContentsCallback($repo) { + return function($tree) use($repo) { + foreach ($tree as $entry) { + if ($entry->type !== "file" || $entry->size <= 0) { + continue; + } + if ($entry->name === "config.m4" || fnmatch("config?.m4", $entry->name)) { + $repo->config_m4 = $entry->name; + } elseif ($entry->name === "package.xml" || $entry->name === "package2.xml") { + $repo->package_xml = $entry->name; + } elseif ($entry->name === "pharext_package.php") { + $repo->pharext_package_php = $entry->name; + } + } + }; + } }