MC Press Online

Saturday, Jun 24th

Last updateFri, 23 Jun 2017 1pm

You are here: Home ARTICLES Programming Programming - Other General TechTip: Sinatra Sings, Ruby Plays

Programming / General

TechTip: Sinatra Sings, Ruby Plays

Support MC Press - Visit Our Sponsors

NEW BOOK!

Flexible Input, Dazzling Output with IBM i


ORDER YOUR COPY

*******************

Click for this Month's

Bookstore Special Deals

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 and www.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 at abartell@krengeltech.com.

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