diff options
author | James Moger <james.moger@gitblit.com> | 2014-04-11 17:55:53 -0400 |
---|---|---|
committer | James Moger <james.moger@gitblit.com> | 2014-04-12 11:31:03 -0400 |
commit | 819efdc8c5ea633e9be1e744ade8b197d21a1962 (patch) | |
tree | fa178791fd466a50537a9d2046d114b8f855032f /src/main/java/com/gitblit/extensions | |
parent | a57d0c36910a96391b79511224eeb2989f52f6e3 (diff) | |
download | gitblit-819efdc8c5ea633e9be1e744ade8b197d21a1962.tar.gz gitblit-819efdc8c5ea633e9be1e744ade8b197d21a1962.zip |
Allow ReceiveHook extensions
Diffstat (limited to 'src/main/java/com/gitblit/extensions')
-rw-r--r-- | src/main/java/com/gitblit/extensions/ReceiveHook.java | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/src/main/java/com/gitblit/extensions/ReceiveHook.java b/src/main/java/com/gitblit/extensions/ReceiveHook.java new file mode 100644 index 00000000..00dcb3e3 --- /dev/null +++ b/src/main/java/com/gitblit/extensions/ReceiveHook.java @@ -0,0 +1,53 @@ +/* + * Copyright 2014 gitblit.com. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package com.gitblit.extensions; + +import java.util.Collection; + +import org.eclipse.jgit.transport.ReceiveCommand; + +import ro.fortsoft.pf4j.ExtensionPoint; + +import com.gitblit.git.GitblitReceivePack; + +/** + * Extension point for plugins to process commits on Pre- and Post- Receive. + * + * @author James Moger + * + */ +public abstract class ReceiveHook implements ExtensionPoint { + + /** + * Called BEFORE received ref update commands have been written to the + * repository. This allows extensions to process or reject incoming pushes + * using whatever logic may be appropriate. + * + * @param receivePack + * @param commands + */ + public abstract void onPreReceive(GitblitReceivePack receivePack, Collection<ReceiveCommand> commands); + + /** + * Called AFTER received ref update commands have been written to the + * repository. This allows extensions to send notifications or trigger + * continuous integration systems. + * + * @param receivePack + * @param commands + */ + public abstract void onPostReceive(GitblitReceivePack receivePack, Collection<ReceiveCommand> commands); +} |