(Quick Reference)

afterInterceptor

Purpose

Allows interception of actions after they have executed, but before the view is rendered.

Examples

Using a block:

class BookController {
    def afterInterceptor = { model ->
        model.foo = "bar"
    }
}

In this example we use a more fine-grained approach, using a Groovy method pointer to specify a helper method to use and a list of action names to be intercepted:

class BookController {

def afterInterceptor = [action: this.&invokeMe, only: ['list']]

private invokeMe(model) { model.foo = "bar" }

def list() { [bookList: Book.list()] } }

In this example we use the Map syntax to constraint the afterInterceptor to execute only for the list action.

Description

To define an interceptor that is executed after an action use the afterInterceptor property:

def afterInterceptor = { model ->
    println "Tracing action ${actionUri}"
}

The first argument of the Closure is the model Map that resulted from the action that executed and will be passed to the view. This lets you manipulate the model before rendering the view. The model might be empty but will not be null.

An afterInterceptor may also inspect or modify the Spring MVC ModelAndView object prior to rendering. In this case, the example becomes:

def afterInterceptor = { model, modelAndView ->
    println "Current view is ${modelAndView.viewName}"
    if (model.someVar) {
        modelAndView.viewName = "/mycontroller/someotherview"
    }
    println "View is now ${modelAndView.viewName}"
}

This allows the view to be changed based on the model returned by the current action. Note that the modelAndView may be null if the action being intercepted called redirect or render.

This example limited the intercepted actions using the only argument but the except argument can also be used to list the actions to not intercept, rather than those to intercept.