A fork of Moebooru (which is a fork of Danbooru) with minimal customizations. https://booru.oke.moe

Joe authored on 11 Jul
app add missing quotation mark 1 month ago
bin Add webpacker 4 months ago
config Remove erb loader from webpacker 4 months ago
db Update travis and bundler, and downgrade minimum postgresql 4 months ago
lib Move all file hasher functions to a module 3 months ago
public add custom favicon 1 month ago
script Update travis and bundler, and downgrade minimum postgresql 4 months ago
test Update comments to use delegate 3 months ago
.browserslistrc Add webpacker 4 months ago
.codeclimate.yml Shiny codeclimate platform engine. 4 years ago
.gitignore Add webpacker 4 months ago
.hgignore Ignore generated translations.js. 5 years ago
.travis.yml Install yarn deps for travis 4 months ago
Gemfile Remove rubygems-based js libraries 4 months ago
Gemfile.lock Update gems 1 month ago
LICENSE Update license year and wording 3 years ago
README.md Additional configuration note for cropper update 4 months ago
Rakefile Double quotes everywhere. 5 years ago
babel.config.js Add webpacker 4 months ago
config.ru Increse memory limit 3 years ago
package.json Use newer cropperjs 4 months ago
postcss.config.js Add webpacker 4 months ago
yarn.lock Bump websocket-extensions from 0.1.3 to 0.1.4 2 months ago
README.md

Code Climate

Moebooru

An image board.

Requirements

As this is ongoing project, there will be more changes on requirement as this project goes. Currently this application is developed using:

  • Ruby 2.6+
  • PostgreSQL 11+
  • Bundler gem
  • node.js
  • yarn
  • ImageMagick
  • And various other requirement for the gems (check Gemfile for the list)

On RHEL5 (and 6), it goes like this (outdated list):

  • gcc
  • gcc-c++
  • ImageMagick
  • jhead
  • libxslt-devel
  • libyaml-devel
  • git
  • openssl-devel
  • pcre-devel
  • postgresql94-devel
  • postgresql94-server
  • readline-devel

Base, EPEL, and postgresql official repositories contain all the requirements.

Installation

Database Setup

After initializing PostgreSQL database, create user for moebooru with createdb privilege:

postgres# create user moebooru_user with password 'the_password' createdb;

Rails Setup

  • Run bundle install
  • Create config/database.yml and config/local_config.rb
  • Initialize database with bundle exec rake db:reset (there will be some errors reported which is expected)
  • Run bundle exec rake db:migrate
  • Start the server (bundle exec unicorn or bundle exec puma if using JRuby/Rubinius)

Configuration

See config/local_config.rb.example. Additionally, as I move to ENV-based configuration, here's the list of currently supported ENV variables:

  • MB_DATABASE_URL: sets database connection configuration. Syntax: postgres://<user>(:<pass>)@<host>(:<port>)/<dbname>.
  • MB_MEMCACHE_SERVERS: addresses of memcache servers. Separated by comma.
  • MB_PIWIK_HOST: sets the host this application will attempt to contact a Piwik installation at. Defaults to false to not use Piwik if unset.
  • MB_PIWIK_ID: sets the Site ID this application will send analytics data for.
  • MB_THREADS: sets number of threads this application is running. Currently used to determine number of connection pool for memcached. Defaults to 1 if unset.

Additional configuration for web server

On setup with separate image servers, additional configuration is required for avatar and inline image cropping to work. Specifically, due to how the image cropping library works, the image servers need to allow CORS for image access from main url.

Plans

  • Bug fixes
  • Documentation
  • And more!