From 3ade1e5d62c0bf131bdc3e5fa636ae6ea920fbf5 Mon Sep 17 00:00:00 2001 From: Dmitry Marakasov Date: Mon, 16 Sep 2024 21:21:12 +0300 Subject: [PATCH] Remove a bunch of not used legacy endpoints --- repologyapp/views/legacy.py | 138 ++++-------------------------------- 1 file changed, 14 insertions(+), 124 deletions(-) diff --git a/repologyapp/views/legacy.py b/repologyapp/views/legacy.py index 37ecbab1..ffb1c55d 100644 --- a/repologyapp/views/legacy.py +++ b/repologyapp/views/legacy.py @@ -50,6 +50,7 @@ def _get_projects_args() -> dict[str, str]: }) +# /metapackages/*: logs are poluted by spam requests from huawei cloud, recheck after banning it @ViewRegistrar('/metapackages/all/') @ViewRegistrar('/metapackages/all//') def metapackages_all(bound: str | None = None) -> Response: @@ -125,20 +126,10 @@ def metapackages_outdated_by_maintainer(maintainer: str, bound: str | None = Non return flask.redirect(flask.url_for('projects', bound=bound, maintainer=maintainer, outdated=1, search=flask.request.args.to_dict().get('search')), 301) -@ViewRegistrar('/repositories/') -def legacy_repositories() -> Response: - return flask.redirect(flask.url_for('repositories_statistics'), 301) - - -@ViewRegistrar('/statistics') -@ViewRegistrar('/statistics/') -def legacy_statistics(sorting: str | None = None) -> Response: - return flask.redirect(flask.url_for('repositories_statistics', sorting=sorting), 301) - - -@ViewRegistrar('/metapackage/') -def metapackage(name: str) -> Response: - return flask.redirect(flask.url_for('project_versions', name=name), 301) +@ViewRegistrar('/metapackages/') +@ViewRegistrar('/metapackages//') +def metapackages(bound: str | None = None) -> Response: + return flask.redirect(flask.url_for('projects', bound=bound, **_get_projects_args()), 301) @ViewRegistrar('/project/') @@ -147,10 +138,10 @@ def project(name: str) -> Response: return flask.redirect(flask.url_for('project_versions', name=name), 301) -@ViewRegistrar('/metapackages/') -@ViewRegistrar('/metapackages//') -def metapackages(bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('projects', bound=bound, **_get_projects_args()), 301) +# /metapackage/*: logs are poluted by spam requests from huawei cloud, recheck after banning it +@ViewRegistrar('/metapackage/') +def metapackage(name: str) -> Response: + return flask.redirect(flask.url_for('project_versions', name=name), 301) @ViewRegistrar('/metapackage//versions') @@ -188,111 +179,7 @@ def metapackage_report(name: str) -> Response: return flask.redirect(flask.url_for('project_report', name=name), 301) -@ViewRegistrar('/api/v1/metapackages/') -@ViewRegistrar('/api/v1/metapackages//') -def api_v1_metapackages(bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound, **_get_projects_args()), 301) - - -@ViewRegistrar('/api/v1/metapackage/') -def api_v1_metapackage(name: str) -> Response: - return flask.redirect(flask.url_for('api_v1_project', name=name), 301) - - -@ViewRegistrar('/api/v1/metapackages/all/') -@ViewRegistrar('/api/v1/metapackages/all//') -def api_v1_metapackages_all(bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound), 301) - - -@ViewRegistrar('/api/v1/metapackages/unique/') -@ViewRegistrar('/api/v1/metapackages/unique//') -def api_v1_metapackages_unique(bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound, families=1), 301) - - -@ViewRegistrar('/api/v1/metapackages/in-repo//') -@ViewRegistrar('/api/v1/metapackages/in-repo///') -def api_v1_metapackages_in_repo(repo: str, bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound, inrepo=repo), 301) - - -@ViewRegistrar('/api/v1/metapackages/outdated-in-repo//') -@ViewRegistrar('/api/v1/metapackages/outdated-in-repo///') -def api_v1_metapackages_outdated_in_repo(repo: str, bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound, inrepo=repo, outdated=1), 301) - - -@ViewRegistrar('/api/v1/metapackages/not-in-repo//') -@ViewRegistrar('/api/v1/metapackages/not-in-repo///') -def api_v1_metapackages_not_in_repo(repo: str, bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound, notinrepo=repo), 301) - - -@ViewRegistrar('/api/v1/metapackages/candidates-in-repo//') -@ViewRegistrar('/api/v1/metapackages/candidates-in-repo///') -def api_v1_metapackages_candidates_in_repo(repo: str, bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound, inrepo=repo, families='5-'), 301) - - -@ViewRegistrar('/api/v1/metapackages/unique-in-repo//') -@ViewRegistrar('/api/v1/metapackages/unique-in-repo///') -def api_v1_metapackages_unique_in_repo(repo: str, bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound, inrepo=repo, families=1), 301) - - -@ViewRegistrar('/api/v1/metapackages/by-maintainer//') -@ViewRegistrar('/api/v1/metapackages/by-maintainer///') -def api_v1_metapackages_by_maintainer(maintainer: str, bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound, maintainer=maintainer), 301) - - -@ViewRegistrar('/api/v1/metapackages/outdated-by-maintainer//') -@ViewRegistrar('/api/v1/metapackages/outdated-by-maintainer///') -def api_v1_metapackages_outdated_by_maintainer(maintainer: str, bound: str | None = None) -> Response: - return flask.redirect(flask.url_for('api_v1_projects', bound=bound, maintainer=maintainer, outdated=1), 301) - - -@ViewRegistrar('/graph/total/metapackages.svg') -def graph_total_metapackages() -> Response: - return flask.redirect(flask.url_for('graph_total_projects'), 301) - - -@ViewRegistrar('/graph/repo//metapackages_total.svg') -def graph_repo_metapackages_total(repo: str) -> Response: - return flask.redirect(flask.url_for('graph_repo_projects_total', repo=repo), 301) - - -@ViewRegistrar('/graph/repo//metapackages_newest.svg') -def graph_repo_metapackages_newest(repo: str) -> Response: - return flask.redirect(flask.url_for('graph_repo_projects_newest', repo=repo), 301) - - -@ViewRegistrar('/graph/repo//metapackages_newest_percent.svg') -def graph_repo_metapackages_newest_percent(repo: str) -> Response: - return flask.redirect(flask.url_for('graph_repo_projects_newest_percent', repo=repo), 301) - - -@ViewRegistrar('/graph/repo//metapackages_outdated.svg') -def graph_repo_metapackages_outdated(repo: str) -> Response: - return flask.redirect(flask.url_for('graph_repo_projects_outdated', repo=repo), 301) - - -@ViewRegistrar('/graph/repo//metapackages_outdated_percent.svg') -def graph_repo_metapackages_outdated_percent(repo: str) -> Response: - return flask.redirect(flask.url_for('graph_repo_projects_outdated_percent', repo=repo), 301) - - -@ViewRegistrar('/graph/repo//metapackages_unique.svg') -def graph_repo_metapackages_unique(repo: str) -> Response: - return flask.redirect(flask.url_for('graph_repo_projects_unique', repo=repo), 301) - - -@ViewRegistrar('/graph/repo//metapackages_unique_percent.svg') -def graph_repo_metapackages_unique_percent(repo: str) -> Response: - return flask.redirect(flask.url_for('graph_repo_projects_unique_percent', repo=repo), 301) - - +# active badges on smartmontools.org, lyx.org and others @ViewRegistrar('/badge/version-only-for-repo//.svg') def badge_version_only_for_repo(repo: str, name: str) -> Response: return flask.redirect( @@ -307,6 +194,8 @@ def badge_version_only_for_repo(repo: str, name: str) -> Response: ) +# /maintainer/*/problems: logs are poluted by spam requests from huawei cloud, recheck after banning it +# XXX: don't forget to remove test and get_db import along with this @ViewRegistrar('/maintainer//problems') def maintainer_problems_legacy(maintainer: str) -> Response: # actual problems listing is tied to repository+maintainer pair, @@ -339,12 +228,13 @@ def maintainer_problems_legacy(maintainer: str) -> Response: ) +# reposiotry template was pointing here, recheck after this is fixed @ViewRegistrar('/addrepo') -@ViewRegistrar('/docs/addrepo') def addrepo() -> Response: return flask.redirect(flask.url_for('docs_requirements'), 301) +# internal performance testing tool accessed it, recheck after this is fixed @ViewRegistrar('/about') def about() -> Response: return flask.redirect(flask.url_for('docs_about'), 301)