From a9c5a155cf069c7dad1a3b42a5bedc45405df2f3 Mon Sep 17 00:00:00 2001 From: Drew DeVault Date: Tue, 10 Jul 2018 08:44:30 -0400 Subject: [PATCH] Improve clone URLs --- gitsrht/blueprints/public.py | 32 +++++++++++++++++--------------- 1 file changed, 17 insertions(+), 15 deletions(-) diff --git a/gitsrht/blueprints/public.py b/gitsrht/blueprints/public.py index 34a8515..2f79604 100644 --- a/gitsrht/blueprints/public.py +++ b/gitsrht/blueprints/public.py @@ -52,24 +52,26 @@ def cgit_passthrough(owner_name, repo_name, cgit_path=""): if r.status_code != 200: abort(r.status_code) base = cfg("network", "git").replace("http://", "").replace("https://", "") - clone_urls = [ - ("ssh://git@{}:{}/{}", "git@{}:{}/{}"), - ("https://{}/{}/{}",) - ] - if "Repository seems to be empty" in r.text: - clone_urls = clone_urls[:2] - clone_text = "" +\ + clone_urls = ["https://{}/{}/{}", "git@{}:{}/{}"] + our_clone_text = """ + + {} + (read-only) + + + {} + (read/write) + + """.format( + clone_urls[0].format(base, owner_name, repo_name), + clone_urls[0].format(base, owner_name, repo_name), + clone_urls[1].format(base, owner_name, repo_name)) + their_clone_text = "" +\ "__CLONE_URL__".format( owner_name, repo_name) + "" - if not clone_text in r.text: + if not their_clone_text in r.text: clone_text = clone_text.replace(" colspan='3'", "") - text = r.text.replace( - clone_text, - " ".join(["{}".format( - url[0].format(base, owner_name, repo_name), - url[-1].format(base, owner_name, repo_name)) - for url in clone_urls]) - ) + text = r.text.replace(their_clone_text, our_clone_text) if "Repository seems to be empty" in r.text: text = text.replace("Clone", "Push") return render_template("cgit.html", -- 2.38.4