Skip to content

Commit

Permalink
Merge pull request #253 from dc-ag/feature/dependentsAsJson
Browse files Browse the repository at this point in the history
Possibility to fetch dependents data as json and via API
  • Loading branch information
vtsykun authored Apr 22, 2024
2 parents 11c860f + 35817a4 commit c38e2dc
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 2 deletions.
6 changes: 6 additions & 0 deletions src/Controller/Api/ApiForwardController.php
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,12 @@ public function item(string $name)
return $this->forward('Packeton\Controller\PackageController::viewPackageAction', ['name' => $name, '_format' => 'json']);
}

#[Route('/packages/{name}/dependents', name: 'packages_dependents', requirements: ['name' => '([A-Za-z0-9_.-]+/[A-Za-z0-9_.-]+?|ext-[A-Za-z0-9_.-]+?)'], methods: ['GET'])]
public function dependents(string $name)
{
return $this->forward('Packeton\Controller\PackageController::dependentsAction', ['name' => $name, '_format' => 'json']);
}

#[Route('/packages/{name}/changelog', name: 'packages_changelog', requirements: ['name' => '%package_name_regex%'], methods: ['GET'])]
public function changelog(#[Vars] Package $package, Request $request)
{
Expand Down
17 changes: 15 additions & 2 deletions src/Controller/PackageController.php
Original file line number Diff line number Diff line change
Expand Up @@ -939,9 +939,14 @@ public function statsAction(Request $req, #[Vars] Package $package): Response
}

#[Route(
'/packages/{name}/dependents',
'/packages/{name}/dependents.{_format}',
name: 'view_package_dependents',
requirements: ['name' => '([A-Za-z0-9_.-]+/[A-Za-z0-9_.-]+?|ext-[A-Za-z0-9_.-]+?)'],
requirements: [
'name' => '([A-Za-z0-9_.-]+/[A-Za-z0-9_.-]+?|ext-[A-Za-z0-9_.-]+?)',
'_format' => '(json)',
],
defaults: ['_format' => 'html'],
methods: ['GET']
)]
#[IsGranted('ROLE_FULL_CUSTOMER')]
public function dependentsAction(Request $req, $name): Response
Expand All @@ -964,6 +969,14 @@ public function dependentsAction(Request $req, $name): Response
$data['meta'] = $this->getPackagesMetadata($data['packages']);
$data['name'] = $name;

if ('json' === $req->getRequestFormat()) {
$response = new JsonResponse($data);
$response->setSharedMaxAge(12*3600);

return $response;
}


return $this->render('package/dependents.html.twig', $data);
}

Expand Down
6 changes: 6 additions & 0 deletions swagger/packages-api.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,12 @@ paths:
summary: 'Update a package'
example: $PackageUpdate
<<: *pkg-param

'/api/packages/{name}/dependents':
get:
tags: [ Packages ]
summary: 'View the dependents of a package'
<<: *pkg-param

'/api/packages/{name}/changelog':
get:
Expand Down

0 comments on commit c38e2dc

Please sign in to comment.