Versions Compared


  • This line was added.
  • This line was removed.
  • Formatting was changed.


Code Block
import com.atlassian.jira.component.ComponentAccessor;
import com.atlassian.jira.issue.IssueInputParameters;
import com.atlassian.jira.bc.issue.IssueService;
import com.atlassian.jira.bc.issue.DefaultIssueService;
import com.atlassian.jira.bc.issue.worklog.WorklogInputParametersImpl.Builder;
import com.atlassian.jira.issue.IssueManager;
import com.atlassian.jira.issue.IssueInputParameters;
import org.slf4j.*;

Logger log = LoggerFactory.getLogger(com.deniz.jira.worklog.scripting.ScriptingService.class);

def issueManager = ComponentAccessor.getIssueManager();
def issueService = ComponentAccessor.getIssueService();
def authenticationContext = ComponentAccessor.getJiraAuthenticationContext();
def customFieldManager = ComponentAccessor.getCustomFieldManager();
def previousTimeSpent = 0;

if (update) {
  previousTimeSpent = previousWorklog.getTimeSpent();

def currentUser = authenticationContext.getLoggedInUser();
def issue=worklog.getIssue();
def epicLinkCf = customFieldManager.getCustomFieldObjectByName("Epic Link");
def epicIssue = issue.getCustomFieldValue(epicLinkCf);

def parentObject=issue.getParentObject();
  def epicIssueOfObject=parentObject.getCustomFieldValue(epicLinkCf);
    //In this case,epic has a child issue and child issue has a subtask.Worklog is done for this subtask.
   epicIssue = epicIssueOfObject;
   if( == 'Epic'){
    //In this case,epic has a subtask.Worklog is done for this subtask.
def issueSpentTime=worklog.getTimeSpent();
def diff = issueSpentTime - previousTimeSpent;

if (epicIssue) {
    log.debug("Subtracting {} seconds from remaining estimate of epic {}", diff, epicIssue.getKey());
    def epicEstimate=epicIssue.getEstimate();
    Long epicEstimateUpdated=epicEstimate-diff;
    if (epicEstimateUpdated < 0) {
      epicEstimateUpdated = 0;
    IssueInputParameters issueInputParameters = issueService.newIssueInputParameters();
    issueInputParameters.setRemainingEstimate((epicEstimateUpdated/60) + "m");
    IssueService.UpdateValidationResult updateValidationResult = issueService.validateUpdate(currentUser, epicIssue.getId(), issueInputParameters);
    if(updateValidationResult.isValid()) {
        issueService.update(currentUser, updateValidationResult);
    } else {
        log.error("!!!Error in Worklog Update Script:{}", getErrorCollection.getErrorCollection())

Setting the Account Specified with "Account Custom Field" to the Worklog Account In Case the Account Field of the Worklog is edited as 'None'

If there is an account value that is set with "Account Custom Field" to an issue, when creating the worklog to this issue, this value comes to the account field of worklog by default. Even if the account field is selected as None while creating the worklog to this issue, this value is set to worklog's account field. These are behaviours that are provided by WorklogPRO.
Also with this script, Even if account value is changed to 'None' while editing the worklog, this value is still set to account field of worklog.
In brief, If the account value is set for the issue with the "Account Custom Field", this account value is set to account field of worklog in the case that worklog's account field is set to 'None'.

Code Block
import com.atlassian.jira.issue.CustomFieldManager;
import com.atlassian.jira.issue.fields.CustomField;
import com.atlassian.jira.component.ComponentAccessor;
import com.deniz.jira.worklog.accounting.AccountImp;
import com.deniz.jira.worklog.accounting.AccountService;
import com.deniz.jira.worklog.accounting.*;
import com.atlassian.jira.issue.*;
import java.util.*;
import org.slf4j.*;

def accountService = ComponentAccessor.getOSGiComponentInstanceOfType(AccountService.class);
def customFieldManager = ComponentAccessor.getCustomFieldManager();

def issue=worklog.getIssue();
def worklogId=;

def cField = customFieldManager.getCustomFieldObjectByName("Account Custom Field");
def cFieldValue = issue.getCustomFieldValue(cField);

if (!account) {
  accountService.addAccountToWorklog(worklogId, cFieldAccountId, worklog.startDate)