Junio C Hamano | 2a24501 | 2005-07-14 00:10:05 -0700 | [diff] [blame] | 1 | git-receive-pack(1) |
| 2 | =================== |
Junio C Hamano | 2a24501 | 2005-07-14 00:10:05 -0700 | [diff] [blame] | 3 | |
| 4 | NAME |
| 5 | ---- |
Junio C Hamano | c3f0baa | 2007-01-18 15:53:37 -0800 | [diff] [blame] | 6 | git-receive-pack - Receive what is pushed into the repository |
Junio C Hamano | 2a24501 | 2005-07-14 00:10:05 -0700 | [diff] [blame] | 7 | |
| 8 | |
| 9 | SYNOPSIS |
| 10 | -------- |
Martin von Zweigbergk | 7791a1d | 2011-07-01 22:38:26 -0400 | [diff] [blame] | 11 | [verse] |
Junio C Hamano | 5a277f3 | 2011-09-06 11:06:32 -0700 | [diff] [blame] | 12 | 'git-receive-pack' <directory> |
Junio C Hamano | 2a24501 | 2005-07-14 00:10:05 -0700 | [diff] [blame] | 13 | |
| 14 | DESCRIPTION |
| 15 | ----------- |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 16 | Invoked by 'git send-pack' and updates the repository with the |
Junio C Hamano | 2a24501 | 2005-07-14 00:10:05 -0700 | [diff] [blame] | 17 | information fed from the remote end. |
| 18 | |
| 19 | This command is usually not invoked directly by the end user. |
Thomas Rast | 0b444cd | 2010-01-10 00:33:00 +0100 | [diff] [blame] | 20 | The UI for the protocol is on the 'git send-pack' side, and the |
Junio C Hamano | 2a24501 | 2005-07-14 00:10:05 -0700 | [diff] [blame] | 21 | program pair is meant to be used to push updates to remote |
Jonathan Nieder | 483bc4f | 2008-06-30 13:56:34 -0500 | [diff] [blame] | 22 | repository. For pull operations, see linkgit:git-fetch-pack[1]. |
Junio C Hamano | 2a24501 | 2005-07-14 00:10:05 -0700 | [diff] [blame] | 23 | |
Felipe Contreras | a75d7b5 | 2009-10-24 11:31:32 +0300 | [diff] [blame] | 24 | The command allows for creation and fast-forwarding of sha1 refs |
Josef Weidendorfer | b1bf95b | 2005-07-31 21:17:43 +0200 | [diff] [blame] | 25 | (heads/tags) on the remote end (strictly speaking, it is the |
Jonathan Nieder | ba020ef | 2008-07-03 00:41:41 -0500 | [diff] [blame] | 26 | local end 'git-receive-pack' runs, but to the user who is sitting at |
Josef Weidendorfer | b1bf95b | 2005-07-31 21:17:43 +0200 | [diff] [blame] | 27 | the send-pack end, it is updating the remote. Confused?) |
| 28 | |
Junio C Hamano | eb0362a | 2005-12-05 00:32:01 -0800 | [diff] [blame] | 29 | There are other real-world examples of using update and |
| 30 | post-update hooks found in the Documentation/howto directory. |
| 31 | |
Jonathan Nieder | ba020ef | 2008-07-03 00:41:41 -0500 | [diff] [blame] | 32 | 'git-receive-pack' honours the receive.denyNonFastForwards config |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 33 | option, which tells it if updates to a ref should be denied if they |
| 34 | are not fast-forwards. |
Junio C Hamano | eb0362a | 2005-12-05 00:32:01 -0800 | [diff] [blame] | 35 | |
Jeff King | c08db5a | 2016-08-24 20:41:57 +0200 | [diff] [blame] | 36 | A number of other receive.* config options are available to tweak |
| 37 | its behavior, see linkgit:git-config[1]. |
| 38 | |
Junio C Hamano | 2a24501 | 2005-07-14 00:10:05 -0700 | [diff] [blame] | 39 | OPTIONS |
| 40 | ------- |
| 41 | <directory>:: |
| 42 | The repository to sync into. |
| 43 | |
Nguyễn Thái Ngọc Duy | 76a8788 | 2018-04-30 17:35:33 +0200 | [diff] [blame] | 44 | PRE-RECEIVE HOOK |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 45 | ---------------- |
| 46 | Before any ref is updated, if $GIT_DIR/hooks/pre-receive file exists |
Shawn O. Pearce | f43cd49 | 2007-03-10 03:28:16 -0500 | [diff] [blame] | 47 | and is executable, it will be invoked once with no parameters. The |
| 48 | standard input of the hook will be one line per ref to be updated: |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 49 | |
Shawn O. Pearce | f43cd49 | 2007-03-10 03:28:16 -0500 | [diff] [blame] | 50 | sha1-old SP sha1-new SP refname LF |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 51 | |
Shawn O. Pearce | f43cd49 | 2007-03-10 03:28:16 -0500 | [diff] [blame] | 52 | The refname value is relative to $GIT_DIR; e.g. for the master |
| 53 | head this is "refs/heads/master". The two sha1 values before |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 54 | each refname are the object names for the refname before and after |
Jeff King | 967506b | 2007-07-02 01:24:59 -0400 | [diff] [blame] | 55 | the update. Refs to be created will have sha1-old equal to 0\{40}, |
| 56 | while refs to be deleted will have sha1-new equal to 0\{40}, otherwise |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 57 | sha1-old and sha1-new should be valid objects in the repository. |
| 58 | |
Junio C Hamano | a85b377 | 2014-09-12 11:17:07 -0700 | [diff] [blame] | 59 | When accepting a signed push (see linkgit:git-push[1]), the signed |
| 60 | push certificate is stored in a blob and an environment variable |
| 61 | `GIT_PUSH_CERT` can be consulted for its object name. See the |
Junio C Hamano | d05b961 | 2014-08-14 15:59:21 -0700 | [diff] [blame] | 62 | description of `post-receive` hook for an example. In addition, the |
| 63 | certificate is verified using GPG and the result is exported with |
| 64 | the following environment variables: |
| 65 | |
| 66 | `GIT_PUSH_CERT_SIGNER`:: |
| 67 | The name and the e-mail address of the owner of the key that |
| 68 | signed the push certificate. |
| 69 | |
| 70 | `GIT_PUSH_CERT_KEY`:: |
| 71 | The GPG key ID of the key that signed the push certificate. |
| 72 | |
| 73 | `GIT_PUSH_CERT_STATUS`:: |
| 74 | The status of GPG verification of the push certificate, |
| 75 | using the same mnemonic as used in `%G?` format of `git log` |
| 76 | family of commands (see linkgit:git-log[1]). |
Junio C Hamano | a85b377 | 2014-09-12 11:17:07 -0700 | [diff] [blame] | 77 | |
Junio C Hamano | b89363e | 2014-08-21 16:45:30 -0700 | [diff] [blame] | 78 | `GIT_PUSH_CERT_NONCE`:: |
| 79 | The nonce string the process asked the signer to include |
| 80 | in the push certificate. If this does not match the value |
| 81 | recorded on the "nonce" header in the push certificate, it |
| 82 | may indicate that the certificate is a valid one that is |
| 83 | being replayed from a separate "git push" session. |
| 84 | |
| 85 | `GIT_PUSH_CERT_NONCE_STATUS`:: |
| 86 | `UNSOLICITED`;; |
| 87 | "git push --signed" sent a nonce when we did not ask it to |
| 88 | send one. |
| 89 | `MISSING`;; |
| 90 | "git push --signed" did not send any nonce header. |
| 91 | `BAD`;; |
| 92 | "git push --signed" sent a bogus nonce. |
| 93 | `OK`;; |
| 94 | "git push --signed" sent the nonce we asked it to send. |
Junio C Hamano | 5732373 | 2014-09-05 10:46:04 -0700 | [diff] [blame] | 95 | `SLOP`;; |
| 96 | "git push --signed" sent a nonce different from what we |
| 97 | asked it to send now, but in a previous session. See |
| 98 | `GIT_PUSH_CERT_NONCE_SLOP` environment variable. |
| 99 | |
| 100 | `GIT_PUSH_CERT_NONCE_SLOP`:: |
| 101 | "git push --signed" sent a nonce different from what we |
| 102 | asked it to send now, but in a different session whose |
| 103 | starting time is different by this many seconds from the |
| 104 | current session. Only meaningful when |
| 105 | `GIT_PUSH_CERT_NONCE_STATUS` says `SLOP`. |
Nguyễn Thái Ngọc Duy | da0005b | 2015-03-11 16:32:45 -0400 | [diff] [blame] | 106 | Also read about `receive.certNonceSlop` variable in |
Junio C Hamano | 5732373 | 2014-09-05 10:46:04 -0700 | [diff] [blame] | 107 | linkgit:git-config[1]. |
Junio C Hamano | b89363e | 2014-08-21 16:45:30 -0700 | [diff] [blame] | 108 | |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 109 | This hook is called before any refname is updated and before any |
| 110 | fast-forward checks are performed. |
| 111 | |
| 112 | If the pre-receive hook exits with a non-zero exit status no updates |
| 113 | will be performed, and the update, post-receive and post-update |
| 114 | hooks will not be invoked either. This can be useful to quickly |
| 115 | bail out if the update is not to be supported. |
| 116 | |
Jeff King | eaeed07 | 2017-04-10 18:13:39 -0400 | [diff] [blame] | 117 | See the notes on the quarantine environment below. |
| 118 | |
Nguyễn Thái Ngọc Duy | 76a8788 | 2018-04-30 17:35:33 +0200 | [diff] [blame] | 119 | UPDATE HOOK |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 120 | ----------- |
| 121 | Before each ref is updated, if $GIT_DIR/hooks/update file exists |
| 122 | and is executable, it is invoked once per ref, with three parameters: |
| 123 | |
| 124 | $GIT_DIR/hooks/update refname sha1-old sha1-new |
| 125 | |
| 126 | The refname parameter is relative to $GIT_DIR; e.g. for the master |
| 127 | head this is "refs/heads/master". The two sha1 arguments are |
| 128 | the object names for the refname before and after the update. |
| 129 | Note that the hook is called before the refname is updated, |
Jeff King | 967506b | 2007-07-02 01:24:59 -0400 | [diff] [blame] | 130 | so either sha1-old is 0\{40} (meaning there is no such ref yet), |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 131 | or it should match what is recorded in refname. |
| 132 | |
| 133 | The hook should exit with non-zero status if it wants to disallow |
| 134 | updating the named ref. Otherwise it should exit with zero. |
| 135 | |
| 136 | Successful execution (a zero exit status) of this hook does not |
Brian Hetro | 0278307 | 2007-08-23 20:44:13 -0400 | [diff] [blame] | 137 | ensure the ref will actually be updated, it is only a prerequisite. |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 138 | As such it is not a good idea to send notices (e.g. email) from |
| 139 | this hook. Consider using the post-receive hook instead. |
| 140 | |
Nguyễn Thái Ngọc Duy | 76a8788 | 2018-04-30 17:35:33 +0200 | [diff] [blame] | 141 | POST-RECEIVE HOOK |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 142 | ----------------- |
| 143 | After all refs were updated (or attempted to be updated), if any |
| 144 | ref update was successful, and if $GIT_DIR/hooks/post-receive |
Markus Heidelberg | 04c8ce9 | 2008-12-19 13:14:18 +0100 | [diff] [blame] | 145 | file exists and is executable, it will be invoked once with no |
Shawn O. Pearce | f43cd49 | 2007-03-10 03:28:16 -0500 | [diff] [blame] | 146 | parameters. The standard input of the hook will be one line |
| 147 | for each successfully updated ref: |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 148 | |
Shawn O. Pearce | f43cd49 | 2007-03-10 03:28:16 -0500 | [diff] [blame] | 149 | sha1-old SP sha1-new SP refname LF |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 150 | |
Shawn O. Pearce | f43cd49 | 2007-03-10 03:28:16 -0500 | [diff] [blame] | 151 | The refname value is relative to $GIT_DIR; e.g. for the master |
| 152 | head this is "refs/heads/master". The two sha1 values before |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 153 | each refname are the object names for the refname before and after |
| 154 | the update. Refs that were created will have sha1-old equal to |
Jeff King | 967506b | 2007-07-02 01:24:59 -0400 | [diff] [blame] | 155 | 0\{40}, while refs that were deleted will have sha1-new equal to |
| 156 | 0\{40}, otherwise sha1-old and sha1-new should be valid objects in |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 157 | the repository. |
| 158 | |
Junio C Hamano | d05b961 | 2014-08-14 15:59:21 -0700 | [diff] [blame] | 159 | The `GIT_PUSH_CERT*` environment variables can be inspected, just as |
Junio C Hamano | a85b377 | 2014-09-12 11:17:07 -0700 | [diff] [blame] | 160 | in `pre-receive` hook, after accepting a signed push. |
| 161 | |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 162 | Using this hook, it is easy to generate mails describing the updates |
| 163 | to the repository. This example script sends one mail message per |
Junio C Hamano | a85b377 | 2014-09-12 11:17:07 -0700 | [diff] [blame] | 164 | ref listing the commits pushed to the repository, and logs the push |
Junio C Hamano | d05b961 | 2014-08-14 15:59:21 -0700 | [diff] [blame] | 165 | certificates of signed pushes with good signatures to a logger |
Junio C Hamano | a85b377 | 2014-09-12 11:17:07 -0700 | [diff] [blame] | 166 | service: |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 167 | |
Martin Ågren | 38cadf9 | 2019-09-07 16:12:51 +0200 | [diff] [blame] | 168 | ---- |
| 169 | #!/bin/sh |
| 170 | # mail out commit update information. |
| 171 | while read oval nval ref |
| 172 | do |
| 173 | if expr "$oval" : '0*$' >/dev/null |
Junio C Hamano | a85b377 | 2014-09-12 11:17:07 -0700 | [diff] [blame] | 174 | then |
Martin Ågren | 38cadf9 | 2019-09-07 16:12:51 +0200 | [diff] [blame] | 175 | echo "Created a new ref, with the following commits:" |
| 176 | git rev-list --pretty "$nval" |
| 177 | else |
| 178 | echo "New commits:" |
| 179 | git rev-list --pretty "$nval" "^$oval" |
| 180 | fi | |
| 181 | mail -s "Changes to ref $ref" commit-list@mydomain |
| 182 | done |
| 183 | # log signed push certificate, if any |
| 184 | if test -n "${GIT_PUSH_CERT-}" && test ${GIT_PUSH_CERT_STATUS} = G |
| 185 | then |
| 186 | ( |
| 187 | echo expected nonce is ${GIT_PUSH_NONCE} |
| 188 | git cat-file blob ${GIT_PUSH_CERT} |
| 189 | ) | mail -s "push certificate from $GIT_PUSH_CERT_SIGNER" push-log@mydomain |
| 190 | fi |
| 191 | exit 0 |
| 192 | ---- |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 193 | |
| 194 | The exit code from this hook invocation is ignored, however a |
| 195 | non-zero exit code will generate an error message. |
| 196 | |
| 197 | Note that it is possible for refname to not have sha1-new when this |
| 198 | hook runs. This can easily occur if another user modifies the ref |
Jonathan Nieder | ba020ef | 2008-07-03 00:41:41 -0500 | [diff] [blame] | 199 | after it was updated by 'git-receive-pack', but before the hook was able |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 200 | to evaluate it. It is recommended that hooks rely on sha1-new |
| 201 | rather than the current value of refname. |
| 202 | |
Nguyễn Thái Ngọc Duy | 76a8788 | 2018-04-30 17:35:33 +0200 | [diff] [blame] | 203 | POST-UPDATE HOOK |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 204 | ---------------- |
| 205 | After all other processing, if at least one ref was updated, and |
| 206 | if $GIT_DIR/hooks/post-update file exists and is executable, then |
Markus Heidelberg | 04c8ce9 | 2008-12-19 13:14:18 +0100 | [diff] [blame] | 207 | post-update will be called with the list of refs that have been updated. |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 208 | This can be used to implement any repository wide cleanup tasks. |
| 209 | |
| 210 | The exit code from this hook invocation is ignored; the only thing |
Jonathan Nieder | ba020ef | 2008-07-03 00:41:41 -0500 | [diff] [blame] | 211 | left for 'git-receive-pack' to do at that point is to exit itself |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 212 | anyway. |
| 213 | |
Jonathan Nieder | 483bc4f | 2008-06-30 13:56:34 -0500 | [diff] [blame] | 214 | This hook can be used, for example, to run `git update-server-info` |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 215 | if the repository is packed and is served via a dumb transport. |
| 216 | |
Martin Ågren | 38cadf9 | 2019-09-07 16:12:51 +0200 | [diff] [blame] | 217 | ---- |
| 218 | #!/bin/sh |
| 219 | exec git update-server-info |
| 220 | ---- |
Shawn O. Pearce | 05ef58e | 2007-03-07 16:52:05 -0500 | [diff] [blame] | 221 | |
Junio C Hamano | 6d35cc7 | 2005-09-02 21:19:26 -0700 | [diff] [blame] | 222 | |
Nguyễn Thái Ngọc Duy | 76a8788 | 2018-04-30 17:35:33 +0200 | [diff] [blame] | 223 | QUARANTINE ENVIRONMENT |
Jeff King | eaeed07 | 2017-04-10 18:13:39 -0400 | [diff] [blame] | 224 | ---------------------- |
| 225 | |
| 226 | When `receive-pack` takes in objects, they are placed into a temporary |
| 227 | "quarantine" directory within the `$GIT_DIR/objects` directory and |
| 228 | migrated into the main object store only after the `pre-receive` hook |
| 229 | has completed. If the push fails before then, the temporary directory is |
| 230 | removed entirely. |
| 231 | |
| 232 | This has a few user-visible effects and caveats: |
| 233 | |
| 234 | 1. Pushes which fail due to problems with the incoming pack, missing |
| 235 | objects, or due to the `pre-receive` hook will not leave any |
| 236 | on-disk data. This is usually helpful to prevent repeated failed |
| 237 | pushes from filling up your disk, but can make debugging more |
| 238 | challenging. |
| 239 | |
| 240 | 2. Any objects created by the `pre-receive` hook will be created in |
| 241 | the quarantine directory (and migrated only if it succeeds). |
| 242 | |
| 243 | 3. The `pre-receive` hook MUST NOT update any refs to point to |
| 244 | quarantined objects. Other programs accessing the repository will |
| 245 | not be able to see the objects (and if the pre-receive hook fails, |
Jeff King | d8f4481 | 2017-04-10 18:14:12 -0400 | [diff] [blame] | 246 | those refs would become corrupted). For safety, any ref updates |
| 247 | from within `pre-receive` are automatically rejected. |
Jeff King | eaeed07 | 2017-04-10 18:13:39 -0400 | [diff] [blame] | 248 | |
| 249 | |
Junio C Hamano | 6d35cc7 | 2005-09-02 21:19:26 -0700 | [diff] [blame] | 250 | SEE ALSO |
| 251 | -------- |
Josh Triplett | d49483f | 2011-07-08 16:14:10 -0700 | [diff] [blame] | 252 | linkgit:git-send-pack[1], linkgit:gitnamespaces[7] |
Junio C Hamano | 6d35cc7 | 2005-09-02 21:19:26 -0700 | [diff] [blame] | 253 | |
Junio C Hamano | 2a24501 | 2005-07-14 00:10:05 -0700 | [diff] [blame] | 254 | GIT |
| 255 | --- |
Christian Couder | 9e1f0a8 | 2008-06-06 09:07:32 +0200 | [diff] [blame] | 256 | Part of the linkgit:git[1] suite |