RETIRED, Gerrit as used by OpenStack
Go to file
Dave Borowitz b8336f176a Move most GPG-related code to a gerrit-gpg module
Bouncy Castle is still an optional dependency for Gerrit, so we want
to avoid accidentally attempting to load Bouncy Castle classes when
they might not be available. Rather than try to guard every
org.bouncycastle.* reference with a hasPGP() check, reduce the surface
area of calls that actually require Bouncy Castle. Move almost all
code that calls Bouncy Castle into a new module, gerrit-gpg.

Callers need only interact with this module by installing the
GpgModule, which is careful to protect all Bouncy Castle class loading
with the appropriate havePGP() check. Moreover, this module doesn't
need to be installed in the gerrit-server package at all, so we can
break the compile-time dependency between gerrit-server and Bouncy
Castle, so accidentally introducing a dependency on Bouncy Castle
results in a compile error.

The REST API and extension APIs dealing with GPG keys only refer to
the GpgKeyInfo POJO, and don't need to actually refer to Bouncy Castle
classes. Add a shim interface, GpgApiAdapter, that is used by
AccountApiImpl to process GPG keys. GpgModule binds this interface to
either the Bouncy Castle enabled implementation, or a not-implemented
implementation.

Since there are various places in the server code where we want to
inspect whether signed push is enabled at the server level, but we
don't want to have to call into gerrit-gpg code to do this, bind a
boolean with @EnableSignedPush from GpgModule.

Change-Id: Idbab00a52d86216cae73d02876d56be54aef6581
2015-08-28 14:13:13 -04:00
.settings Enable Eclipse warning 'resource not managed via try-with-resource' 2015-08-27 18:01:01 +09:00
bucklets Rename __standalone_mode__ to STANDALONE_MODE 2014-11-24 08:44:12 +00:00
contrib abandon_stale: Allow singular form of age parameter 2015-07-06 12:12:28 +09:00
Documentation Remove contact store functionality 2015-08-28 14:08:58 -04:00
gerrit-acceptance-tests Move most GPG-related code to a gerrit-gpg module 2015-08-28 14:13:13 -04:00
gerrit-antlr Kill @Rewrite support in queries 2015-05-27 03:55:33 +00:00
gerrit-cache-h2 H2CacheImpl: Support get(K, Callable<? extends V>) 2015-08-07 17:04:18 -07:00
gerrit-common Remove contact store functionality 2015-08-28 14:08:58 -04:00
gerrit-extension-api Move most GPG-related code to a gerrit-gpg module 2015-08-28 14:13:13 -04:00
gerrit-gpg Move most GPG-related code to a gerrit-gpg module 2015-08-28 14:13:13 -04:00
gerrit-gwtdebug Organize imports 2014-12-18 11:16:03 +09:00
gerrit-gwtexpui Fix Checkstyle warnings about empty catch blocks 2015-08-26 09:24:07 +09:00
gerrit-gwtui Remove contact store functionality 2015-08-28 14:08:58 -04:00
gerrit-gwtui-common Remove contact store functionality 2015-08-28 14:08:58 -04:00
gerrit-httpd Remove contact store functionality 2015-08-28 14:08:58 -04:00
gerrit-launcher Use try-with-resources statements 2015-06-23 21:11:57 +02:00
gerrit-lucene ChangeField: Add LEGACY_ID2 2015-08-05 09:57:54 -07:00
gerrit-main Replace C-style array declarations with Java-style declarations 2015-03-19 12:15:43 +09:00
gerrit-oauth Merge branch 'stable-2.10' into stable-2.11 2015-05-07 10:37:48 +09:00
gerrit-openid Use try-with-resources statements 2015-06-23 21:11:57 +02:00
gerrit-patch-commonsnet Use try/multi-catch 2015-06-25 16:37:27 +09:00
gerrit-patch-jgit Pass ChangeInfo object to extension panels 2015-08-04 14:05:24 +02:00
gerrit-pgm Move most GPG-related code to a gerrit-gpg module 2015-08-28 14:13:13 -04:00
gerrit-plugin-api Set version to 2.11.3 2015-08-05 10:22:03 +09:00
gerrit-plugin-archetype Set version to 2.11.3 2015-08-05 10:22:03 +09:00
gerrit-plugin-gwt-archetype Set version to 2.11.3 2015-08-05 10:22:03 +09:00
gerrit-plugin-gwtui Fix modifier order 2015-08-26 09:23:48 +09:00
gerrit-plugin-js-archetype Set version to 2.11.3 2015-08-05 10:22:03 +09:00
gerrit-prettify Pass ChangeInfo object to extension panels 2015-08-04 14:05:24 +02:00
gerrit-reviewdb Move most GPG-related code to a gerrit-gpg module 2015-08-28 14:13:13 -04:00
gerrit-server Move most GPG-related code to a gerrit-gpg module 2015-08-28 14:13:13 -04:00
gerrit-sshd Commands: Use @AutoAnnotation 2015-08-28 09:55:02 +09:00
gerrit-util-cli Add missing braces around if- for- and while-statements 2015-03-19 12:15:42 +09:00
gerrit-util-http RequestUtilTest: Convert to use Google Truth 2015-06-04 09:41:29 +09:00
gerrit-util-ssl Turn on many more Eclipse warnings, and fix them 2014-10-29 15:00:17 -07:00
gerrit-war Move most GPG-related code to a gerrit-gpg module 2015-08-28 14:13:13 -04:00
lib Update AutoValue to 1.1 2015-08-28 09:54:52 +09:00
plugins Use try-with-resource when opening stream 2015-08-27 18:40:14 +09:00
ReleaseNotes Merge branch 'stable-2.11' 2015-08-21 13:50:48 +09:00
tools Move most GPG-related code to a gerrit-gpg module 2015-08-28 14:13:13 -04:00
website/releases Update out of date hyperlinks 2015-06-17 22:38:13 +00:00
.buckconfig Disentangle BUCK caches for internally built and downloaded artifacts 2015-07-07 12:59:51 +02:00
.buckversion Update Buck to newest version 2015-05-10 20:03:16 +02:00
.editorconfig Add basic EditorConfig 2015-03-03 07:12:16 +00:00
.gitignore Revert "Add UNIT_TEST_GERRIT_SITE to .gitignore" 2015-04-27 14:49:03 +09:00
.gitmodules Add singleusergroup plugin 2013-11-09 07:45:00 +01:00
.mailmap Update mailmap 2015-04-08 07:50:41 +00:00
.pydevproject Update PyDev project to use Python 2.7 2014-10-02 15:16:44 +09:00
.watchmanconfig Watchman: Add buck-out dir to ignored directories 2014-08-21 07:32:37 +02:00
BUCK Buck: Simplify build rules 2015-06-17 21:42:42 +02:00
COPYING Initial project setup of Gerrit 2 2008-11-14 16:59:34 -08:00
INSTALL Remove Gerrit 1.x to 2.x import tools 2009-03-27 20:20:10 -07:00
README.md README: Update events information 2015-07-06 01:47:38 +00:00
SUBMITTING_PATCHES Update push URL in SUBMITTING_PATCHES 2012-03-29 00:57:14 -04:00
VERSION Set version to 2.11.3 2015-08-05 10:22:03 +09:00

