Error to send mail

Hello,

in an email connector, I would like to send an email to the contributors of a lane. A consultant came to help us and writed this code :

in the "Tools" script :

import java.util.logging.Logger;

import org.ow2.bonita.facade.IdentityAPI;
import org.ow2.bonita.facade.QueryRuntimeAPI;
import org.ow2.bonita.facade.exception.UserNotFoundException;
import org.ow2.bonita.util.AccessorUtil;
import org.ow2.bonita.facade.identity.ContactInfo;
import org.ow2.bonita.facade.runtime.TaskInstance;
import org.ow2.bonita.facade.uuid.ActivityInstanceUUID;

final Logger LOG = Logger.getLogger('org.bonitasoft.scripts.Tool');

//Get list of mail address from a list of users. Result will be formated as a String separated by commas
String listOfUserEmailSeparatedByComma(List<String> listOfUsers){
    List<String> result=[];
    for(String username:listOfUsers){
        String email=null;
        try{
            email=providedscripts.BonitaUsers.getUserEMail(username);
        }catch(UserNotFoundException ex){
            LOG.warning('User: '+username+' doesn\'t exist in Bonita database.');
        }
        if(email!=null && !email.isEmpty()){
            result.add(email);
        }    
    }
    
    return org.codehaus.groovy.runtime.DefaultGroovyMethods.join(result,',');
}

//Get the list of candidates of a specific task
List<String> getTaskCandidates(ActivityInstanceUUID taskInstanceUUID){
    final QueryRuntimeAPI queryRuntimeAPI=AccessorUtil.getQueryRuntimeAPI();
    List<String> result=new ArrayList<String>();
    result.addAll(new ArrayList<String>(queryRuntimeAPI.getTaskCandidates(taskInstanceUUID)));
    
    return result;
}

//Get list of mail address from the list of candidate of a task. Result will be formated as a String separated by commas
String getEmailTaskCandidates(ActivityInstanceUUID taskInstanceUUID){
    List<String> candidates=getTaskCandidates(taskInstanceUUID);
    return listOfUserEmailSeparatedByComma(candidates);
}

And in the email connector :

${new Tools().getEmailTaskCandidates(activityInstance.getUUID())}

The code works in local but not on the development server where Talend crashes (we use Bonita in Talend) and no error in the logs.

With the Java log, we have nothing after :

result.addAll(queryRuntimeAPI.getTaskCandidates(taskInstanceUUID));

As queryRuntimeAPI.getTaskCandidates() returns a Set<String>, I tried to convert it with :

result.addAll(new ArrayList<String>(queryRuntimeAPI.getTaskCandidates(taskInstanceUUID)));

but it doesn't work.

 

Thank you for you help :)

It was a Talend or Bonitasoft consultant? or someone from another company ? And can you confirm that this is about Bonita 5 ?