Routes
Routing provides you tools that map URLs to controller actions. By defining routes, you can separate how your application is implemented from how its URL’s are structured. Routes wire up real-time web socket handlers, and define a series of pipeline transformations for scoping middleware to sets of routes.
A route connects a HTTP request to an action inside a controller. When your Maze application receives an incoming request for: GET /users/24
it asks the Maze router to match it to a controller action. If the router finds a match get users/:id, UsersController, :index
the request is dispatched to the UsersController.index action with { id: 24 } in the params hash.
Configuring Routes
Routes are configured in the {project_name}/config/routes.cr
file.
Defining Routes
The routes macro accepts a pipeline name and a scope, in which all routes defined within this block will make use of the pipeline and the url will be scoped.
Lets say you are defining a static website and you want the URL to be displayed as http://www.mycoolsite.com/page
. You will define your routes as:
The routes macro takes a last argument. And a block within the block is where you define your routes.
Mapping the above route
Http Method
Resource
Controller
Action
get
"/about"
StaticController
:about
Your action will need to return a string or render a view or this will cause your routes to throw an error during compilation.
Resources
The router supports other macros besides those for HTTP verbs like get, post, and put. The most important among them is resources
, which expands out to eight endpoints.
Let’s add a resource to the config/routes.cr
Then go to the root of your project, and run maze routes
It outputs the standard matrix of HTTP verbs, controller, action, pipeline, scope, and URI pattern.
Scoped Routes
Scopes are a way to group routes under a common path prefix and scoped set of pipeline handlers. We might want to do this for admin functionality, APIs, and especially for versioned APIs. Let’s say we have user-generated posts on a site, and that those posts first need to be approved by an admin. The semantics of these resources are quite different, and they might not share the same controller. Scopes enable us to segregate these routes.
The paths to the user facing reviews would look like a standard resource.
But for the admin console paths could be prefixed with /admin.
We accomplish this with a scoped route that sets a path option to /admin like this one. For now, let’s not nest this scope inside of any other scopes (like the scope "/", HelloWeb provides in a new app).
Excluding and Including Actions
Sometimes you want to use resources
as a shortcut for defining routes, and with that you don't want to define routes for actions that don't exist yet. Resources
allow you to pass another argument, only:
or except:
to either include actions or exclude them from being generated.
This will define the following routes:
Last updated