Sinatra Sings, Ruby Plays
Originally published: MCPress Online on 3/6/15.
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
require 'sinatra' get '/hi' do "Hello World!" end
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.
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 22.214.171.124 - - [23/Jan/2015 11:31:33] "GET / HTTP/1.1" 404 439 0.0394 126.96.36.199 - - [23/Jan/2015 11:31:33] "GET /__sinatra__/404.png HTTP/1.1" 200 18893 0.0071 188.8.131.52 - - [23/Jan/2015 11:31:34] "GET /favicon.ico HTTP/1.1" 404 450 0.0165 184.108.40.206 - - [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.
- Call web APIs from RPG
- Process XML and JSON
- Offer web services
Affordable IBM i cloud hosting
CyberSource Toolkit for i
- Process credit cards from native RPG
- Integrate CyberSource payment services
Need some assistance with Ruby? We can help. Contact us below.