Batten down the hatches - Server-Side Security of OpenEdge Mobile

Default Blog Top Image
by Gary Calcott Posted on March 28, 2013

In part one of our look at security on OpenEdge Mobile we focused on making the client-side secure. As promised, in this short blog, we’ll take a deeper dive into the server-side of OpenEdge Mobile.

First of all, let’s briefly review the architecture of OpenEdge Mobile:

Progressblogimage

The JavaScript Data Object (JSDO) facility is the run-time facility of OpenEdge Mobile which enables mobile apps to easily communicate with back-end services. Under the covers, the protocol between the mobile client and the Web Server is HTTP(S)/REST. Mobile Services are securely housed in the Web Server and in-turn, access Mobile Interfaces on the OpenEdge AppServer to execute business logic.

On the Web Server Tier, OpenEdge provides application security templates which the application developers and production admins can customize to protect resources (a.k.a. Mobile Web Applications, see Figure 1 above). Mobile Web Apps are protected via similar mechanisms. The templates configure the industry standard Spring Security Version 3.1 framework which is co-packaged with the OpenEdge application to manage security for the mobile application’s REST resources.

Spring security is a comprehensive, peer-reviewed framework and having it tightly integrated with the OpenEdge platform is a huge benefit for system architects and developers. No longer do architects and developers need to develop “home grown” solutions to provide authentication and authorization, as they can now fully leverage the respected and well documented Spring framework for their security needs. The Spring templates are located in the WEB-INF directory of an OpenEdge project in Progress Developer Studio for OpenEdge.

Here’s a snippet of the web.xml file contained in the WEB-INF directory:

Progressblogimage2

Note that we’ve enabled an authentication model of “anonymous” here. Let’s drill down one level to explore appSecurity-anonymous.xml:

Progressblog3

REST Manager (or ‘RESTMAN’) is an administration utility for managing the lifecycle of mobile applications. We’ll make ‘RESTMAN’ the topic of a future blog. Let’s move down the file….

progressblog4

Here we can see a first introduction of how we can configure the generation and transportation of an authenticated user token into an OpenEdge Client Principal object which can be used on the AppServer Tier for handling fine-grained access to protected resources. Additionally we can see an indication of how Cross-origin Resource Sharing (CORS) can be configured to enable cross-domain access from (mobile) JavaScript clients.

Moving down the file further, we can see how we can evaluate access to protected resources:

progressblog5

This has been a very brief tour of server-side security in OpenEdge 11.2. As previously mentioned, in a future post we’ll dissect some of the capabilities outlined above, e.g. the ‘RESTMAN’ utility. We’ll also explore how OpenEdge enables Single-Sign-On across the end-to-end platform for secure access to protected resources.

 


Gary Calcott
Gary is responsible for developing go-to-market strategies, providing technical marketing support and developing best practice materials for the Rollbase aPaaS platform.
More from the author

Related Tags

Related Articles

The Key Benefits of CI/CD - Continuous Integration and Delivery
Learn about the ways Progress Professional Services deploys CI/CD to help OpenEdge customers and how they can help your organization.
Using OpenTelemetry Metrics Support in OpenEdge on Azure
The OpenEdge 12.6 release introduced support for OpenTelemetry Metrics with OpenEdge Command Center 1.2.
Prefooter Dots
Subscribe Icon

Latest Stories in Your Inbox

Subscribe to get all the news, info and tutorials you need to build better business apps and sites

Loading animation