Forums

Articles
Create
cancel
Showing results for 
Search instead for 
Did you mean: 

Jira Automation: Updating a Confluence page with information from Jira issues

This article provides instructions for creating a solution that utilizes Jira Automation and the Confluence REST API to update a Confluence page with information from Jira issues.
For instance, When a label is added to a Jira issue, the label and the issue key should be added to an existing Confluence page.

Solution

The plan is as follows:

  1. Get the page details using the REST API endpoint Get page by id.

  2. Retrieve the page content and the page version.

  3. Update the page using the REST API endpoint  Update page. This Endpoint overwrites the existing page content. Therefore, we needed to retrieve the page content in Step 2.

Get Page ID

  • Use this API endpoint Get pages to get the Confluence page id.
    Or you can get the page id from the Confluence page:

    • Go to the ellipses (...) at the top-right of the page > Advanced Details > Page Information

Get the version number

  • Use this API endpoint Get page by id to get the page version.

  • Use Jira smart values to save the page version.

    {{webResponse.body.version.number}}

Get the page content

  • Use this API endpoint Get page by id and append this parameter ?body-format=storage at the end of the URL to get the page content. Example:

    https://<Cloud URL>/wiki/api/v2/pages/<Page ID>?body-format=storage
  • Use Jira smart values to save the page content.

    {{webResponse.body.body.storage.value}}


Build the automation rule

  1. Add a Field value changed trigger and select the labels field when a value is added.

  2. Add a Send web request to get the page information and add the following information:

    • Web request URL: https://<Cloud URL>/wiki/api/v2/pages/<Page ID>?body-format=storage

    • Method: GET

    • Web request body: Empty

    • Select the checkbox: "Delay execution of subsequent rule actions until we've received a response for this web request"

    • Add the following headers:

      • Accept: application/json

      • Content-Type: application/json

      • Authorization: Basic <encoded Email:APIToken>
        GETpageinfo.png

 

  1. Add another Send web request to update the page and add the following information:

    • Web request URL: https://<Cloud URL>/wiki/api/v2/pages/<Page ID>

    • Method: PUT

    • Web request body: Custom data

      {
        "id": "<Page ID>",  //pageID
        "status": "current",
         "title": "<Page Title>",  //Pagetitle
         "body": {
          "representation": "storage",
          "value": "{{webResponse.body.body.storage.value}}\n{{issue.key}} {{issue.labels}}" //Page current content + new content
        },
        "version": {
          "number": "{{#=}}{{webResponse.body.version.number}} + 1{{/}}"  //Increment page version
        }
      }
    • Add the following headers:

34 comments

Yong Yang
Community Champion
April 3, 2024

 Hi @Hala ElRoumy 

Thanks for your sharing.

Automation for Jira (A4J) is a Jira App, which was acquired by Atlassian. And the rebradning name is Jira Automaiton, I think.

Thanks,

YY哥

Like Hala ElRoumy likes this
Hala ElRoumy
Atlassian Team
Atlassian Team members are employees working across the company in a wide variety of roles.
April 4, 2024

Updated. Thanks @Yong Yang

Like Yong Yang likes this
vincenzo_spatafora
Contributor
June 10, 2024

Hi @Hala ElRoumy, thanks for sharing that.

What about the case where you need to edit/update (PUT) a specific cell of a table which is in Confluence?

See please attached file showing the table where I would like my automation rule is update the status of the JIra tickets (as their transition changes).

Thanks in advance, Vincenzo.

Table_in_Confluence.PNG

vincenzo_spatafora
Contributor
June 10, 2024

Hi @Yong Yang, thanks for that.

What about the case where you need to edit/update (PUT) a specific cell of a table which is in Confluence?

See please attached file showing the table where I would like my Jira automation rule to update the status of the JIra tickets (as their transition changes).

I use Jira DC version 9.12.5.

Thanks in advance, Vincenzo.

 

Yong Yang
Community Champion
June 10, 2024

Hi @vincenzo_spatafora 

About jira issue status update in confluence page, if you insert jira issue macro into the page, the jira issues' status will change accordingly in the confluence page (refresh) once jira issue's status is transitioned. 

I don't for your scenario, it seems we don't need automation.

Like vincenzo_spatafora likes this
vincenzo_spatafora
Contributor
June 10, 2024

Thank You @Yong Yang, thanks for your comment.

Kind Regards, Vincenzo. 

Like Yong Yang likes this
vincenzo_spatafora
Contributor
June 10, 2024

And @Yong Yang

would you know the syntax to add 2 (or 3) issues key in the confluence macro?

I have tried the follwoing but it doesn't work; it picks alwasy the first issue key.

Thanks in advance, Vincenzo.

Confluence_Macro.PNG

 

Yong Yang
Community Champion
June 10, 2024

key in (xx,  xx)

Like vincenzo_spatafora likes this
vincenzo_spatafora
Contributor
June 10, 2024

Thank You very much @Yong Yang , very appreciated.

Kind Regards, Vincenzo.

Anthony Nguyen
Contributor
June 17, 2024

Doesn't work for me, unfortunately.

Sending {{webResponse.body.body.storage.value}} back in during step 3 causes error for me if it is anything other than simple text.


Resolved: 

https://community.atlassian.com/t5/Confluence-questions/Web-Request-GET-Get-Page-into-PUT-Update-Page-is-not-working/qaq-p/2728904

Yong Yang
Community Champion
June 17, 2024

duplicated body? {{webResponse.body.body.storage.value}}

Please show us your payload so that we can identify how to write it

Anthony Nguyen
Contributor
June 17, 2024

Thank you, I figured out the mistake. If {{...value}} contains any elements like smart link, the unescaped " in them causes an issue when trying to use it again for update. I believe I resolved it by doing {{...value.replace("\"", "\\\"")}}. I'll add a link to my question to my original comment.

Just use jsonEncode.

Like Yong Yang likes this
vincenzo_spatafora
Contributor
June 19, 2024

Hi @Anthony Nguyen,

how have you managed the Authorization Basic part?

I get Error 401.

Thanks, Vincenzo. 

Carl Pritchett
Contributor
June 24, 2024

For 401, you need to ensure you are using the Authorization header with the value

Basic <base64 encoded email_Address:api-key>

See this article https://developer.atlassian.com/cloud/confluence/basic-auth-for-rest-apis/

Like # people like this
Juan D’Achiardi
I'm New Here
I'm New Here
Those new to the Atlassian Community have posted less than three times. Give them a warm welcome!
August 5, 2024

@Hala ElRoumy thank you so much for sharing this. It's exactly what I need. However, I am getting a 404 response on the web requests. What I am doing in my automation is: 

Trigger:

  • When a version is released

Actions:

  • Transition issues tagged with that fixVersion to Deployed
  • Create a page in Confluence
  • Store a variable with the created page id {{pageId}}
  • Log the {{pageId}} variable
  • Using the stored value, retrieve the content of the created page via the confluence API  
    • GET | https://<ourcompany>.atlassian.net/wiki/api/v2/pages/{{pageId}}?body-format=storage

  • Store a variable with the part of the response that I need {{content}}
  • Modify the {{content}} and store as {{updatedContent}}
  • Using the new value, update the page
    • PUT | https://<ourcompany>.atlassian.net/wiki/api/v2/pages/{{pageId}} with custom data in the request body

Unfortunately, for both the requests GET and PUT, I am getting 404s. When I try to run manually on terminal or postman, it works fine.

Do you have any ideas or can you see what I am doing wrong?

Hala ElRoumy
Atlassian Team
Atlassian Team members are employees working across the company in a wide variety of roles.
August 5, 2024

Hi @Juan D’Achiardi , You are welcome. I'm glad the post was helpful.

If you are creating a new page and not updating an existing one, you can just use the Create page endpoint and add the content you want to the page body in the same request.

Example:

