An Atlassian Bitbucket Server plugin to check on various file attributes, like size, name.
The plugin is available in the Atlassian Marketplace and can be installed directly in Bitbucket Server using the Universal Plugin Manager (UPM), see here for details.
In order to configure the hook on a project level go to your project and select Settings > Hooks -> File Size Hook.
In order to configure the hook on a repository level go to your repository and select Settings > Hooks > File Size Hook. The following example rejects all files larger then 1MB (1048576 bytes).
In order to configure the hook on a project level go to your project and select Settings > Merge checks > File Name Hook.
In order to configure the hook on a repostory level go to your repository and select Settings > Merge checks > File Name Hook. The following example rejects all files matching the pattern readme.md when the file is pushed or part of a merge request(pull request).
5.0.4 (2022-07-28)
Fix bug where refs were not collected properly
5.0.3 (2022-07-27)
Code improvements as suggested by Intellij
5.0.2 (2022-07-22)
Add logging support via logback, logs will now be written to atlassian-bitbucket.log when debug is enabled in the Bitbucket GUI
5.0.1 (2022-07-20)
Minor updates
5.0.0 (2022-07-01)
Updates to support Bitbucket 8.x
3.3.2 (2018-04-15)
- Fix: FileSize Hook: NullPointerException when size is null, thanks lucamilanesio for providing a fix.
3.3.1 (2018-03-03)
3.3.0 (2018-02-28)
- Performance Improvement: New branch creation causes the plugin to iterate over all changesets, thanks raspy for providing a fix.
3.2.0 (2017-12-30)
- Compatibility with Bitbucket Server 5.2.x
- Rework of configuration UI
- Update of documentation for File Name Hook configuration location
3.1.0 (2017-11-26)
- Fix: When multiple size rules use the same size, only last rule is effective
- Feature: File hook should be available at Project level. Please note that the UI is not perfect yet and will be adjusred in one of the next versions.
3.0.1 (2017-11-12)
- Fixes in a corner case issue to find the correct git hash, thanks syee514 for providing a fix.
3.0.0 (2017-05-07)
- Compatibility with Bitbucket Server 5.0.x
2.4.0 (2016-09-09)
- File Name Hook:
- Checks the file name pattern also for merge requests(pull requests) and not only for pushes, thanks ellaz for providing the pull request.
2.3.1 (2016-08-31)
- Fixes an issue with rollback commits and forced pushed to Bitbucket, thanks ar613 for providing a fix.
2.3.0 (2016-03-15)
- Allows to specify branch name patterns for the File Size Hook and File Name Hook.
2.2.0 (2016-01-23)
- Tag commits are now excluded
2.1.2 (2016-01-22)
- File Size Hook:
- File Name Hook:
2.1.1 (2015-10-18)
- Allows to specify exclude patterns for the File Size Hook and File Name Hook.
2.1.0 (2015-10-18)
- Allows to specify exclude patterns for the File Size Hook and File Name Hook.
2.0.0 (2015-09-29)
- Compatibility with Bitbucket Server 4.0.x
1.1.0 (2015-03-15)
- File Size Hook:
- Allows now to specify up to 5 different pattern and size combinations.
- Fixes: Plugin crashes when pushing a branch delete #2
- File Name Hook:
- New hook which allows to check on the file name and reject pushes if files matches the specified pattern
1.0.0 (2015-01-15)
- Reject commits containing files which exceed a configurable file size. Files can be identified by regular expressions.
The following tools are required to build the plugin:
- java 1.8
- atlassian sdk
Instructions on how to install the Atlassian SDK can be found here
Clone the repository:
git clone https://github.com/christiangalsterer/stash-filehooks-plugin.git
Edit the pom.xml in the root of the checkout, and change the line (change to match the version of Bitbucket you want to build against):
<bitbucket.version>7.13.0</bitbucket.version>
Build the plugin
atlas-mvn clean install
Copyright 2015 Christian Galsterer
Copyright 2017 Motorola Solutions, Inc.
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.