Gerrit Code Review

Gerrit is a code review and project management tool for Git based projects.

Objective

Gerrit makes reviews easier by showing changes in a side-by-side display, and allowing inline comments to be added by any reviewer.

Gerrit simplifies Git based project maintainership by permitting any authorized user to submit changes to the master Git repository, rather than requiring all approved changes to be merged in by hand by the project maintainer.

Documentation

For information about how to install and use Gerrit, refer to the documentation.

Source

Our canonical Git repository is located on googlesource.com. There is a mirror of the repository on Github.

Reporting bugs

Please report bugs on the issue tracker.

Contribute

Gerrit is the work of hundreds of contributors. We appreciate your help!

Please read the contribution guidelines.

Note that we do not accept Pull Requests via the Github mirror.

Getting in contact

The IRC channel on freenode is #gerrit. An archive is available at: echelog.com.

The Developer Mailing list is repo-discuss on Google Groups.

License

Gerrit is provided under the Apache License 2.0.

Build

Install Buck and run the following:

    git clone --recursive https://gerrit.googlesource.com/gerrit
    cd gerrit && buck build all

Install binary packages (Deb/Rpm)

The instruction how to configure GerritForge/BinTray repositories is here

On Debian/Ubuntu run:

    apt-get update & apt-get install gerrit=<version>-<release>

NOTE: release is a counter that starts with 1 and indicates the number of packages that have been released with the same version of the software.

On CentOS/RedHat run:

    yum clean all && yum install gerrit-<version>[-<release>]

NOTE: release is optional. Last released package of the version is installed if the release number is omitted.

Events

  • November 7-8 2015: Gerrit User Conference, Mountain View. (Register).
  • November 9-13 2015: Gerrit Hackathon, Mountain View. (Invitation Only).
  • March 2016: Gerrit Hackathon, Berlin. (Details to be confirmed).