A platform to create, publish and edit sites
Ruby CoffeeScript CSS HTML Other
Failed to load latest commit information.
.tx add the transifex config file + add minimal French translations in or… Oct 26, 2015
app add a missing index regarding the snippets Jul 4, 2017
bin fix a bug with page redirect_url property (accepts now /) + UI specs … Feb 2, 2016
config feature: per-site asset host May 30, 2017
doc/changelogs no more rspec warnings (remove all the calls to should) Dec 18, 2014
lib Merge pull request #1211 from interhive/feature-per-site-asset-host Jun 27, 2017
public Update favicons Dec 20, 2015
spec Merge branch 'master' of github.com:locomotivecms/engine Jun 29, 2017
vendor/assets fix issue #1152: Editing images and cross origin request problem May 31, 2017
.bowerrc new version if Steam + use Bower in dev to fetch the last versions of… Nov 13, 2015
.coveralls.yml coverall integration Jan 13, 2015
.gitignore new locales: zh-CN, ru, lt + pulled changes for other locales + rely … Apr 27, 2016
.rspec specs are failing because of https://jira.mongodb.org/browse/MONGOID-… Oct 10, 2015
.travis.yml use Travis container-based infrastructure Sep 24, 2015
Gemfile modify the content entry from to handle password confirmation virtual… Jun 20, 2017
Gemfile.lock modify the content entry from to handle password confirmation virtual… Jun 20, 2017
LICENSE upgrade gems + update copyright + make sure all the site locales are … Mar 10, 2017
README.md upgrade gems + update copyright + make sure all the site locales are … Mar 10, 2017
Rakefile merge Nic work about the API + upgrade the README Apr 1, 2015
bower.json fix a couple of issues with the datetimepicker JS component (one of t… Mar 11, 2016
locomotive_cms.gemspec ship with the last version of Steam + bump version to 3.3.0.rc3 Jun 2, 2017



Build Status Code Climate Dependency Status Coverage Status Join the chat at https://gitter.im/locomotivecms/engine

Locomotive is an open source platform to create, publish and edit sites (CMS). It is designed to save time and help you focus on what matters: front-end technology, standard development process and a very low learning curve for your clients.

Locomotive relies on a very original workflow:

  • Sites are coded locally using our open source tool: Wagon. A desktop version (not open source and not tested in v3) is also available here.
  • Sites are deployed to the platform (engine) thanks to our internal API.
  • A back-office for the end-users is automatically generated based on the custom models and editable regions described by the developers.


Visit the Locomotive official website [here](http:// locomotive.works) for more information.


  • Multi-sites natively supported
  • Uses Liquid, a simple and clean templating language
  • Easy to add custom content types, no SQL needed
  • Beautiful and intuitive editing interface
  • Can fully localize all the content and pages
  • Embed a Restful API to manage every site
  • Develop and preview sites locally with your favorite tools (Wagon)
  • Support for SASS, HAML and Coffee Script (Wagon)

Instructions and help


V3 has launched! Which means a lot of stuff changed and we got bunch of new features shipped in. However, Locomotive will be updated frequently with more awesome features. Have a look at our Trello board to see what's next or see where you can help out.


Here is a list of the main gems used to power the Locomotive platform:

  • Rails 4.2 - web framework
  • Bootstrap - UI framework
  • Mongoid 5 - Object-Document-Mapper for MongoDB 2/3
  • Devise 3.4 - Authentication
  • Carrierwave - Upload
  • Pundit - Permissions

Translating the back-office

By default, the Locomotive back-office is fully translated in English, Dutch and Greek.

Adding a new language is pretty straightforward since we now manage all our I18n translation keys in Transifex, a platform dedicated to this kind of task.

Here is our Transifex portal page: https://www.transifex.com/locomotive/locomotive-engine. Feel free to sign up and translate!

How to contribute

Locomotive is an open source project, we encourage contributions. If you have found a bug and want to contribute a fix, or have a new feature you would like to add, follow the steps below to get your patch into the project:

  • Install ruby, mongoDB and phantomjs
  • Clone the project git clone git@github.com:locomotivecms/engine.git
  • Setup a virtual host entry for test.example.com to point to localhost
  • Start mongodb if it is not already running
  • Run the tests bundle exec rake
  • Write your failing tests
  • Make the tests pass
  • Create a GitHub pull request

For new features (especially large ones) it is best to create a topic on the Google group first to make sure it fits into the goals of the project.


Feel free to contact me at did at locomotivecms dot com.

Copyright (c) 2017 NoCoffee, released under the MIT license