TechTip: Sinatra Sings, Ruby Plays

General
Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

Looking to develop your first web app with Ruby? Try Sinatra. Sinatra is a DSL for quickly creating web applications in Ruby with minimal effort.

 

Frank Sinatra—classic music you can tap your foot to while coding. Sinatra the web framework? That's something you can use to quickly create a web app in Ruby with minimal effort. My history with Ruby-based web apps leans more on the RubyOnRails web framework.A framework that is beyond excellent, though, also takes time to learn how to fully use it. Sinatra on the other hand doesn't do as much "magic" as Rails. By "magic," I mean the things that just work and you don't know why. Sinatra simply has more in plain view, like how routing of requests works. In this article, I'll introduce you to Sinatra on IBM i and explain how to install and use it.

 

First things first. We need to install the sinatra Gem. I always like to store one-off tests like this in their own Gem set. A Gem set is simply a different IFS directory where Gems can be installed other than the default of /PowerRuby/prV2R0/lib/ruby/gems/2.0.0. Run the below two commands in a PASE shell (i.e., CALL QP2TERM) to create a new Gem set directory and then set the GEM_HOME to that same directory.

 

$ mkdir -p /home/<user>/gemsets/sinatra_ibm_db

$ export GEM_HOME=/home/<user>/gemsets/sinatra_ibm_db

 

Next we obtain the sinatra Gem using the gem install command, as shown below. Notice it installed the rack-protection Gem also (as this is a dependency of Sinatra, the beauty of a package manager like RubyGems).

 

$ gem install sinatra

Fetching: rack-protection-1.5.3.gem (100%)

Successfully installed rack-protection-1.5.3

Fetching: sinatra-1.4.5.gem (100%)

Successfully installed sinatra-1.4.5

2 gems installed

 

For starters, we're going to do a dead simple web application that conveys the colloquial "Hello World!" response. Open your favorite IFS editor and paste the following code into a file named hi.rb. Note, I put the hi.rb file in directory /home/aaron/sinatra_db.

 

require 'sinatra'

get '/hi' do

"Hello World!"

end

 

The require statement is like an RPG /copy and brings in the sinatra Gem capabilities. The get portion is actually a Ruby method call with a Ruby block. Method calls in Ruby can omit the open and close parentheses you see in other languages. The '/hi' portion is the single parameter being passed, and the do through the end is the Ruby block. Ruby blocks are a much longer discussion, though you can learn more here. Essentially, this syntax is declaring that when a request comes in for http://mydomain.com/hi, it will get processed by this block of code and output "Hello World!"

 

To test our new program, we will need to start the Sinatra web server. Before doing that, we need to tell the Ruby runtime about our newly created Gem set by altering the GEM_PATH environment variable, as shown below.

 

$ export GEM_PATH=/PowerRuby/prV2R0/lib/ruby/gems/2.0.0:/home/<user>/gemsets/sinatra_ibm_db

 

Now we can invoke the hi.rb program with the ruby binary and pass in the IP address we want it to listen on using the -o option, as shown below. Note, 0.0.0.0 declares to listen on all interfaces. This is the lazy way to start it. If we left the -o0.0.0.0 off, it would instead use localhost, which means the server is only available from the local machine (i.e., the IBM i) and therefore you wouldn't be able to access it from your laptop.

 

$ ruby hi.rb -o0.0.0.0

== Sinatra/1.4.5 has taken the stage on 4567 for development with backup from Thin

Thin web server (v1.6.2 codename Doc Brown)

Maximum connections set to 1024

Listening on 0.0.0.0:4567, CTRL+C to stop

 

As you can see above, there are now some additional log statements sent to the display to tell us the web server is up and listening on 0.0.0.0:4567. Now open your browser and point it at URL http://<ibmi_ip>;:4567, and replace <ibmi_ip> with that of your own. If you don't enter a path on the URL, then you should get a message similar to the one below, which is Sinatra's humorous way of relaying an HTTP 404 Not Found message.

 

030615BartellFigure1 404

Figure 1: Sinatra returns a humorous HTTP 404 message when path is not found.

 

Adding /hi to the end of the URL will produce a successful response from our small web app, and you should now see Hello World!, as shown below.

 

If you go back to your PASE session, you will see a log for each one of your requests to the server, as shown below. This is helpful for debugging purposes once your requests get more complex.

 

 

$ ruby hi.rb -o0.0.0.0

 

== Sinatra/1.4.5 has taken the stage on 4567 for development with backup from Thin

 

Thin web server (v1.6.2 codename Doc Brown)

 

Maximum connections set to 1024

 

Listening on 0.0.0.0:4567, CTRL+C to stop

 

12.12.12.12 - - [23/Jan/2015 11:31:33] "GET / HTTP/1.1" 404 439 0.0394

 

12.12.12.12 - - [23/Jan/2015 11:31:33] "GET /__sinatra__/404.png HTTP/1.1" 200 18893 0.0071

 

12.12.12.12 - - [23/Jan/2015 11:31:34] "GET /favicon.ico HTTP/1.1" 404 450 0.0165

 

12.12.12.12 - - [23/Jan/2015 11:35:48] "GET /hi HTTP/1.1" 200 12 0.0086

 

 

Hopefully, this gives you a good jump start with Sinatra on IBM i. You can get an idea of Sinatra's popularity compared to Rails by going to TheRubyToolbox.com's "Web App Framework" category. I mention this because popularity (which includes frequency of attention by the developers) is something I use to gauge the adoption-level for any given piece of technology. You can also gain additional knowledge of the many capabilities of Sinatra via the documentation pages.

 

Aaron Bartell

Aaron Bartell is Director of IBM i Innovation for Krengel Technology, Inc. Aaron facilitates adoption of open-source technologies on IBM i through professional services, staff training, speaking engagements, and the authoring of best practices within industry publications andwww.litmis.comWith a strong background in RPG application development, Aaron covers topics that enable IBM i shops to embrace today's leading technologies, including Ruby on Rails, Node.js, Git for RPG source change management, and RSpec for unit testing RPG. Aaron is a passionate advocate of vibrant technology communities and the corresponding benefits available for today's modern application developers. Connect with Aaron via email atThis email address is being protected from spambots. You need JavaScript enabled to view it..

Aaron lives with his wife and five children in southern Minnesota. He enjoys the vast amounts of laughter that having a young family brings, along with camping and music. He believes there's no greater purpose than to give of our life and time to help others.

BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$

Book Reviews

Resource Center

  •  

  • LANSA Business users want new applications now. Market and regulatory pressures require faster application updates and delivery into production. Your IBM i developers may be approaching retirement, and you see no sure way to fill their positions with experienced developers. In addition, you may be caught between maintaining your existing applications and the uncertainty of moving to something new.

  • The MC Resource Centers bring you the widest selection of white papers, trial software, and on-demand webcasts for you to choose from. >> Review the list of White Papers, Trial Software or On-Demand Webcast at the MC Press Resource Center. >> Add the items to yru Cart and complet he checkout process and submit

  • SB Profound WC 5536Join us for this hour-long webcast that will explore:

  • Fortra IT managers hoping to find new IBM i talent are discovering that the pool of experienced RPG programmers and operators or administrators with intimate knowledge of the operating system and the applications that run on it is small. This begs the question: How will you manage the platform that supports such a big part of your business? This guide offers strategies and software suggestions to help you plan IT staffing and resources and smooth the transition after your AS/400 talent retires. Read on to learn: