Controllers are classes used to help you with handling your route request. A new controller can be created using a command node ivy make:controller {controllerName} in project root.

node ivy make:controller UserController

will generate a file app/controllers/UserController.js.

Request handlers

Functions defined in the controller can be used to handle your request on the same exact way as Route callback works. So, we've got UserController previousely created, lets add index route handler there.

   * This method returns the list of users.
   * @return {}
  **/index(){return[{ name:"Adam", age:23},{ name:"Joe", age:25},{ name:"Phoebe", age:20}];}}namespace('App/Controller/UserController', UserController);

We made a method in the controller, what now? All thats left to be done is to create a new route for that method in our routes.js file.

Route.get('/users','[email protected]');

Right now, after we hit the route /users we will get the json response containing the values returned from the controller's method index().


The thing you will, most likely, do very often is performing CRUD (Create, Read, Update, Delete) operations. And, guess what? Ivy can help you with that as well. Creating CRUD controller is done with --resource option for the commander.

node ivy make:controller UserController --resource

will generate app/controllers/UserController.js containing all the relevant methods for that resource

    * Show all the results.
    * Show resource.
    * @param request
    * Creates a resource.
    * @param request
    * Updates a resource.
    * @param request
    * Delete a resource.
    * @param request
    **/remove(request){}}namespace('App/Controller/UserController', UserController);