Skip to main content

Version: 23.10

Groovy Service

Provides a generic Fluent API Groovy script service which can provide reusable scripts to be called by other services.

Service Invoke Parameters

Parameters are not nullable except where otherwise indicated.

ParameterDescription
svcDefSvcDef
A service definition value object.
requestHttpServletRequest
A HTTP servlet request.
userUser
Nullable. An authenticated user.
requestHttpServletRequest
The HTTP servlet request of the calling code.
paramsMap
Nullable. A map of parameters provided by the service caller, or request parameters map if called from REST Groovy Service Invoke API.
params.jobJob
Nullable. An associated job action Job, added when the Groovy Service is called from $func.invoke().
params.jobActionJobAction
Nullable. An associated JobAction, added when the Groovy Service is called from $func.invoke().

Script Result

The script can optionally return a value.

Error Handling

If an error occurs invoking the Groovy Service, the error is recorded in the Journey Manager database error log.

Templates

Service

import com.avoka.core.groovy.GroovyLogger as logger
import com.avoka.tm.vo.*
import javax.servlet.http.*

class FluentGroovyService {

/*
* Perform a groovy service invocation
*
* return: the result object
*/
Object invoke(SvcDef svcDef, HttpServletRequest request, User user, Map params) {

// TODO: perform your logic
def result = 'groovy result - ' + params.formId

return result
}
}

Unit Test

import com.avoka.core.groovy.GroovyLogger as logger
import com.avoka.tm.svc.*
import com.avoka.tm.vo.*
import org.junit.Test

class UnitTest extends AbstractJUnitTest {

/*
* Perform service unit test
*
* throws exception if unit test fails
*/
@Test
void test() throws Exception {

Map args = [
"formId": 23
]

Map params = [
"svcDef": svcDef,
"request": null,
"user": null,
"params": args
]

def result = new ServiceInvoker(svcDef).invoke(params)

// Check result
logger.info result

assert "groovy result - 23" == result
}
}