Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/proshoumma/ReForum
A minimal forum board application. Built on top of React-Redux frontend, ExpressJS-NodeJS backend (with PassportJS for OAuth) and MongoDB databse.
https://github.com/proshoumma/ReForum
expressjs mongodb-database passportjs reactjs redux
Last synced: 2 months ago
JSON representation
A minimal forum board application. Built on top of React-Redux frontend, ExpressJS-NodeJS backend (with PassportJS for OAuth) and MongoDB databse.
- Host: GitHub
- URL: https://github.com/proshoumma/ReForum
- Owner: proshoumma
- License: mit
- Archived: true
- Created: 2016-12-13T06:49:36.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2023-03-20T11:49:38.000Z (almost 2 years ago)
- Last Synced: 2024-05-22T20:33:46.360Z (8 months ago)
- Topics: expressjs, mongodb-database, passportjs, reactjs, redux
- Language: JavaScript
- Homepage:
- Size: 948 KB
- Stars: 751
- Watchers: 35
- Forks: 175
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![logo](./docs/design_assets/logo.png)
# ReForum
A minimal forum application built with the following technologies:
* [React](https://facebook.github.io/react/)
* [Redux](http://redux.js.org/)
* [Webpack](https://webpack.js.org/)
* [ExpressJS](https://expressjs.com/)
* [PassportJS](http://passportjs.org/)
* [MongoDB](https://www.mongodb.com/)### Application Features
* Users can post a discussion
* Users can reply their opinions regarding discussion
* Users can favorite discussions
* Users have their own profile page
* Admin can create new forum categories
* Admin have a lot of power over every users discussions and opinions :-p### Documentations
* [API Docs](https://github.com/shoumma/ReForum/blob/master/docs/api.md)
* [System Overview](https://github.com/shoumma/ReForum/blob/master/docs/system_overview.md)### Home View
![home view](./docs/design_assets/home_view.jpg)### Admin View
![admin view](./docs/design_assets/admin_view.jpg)## Deploy on you own server
Please make sure you have following software installed in your system:
* Node.js > 6.0
* NPM / Yarn
* Git
* MongoDBFirst we need to clone the repository:
```
$ git clone https://github.com/shoumma/ReForum
```Then we have to install the necessary dependencies using either NPM or Yarn:
```
$ npm i
```
```
$ yarn
```Since the app currently uses GitHub authentication, we need to configure a GitHub OAuth application. You can register a new application from this link https://github.com/settings/developers
We need to grab the following information from the OAuth application.
* Client ID
* Client Secret
* Callback URLThe `Callback URL` is the domain where GitHub will redirect the user after a successful login. You can use a domain name or local host. But we need to append the URL with the path `/api/user/authViaGitHub/callback`. So, the complete url will look like:
`https://localhost:8080/api/user/authViaGitHub/callback`Now, we need to configure the credentials inside of the codebase. Open the file `config/credentials.js` add the necessary information. The file looks like this:
```js
module.exports = {
GITHUB_CLIENT_ID: '',
GITHUB_CLIENT_SECRET: '',
GITHUB_CALLBACK_URL: '',
DBURL: '',
};
```We need to provide all the information here. You can notice that we need the database url here too. My `local` MongoDB url looks like:
```
mongodb://localhost:27017/reforum
```Now we are ready to run the application. You can run either run the development environment of the application which will include Hot-Reload for JS codes using Webpack and the Redux dev tool extension, or you can run the production edition. The default port for developer edition is `8080`, and for production is `process.env.PORT`.
To run the app in development environment:
```
$ npm run start:dev
```To run the app in production environment:
```
$ npm run start
```Now, if you visit [http://localhost:8080](http://localhost:8080) (if you ran the dev), or the production URL, you will see that the application is up and running. Congratulation! But, wait a minute, it's showing you `Sorry, couldn't find the forum`. That is because, we didn't create any forum yet. You can now sign up via github and then visit the admin panel with the url [http://localhost:8080/admin](http://localhost:8080/admin). The application is currently configured in a way that, the first user will become the admin for the system.
Here we can create new forums and that forum will be displayed in the application. The first forum will be used as default forum.
Congratulation! You now have a clone of this application in your server. :-)
## Path for Future Work
* Add search functionality
* Add unit tests for both backend and frontend
* Ability to change the name and logo of the site from admin panel.
* Make the installation process more interactive
* Add multiple theme support.## License
[MIT License](https://github.com/shoumma/Mister-Poster/blob/master/LICENSE). Do whatever you want to do. :-)## Conclusion
The application is created with lots of ♥. Any pull request, issues and contribution is very appreciated. It would be really great if we can take this application to the next level, where it can be used as a platform for forums.[Provash Shoumma](https://twitter.com/proshoumma)