THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
If you're happy with this project, please help to improve it by solving issues, writing pull-requests and other improvements. Always keep in mind, what you get for free here and give back.
We do NOT suggest anyone to move away from the wonderful ActiveCollab which we loved for nealy a decade and still love. Anyway structures changed for us and ActiveCollab wasn't the right tool for us anymore. But it might be different for you and ActiveCollab is still a very very good choice & wonderful software with a wonderful team. THANK YOU VERY MUCH @ActiveCollab Team for all your great work!
If you need to move from ActiveCollab to Jira®, this tool may help you to do that and keep most of your assets.
- PHP >=7.3
- Composer
- Jira® Server >= 8.x (tested with 8.10.0)
- ActiveCollab >= 5. (tested with ActiveCollab 6.2.135)
ActiveCollabToJiraMigrator provides an export tool with UI, based on PHP and the ActiveCollab Feather SDK using the ActiveCollab SDK to create imports for Jira® based on the (JSON import functionality)[https://confluence.atlassian.com/adminjiraserver089/importing-data-from-json-1005346888.html].
Most of these are only partially supported, because the systems structure is different:
- User => Users
- Project => Project
- Task => Task
- Subtask => Sub-task
- Comment => Comment
- Task attachment => Task attachmant
- Tracked time => Worklog
- Companies
- Task Lists / Milestones (migrated as label)
- Comment files / attachments
- Reactions
- Notes
- Discussions
- Receipts
- ...
- Read this project documentation and code to understand what it does and how it works.
- Copy to your webserver and set
/app
as DocumentRoot for your VirtualHost. likethisactivecollabtojiramigrator.example.com
(Example) - Run
composer install
on the base directory via bash. - Copy
config/EXAMPLE.config.php
toconfig/config.php
- Set all values in
config/config.php
, especially the secret Keep your secret safe and secure! - Open https://thisactivecollabtojiramigrator.example.com/index.php?secret=_secret_ (Your secret from config.php) in your browser. You should see a form.
- Enter your ActiveCollab Admin Credentials, set your offsets and limits (to allow splitting the export)
- Export and check the results carefully
- Enable debug mode in config.php to see details and check for errors
!! Due to limitations in Jira Import some ActiveCollab entities are not migrated at all. See below. !! If you wish to add these functionalities, you may help to develop Export/JiraRestExporter which uses the Jira® API instead of the import. Anyway some structural differences will never be 1:1 migratable like expenses, project expenses, non-task time records and others. Here you'll need other workarounds or JiraApps which allow API-based creation.
!! Futhermore there are properties / settings which are not supported by Jira® Import which may also lead to unwanted access elevation. See below !!
- The Jira® importer doesn't provide a sandbox environment. Data may be inconsistent if import fails. So TAKE BACKUPS to be able to restore the clean state before the import!
- Jira® has an issue with "External issue ID", which occurs if you split your import, see https://jira.atlassian.com/browse/JRASERVER-64477 - so you should try the workaround mentioned in this comment: https://jira.atlassian.com/browse/JRASERVER-64477?focusedCommentId=2274882&page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#comment-2274882 by Joe Harmon: "There is another workaround that I found. The external issue ID is created per project that you import. The first time that I import it, I changed it to a global fields for any project. After that, after I import it doesn't duplicate the field anymore." and set the custom field global after the first import. Due to this issue it might also be a good idea to create only one large import file.
- Project expenses
- Project time records
- Project task lists
- Project notes
- Project files
- Task expenses
- Comment attachments These entities are not migrated at all.
Furthermore the following properties / settings are not supported:
- Project roles
- Attachments hidden from client
- https://developers.activecollab.com/api-documentation/
- https://github.com/activecollab/activecollab-feather-sdk
- The Jira JSON import documentation doesn't seem to list all available fields. So if you need further fields, you should follow this documentation (https://confluence.atlassian.com/jirakb/how-to-enable-json-export-in-jira-server-723158427.html) to enable JSON export in tasks and export some tasks to see the exported format, which seems to match the import format.
All product names, logos, and brands are property of their respective owners. All company, product and service names used are for identification purposes only. Use of these names, logos, and brands does not imply endorsement.