##// END OF EJS Templates
pull requests: when creating, disable other_ref on other_repo change until new data has been loaded
pull requests: when creating, disable other_ref on other_repo change until new data has been loaded

File last commit:

r4192:e73a69cb kallithea-2.2.5-r...
r4557:cb360bf4 default
Show More
locking.rst
41 lines | 1.3 KiB | text/x-rst | RstLexer

Kallithea repository locking system

Repos with locking function=disabled is the default, that's how repos work today.
Repos with locking function=enabled behaves like follows:

Repos have a state called locked that can be true or false. The hg/git commands hg/git clone, hg/git pull, and hg/git push influence this state:

  • The command hg/git pull <repo> will lock that repo (locked=true) if the user has write/admin permissions on this repo
  • The command hg/git clone <repo> will lock that repo (locked=true) if the user has write/admin permissions on this repo

Kallithea will remember the user id who locked the repo only this specific user can unlock the repo (locked=false) by calling

  • hg/git push <repo>

every other command on that repo from this user and every command from any other user will result in http return code 423 (locked)

additionally the http error includes the <user> that locked the repo (e.g. “repository <repo> locked by user <user>”)

So the scenario of use for repos with locking function enabled is that every initial clone and every pull gives users (with write permission) the exclusive right to do a push.

Each repo can be manually unlocked by admin from the repo settings menu.