Use the API endpoint Create page with the following configuration:
Web request URL: https://<Site Cloud URL>/wiki/api/v2/pages
HTTP method: POST
Web request body: Custom data
Custom data:

{
  "spaceId": "<SPACEID from Confluence>",
  "title": "<Title has to be unique>",
  "body": {
    "representation": "storage",
    "value": "<The content you want>"
  }
}

How to get the space ID? 
Run this API in the browser:
https://<Site Cloud URL>/wiki/rest/api/space/<SPACE KEY>

Can you please try it out and share a screenshot of the rule? Thanks!

Ella Z
I'm New Here
I'm New Here
Those new to the Atlassian Community have posted less than three times. Give them a warm welcome!
August 16, 2024

never mind! i found the solution.

Like Hala ElRoumy likes this
Hala ElRoumy
Atlassian Team
Atlassian Team members are employees working across the company in a wide variety of roles.
August 16, 2024

@Ella Z If there's anything else, let me know ;) 

Jason M_
Contributor
September 14, 2024

@Ella Z Could I perhaps trouble you for any additional details regarding the solution found, on that fateful day of August 16th? 

Kim Serradell
I'm New Here
I'm New Here
Those new to the Atlassian Community have posted less than three times. Give them a warm welcome!
February 5, 2025

Hello

I've been able to make the example work but the content of the page is only showing the issue key (which is useless for me).

If I try to add the description of the issue to the Confluence page like this:

{
  "id": "<Page ID>",  //pageID
  "status": "current",
   "title": "<Page Title>",  //Pagetitle
   "body": {
    "representation": "storage",
    "value": "{{webResponse.body.body.storage.value}}\n{{issue.description}} {{issue.labels}}" //Page current content + new content
  },
  "version": {
    "number": "{{#=}}{{webResponse.body.version.number}} + 1{{/}}"  //Increment page version
  }
} 

 Then I have an error:

Error found in the HTTP body response:
{"errors":[{"status":400,"code":"INVALID_MESSAGE","title":"Invalid message","detail":null}]}

What am I doing wrong?

Any help would be appreciated.

KiM

Bill Sheboy
Rising Star
Rising Star
Rising Stars are recognized for providing high-quality answers to other users. Rising Stars receive a certificate of achievement and are on the path to becoming Community Leaders.
February 5, 2025

Hi @Kim Serradell -- Welcome to the Atlassian Community!

First thing, this is a very old article / thread, so it may help to create a new question and perhaps add a link back to the article.  That will ensure the maximum number of people see it to offer suggestions.

Until that new question is created...

Depending upon the contents of your Description field, it may be producing an invalid JSON expression.  Perhaps try adding encoding to the field to help:

{{issue.description.jsonEncode}}

https://support.atlassian.com/cloud-automation/docs/jira-smart-values-text-fields/#Json-encoding

Kind regards,
Bill

Like # people like this
Chris_Parkes
Contributor
February 5, 2025

This is super useful - great document and thanks for sharing!

Like Hala ElRoumy likes this
Kim Serradell
I'm New Here
I'm New Here
Those new to the Atlassian Community have posted less than three times. Give them a warm welcome!
February 6, 2025

Thanks for your input @Bill Sheboy

Unfortunately, I did not work.

I will try to reach Atlassian Support.

 

Hala ElRoumy
Atlassian Team
Atlassian Team members are employees working across the company in a wide variety of roles.
February 6, 2025

Hi @Kim Serradell, I'm happy to see you found this article helpful. 

I see Bill has already suggested a good solution. To look further into the rule and help debug it, please contact our support and I would be happy to assist you! 

Thanks,
Hala

Hala ElRoumy
Atlassian Team
Atlassian Team members are employees working across the company in a wide variety of roles.
February 6, 2025

Thank you @Chris_Parkes for your feedback! I'm happy that you found it useful! :)

Like Chris_Parkes likes this

Comment

Log in or Sign up to comment
TAGS
AUG Leaders

Atlassian Community Events