Writing an Ext.Direct Backend in Node.js
Some of you may have tried it, but there are still many developers who haven’t used this hidden gem — Sencha Ext.Direct. It was announced in 2009 and named one of the best features introduced in Ext JS 3.0.
In this article, we will introduce you to Ext.Direct and provide examples of an Ext.Direct connector and backend for Node.js.
Why You Should Consider Ext.Direct
In essence, Ext.Direct is a language and platform agnostic technology to communicate between client and server. All calls are initiated from the client-side and offer features that make coding fun again. I love to call it RPC on steroids. The most important feature is that Ext.Direct is bundled with Ext JS, so you don’t need any extra libraries on the client-side to get it running. You also have the ability to retry calls, upload files and batch transactions. You can find the full specs here.
Ext JS is server-side agnostic, so you can consume a wide range of web services. That’s why it’s such a powerful client-side framework. The most popular ways to communicate are REST, regular Ajax calls using JSON or XML data and JSONP. Although these are indeed popular and widely used, there are times when you want a more flexible and framework-friendly stack. This is where Ext.Direct shines.
Ext.Direct is used to call exposed or predefined server-side methods. The beauty is that calling any server-side procedure feels like executing any other JavaScript method locally. For example:
ExtRemote.DXStaff.create({firstName:’John’,lastName:’Smith’});
You don’t have to think about what’s in between and how to treat the backend. It’s just another object with methods you can call and get a response, regardless of whether it’s a data selection from a database or a mathematical computation. Another benefit of Ext.Direct is the very tight integration with data stores and forms. In this case, all you have to do is specify endpoint methods for CRUD actions and load/submit methods for the forms.
With Sencha Touch 2.3, Ext.Direct specs are now fully implemented with support for forms along with CRUD functionality for data stores. The same syntax can be applied for both Ext JS and Sencha Touch. Extensive documentation is provided as part of the following examples and backend connector as well as in the Sencha docs.
Current Server-side Stacks
Now, let’s look at the server-side. You may wonder whether you can leverage Ext.Direct, if your company is running PHP or Java. Ext.Direct comes with a simple implementation in PHP, and there are lots of other implementations available that are supported by our community members. For example, there are Java, Perl, Ruby, .NET, ColdFusion and Python implementations to name a few. Recently, we got a new addition to this growing list — a backend for Node.js.
Ext.Direct Connector and Backend for Node.js
If you plan to adopt Node.js for your backend solution and would like to try Ext.Direct features, you will need the Ext.Direct Connector for Node.js. It can be found in the npm repository here. You can download and install it via npm or grab the source code from github.
To help you get started, we created an extensive set of examples that you can find here. They cover the most common scenarios and widgets that our frameworks support.
In order to make it easier for developers who are not familiar with writing a Node.js backend, we also provided a full-featured web server to serve static content. As for database choices, we supplied both MySQL and MongoDB examples as well as a client for Ext JS 4.2.x and Sencha Touch 2.3.x.
The backend provides the following features:
- API auto-discovery
- Flexible server port
- logging
- Development / Production environment
- Ext.Direct router and static page serving
- File upload
- Session support
- CORS support
- Flexible response headers and age
- Both http and https protocols
After you download the Node.js backend, you will have to configure it. If you’re using MySQL, you will also have to import the DB schema (optional and used only for examples). Unless you plan to make any changes to the server scripts, everything you need can be configured from the two scripts named server-config.json
and db-config.json.
Once you’ve configured them, run this command in the terminal:
npm install
This will install all of the required modules and dependencies.
Let’s take a closer look at config options for Ext.Direct, as all of the others are self-explanatory.
Now that your server is configured, you can start it up: issue this command from the terminal (we assume that you’ve already installed the Node.js server):
node server.js
By default, the server is configured to respond to requests via port 3000. If you intend to serve from port 80 (standard http), you have to change that inside the config file and run the server with superuser privileges.
sudo node server.js
If you plan to serve the application from the same server, then place its files inside the /public
folder.
This is what the simplest HelloWorld API method would look like:
You can call this method from both Ext JS and Sencha Touch using the same syntax:
This is what the common function signature would look like:
We hope you find the examples useful. Try them out and share your feedback with us on the Sencha forum. Happy coding!
We’re excited to announce the official release of Rapid Ext JS 1.0, a revolutionary low-code…
The Sencha team is pleased to announce the availability of Sencha Architect version 4.3.6. Building…
Sencha, a leader in JavaScript developer tools for building cross-platform and enterprise web applications, is…