Project

cloak_id

0.0
No commit activity in last 3 years
No release in over 3 years
The cloak id gem allows developers to easily hide the actual (database) id of resources through obfuscation.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

> 4.0
 Project Readme

CloakId

Hide your database ids from users of your webapp.

Using sequential ids makes predicting the ids of other resources in your application simple, and can provide details about how your app is growing (how many users, etc.) to current and potential competitors. Obfuscating identifiers isn't meant to be a primary means of providing security, but it can help to keep confidential information from being completely public.

Making use of the gem will replace the identifier in URLs: e.g. http://my.railsapp.com/users/U3OFSP23

as well as in JSON representations of resources

e.g. {"id":"U3OFSP23", "name": "Joe User", "active":true}

Installation

Add this line to your application's Gemfile:

gem 'cloak_id'

And then execute:

$ bundle

Or install it yourself as:

$ gem install cloak_id

To seed the random key used during cloaking, execute the following command

rails generate cloak_id::install

This command is optional, but if it not done then your application will make use of a global default key, leading to identical cloaked ids being generated for identically named models. This value will be used to seed the transformation, and help ensure the quality of the obfuscation.

Usage

In your model files (that inherit from Active Record) add the 'cloak_id' call to enable the obfuscating of the ids.

class User < ActiveRecord::Base
  cloak_id
end

What the gem does

The cloak_id gem provides a way to "cloak" your identifiers. This doesn't provide any real security, but instead makes it less obvious to what the underlying database id of a resource really is. This is desirable in cases where you want to make it more difficult for users to guess identifiers, or for observers to judge how fast your application is growing.

This technique does not provide any real security - it only makes it more difficult for casual observers to guess resource identifiers.

The logic behind the transformation is to use a prime number to generate a simple, yet reversible hash of the database id. That newly obscured hash is then encoded as a string, to further hide its meaning. This will happen when generating forms from ActiveRecords (when using the entire object or the to_param call), as well as when encoding the object in JSON format.

The obfuscation techinque is largely based on the one used by the Python Project "opaque_id" (https://github.com/marekweb/opaque-id) by Marek Z., and released under the MIT License.

Customizing your cloaking

The cloak_id method call takes an option hash that controls how the cloaking occurs:

option name description
key The key to use for obfuscating identifier. This can be either an integer or a string. This is an optional parameter. If the user does not provide one, then this will be based on the name of the model itself. This means that "common" models (e.g. User) may have the same obfuscated values across different web apps. This can be prevented by passing in a value to this parameter or by setting a seed (by running rails generate cloak_id install)
prefix Obfuscating the identifier results in a string. To better help developers understand what type of resource if being identified, an optional prefix may be specified. If none is provided, then a prefix will be created based on the name of the model. This prefix must start with a alphabetic character.

###Examples This line will result in a cloaked identifier encoded with a specifically defined key, and the resulting cloaked identifier will begin with UU.

cloak_id key:'SampleKey', prefix:'UU'

After this call, most instances of the id will be replaced with the cloaked id. This includes calls to serialize the resoruce as XML or JSON, as well as when it is used as a parameter in forms, or in RESTful API calls. The "id" call will not change, as this gem does not actually change the underlying id of the object. Just how it is displayed.

To access the cloaked id directly, you may call self.cloaked_id

Retrieving objects from the database from cloaked ids can happen in two ways

ClassName.find(cloaked_id)

or

ClassName.find_by_cloaked_id(cloaked_id)

Objects that have had their id cloaked will use a "smart" find method. This method will inspect the id to see if it appears to be a cloaked id (all cloaked ids must start with an alphabetic character), and if it does, then it will use the find_by_cloaked_id method. If it is numeric, or if it does not begin with the expected prefix, then it will fall back to use the out-of-the-box find functionality.

Because of this logic, most cases will work without any changes to the code that makes use of the cloaked resource.

Contributing

  1. Fork it ( https://github.com/elleleb/cloak_id/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request