The gem provides an interface to manage mailing lists, scheduling of email mailings, subscribe/unsubscribe from lists by contacts, and view reports of bounces and possible track views of emails. Currently unsubscribes a contact from all email lists. We might add a subscription management interface later to let a user unsubscribe selectively from a selection of mailing lists. An interface is provided to register mailable objects such as a newsletter from our newsletter gem. You can see how to do this in the Mailable Registry: app/models/mail_manager/mailable_registry.rb
Also available as a stand alone application called iReach including the newsletter manager (newsletter template and elements manager, simple wysiwyg interface to create newsletters, and newsletter archive) and user access management. There is also the i_reach gem that ties mail_manager and newsletter together into one gem.
- Rails 3.2.x (currently tested with rails 3.2.21)
- Ruby 2.1.5 (currently tested with 2.1.5, we have tested against 1.9.3, but ruby devs no longer support it)
- Delayed::Job - (currently the only queue job runnerwe support)
- RVM - How we control our ruby environment (mainly concerns development)
- currently we use github/git for our repository
Using bundler, edit your Gemfile.. add a one of the following lines:
gem 'mail_manager', '~>3' # this points to the latest rails stable 3.2.x version # OR gem 'mail_manager', git: 'https://github.com/LoneStarInternet/mail_manager.git', branch: 'rails3.2.x' # for the bleeding edge rails 3.2.x version
Then run bundle install:
Generate and configure the mail manager settings file at config/mail_manager.yml: (replace table prefix with something... or nothing if you don't want to scope it)
Generate delayed_jobs (this is the only job runner we support right now):
rails g delayed_job:active_record
NOTE: you need to create an email account that will receive bounces from your mailings (and allow POP)... configure in the following file:
Add your routes to config/routes.rb (you can say where with at: '/path')
mount MailManager::Engine, at: '/admin/mail_manager'
This is where amost all of your configuration options are for this gem... current generator will add documentation to it (preserving your current settings) .. we'll probably want to upgrade to something like: AppConfig gem
You can generate this file like above (where table_prefix is for prefixing table names):
- This generator adds settings documentation to the yml file
- You can override values with a config/mail_manager.local.yml
- For a full description See the documentation
Securing your App
We implemented CanCan. If you'd like to secure your actions to certain users and don't currently have any authorization in your app, you can follow the following steps if you want an easy config.. or you could make it more finely grained.. currently its all or nothing.
If you wish to contribute, you should follow these instructions to get up and running: See the wiki
Please write tests for any new functionality and run the test suite to make sure all tests are passing.
Thanks in advance for your contributions to the project!