Automatic REST Crud
In cborm 2.5 we introduced the Base Resource Handler for ORM entities. This base handler will create a nice framework for creating a RESTFul CRUD for your entities based on ColdBox Resources: https://coldbox.ortusbooks.com/the-basics/routing/routing-dsl/resourceful-routes
This means that we will create all the boilerplate code to list, show, create, update and delete your entities. Including relationships, validation, population, pagination and different ways to render (include/exclude) your data thanks to Mementifier. Get ready to start creating RESTFul services in no time!
You must be using ColdBox 6 for this feature to work
Settings
To start off with our resources support, you can start by adding the following settings to your config/Coldbox.cfc in the moduleSettings.cborm
struct:
eventLoader
: If enabled, upon application startup it will register all the following events for EVERY entity managed by HibernatemaxRows
: By default the cborm resource handler will paginate results, you can choose your pagination window here.maxRowsLimit
: By default it will not allow more than 500 records to be returned from the listing method. However, you can make this 0 or anything you like.
Registered Events
Once the resource event loader is activated, it will ask Hibernate for all the managed entities and register the following events in ColdBox so you can create interceptors that listen to them:
pre{entityName}List
post{entityName}List
pre{entityName}Save
post{entityName}Save
pre{entityName}Show
post{entityName}Show
pre{entityName}Update
post{entityName}Update
pre{entityName}Delete
post{entityName}Delete
Define Your Entities
It's time to focus on your entities now. Build out the properties, relationships, methods and make sure you add the mementifier and validation settings so our base handler can use it for validation and for data rendering:
The mementifier is a critical piece as it will allow you to pass in to the rest service includes
and excludes
so you can decide what will be marshalled out of the service.
Register The Resource
Now that you have finished your entities, you can now register the resources you will be managing. Open your config/ColdBox.cfc
or your Module's router:
This will generate all the resourceful routes as per the ColdBox Resources Routing:
Create the Handler
Now that your resources are created, create the handler that matches the resource. You can use CommandBox: coldbox create handler settings
or just create the file manually. Make sure it extends our cborm resource handler: cborm.models.resources.BaseHandler
The Base Handler requires 1 injection and at most two settings for it to work properly:
ORM Service Injection
You will inject the orm service that will be providing the operations on your RESTFul service, this can be a virtual service a concrete service.
Private Properties
You have two private properties you can set:
sortOrder
: The default sorting order string:permission, name, data desc, etc
entity
: The name of the entity this resource handler controls. Singular name please.
Generated Actions
The base resource handler will generate the following methods for you that will match the routes that you registered via the resources()
method.
Action | HTTP Method | Purpose | Route | Throws |
| GET | List resources |
| none |
| POST | Create a resource |
| Validation |
| GET | Get one resource |
| EntityNotFound |
| PUT/PATCH | Update a resource |
| EntityNotFound, Validation |
| DELETE | Delete a resource |
| EntityNotFound |
Consistent Output
REST is all about uniformity and consistency. The output packet produced by any of the actions you create or use, will adhere to the following schema:
Utility Methods
We also offer you a few utility methods once you start overriding the action methods:
Action Parameters
Each action can take in not only the incoming parameters that your entities require for population and saving, but also we have added a few to help you:
Index()
Parameter | Type | Default | Description |
|
|
| One or a list of properties you want to include in the output packet apart from the default Includes defined in your entity. Adheres to the mementifier |
|
|
| One or a list of properties you want to exclude in the output packet apart from the default excludes defined in your entity. Adheres to the mementifier |
|
|
| If true, it will ignore all default includes and excludes and ONLY use the includes and excludes you pass. Adheres to the mementifier |
|
|
| The sort ordering you want to apply to the result set. Adheres to the criteria query sort() method |
|
|
| Pagination is included, so you can pass in the page of records you would like to visualize. |
Create()
Parameter | Type | Default | Description |
|
|
| One or a list of properties you want to include in the output packet apart from the default Includes defined in your entity. Adheres to the mementifier |
|
|
| One or a list of properties you want to exclude in the output packet apart from the default excludes defined in your entity. Adheres to the mementifier |
|
|
| If true, it will ignore all default includes and excludes and ONLY use the includes and excludes you pass. Adheres to the mementifier |
Show()
Parameter | Type | Default | Description |
|
|
| One or a list of properties you want to include in the output packet apart from the default Includes defined in your entity. Adheres to the mementifier |
|
|
| One or a list of properties you want to exclude in the output packet apart from the default excludes defined in your entity. Adheres to the mementifier |
|
|
| If true, it will ignore all default includes and excludes and ONLY use the includes and excludes you pass. Adheres to the mementifier |
|
|
| The incoming ID of the resource to show |
Update()
Parameter | Type | Default | Description |
|
|
| One or a list of properties you want to include in the output packet apart from the default Includes defined in your entity. Adheres to the mementifier |
|
|
| One or a list of properties you want to exclude in the output packet apart from the default excludes defined in your entity. Adheres to the mementifier |
|
|
| If true, it will ignore all default includes and excludes and ONLY use the includes and excludes you pass. Adheres to the mementifier |
|
|
| The incoming ID of the resource to show |
Delete()
Parameter | Type | Default | Description |
|
|
| The incoming ID of the resource to show |
Overriding Actions
You can also override the actions we give you so you can spice them up as you see fit. A part from calling the super class to finalize your REST call, we have allso added some extra arguments to your base actions so you can have fine-grained control of populations, validations, querying and much more.
index() Arguments
Parameter | Type | Default | Description |
|
|
| You can pass your own criteria object that we will use to execute to retrieve the records |
|
|
| If you pass in a results struct, then you did the search and we will just marshall the results using pagination. The struct must contain the following:
|
create() Arguments
Parameter | Type | Default | Description |
|
|
| The arguments you want to send into the |
|
|
| The arguments you want to send into the |
update() Arguments
Parameter | Type | Default | Description |
|
|
| The arguments you want to send into the |
|
|
| The arguments you want to send into the |
Happy Coding!
Last updated