## Devise based authentication for AlchemyCMS [![Build Status](https://github.com/AlchemyCMS/alchemy-devise/workflows/CI/badge.svg?branch=main)](https://github.com/AlchemyCMS/alchemy-devise/actions) [![Gem Version](https://badge.fury.io/rb/alchemy-devise.svg)](http://badge.fury.io/rb/alchemy-devise) [![Test Coverage](https://codeclimate.com/github/AlchemyCMS/alchemy-devise/badges/coverage.svg)](https://codeclimate.com/github/AlchemyCMS/alchemy-devise/coverage) [![Code Climate](https://codeclimate.com/github/AlchemyCMS/alchemy-devise/badges/gpa.svg)](https://codeclimate.com/github/AlchemyCMS/alchemy-devise) [![security](https://hakiri.io/github/AlchemyCMS/alchemy-devise/main.svg)](https://hakiri.io/github/AlchemyCMS/alchemy-devise/main) AlchemyCMS has no authentication in its core. So it is possible to bring your own authentication and use it to authorize users in AlchemyCMS. If you don't have your own authentication, you can use this gem. ## Install Just put the gem into your projects `Gemfile`. ```ruby # Gemfile gem 'alchemy-devise' ``` and run `bundle install`. Then run the installer: ```bash $ bin/rails g alchemy:devise:install ``` ## Upgrading After updating the gem, please run the installer again. ```bash $ bundle update alchemy-devise $ bin/rails g alchemy:devise:install ``` ## Devise modules Default Devise modules included in `Alchemy::User` model - `:database_authenticatable` - `:trackable` - `:validatable` - `:timeoutable` - `:recoverable` If you want to add additional modules into the Alchemy user class append them to `Alchemy.devise_modules` in an initializer in your app. ### Register additional modules example ```ruby # config/initializers/alchemy.rb Alchemy.devise_modules << :registerable ``` ### Using old encryption If your app uses an old encryption that needs the +devise-encryptable+ gem you also need to load the devise module. ```ruby # config/initializers/alchemy.rb Alchemy.devise_modules << :encryptable ``` ## Testing If you want to contribute (and you should ^_^), you need to run the tests locally on your machine. Just follow these pretty rails standard way of testing projects: ### 1. Once to prepare the test suite: Clone the repo to your local harddrive. Then ```bash $ bundle install $ rake alchemy:spec:prepare ``` ### 2. Run the tests with: ```bash $ rspec ``` _Optional:_ Even shorter ```bash $ rake ``` That prepares the database and runs the Rspec task in one step. Getting Help ------------ * If you have bugs, please use the [issue tracker on Github](https://github.com/AlchemyCMS/alchemy-devise/issues). * For Q&A and general usage, please use the [Slack](https://slackin.alchemy-cms.com) Resources --------- * Homepage: * Live-Demo: (user: demo, password: demo123) * API Documentation: * Issue-Tracker: * Sourcecode: * Slack: License ------- * BSD: