Low commit activity in last 3 years
No release in over a year
Adds custom handling for database uniqueness constraints to ActiveRecord.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 2.0
~> 13.0
~> 3.0
~> 1.56
 Project Readme

Has Unique Attribute

Applies validation errors to ActiveRecord model attributes when database uniqueness constraints fail.

NOTE: At the moment, only PostgreSQL is supported.

Installation

Add this line to your application's Gemfile:

gem 'has_unique_attribute'

And then execute:

$ bundle

Or install it yourself as:

$ gem install has_unique_attribute

Then, make it available to your models:

class ApplicationRecord < ActiveRecord::Base
  extend HasUniqueAttribute

  # ...
end

Usage

Use the has_unique_attribute helper to add a handler to your model:

class User < ApplicationRecord
  has_unique_attribute :email
end

This will match errors on an index name index_users_on_email and add validation errors to the email attribute.

Specifying an Index Name

To customize the name of the index matched, use the index option:

class User < ApplicationRecord
  has_unique_attribute :email, index: 'custom_index_name'
end

Customizing the Error Message

To customize the error message applied, use the message option:

class Project < ApplicationRecord
  has_unique_attribute :name, message: 'already exists'
end

It's also possible to specify an I18n key for a translation:

class Project < ApplicationRecord
  has_unique_attribute :name, message: :duplicate
end

By default, the :taken error translation is applied to attributes. This mimics the behaviour of the uniqueness validator.

Handling Composite Indexes

Composite (multi-column) indexes will need the index name to be specified explicitly:

class Membership < Application
  belongs_to :user
  belongs_to :club

  has_unique_attribute :user, index: 'index_memberships_on_club_id_and_user_id', message: 'is already a member'
end

The error is only applied to the specified attribute.

Caveats

  • Errors triggering the has_unique_attribute behaviour happen further into the save process than standard validations (after validation and before_save callbacks are fired). Behaviours that should not be executed if a uniqueness constraint fails should be placed after_save or after_commit, or be transactional (and rolled-back as part of the transaction).
  • The create_or_find_by methods require that an ActiveRecord::RecordNotUnique error be raised, which has_unique_attribute consumes and does not rethrow.

Development

After checking out the repo, run bin/setup to install dependencies. Then, run bin/rspec to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/mintyfresh/has_unique_attribute.