push_rules.md 7,1 КБ
Newer Older
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
1
2
3
4
---
type: reference, howto
---

Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
5
# Push Rules **(STARTER)**
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
6

Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
7
8
Gain additional control over what can and can't be pushed to your repository by using
regular expressions to reject pushes based on commit contents, branch names or file details.
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
9
10
11
12

## Overview

GitLab already offers [protected branches][protected-branches], but there are
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
13
cases when you need some specific rules like preventing Git tag removal or
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
enforcing a special format for commit messages.

Push rules are essentially [pre-receive Git hooks][hooks] that are easy to
enable in a user-friendly interface. They are defined globally if you are an
admin or per project so you can have different rules applied to different
projects depending on your needs.

## Use cases

Every push rule could have its own use case, but let's consider some examples.

### Commit messages with a specific reference

Let's assume you have the following requirements for your workflow:

Takuya Noguchi's avatar
Takuya Noguchi включено в состав коммита
29
- every commit should reference a Jira issue, for example: `Refactored css. Fixes JIRA-123.`
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
30
- users should not be able to remove Git tags with `git push`
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
31
32

All you need to do is write a simple regular expression that requires the mention
Takuya Noguchi's avatar
Takuya Noguchi включено в состав коммита
33
of a Jira issue in the commit message, like `JIRA\-\d+`.
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
34
35
36
37
38
39
40

Now when a user tries to push a commit with a message `Bugfix`, their push will
be declined. Only pushing commits with messages like `Bugfix according to JIRA-123`
will be accepted.

### Restrict branch names

Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
41
Let's assume there's a strict policy for branch names in your company, and
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
42
43
44
45
46
47
48
49
50
51
52
53
you want the branches to start with a certain name because you have different
GitLab CI jobs (`feature`, `hotfix`, `docker`, `android`, etc.) that rely on the
branch name.

Your developers however, don't always remember that policy, so they push
various branches and CI pipelines do not work as expected. By restricting the
branch names globally in Push Rules, you can now sleep without the anxiety
of your developers' mistakes. Every branch that doesn't match your push rule
will get rejected.

## Enabling push rules

Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
54
NOTE: **Note:**
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
55
56
57
58
59
60
61
62
63
64
65
66
GitLab administrators can set push rules globally under
**Admin area > Push Rules** that all new projects will inherit. You can later
override them in a project's settings.

1. Navigate to your project's **Settings > Repository** and expand **Push Rules**
1. Set the rule you want
1. Click **Save Push Rules** for the changes to take effect

The following options are available.

| Push rule | GitLab version | Description |
| --------- | :------------: | ----------- |
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
67
| Removal of tags with `git push` | **Starter** 7.10 | Forbid users to remove Git tags with `git push`. Tags will still be able to be deleted through the web UI. |
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
68
| Check whether author is a GitLab user | **Starter** 7.10 | Restrict commits by author (email) to existing GitLab users. |
Drew Blessing's avatar
Drew Blessing включено в состав коммита
69
| Committer restriction | **Premium** 10.2 | GitLab will reject any commit that was not committed by the current authenticated user |
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
70
71
72
73
74
75
76
77
78
| Check whether commit is signed through GPG | **Premium** 10.1 | Reject commit when it is not signed through GPG. Read [signing commits with GPG][signing-commits]. |
| Prevent committing secrets to Git | **Starter** 8.12 | GitLab will reject any files that are likely to contain secrets. Read [what files are forbidden](#prevent-pushing-secrets-to-the-repository). |
| Restrict by commit message | **Starter** 7.10 | Only commit messages that match this regular expression are allowed to be pushed. Leave empty to allow any commit message. Uses multiline mode, which can be disabled using `(?-m)`. |
| Restrict by commit message (negative match)| **Starter** 11.1 | Only commit messages that do not match this regular expression are allowed to be pushed. Leave empty to allow any commit message. Uses multiline mode, which can be disabled using `(?-m)`. |
| Restrict by branch name | **Starter** 9.3 | Only branch names that match this regular expression are allowed to be pushed. Leave empty to allow any branch name. |
| Restrict by commit author's email | **Starter** 7.10 | Only commit author's email that match this regular expression are allowed to be pushed. Leave empty to allow any email. |
| Prohibited file names | **Starter** 7.10 | Any committed filenames that match this regular expression are not allowed to be pushed. Leave empty to allow any filenames. |
| Maximum file size | **Starter** 7.12 | Pushes that contain added or updated files that exceed this file size (in MB) are rejected. Set to 0 to allow files of any size. |

Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
79
TIP: **Tip:**
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
80
GitLab uses [RE2 syntax](https://github.com/google/re2/wiki/Syntax) for regular expressions in push rules, and you can test them at the [GoLang regex tester](https://regex-golang.appspot.com).
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
81
82
83
84
85
86
87
88
89
90
91
92
93

## Prevent pushing secrets to the repository

> [Introduced][ee-385] in [GitLab Starter][ee] 8.12.

You can turn on a predefined blacklist of files which won't be allowed to be
pushed to a repository.

By selecting the checkbox *Prevent committing secrets to Git*, GitLab prevents
pushes to the repository when a file matches a regular expression as read from
[`files_blacklist.yml`][list] (make sure you are at the right branch
as your GitLab version when viewing this file).

Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
94
NOTE: **Note:**
Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
Files already committed won't get restricted by this push rule.

Below is an example list of what will be rejected by these regular expressions:

```shell
#####################
# AWS CLI credential blobs
#####################
.aws/credentials
aws/credentials
homefolder/aws/credentials

#####################
# Private RSA SSH keys
#####################
/ssh/id_rsa
/.ssh/personal_rsa
/config/server_rsa
id_rsa
.id_rsa

#####################
# Private DSA SSH keys
#####################
/ssh/id_dsa
/.ssh/personal_dsa
/config/server_dsa
id_dsa
.id_dsa

#####################
# Private ed25519 SSH keys
#####################
/ssh/id_ed25519
/.ssh/personal_ed25519
/config/server_ed25519
id_ed25519
.id_ed25519

#####################
# Private ECDSA SSH keys
#####################
/ssh/id_ecdsa
/.ssh/personal_ecdsa
/config/server_ecdsa
id_ecdsa
.id_ecdsa

#####################
# Any file with .pem or .key extensions
#####################
*.pem
*.key

#####################
# Any file ending with _history or .history extension
#####################
pry.history
bash_history
```

Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
156
157
158
159
160
161
162
163
164
165
166
167
<!-- ## Troubleshooting

Include any troubleshooting steps that you can foresee. If you know beforehand what issues
one might have when setting this up, or when something is changed, or on upgrading, it's
important to describe those, too. Think of things that may go wrong and include them here.
This is important to minimize requests for support, and to avoid doc comments with
questions that you know someone might ask.

Each scenario can be a third-level heading, e.g. `### Getting error message X`.
If you have none to add when creating a doc, leave this section in place
but commented out to help encourage others to add to it in the future. -->

Marcel Amirault's avatar
Marcel Amirault включено в состав коммита
168
169
170
171
172
173
[protected-branches]: ../user/project/protected_branches.md
[signing-commits]: ../user/project/repository/gpg_signed_commits/index.md
[ee-385]: https://gitlab.com/gitlab-org/gitlab-ee/issues/385
[list]: https://gitlab.com/gitlab-org/gitlab-ee/blob/master/ee/lib/gitlab/checks/files_blacklist.yml
[hooks]: https://git-scm.com/book/en/v2/Customizing-Git-Git-Hooks
[ee]: https://about.gitlab.com/pricing/