The Homebrewery
The Homebrewery is a tool for making authentic looking D&D content using Markdown. It is distributed under the terms of the MIT License.
Quick Start
The easiest way to get started using The Homebrewery is to use it on our website. The code is open source, so feel free to clone it and tinker with it. If you want to make changes to the code, you can run your own local version for testing by following the installation instructions below.
Installation
First, install three programs that The Homebrewery requires to run and retrieve updates:
-
install node
-
install mongodb (Community version)
For the easiest installation, follow these steps:
- In the installer, uncheck the option to run as a service.
- You can install MongoDB Compass if you want a GUI to view your database documents.
- Go to the C:\ drive and create a folder called "data".
- Inside the "data" folder, create a new folder called "db".
- Open a command prompt or other terminal and navigate to your MongoDB install folder (C:\Program Files\Mongo\Server\4.4\bin).
- In the command prompt, run "mongod", which will start up your local database server.
- While MongoD is running, open a second command prompt and navigate to the MongoDB install folder.
- In the second command prompt, run "mongo", which allows you to edit the database.
- Type
use homebrewery
to create The Homebrewery database. You should seeswitched to db homebrewery
. - Type
db.brews.insert({"title":"test"})
to create a blank document. You should seeWriteResult({ "nInserted" : 1 })
. - Search in Windows for "Advanced system settings" and open it.
- Click "Environment variables", find the "path" variable, and double-click to open it.
- Click "New" and paste in the path to the MongoDB "bin" folder.
- Click "OK" three times to close all the windows.
-
install git (select the option that allows Git to run from the command prompt).
Checkout the repo (documentation):
git clone https://github.com/naturalcrit/homebrewery.git
Second, you will need to add the environment variable NODE_ENV=local
to allow
the project to run locally.
You can set this temporarily in your shell of choice:
- Windows Powershell:
$env:NODE_ENV="local"
- Windows CMD:
set NODE_ENV=local
- Linux / macOS:
export NODE_ENV=local
Third, you will need to install the Node dependencies, compile the app, and run it using the two commands:
npm install
npm start
You should now be able to go to http://localhost:8000 in your browser and use The Homebrewery offline.
Running the application via Docker
Please see the docs here: README.DOCKER.md
Running the application on FreeBSD or FreeNAS
Please see the docs here: README.FreeBSD.md
Standalone PHB Stylesheet
If you just want the stylesheet that is generated to make pages look like they are from the Player's Handbook, you will find it in the phb.standalone.css file.
If you are developing locally and would like to generate your own, follow the
above steps and then run npm run phb
.
Issues, Suggestions, and Bugs
If you run into any issues using The Homebrewery or have suggestions for improvement, please submit an issue on GitHub. You can also get help for issues on the subreddit r/homebrewery
Changelog
You can check out the changelog.
License
This project is licensed under the MIT license, which means you are free to use The Homebrewery in any way that you want, except for claiming that you made it yourself.
If you wish to sell, or in some way gain profit for, what's created on this site, it's your responsibility to ensure you have the proper licenses/rights for any images or resources used.
Contributing
You are welcome to contribute to the development and maintenance of the project! There are several ways of doing that:
- At the moment, we have a huge backlog of issues and some
of them are outdated, duplicates, or don't contain any useful info. To help, you can mark duplicates, try to
reproduce some complex or weird issues, try finding a workaround for a
reported bug, or just mention our issue managers team to let them know about
outdated issues via
@naturalcrit/issue-managers
. - Our subreddit is constantly growing and there are number of bug reports. Any help with sorting them out is very welcome.
- And of course you can contribute by fixing a bug or implementing a new feature by yourself, we are waiting for your pull requests!
Anyway, if you would like to get in touch with the team and discuss/coordinate your contribution to the project, please join our gitter chat.