Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 1 | git-shell(1) |
| 2 | ============ |
| 3 | |
| 4 | NAME |
| 5 | ---- |
Junio C Hamano | 3b4609d | 2010-09-30 00:04:34 | [diff] [blame] | 6 | git-shell - Restricted login shell for Git-only SSH access |
Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 7 | |
| 8 | |
| 9 | SYNOPSIS |
| 10 | -------- |
Junio C Hamano | 15567bc | 2011-07-23 00:51:59 | [diff] [blame] | 11 | [verse] |
Junio C Hamano | 5e7f131 | 2013-03-21 22:49:01 | [diff] [blame] | 12 | 'chsh' -s $(command -v git-shell) <user> |
| 13 | 'git clone' <user>`@localhost:/path/to/repo.git` |
| 14 | 'ssh' <user>`@localhost` |
Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 15 | |
| 16 | DESCRIPTION |
| 17 | ----------- |
Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 18 | |
Junio C Hamano | 5e7f131 | 2013-03-21 22:49:01 | [diff] [blame] | 19 | This is a login shell for SSH accounts to provide restricted Git access. |
| 20 | It permits execution only of server-side Git commands implementing the |
| 21 | pull/push functionality, plus custom commands present in a subdirectory |
| 22 | named `git-shell-commands` in the user's home directory. |
Junio C Hamano | 3b4609d | 2010-09-30 00:04:34 | [diff] [blame] | 23 | |
Junio C Hamano | 5e7f131 | 2013-03-21 22:49:01 | [diff] [blame] | 24 | COMMANDS |
| 25 | -------- |
Junio C Hamano | 3b4609d | 2010-09-30 00:04:34 | [diff] [blame] | 26 | |
Junio C Hamano | 5e7f131 | 2013-03-21 22:49:01 | [diff] [blame] | 27 | 'git shell' accepts the following commands after the '-c' option: |
| 28 | |
| 29 | 'git receive-pack <argument>':: |
| 30 | 'git upload-pack <argument>':: |
| 31 | 'git upload-archive <argument>':: |
| 32 | Call the corresponding server-side command to support |
| 33 | the client's 'git push', 'git fetch', or 'git archive --remote' |
| 34 | request. |
| 35 | 'cvs server':: |
| 36 | Imitate a CVS server. See linkgit:git-cvsserver[1]. |
| 37 | |
| 38 | If a `~/git-shell-commands` directory is present, 'git shell' will |
| 39 | also handle other, custom commands by running |
| 40 | "`git-shell-commands/<command> <arguments>`" from the user's home |
| 41 | directory. |
| 42 | |
| 43 | INTERACTIVE USE |
| 44 | --------------- |
| 45 | |
| 46 | By default, the commands above can be executed only with the '-c' |
| 47 | option; the shell is not interactive. |
| 48 | |
| 49 | If a `~/git-shell-commands` directory is present, 'git shell' |
| 50 | can also be run interactively (with no arguments). If a `help` |
| 51 | command is present in the `git-shell-commands` directory, it is |
| 52 | run to provide the user with an overview of allowed actions. Then a |
| 53 | "git> " prompt is presented at which one can enter any of the |
| 54 | commands from the `git-shell-commands` directory, or `exit` to close |
| 55 | the connection. |
| 56 | |
| 57 | Generally this mode is used as an administrative interface to allow |
| 58 | users to list repositories they have access to, create, delete, or |
| 59 | rename repositories, or change repository descriptions and |
| 60 | permissions. |
| 61 | |
| 62 | If a `no-interactive-login` command exists, then it is run and the |
| 63 | interactive shell is aborted. |
| 64 | |
| 65 | EXAMPLE |
| 66 | ------- |
| 67 | |
| 68 | To disable interactive logins, displaying a greeting instead: |
| 69 | + |
| 70 | ---------------- |
| 71 | $ chsh -s /usr/bin/git-shell |
| 72 | $ mkdir $HOME/git-shell-commands |
| 73 | $ cat >$HOME/git-shell-commands/no-interactive-login <<\EOF |
| 74 | #!/bin/sh |
| 75 | printf '%s\n' "Hi $USER! You've successfully authenticated, but I do not" |
| 76 | printf '%s\n' "provide interactive shell access." |
| 77 | exit 128 |
| 78 | EOF |
| 79 | $ chmod +x $HOME/git-shell-commands/no-interactive-login |
| 80 | ---------------- |
| 81 | |
| 82 | SEE ALSO |
| 83 | -------- |
| 84 | ssh(1), |
| 85 | linkgit:git-daemon[1], |
| 86 | contrib/git-shell-commands/README |
Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 87 | |
Junio C Hamano | 1a4e841 | 2005-12-27 08:17:23 | [diff] [blame] | 88 | GIT |
| 89 | --- |
Junio C Hamano | f7c042d | 2008-06-06 22:50:53 | [diff] [blame] | 90 | Part of the linkgit:git[1] suite |