blob: 3433c157f79e3bb06ea76333fcc27fb457854b20 [file] [log] [blame]
Marian Harbachebeb1542019-12-13 10:42:46 +01001:linkattrs:
Edwin Kempin6a789632015-02-13 11:48:04 +01002= Plugins
3
4The Gerrit server functionality can be extended by installing plugins.
5
6[[installation]]
7== Plugin Installation
8Plugin installation is as easy as dropping the plugin jar into the
9`$site_path/plugins/` folder. It may take
10link:config-gerrit.html#plugins.checkFrequency[a few minutes] until
11the server picks up new and updated plugins.
12
Patrick Hiesel05e7f302019-03-08 11:40:42 +010013Due to caching, you might need to flush your browser cache after
14installing a plugin. Users will usually see the result within
15several minutes.
16
Edwin Kempin6a789632015-02-13 11:48:04 +010017Plugins can also be installed via
18link:rest-api-plugins.html#install-plugin[REST] and
19link:cmd-plugin-install.html[SSH].
20
21[[development]]
22== Plugin Development
23
24How to develop plugins is described in the link:dev-plugins.html[
25Plugin Development Guide].
26
27If you want to share your plugin under the link:licenses.html#Apache2_0[
28Apache License 2.0] you can host your plugin development on the
Marian Harbach34253372019-12-10 18:01:31 +010029link:https://gerrit-review.googlesource.com[gerrit-review,role=external,window=_blank] Gerrit
Edwin Kempin6a789632015-02-13 11:48:04 +010030Server. You can request the creation of a new Project by email
31to the link:https://groups.google.com/forum/#!forum/repo-discuss[Gerrit
Marian Harbach34253372019-12-10 18:01:31 +010032mailing list,role=external,window=_blank]. You would be assigned as project owner of the new plugin
Edwin Kempin6a789632015-02-13 11:48:04 +010033project so that you can submit changes on your own. It is the
34responsibility of the project owner to maintain the plugin, e.g. to
35make sure that it works with new Gerrit versions and to create stable
36branches for old releases.
37
38[[core-plugins]]
39== Core Plugins
40
Edwin Kempinef1b8112019-10-29 09:27:00 +010041link:dev-core-plugins.html[Core plugins] are packaged within the Gerrit
42war file and can easily be installed during the link:pgm-init.html[
43Gerrit initialization].
Edwin Kempin6a789632015-02-13 11:48:04 +010044
David Pursehouse95611c42019-09-19 10:11:17 +090045Note that the documentation and configuration links in the list below are
46to the plugins' master branch. Please refer to the appropriate branch or
47revision for the Gerrit version you are using.
48
Paladox none191adf32018-02-09 20:24:17 +000049[[codemirror-editor]]
50=== codemirror-editor
51
Ben Rohlfsda0a62b2021-04-26 17:02:19 +020052CodeMirror JavaScript plugin for Gerrit.
Paladox none191adf32018-02-09 20:24:17 +000053
David Pursehouse122f0782018-09-28 13:45:23 +090054link:https://gerrit-review.googlesource.com/admin/repos/plugins/codemirror-editor[
Marian Harbach34253372019-12-10 18:01:31 +010055Project,role=external,window=_blank] |
Paladox none191adf32018-02-09 20:24:17 +000056
Edwin Kempinecee5f62015-04-16 13:54:25 +020057[[commit-message-length-validator]]
Edwin Kempin6a789632015-02-13 11:48:04 +010058=== commit-message-length-validator
59
60This plugin checks the length of a commit’s commit message subject and
61message body, and reports warnings or errors to the git client if the
62lengths are exceeded.
63
David Pursehouse122f0782018-09-28 13:45:23 +090064link:https://gerrit-review.googlesource.com/admin/repos/plugins/commit-message-length-validator[
Marian Harbach34253372019-12-10 18:01:31 +010065Project,role=external,window=_blank] |
Edwin Kempin6a789632015-02-13 11:48:04 +010066link:https://gerrit.googlesource.com/plugins/commit-message-length-validator/+doc/master/src/main/resources/Documentation/about.md[
Marian Harbach34253372019-12-10 18:01:31 +010067Documentation,role=external,window=_blank] |
Edwin Kempin6a789632015-02-13 11:48:04 +010068link:https://gerrit.googlesource.com/plugins/commit-message-length-validator/+doc/master/src/main/resources/Documentation/config.md[
Marian Harbach34253372019-12-10 18:01:31 +010069Configuration,role=external,window=_blank]
Edwin Kempin6a789632015-02-13 11:48:04 +010070
David Pursehouse1e150732018-11-10 07:57:16 +090071[[delete-project]]
72=== delete-project
73
74Provides the ability to delete a project.
75
76link:https://gerrit-review.googlesource.com/admin/repos/plugins/delete-project[
Marian Harbach34253372019-12-10 18:01:31 +010077Project,role=external,window=_blank] |
David Pursehouse1e150732018-11-10 07:57:16 +090078link:https://gerrit.googlesource.com/plugins/delete-project/+doc/master/src/main/resources/Documentation/about.md[
Marian Harbach34253372019-12-10 18:01:31 +010079Documentation,role=external,window=_blank] |
David Pursehouse1e150732018-11-10 07:57:16 +090080link:https://gerrit.googlesource.com/plugins/delete-project/+doc/master/src/main/resources/Documentation/config.md[
Marian Harbach34253372019-12-10 18:01:31 +010081Configuration,role=external,window=_blank]
David Pursehouse1e150732018-11-10 07:57:16 +090082
Edwin Kempinecee5f62015-04-16 13:54:25 +020083[[download-commands]]
Edwin Kempin6a789632015-02-13 11:48:04 +010084=== download-commands
85
86This plugin defines commands for downloading changes in different
87download schemes (for downloading via different network protocols).
88
David Pursehouse122f0782018-09-28 13:45:23 +090089link:https://gerrit-review.googlesource.com/admin/repos/plugins/download-commands[
Marian Harbach34253372019-12-10 18:01:31 +010090Project,role=external,window=_blank] |
Edwin Kempin6a789632015-02-13 11:48:04 +010091link:https://gerrit.googlesource.com/plugins/download-commands/+doc/master/src/main/resources/Documentation/about.md[
Marian Harbach34253372019-12-10 18:01:31 +010092Documentation,role=external,window=_blank] |
Edwin Kempin6a789632015-02-13 11:48:04 +010093link:https://gerrit.googlesource.com/plugins/download-commands/+doc/master/src/main/resources/Documentation/config.md[
Marian Harbach34253372019-12-10 18:01:31 +010094Configuration,role=external,window=_blank]
Edwin Kempin6a789632015-02-13 11:48:04 +010095
David Ostrovsky55ff68f2019-01-18 23:25:50 +010096[[gitiles]]
97=== gitiles
98
99Plugin running Gitiles alongside a Gerrit server.
100
101link:https://gerrit-review.googlesource.com/admin/repos/plugins/gitiles[
Marian Harbach34253372019-12-10 18:01:31 +0100102Project,role=external,window=_blank]
David Ostrovsky55ff68f2019-01-18 23:25:50 +0100103
David Pursehouse89b3a122016-07-08 18:18:07 +0900104[[hooks]]
105=== hooks
106
107This plugin runs server-side hooks on events.
108
David Pursehouse122f0782018-09-28 13:45:23 +0900109link:https://gerrit-review.googlesource.com/admin/repos/plugins/hooks[
Marian Harbach34253372019-12-10 18:01:31 +0100110Project,role=external,window=_blank] |
David Pursehouse89b3a122016-07-08 18:18:07 +0900111link:https://gerrit.googlesource.com/plugins/hooks/+doc/master/src/main/resources/Documentation/about.md[
Marian Harbach34253372019-12-10 18:01:31 +0100112Documentation,role=external,window=_blank] |
David Pursehouse89b3a122016-07-08 18:18:07 +0900113link:https://gerrit.googlesource.com/plugins/hooks/+doc/master/src/main/resources/Documentation/config.md[
Marian Harbach34253372019-12-10 18:01:31 +0100114Configuration,role=external,window=_blank]
David Pursehouse89b3a122016-07-08 18:18:07 +0900115
David Ostrovsky93586852019-04-17 15:02:12 -0700116[[plugin-manager]]
117=== plugin-manager
118
119This plugins provides an initial wizard to discover and install Gerrit plugins.
120Per default GerritForge CI is used to download the plugin artifacts from, but
121this can be changed per plugin configuration.
122
123link:https://gerrit-review.googlesource.com/admin/repos/plugins/plugin-manager[
Marian Harbach34253372019-12-10 18:01:31 +0100124Project,role=external,window=_blank]
David Ostrovsky93586852019-04-17 15:02:12 -0700125link:https://gerrit.googlesource.com/plugins/plugin-manager/+doc/master/src/main/resources/Documentation/about.md[
Marian Harbach34253372019-12-10 18:01:31 +0100126Documentation,role=external,window=_blank]
David Ostrovsky93586852019-04-17 15:02:12 -0700127link:https://gerrit.googlesource.com/plugins/plugin-manager/+doc/master/src/main/resources/Documentation/config.md[
Marian Harbach34253372019-12-10 18:01:31 +0100128Configuration,role=external,window=_blank]
David Ostrovsky93586852019-04-17 15:02:12 -0700129
Edwin Kempinecee5f62015-04-16 13:54:25 +0200130[[replication]]
Edwin Kempin6a789632015-02-13 11:48:04 +0100131=== replication
132
133This plugin can automatically push any changes Gerrit Code Review makes
134to its managed Git repositories to another system. Usually this would
135be configured to provide mirroring of changes, for warm-standby
136backups, or a load-balanced public mirror farm.
137
David Pursehouse122f0782018-09-28 13:45:23 +0900138link:https://gerrit-review.googlesource.com/admin/repos/plugins/replication[
Marian Harbach34253372019-12-10 18:01:31 +0100139Project,role=external,window=_blank] |
Edwin Kempin6a789632015-02-13 11:48:04 +0100140link:https://gerrit.googlesource.com/plugins/replication/+doc/master/src/main/resources/Documentation/about.md[
Marian Harbach34253372019-12-10 18:01:31 +0100141Documentation,role=external,window=_blank] |
Edwin Kempin6a789632015-02-13 11:48:04 +0100142link:https://gerrit.googlesource.com/plugins/replication/+doc/master/src/main/resources/Documentation/config.md[
Marian Harbach34253372019-12-10 18:01:31 +0100143Configuration,role=external,window=_blank]
Edwin Kempin6a789632015-02-13 11:48:04 +0100144
Edwin Kempinecee5f62015-04-16 13:54:25 +0200145[[reviewnotes]]
Edwin Kempin6a789632015-02-13 11:48:04 +0100146=== reviewnotes
147
148Stores review information for Gerrit changes in the `refs/notes/review`
149branch.
150
David Pursehouse122f0782018-09-28 13:45:23 +0900151link:https://gerrit-review.googlesource.com/admin/repos/plugins/reviewnotes[
Marian Harbach34253372019-12-10 18:01:31 +0100152Project,role=external,window=_blank] |
Edwin Kempin6a789632015-02-13 11:48:04 +0100153link:https://gerrit.googlesource.com/plugins/reviewnotes/+doc/master/src/main/resources/Documentation/about.md[
Marian Harbach34253372019-12-10 18:01:31 +0100154Documentation,role=external,window=_blank]
Edwin Kempin6a789632015-02-13 11:48:04 +0100155
Edwin Kempinecee5f62015-04-16 13:54:25 +0200156[[singleusergroup]]
Edwin Kempin6a789632015-02-13 11:48:04 +0100157=== singleusergroup
158
159This plugin provides a group per user. This is useful to assign access
160rights directly to a single user, since in Gerrit access rights can
161only be assigned to groups.
162
David Ostrovsky8dbc1282019-04-17 17:40:01 -0700163[[webhooks]]
164=== webhooks
165
166This plugin allows to propagate Gerrit events to remote http endpoints.
167
168link:https://gerrit-review.googlesource.com/admin/repos/plugins/webhooks[
Marian Harbach34253372019-12-10 18:01:31 +0100169Project,role=external,window=_blank] |
David Ostrovsky8dbc1282019-04-17 17:40:01 -0700170link:https://gerrit.googlesource.com/plugins/webhooks/+doc/master/src/main/resources/Documentation/about.md[
Marian Harbach34253372019-12-10 18:01:31 +0100171Documentation,role=external,window=_blank] |
David Ostrovsky8dbc1282019-04-17 17:40:01 -0700172link:https://gerrit.googlesource.com/plugins/webhooks/+doc/master/src/main/resources/Documentation/config.md[
Marian Harbach34253372019-12-10 18:01:31 +0100173Configuration,role=external,window=_blank]
David Ostrovsky8dbc1282019-04-17 17:40:01 -0700174
Edwin Kempin6a789632015-02-13 11:48:04 +0100175[[other-plugins]]
176== Other Plugins
177
Marco Miller5137ba52020-02-18 16:06:14 -0500178Besides core plugins there are many other Gerrit plugins available. This Gerrit home
179link:https://www.gerritcodereview.com/plugins.html[page for plugins] lists them.
Edwin Kempin6a789632015-02-13 11:48:04 +0100180
181GERRIT
182------
183Part of link:index.html[Gerrit Code Review]
184
185SEARCHBOX
186---------