Go to file
2020-05-22 00:27:15 -07:00
.circleci
app [Comments] Prevent hidden comment leak in API 2020-05-20 18:32:31 -07:00
bin
config [Discord] Fix discord domain after discord changed it 2020-05-08 18:45:37 -07:00
db Post image hash temp 2020-05-14 10:47:59 -07:00
doc
lib
public Upgrade jQuery to 3.5.0 2020-04-29 18:55:50 -07:00
script Migration changes 2020-03-05 12:41:44 -08:00
test
tmp
vagrant
.editorconfig
.env
.eslintrc.yml
.gitignore
.ruby-version
babel.config.js
Capfile
config.ru
Gemfile [DText] New dtext version - Fix wiki links with anchors 2020-05-22 00:27:15 -07:00
Gemfile.lock [DText] New dtext version - Fix wiki links with anchors 2020-05-22 00:27:15 -07:00
INSTALL_DEV.ubuntu
INSTALL.debian
LICENSE
package.json
postcss.config.js
Procfile
Rakefile
README.md Repalced the IPv4 Address with the hostname of the VM 2020-04-06 17:24:46 +02:00
Vagrantfile Added an inline script to install the necessary linux headers for the guest additions 2020-04-05 22:34:16 +02:00
yarn.lock Upgrade jQuery to 3.5.0 2020-04-29 18:55:50 -07:00

Installation (Easy mode - For development environments)

Prerequisites

  • Latest version of VirtualBox and the VM Extension Pack (download)
  • Latest version of Vagrant (download)

Installation

  1. Download and install the prerequisites
  2. Open Command Prompt/Terminal and run the following commands:
    vagrant plugin install vagrant-hostmanager  
    vagrant plugin install vagrant-bindfs  
    vagrant plugin install vagrant-vbguest
    
  3. Download and extract the repo
  4. cd into the repo using Command Prompt/Terminal
  5. Run the following command: vagrant up
  6. Once vagrant exists with an error, execute vagrant up again (Workaround to install the linux headers required by the guest additions)
  7. This would be a good time to rewatch your favorite TV series installment, cook & have breakfast/lunch/dinner, walk the dog, clean your room, etc.
    By the time you get back the install will surely have completed.1
  8. To confirm the installation worked, open the web browser of your choice and enter http://e621.lc into the address bar and see if the website loads correctly.

1 If the install did not finish by the time an activity is complete please select another activity to avoid crippling boredom.

VirtualBox Troubleshooting

In case the VM doesn't start with the error VT-x not available and the error description WHvCapabilityCodeHypervisorPresent is FALSE! the the following solution should resolve the issue:

This error usually occours, when the Hyper-V or the Windows Hypervisor Platform features are activated.
To deactivate these features, press the windows key and enter Turn Windows features on or off, here you can deactivate both features by unchecking their respective checkboxes. Don't forget to restart the computer after deactivating the features.

Installation

It is recommended that you install Danbooru on a Debian-based system since most of the required packages are available on APT. Danbooru has been successfully installed on Fedora, CentOS, FreeBSD, and OS X. The INSTALL.debian install script is straightforward and should be simple to adapt for other platforms.

For best performance, you will need at least 256MB of RAM for PostgreSQL and Rails. The memory requirement will grow as your database gets bigger.

On production Danbooru uses PostgreSQL 9.4, but any 9.x release should work.

Use your operating system's package management system whenever possible. This will simplify the process of installing init scripts, which will not always happen when compiling from source.

Troubleshooting

These instructions won't work for everyone. If your setup is not working, here are the steps I usually recommend to people:

  1. Test the database. Make sure you can connect to it using psql. Make sure the tables exist. If this fails, you need to work on correctly installing PostgreSQL, importing the initial schema, and running the migrations.

  2. Test the Rails database connection by using rails console. Run Post.count to make sure Rails can connect to the database. If this fails, you need to make sure your Danbooru configuration files are correct.

  3. Test Nginx to make sure it's working correctly. You may need to debug your Nginx configuration file.

  4. Check all log files.

Services

Danbooru employs numerous external services to delegate some functionality.

For development purposes, you can just run mocked version of these services. They're available in scrtip/mock_services and can be started automatically using Foreman and the provided Procfile.

Amazon Web Services

In order to enable the following features, you will need an AWS SQS account:

  • Pool versions
  • Post versions
  • IQDB
  • Saved searches
  • Related tags

Google APIs

The following features requires a Google API account:

  • Bulk revert
  • Post versions report

IQDB Service

IQDB integration is delegated to the IQDBS service.

Archive Service

In order to access versioned data for pools and posts you will need to install and configure the Archives service.

Reportbooru Service

The following features are delegated to the Reportbooru service:

  • Related tags
  • Missed searches report
  • Popular searches report
  • Favorite searches
  • Upload trend graphs

Recommender Service

Post recommendations require the Recommender service.

Cropped Thumbnails

There's optional support for cropped thumbnails. This relies on installing libvips-8.6 or higher and setting Danbooru.config.enable_image_cropping to true.