Copyright (c) 2008 - 2012 John Reese - http://noswap.com
Copyright (c) 2012 - 2016 MantisBT Team - mantisbt-dev@lists.sourceforge.net
Released under the MIT license
The Source plugin provides a flexible framework for fully integrating any sort of Version Control System (VCS) with Mantis, including support for multiple repositories, changesets or revisions, and file path tracking. It has many features already, such as importing repository history and optional support for remote check-ins or imports, and utilizes a class-based API to access objects in the database.
Initial support is included for Subversion and Git repositories using the following extension plugins:
- SourceBitBucket: Git repositories hosted on BitBucket.
- SourceCgit: Git repositories accessible via a cgit web frontend installation.
- SourceGithub: Git repositories hosted on GitHub.
- SourceGitlab: Git repositories hosted on GitLab.
- SourceGitweb: Git repositories accessible via a GitWeb web frontend installation.
- SourceHgWeb: Mercurial repositories accessible via a HgWeb frontend installation.
- SourceSFSVN: SVN repositories hosted on SourceForge.
- SourceSVN: SVN repositories locally accessible by the SVN binaries.
- SourceViewVC: SVN repositories accessible via a ViewVC web frontend installation.
- SourceWebSVN: SVN repositories accessible via a WebSVN web frontend installation.
Support for additional source control tools should be rather straightforward to implement due to the flexibility inherent in the integration framework and API.
The Source Integration framework requires MantisBT version 1.3.0 or higher.
Depending on which version of MantisBT you are using, please make sure to get the source code from the appropriate branch in the Plugin's GitHub repository, as per the table below:
MantisBT version | Branch | Notes |
---|---|---|
2.0.x | modern-ui | Beta |
1.3.x | master | Current release |
1.2.x | master-1.2.x | Legacy |
-
Download the appropriate version (see Compatibility section above) or clone a copy of the source code and checkout the correct branch.
-
Copy the primary Source plugin (the
Source/
directory) into your Mantis installation'splugins/
directory. -
Copy all the remaining plugins, or just the appropriate ones for your repositories, into your Mantis installation's
plugins/
directory. -
While logged into your Mantis installation as an administrator, go to 'Manage' -> "Manage Plugins".
-
In the "Available Plugins" list, you'll find the "Source Control Integration" and additional plugins:
a. First, click the "Install" link for the "Source Control Integration" plugin.
b. Next, click the "Install" link next to any additional Source Control plugins appropriate for your repositories.
-
Click on the "Source Control Integration" plugin to configure it.
NOTE: an API Key must be set up to import changesets via shell. To generate a random key, run
openssl rand -hex 12
-
Go to "Repositories" and enter your repository name, select the repository type, and click "Create Repository" to begin adding your first repository.
-
Configure the repository, following the specific documentation for the relevant plugin extension:
-
Once configured, click the "Return to Repository" link and click either the "Import Everything" or "Import Newest Data" button to perform initial import of repository changesets and verify configuration.
-
Once satisfied that your repository is configured & working correctly, you can automate the import of new changesets by configuring a cron job on the web server where your Mantis installation resides, as follows:
-
import via curl (could run into timeouts on large repositories, or block your webserver)
curl "http://host.domain.tld/mantisbt/plugin.php?page=Source/import&id=all&api_key=<YOUR_API_KEY>"
-
import via shell
php-cgi -f plugin.php page=Source/import id=all api_key=<YOUR_API_KEY>
Please be aware of the difference between
php-cgi
andphp-cli
. The import won't run with php-cli.
This will import new changesets for all configured repositories.
-
-
Add additional repositories as needed.
The following support channels are available if you wish to file a bug report, or have questions related to use and installation:
- GitHub issues tracker
- Gitter chat room
- If you feel lucky you may also want to try the legacy #mantisbt IRC channel on Freenode (irc://freenode.net/mantisbt) but since hardly anyone goes there nowadays, you may not get any response.
All code contributions (bug fixes, new features and enhancements, additional VCS integration plugins) are welcome and highly encouraged, preferably as a Pull Request.
The latest source code is available on GitHub; John Reese's original project documentation can be found on his web site, noswap.com.