The best Rails 3.1 and Rails 3.2 forum engine. Ever.
Pull request Compare This branch is even with phlipper:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Failed to load latest commit information.

Forem - using the forem-theme-twist theme

Forem, using the forem-theme-twist theme

For other screenshots, please see the doc folder

Forem Build status

"NO U!"

Forem is an engine for Rails that aims to be the best little forum system ever. The end goal is to have an engine that can be dropped into an application that provides the basic functionality of forums, topics and posts.

We are currently undergoing large changes. If you want to use this project, please keep this in mind. You can view a list of the intended changes on our Version 1.0 Roadmap


A demo application can be found at, and the source for this application can be found on the repository


Installing Forem is easy.

Specify Gem dependencies

gem 'forem', :git => "git://"

And then one of kaminari or will_paginate

gem 'kaminari', '0.13.0'
# OR
gem 'will_paginate', '3.0.3'

Run the installer

Ensure that you first of all have a User model and some sort of authentication system set up. We would recommend going with Devise, but it's up to you. All Forem needs is a model to link topics and posts to.

Run rails g forem:install and answer any questions that pop up. There's sensible defaults there if you don't want to answer them.

And you're done! Yaaay!

For more information on installing, please see the "Installation" wiki page


Here's a comprehensive list of the features currently in Forem:

If there's a feature you think would be great to add to Forem, let us know on the Issues page

Auto Discovery Links

If you would like to add auto discovery links for the built in forum Atom feeds, then add the following method inside your <head> tag:

<%= forem_atom_auto_discovery_link_tag %>

View Customisation

If you want to customise Forem, you can copy over the views using the (Devise-inspired) forem:views generator:

rails g forem:views

You will then be able to edit the forem views inside the app/views/forem of your application. These views will take precedence over those in the engine.

Extending Classes

All of Forem’s business logic (models, controllers, helpers, etc) can easily be extended / overridden to meet your exact requirements using standard Ruby idioms.

Standard practice for including such changes in your application or extension is to create a directory app/decorators. place file within the relevant app/decorators/models or app/decorators/controllers directory with the original class name with _decorator appended.

Adding a custom method to the Post model:

# app/decorators/models/forem/post_decorator.rb

Forem::Post.class_eval do
  def some_method

Adding a custom method to the PostsController:

# app/decorators/controllers/forem/posts_controller_decorator.rb

Forem::PostsController.class_eval do
  def some_action

The exact same format can be used to redefine an existing method.


We currently have support for the following languages:

  • Brazillian (pt-BR)
  • Bulgarian
  • Chinese (zh-CN)
  • Dutch
  • English
  • Farsi (Persian)
  • German
  • Italian
  • Polish
  • Portuguese (pt-PT)
  • Russian
  • Spanish
  • Lithuanian

Patches for new translations are very much welcome!


File an issue and we'll get around to it when we can.

Developing on forem

Forem is implemented as a Rails engine and its specs are run in the context of a dummy Rails app. The process for getting the specs to run is similar to setting up a regular rails app:

bundle exec rake forem:dummy_app

Once this setup has been done, Forem's specs can be run by executing this command:

bundle exec rspec spec

More information can be found in this issue in the bugtracker.

If all the tests are passing (they usually are), then you're good to go! Develop a new feature for Forem and be lavished with praise!


  • Ryan Bigg
  • Philip Arndt
  • Josh Adams
  • Adam McDonald
  • Zak Strassburg
  • And more

Places using Forem

If you want yours added here, just ask!