Come for the products,
stay for the community

The Atlassian Community can help you and your team get more value out of Atlassian products and practices.

Atlassian Community about banner
4,293,653
Community Members
 
Community Events
165
Community Groups

Confluence Scrptrunner event handler not working for PageCopyEvent

Hi Guys,

We are trying to get the scriptrunner Confluence event handler working for PageCopyEvent.
Unfortunately the event handler seems to be totally ignored.
Running on the console for a specific page is successful but in in the real system nothing is triggered.
No errors or debugs showing in the logs either.

Even running this basic code, nothing is logged when a page is  copied

import org.apache.log4j.Logger
import org.apache.log4j.Level

def log = Logger.getLogger("com.methoda.test")
log.setLevel(Level.DEBUG)

 

Our need is to delete certain labels in the target page when a page is copied 

This is the actual  code that  we are trying to run in the end:

import com.atlassian.confluence.pages.Page
import com.atlassian.confluence.pages.PageManager
import com.atlassian.confluence.event.events.content.page.PageEvent
import com.atlassian.confluence.pages.CommentManager
import com.atlassian.sal.api.component.ComponentLocator
import com.atlassian.confluence.labels.LabelManager
import com.atlassian.confluence.event.events.content.page.PageCopyEvent
import org.apache.log4j.Logger
import org.apache.log4j.Level

def log = Logger.getLogger("logger.test")
log.setLevel(Level.DEBUG)
def labelManager = ComponentLocator.getComponent(LabelManager)

//def pageManager = ComponentLocator.getComponent(PageManager)
//def origin=pageManager.getPage(65723)
//def destination=pageManager.getPage(1114170)

def event = event as PageCopyEvent
def originpage = event.getOrigin() 
def destinationpage = event.getDestination() 
def label = originpage.getLabels()


log.debug("origin: "originpage" destination: " destinationpage " labels: " + label)
for(def item: label){
if(item.toString().contains('syswt_pagepublished') || item.toString().contains('syswt_published-to-'))

{ labelManager.removeLabel(destinationpage, labelManager.getLabel(item)) }

}

log.debug("labels: "+label)

 

Would really appreciate some help with this.

 

Thanks.

 

1 answer

Suggest an answer

Log in or Sign up to answer
TAGS
Community showcase
Posted in Jira Service Management

Jira Service Management Documentation Opportunities

Hello everyone, Hope everyone is safe! A few months ago we posted an article sharing all the new articles and documentation that we, the AMER Jira Service Management team created. As mentioned ...

215 views 0 6
Join discussion

Community Events

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

Find an event

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

Unfortunately there are no Community Events near you at the moment.

Host an event

You're one step closer to meeting fellow Atlassian users at your local event. Learn more about Community Events

Events near you