Together, let's build amazing PHP forum software.
I’m Toby Zerner, the developer of esoTalk. Years ago, I built esoTalk as a fresh, lightweight forum software alternative. esoTalk is nice but it is not built on a sustainable foundation.
As it stands, there is a need for modern, well-architected, powerful forum software that is easy to use and self-host. That’s what Flarum is. But I'm a full-time student and I don't have time to do this by myself. So I'm opening up Flarum to the world — let's build it together.
I have a vision for Flarum — one that has grown over years of playing with forums, developing esoTalk, and learning from mistakes. It is captured by the following four points:
- Modern design. Beautiful, clean, customizable. Forum design hasn’t evolved with the rest of the web; let's finally bring it up to speed.
- Unopinionated feature-set. Every community is different, and forum software should be able to adapt to — rather than define — how a community is run. As such, Flarum will have a lightweight core, and most features will be implemented as optional extensions.
- High performance. Flarum should perform well on scales big and small, and on a large range of devices.
- Sustainable architecture. Flarum should be built for the future, on a strong foundation which can evolve with the technologies that power it.
Flarum is open-source software released under the MIT license.
I've carefully considered which frameworks to use to build Flarum. Here's the reasoning:
PHP remains the most user-friendly language for deploying web scripts, especially on shared hosting. The Laravel framework will allow for rapid development of Flarum’s API, and has a large community which will encourage collaboration and evolution.
Ember.js is a mature JavaScript framework which will power Flarum’s front-end. Use of a JavaScript framework allows us to build a fast, dynamic interface which feels more like an app than a simple web page.
Don't like the fact that Flarum is an Ember.js app? Take a look at FluxBB 2, which is being developed in a more traditional manner with Laravel.
I’ve been working on a prototype for some time in-between my studies. In addition to interface design, most of my time has been spent building out the architecture: making decisions about which frameworks to use, the most effective way to componentize everything, standardizing the API, etc.
You might notice that a lot of the code is a bit of a mess right now. This is because I wanted to get things working on a superficial level in order to record material for the Kickstarter video, and since then I haven't yet had sufficient time to clean it up. Please be aware that the mess is not at all indicative of the standard that we're aiming for!
- The basic technology stack (Laravel and Ember – see above)
- The architectural foundation (core/API/web layers)
- Some of the API (discussion and post read + write)
- Discussion list view and basic search functionality
- Discussion viewing and scrolling
The priority at the moment is to build out a lightweight core, and only start building Extensions when it is relatively stable. Below is a list of the things to work on immediately, with links to the relevant discussion.
- Interface redesign (#1)
- Upgrade to Laravel 5 (#2)
- Set up testing frameworks in both Laravel (#3) and Ember (#4)
- Further consolidation of Extension interfaces (see Extensions)
- Develop user authentication strategy (#5)
- Implement replying, post editing, discussion creation (#6)
- Implement discussion title editing (#7)
- Implement post deletion (#8)
- Implement discussion deletion (#9)
- Design user profile interface (#10)
- Design admin interfaces (#11)
- Build Notifications system (#12)
For a full list of planned features, see Features.
Currently Flarum is in its very early stages, and it isn’t pretty. It is far from usable. Set it up only if you know what you’re doing, and expect it to break a lot.
-
Make sure you have Composer, ember-cli, and Bower installed globally.
-
Create a new Laravel 4 project.
-
Clone the Flarum repository into the workbench and install dependencies:
git clone https://github.com/flarum/core.git workbench/flarum/core cd workbench/flarum/core composer install cd ../../.. php artisan dump-autoload
-
Create a new MySQL database and configure your database details in
app/config/database.php
. -
Run the Flarum migrations and database seeder to generate dummy data:
php artisan migrate --bench="flarum/core" php artisan db:seed --class="Flarum\Core\Support\Seeders\DatabaseSeeder"
-
Add the Flarum service providers to the
providers
array inapp/config/app.php
:'Flarum\Core\CoreServiceProvider', 'Flarum\Api\ApiServiceProvider', 'Flarum\Web\WebServiceProvider'
-
Remove the default route in
app/routes.php
. -
Run the following commands to compile the Ember app:
cd workbench/flarum/core/ember npm install bower install ember serve --output-path="../public"
-
Visit your Laravel application in a browser.
Note: You must access the Laravel application so that it is at the top level (i.e. not under any sub-directories.) To do this, you can either set your web server's document root to the
public
folder of your application, or you can configure a virtual host pointing to thepublic
folder.
If you’re having trouble, do not create a new issue — instead, get help on the Flarum Development Forum or hop on the IRC channel (#flarum on irc.freenode.net).
Building Flarum is going to be a team effort, and we'd love for you to help! All contributions are welcomed.
-
Contribute code. Start by becoming familiar with Flarum's source code and its Architecture. Then have a look at what needs to be done in the list above, and see if there's anything you can help out with. See below for instructions on submitting a Pull Request.
-
Participate in discussion. Review the wiki and issues and contribute your constructive thoughts. We'd also love to hear general feedback on the Flarum Development Forum, on IRC (#flarum on irc.freenode.net), and on Twitter.
-
Spread the word. Know someone who could help out? Please share this project with them!
In this early stage of development, bug reports won't be particularly helpful, because things will be constantly changing and breaking.
-
Review the Flarum Contributor License Agreement. (Why?)
-
Install Flarum as detailed in the instructions above.
-
Create a new branch.
git checkout -b new-flarum-branch
Please implement only one feature/bugfix per branch to keep pull requests clean and focused.
-
Code.
-
Commit.
- Commit messages are required.
- They should include a short description of the changes on the first line, then a blank line, then more details if necessary.
-
Clean up. Squash together minor commits.
git rebase -i
-
Update your branch so that it is based on top of the latest code from the Flarum repository.
git fetch origin git rebase origin/master
-
Fork your repository on GitHub and push to it.
git remote add mine git@github.com:<your user name>/flarum.git git push mine new-flarum-branch
-
Submit a pull request.
- Go to the Flarum repository you just pushed to (e.g. https://github.com/your-user-name/flarum).
- Click "Pull Request".
- Write your branch name in the branch field.
- Click "Update Commit Range".
- Ensure that the correct commits and files changes are included.
- Fill in a descriptive title and other details about your pull request.
- Click "Send pull request".
-
Respond to feedback.
- We may suggest changes to your code. Maintaining a high standard of code quality is important for the longevity of this project — use it as an opportunity to improve your own skills and learn something new!
Currently the only person on the core development team is Toby Zerner (@tobscure). Over time, judged by display of commitment to the project, and quantity/quality of contributions, I will be looking for more people to join the core development team. Please do not email me asking to be on the core team; rather, demonstrate initiative and commitment to the project, and I will more than likely notice!
By contributing your code to Flarum you grant Toby Zerner a non-exclusive, irrevocable, worldwide, royalty-free, sublicenseable, transferable license under all of Your relevant intellectual property rights (including copyright, patent, and any other rights), to use, copy, prepare derivative works of, distribute and publicly perform and display the Contributions on any licensing terms, including without limitation: (a) open source licenses like the MIT license; and (b) binary, proprietary, or commercial licenses. Except for the licenses granted herein, You reserve all right, title, and interest in and to the Contribution.
You confirm that you are able to grant us these rights. You represent that You are legally entitled to grant the above license. If Your employer has rights to intellectual property that You create, You represent that You have received permission to make the Contributions on behalf of that employer, or that Your employer has waived such rights for the Contributions.
You represent that the Contributions are Your original works of authorship, and to Your knowledge, no other person claims, or has the right to claim, any right in any invention or patent related to the Contributions. You also represent that You are not legally obligated, whether by entering into an agreement or otherwise, in any way that conflicts with the terms of this license.
Toby Zerner acknowledges that, except as explicitly described in this Agreement, any Contribution which you provide is on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.