<?xml version="1.0" encoding="UTF-8" ?>

<bugzilla version="5.2"
          urlbase="https://bugzilla.altlinux.org/"
          
          maintainer="jenya@basealt.ru"
>

    <bug>
          <bug_id>54821</bug_id>
          
          <creation_ts>2025-06-17 15:32:35 +0300</creation_ts>
          <short_desc>autocomplete gears subdirectory in URLs</short_desc>
          <delta_ts>2025-06-17 16:01:55 +0300</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>2</classification_id>
          <classification>Infrastructure</classification>
          <product>Infrastructure</product>
          <component>git.altlinux.org</component>
          <version>unspecified</version>
          <rep_platform>all</rep_platform>
          <op_sys>Linux</op_sys>
          <bug_status>NEW</bug_status>
          <resolution></resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P5</priority>
          <bug_severity>enhancement</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Arseny Maslennikov">arseny</reporter>
          <assigned_to name="placeholder@altlinux.org">placeholder</assigned_to>
          <cc>glebfm</cc>
    
    <cc>ldv</cc>
    
    <cc>rider</cc>
          
          <qa_contact name="Andrey Cherepanov">cas</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>267314</commentid>
    <comment_count>0</comment_count>
    <who name="Arseny Maslennikov">arseny</who>
    <bug_when>2025-06-17 15:32:35 +0300</bug_when>
    <thetext>Как извеcтно, gitweb, анализируя URL в запросах, не ориентируется на последний компонент пути до query string, если эта query string содержит квазипараметр `p=`.

В пользовательских каталогах public и packages можно даже опустить:
https://git.altlinux.org/people/specbot/public?p=specs.git
(к пути дописывается /, происходит перенаправление, последний компонент остаётся пустым, и, видимо, поэтому показывают репозиторий)

Из нижеописанных путей только первый показывает коммит, на который смотрит HEAD у репозитория:
1) https://git.altlinux.org/gears/x/..git?p=xz.git;a=commit;h=HEAD
2) https://git.altlinux.org/gears/x/?p=xz.git;a=commit;h=HEAD
3) https://git.altlinux.org/gears/..git?p=xz.git;a=commit;h=HEAD
4) https://git.altlinux.org/gears/?p=xz.git;a=commit;h=HEAD

2 и 4, правда, показывают листинг, игнорируя query string.

Предлагаю для URL из gears/, если последний компонент пути *.git указан сразу после gears, вычислять нужный префикс из параметра `p=` и дописывать (т. н. rewrite) его после gears/.
Например, по URL (3) отдавать то, что было бы отдано по URL (1).</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>267315</commentid>
    <comment_count>1</comment_count>
    <who name="Arseny Maslennikov">arseny</who>
    <bug_when>2025-06-17 15:33:23 +0300</bug_when>
    <thetext>Можно и (4) в (3) превращать, но если есть причины так не делать, то не надо.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>267318</commentid>
    <comment_count>2</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2025-06-17 15:43:12 +0300</bug_when>
    <thetext>https://git.altlinux.org/gears/x/xz.git?p=xz.git;a=commit;h=HEAD - а разве не такой URL должен быть ? всё остальное выглядит как ошибки, с которых надо сделать редирект.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>267319</commentid>
    <comment_count>3</comment_count>
    <who name="Arseny Maslennikov">arseny</who>
    <bug_when>2025-06-17 15:51:31 +0300</bug_when>
    <thetext>(In reply to Anton Farygin from comment #2)
&gt; https://git.altlinux.org/gears/x/xz.git?p=xz.git;a=commit;h=HEAD - а разве
&gt; не такой URL должен быть ? всё остальное выглядит как ошибки, с которых надо
&gt; сделать редирект.

Пожалуй, да, но gitweb удивительным образом так себя не ведёт.

https://sourceware.org/git/glibc.git?p=glibc.git;a=blob;f=string/strerrordesc_np.c;hb=glibc-2.41
https://sourceware.org/git/bzip2.git?p=glibc.git;a=blob;f=string/strerrordesc_np.c;hb=glibc-2.41

По обоим этим URL выдаётся контент из glibc.git.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>267320</commentid>
    <comment_count>4</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2025-06-17 15:55:07 +0300</bug_when>
    <thetext>непонятно только какое поведение должно быть ?
404 ?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>267322</commentid>
    <comment_count>5</comment_count>
    <who name="Arseny Maslennikov">arseny</who>
    <bug_when>2025-06-17 15:59:31 +0300</bug_when>
    <thetext>(In reply to Anton Farygin from comment #2)
&gt; https://git.altlinux.org/gears/x/xz.git?p=xz.git;a=commit;h=HEAD - а разве
&gt; не такой URL должен быть ? всё остальное выглядит как ошибки, с которых надо
&gt; сделать редирект.

У нас некоторые члены team на это завязываются и, составляя URL, чтобы опубликовать на него ссылку, пишут в последнем компоненте `..git`, в т. ч. в документации на altlinux.org, в том числе в рекомендациях начинающим мейнтейнерам.

IMHO, делать здесь простые и незапутывающие URL уже поздно, проще где-то описать алгоритм в человекопонимаемом виде.

Тем более, был экспериментальный cgit-интерфейс к контенту на git.a.o, где URL совсем другие.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>267324</commentid>
    <comment_count>6</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2025-06-17 16:01:55 +0300</bug_when>
    <thetext>Для тех случаев, когда указаны непротиворечащие URL - можно сделать редирект.

Если в URL явная ошибка, то 404 будет отличным выбором, на мой взгляд.</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>