1 Gems and Bundler
Code reuse is a deciding factor for programmer productivity. In Ruby
the unit of reuse is called a
rubygems is the package manager for ruby,
it let's you install gems on your system.
A gem has a name (e.g.
rake) and a version number (e.g.
It can be written in plain ruby or sometimes in ruby and c. Many gems
depend on system libraries that need to be installed before the gem can
be installed. For example the rmagick
gem for image manipulation needs the library
So most of the time installing a gem is as simple as
> gem install rails_best_practices Successfully installed rails_best_practices-1.15.7 Parsing documentation for rails_best_practices-1.15.7 Installing ri documentation for rails_best_practices-1.15.7 Done installing documentation for rails_best_practices after 2 seconds 1 gem installed
But sometimes you have to do other installations first. On your development machine this might look like this:
# install node on a mac > brew install nodejs > gem install uglifier
Sometimes you need to set include paths when compiling the c-part of the gem, e.g.:
> gem install eventmachine ... error messages ... In file included from binder.cpp:20: ./project.h:116:10: fatal error: 'openssl/ssl.h' file not found #include <openssl/ssl.h> ^ > brew install openssl > gem install eventmachine -- --with-cppflags=-I/usr/local/opt/openssl/include
In production you probably have to deal with Linux, and you may not have the right permissions to install system libraries. A typical example would be:
$dev> ssh my.production.machine $production> sudo apt-get install libmagick++-dev $production> gem install rmagick $production> gem install paperclip
Now that you have installed the gem once by hand you can be sure that it can also be reinstalled by bundler.
1.2 dependency hell
For a rails project you will be using a lot of gems. This will lead to two problems:
- dependency resolution: gem A depends on version 1.1 of gem C, while gem B wants at least version 1.5. You need to find the right version of every gem in your project that actually fits together
- different installation: when deploying to a production server, or even just when shareing code with other developers you need to make sure that the same constellation of gems and versions is used on every machine
1.3 bundler saves us
Bundler is the name of the tool that saves us from dependency hell.
Bundler is itself a gem, so you install it with
gem install bundler.
Beware: the command you will be using called
bundle, not bundler.
There is how it works: In every ruby project you write
Gemfile in which you define which gems and (to a certain degree) which versions you want.
When you run
bundle install bundler will:
- read the Gemfile,
- pick out compatible versions of all the gems (if possible),
- install all these gems
The lock-file contains a complete list of all the gems necessary for your project, and their version numbers. These are now locked down, and will not change!
When deploying to a new development machine or the production server,
bundle install and the exact same versions are now installed.
1.4 defining versions
In the Gemfile you can specify which versions should be used. But don't overdo it! Bundler does a good job picking versions, if you specify every version number by hand you are doing too much work.
Some examples of the different ways of specifying version number and source:
# Gemfile source 'https://rubygems.org' ruby '2.3.1' gem 'rails', '~> 5.0.0', '>= 126.96.36.199' gem 'sqlite3' gem 'puma', '~> 3.0'
~> will only allow an increase in the
last (right most) number, so
~> 5.0.0 does allow
188.8.131.52 but not
This is called a pessimistic version constraint, read more about
it in the rubygem documentation.
1.5 gems and rails
The configuration for a gem is found in the initializer directory,
for example for
devise the configuration file would be
A gem may install new generators for rails, run
rails generate to see a list
of available generators.
A gem may install rake tasks, run
rails -T to see a list.
2 Some Gems
2.1 Frontend Stuff for rails
In your gemfile:
source 'https://rails-assets.org' do gem 'rails-assets-bootstrap-sass' gem 'rails-assets-angular' gem 'rails-assets-leaflet' end
- gem autoprefixer-rails - Parse CSS and add vendor prefixes to CSS rules using values from the Can I Use website. Search for libraries at https://rails-assets.org
2.2 Graphing, Graphics, WebGL
- gem novus-nvd3-rails A reusable chart library for d3.js
- gem gruff create PNG graphs (e.g. for reuse in non-html documents)
- gem rmagick Ruby bindings for ImageMagick image manipulation library
- gem rqrcode create QR codes
2.3 File Upload
Uploading Pictures and displaying them is a common task with two good solutions:
Both use the library ImageMagick:
- gem rmagick image processing with image magick
You might also want to know how to use ImageMagick on the UNIX commandline:
- command line tool convert to convert to different formats and
- command line tool mogrify to resize, blur, crop, draw on, flip, join, ... an image and overwrite it.
- gem devise for login,
- gem omniauth to integrate authentication methods.
- gem cancancan if you need roles and permissions
You don't want the database keys to be visible in your URLs? Use Friendly IDs instead:
- gem friendlyid
2.6 Parsing xml and html
- gem nokogiri
(this is also used by capybara)
2.7 Parsing Markdown
Letting users enter HTML is a dangerous idea - it's really hard to avoid the security problems. An alternative is to let them enter a simpler markup language, like Markdown. You store the markdown in your database, and convert it to HTML when displayed using a gem:
Do you need to displaying a lot of items? Use a pagination gem to go through them page by page:
You need to search in more than just one attribute of your model? use a search gem:
- gem ransack for building search fields
- gem pg_search uses postgresql's fulltext search
- gem searchkick uses elasticsearch with many more options for fulltext search, e.g. for misspellings
- other gems in category rails_search of the ruby toolbox
2.10 Activity Stream
If you want to give users an overview of what happened recently you can use an activity stream, similar to what you see in facebook.
- gem public_activity
2.11 Admin Backend
Create a Backend for manipulating data with a few lines of code:
- gem activeadmin
2.12 Sending Mail
To send mail from Rails use ActionMailer.
To see the generated mails in your web browser instead of sending them, use the gem letter_opener
2.13 HTTP Requests
This might be handy for downloading from Webpages or APIs
- gem curb - the http library curl for ruby
2.14 Using APIs
- gem octokit - for github
- gem twitter
- gem gravatar
- gem koala - for facebook
- gem barometer - A multi API consuming weather forecasting superstar
- gem gmaps4rails
sometimes you want to convert longitude/latitude coordinates to street addresses, or the reverse
- gem geocoder
- gem factory_girl for creating test data.
- gem capybara as the "browser" for acceptance tests, with
2.17 Understanding your Code better
- gem better_errors
- gem meta_request - supporting gem for Rails Panel, a Google Chrome extension for Rails development
- gem annotate - inserts the db schema as comments in your model.rb file
- gem railroady - UML diagram generation for Rails projects, capable of analyzing existing models and controllers
- gem bullet - helps you improve your usage of activerecord queries
- gem metric_fu - many code metrics for your rails project
- gem rails_best_practices
- gem rubocop - static code analyzer
- gem derailed_benchmarks
- gem brakeman - checks for security vulnerabilities