How to tell if a plugin is used in a Bamboo build plan?

We are planning to upgrade from Bamboo 4.4.5 to the latest version. It turns out that many of the plugins we have in our 4.4.5 instance are not available in a compatible version with the latest Bamboo. I know some of the plugins were originally installed 'on speculation' that we might use them, and probably are not being used.

I'd like to know for sure what plugins are actually being used. We have almost 800 build plans, so manually looking at every job is not an option.

Is there something in the admin section of bamboo that I've missed that will list the plugins being used? Or, a database query I can use to see what plugins are being used?

1 answer

1 accepted

This widget could not be displayed.

Hi Ken,

You can check which plugins are currently installed in your 4.4.5 instance by going to Bamboo Administration > Plugins > Manage Add-Ons. There you can see all the User-installed add-ons.

To check which plans use which plugins, you can connect to your database and run this SQL query:

SELECT p.title AS project, b.title AS plan,
(SUBSTRING(bd.xml_definition_data,
        (LOCATE('<pluginKey>', bd.xml_definition_data)) +11,
        (LOCATE('</pluginKey>', bd.xml_definition_data) - 11 - LOCATE('<pluginKey>', bd.XML_DEFINITION_DATA)))) AS plugin_key
  FROM build             AS b
  JOIN build_definition  AS bd ON b.build_id = bd.build_id
  JOIN project           AS p  ON b.project_id = p.project_id
WHERE plugin_key IS NOT NULL
ORDER BY project, plan;

NOTE: This query might not work depending on the database you use. This works with HSQL at least.

This retrieves the Project name, the Plan name, and the keys of the plugins they use. If you just want to see the keys of the plugins being used regardless of project or plan, this SQL query can tell you that:

SELECT DISTINCT
(SUBSTRING(bd.xml_definition_data,
        (LOCATE('<pluginKey>', bd.xml_definition_data)) +11,
        (LOCATE('</pluginKey>', bd.xml_definition_data) - 11 - LOCATE('<pluginKey>', bd.XML_DEFINITION_DATA)))) AS plugin_key
  FROM build             AS b
  JOIN build_definition  AS bd ON b.build_id = bd.build_id
  JOIN project           AS p  ON b.project_id = p.project_id
WHERE plugin_key IS NOT NULL;

NOTE: This query might not work depending on the database you use. This works with HSQL at least.

Then you can compare the Add-ons page with the query results, and uninstall the user-installed plugins not being used.

I hope this helps!

Kind regards,
Felipe Kraemer
Atlassian Support

With a few tweaks to work with mySql, it worked perfectly. Thanks!

Suggest an answer

Log in or Sign up to answer
Atlassian Summit 2018

Meet the community IRL

Atlassian Summit is an excellent opportunity for in-person support, training, and networking.

Learn more
Community showcase
Posted Wednesday in New to Jira

Are you planning to trial, or are currently trialling Jira Software? - We want to talk to you!

Hello! I'm Rayen, a product manager at Atlassian. My team and I are working hard to improve the trial experience for Jira Software Cloud. We are interested in   talking to 20 people planning t...

115 views 2 0
Join discussion

Atlassian User Groups

Connect with like-minded Atlassian users at free events near you!

Find a group

Connect with like-minded Atlassian users at free events near you!

Find my local user group

Unfortunately there are no AUG chapters near you at the moment.

Start an AUG

You're one step closer to meeting fellow Atlassian users at your local meet up. Learn more about AUGs

Groups near you