Skip to content
/ iri Public

Simple and immutable URI/URL builder in Ruby, with a fluent interface

License

Notifications You must be signed in to change notification settings

yegor256/iri

Folders and files

NameName
Last commit message
Last commit date

Latest commit

6dbaa43 · Mar 29, 2025
Feb 23, 2025
Feb 19, 2025
Mar 26, 2025
Mar 25, 2025
Feb 22, 2025
Jun 4, 2023
Mar 2, 2025
Apr 17, 2019
Mar 25, 2025
Mar 1, 2025
Mar 27, 2025
Mar 29, 2025
Jan 3, 2025
Feb 27, 2025
Mar 10, 2025
Feb 21, 2025
Feb 22, 2025
Jan 27, 2025
Sep 22, 2022

Repository files navigation

Immutable URI Builder for Ruby

EO principles respected here DevOps By Rultor.com We recommend RubyMine

rake Gem Version Maintainability Yard Docs License Test Coverage Hits-of-Code

The class Iri helps you build a URI and then modify its parts via a simple fluent interface:

require 'iri'
url = Iri.new('http://google.com/')
  .append('find').append('me') # -> http://google.com/find/me
  .add(q: 'books about OOP', limit: 50) # -> ?q=books+about+OOP&limit=50
  .del(:q) # remove this query parameter
  .del('limit', 'speed') # also remove these two
  .over(q: 'books about tennis', limit: 10) # replace these params
  .scheme('https') # replace 'http' with 'https'
  .host('localhost') # replace the host name
  .port('443') # replace the port
  .fragment('page-4') # replaces the fragment part of the URI, after the '#'
  .query('a=1&b=2') # replaces the entire query part of the URI
  .path('/new/path') # replace the path of the URI, leaving the query untouched
  .cut('/q') # replace everything after the host and port
  .to_s # convert it to a string

The full list of methods is here.

Install it:

gem install iri

Or add this to your Gemfile:

gem 'iri'

Pay attention, it is not a parser. The only functionality this gem provides is building URIs.

It is very convenient to use inside HAML, for example:

- iri = Iri.new(request.url)
%a{href: iri.over(offset: offset + 10)} Next Page
%a{href: iri.over(offset: offset - 10)} Previous Page

Of course, it's better to create the iri object only once per request and re-use it where you need. It's immutable, so you won't have any side-effects.

PS. See how I use it in this Sinatra web app: yegor256/0rsk.

How to contribute

Read these guidelines. Make sure your build is green before you contribute your pull request. You will need to have Ruby 2.3+ and Bundler installed. Then:

bundle update
bundle exec rake

If it's clean and you don't see any error messages, submit your pull request.