Skip to content
This repository has been archived by the owner on Dec 29, 2024. It is now read-only.
/ passrock Public archive

Passrock Ruby Client

License

Notifications You must be signed in to change notification settings

prashantrajan/passrock

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Passrock

Gem Version Code Climate

Ruby client library for programmatic access to the Passrock Binary Database.

This library adheres to SemVer. Pre v1.0.0 is considered alpha level software.

Installation

Add this line to your application's Gemfile:

gem 'passrock'

And then execute:

$ bundle

Usage

Plain Ol' Ruby (PORO)

require 'passrock'

passrock_db = Passrock::PasswordDb.new(:password_db => '/path/to/passrock_db_dir', :private_key => 'your private key')
passrock_db.secure?('password') # => false
passrock_db.insecure?('PASSWORD') # => true

Ruby on Rails

This library provides a custom ActiveModel validation:

# Configure: config/initializers/passrock.rb
Passrock.configure do |config|
  config.password_db = '/path/to/passrock_db_dir'
  config.private_key = 'your private key'
end

# Model
# e.g. app/models/user.rb
validates :password, :passrock_secure => true
# Customize the error message (see: http://guides.rubyonrails.org/i18n.html#error-message-scopes)
# e.g. config/locales/en.yml
activerecord:
  errors:
    messages:
      passrock_secure: "appears to be a commonly used password"

Contributing

  1. Fork it
  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 new Pull Request

Specs

To run the spec suite:

  bundle install
  cp .env.example .env # and change the env values
  bundle exec rake spec