Real-time imageboard in node.js and redis http://doushio.com/moe/
Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.
 
 
 
 
 
 
Lal'C Mellk Mal cda3059869 "Only upload images" option vor 2 Wochen
admin Use more arrow functions vor 1 Monat
archive pipeline.js: use promises vor 2 Monaten
client "Only upload images" option vor 2 Wochen
curfew Remove `hook_sync` and `trigger_sync` vor 2 Monaten
docs nofollow noopener noreferrer vor 3 Jahren
imager Async imager jobs vor 2 Wochen
lib Remove yepnope vor 3 Jahren
lua Use active posts from Lua vor 3 Jahren
report Nodemailer 6.4.10 vor 3 Monaten
server Fix tweet fetching vor 2 Wochen
tmpl Modernize tmpl JS vor 2 Wochen
tripcode Port tripcode to NAPI vor 3 Monaten
upkeep Async upkeep/clean.js vor 1 Monat
www sockjs client 1.4.0; force ws or xhr-streaming vor 3 Monaten
.gitignore Document spoiler images vor 1 Monat
.ignore Don't grep minified JS vor 3 Jahren
LICENSE Update copyright year to 2020 vor 1 Monat
Makefile New script-building pipeline vor 7 Jahren
README.md Document spoiler images vor 1 Monat
TODO Inline/remove remaining hooks vor 1 Monat
builder.js New script-building pipeline vor 7 Jahren
common.js Use config prefix in client code vor 1 Monat
config.js.example sockjs client 1.4.0; force ws or xhr-streaming vor 3 Monaten
db.js Async commit_image_alloc vor 1 Monat
deps.js Inline/remove remaining hooks vor 1 Monat
etc.js Provide async exec, execFile vor 2 Wochen
hot.js.example Hackily fade inserted images in vor 2 Jahren
make_client.js Provide async exec, execFile vor 2 Wochen
package.json Bump node-fetch from 2.6.0 to 2.6.1 (#126) vor 2 Wochen
pipeline.js async make_client vor 1 Monat
tail.js Use setImmediate in tail vor 7 Jahren

README.md

Real-time imageboard. MIT licensed.

Setup:

  • Install dependencies listed below
  • Sign up for reCAPTCHA
  • Create a GitHub Application (callback URL = site URL + /login)
  • Copy config.js.example to config.js and configure
  • Copy hot.js.example to hot.js and configure
  • Copy imager/config.js.example to imager/config.js and configure
  • Copy report/config.js.example to report/config.js and configure
  • Clone assets and copy the kana spoiler image folder as ./www/kana/ (or create your own!).
  • Run npm install to install npm deps and compile a few helpers
  • Run node builder.js to run an auto-reloading development server

Production:

  • Have your webserver serve www/ (or wherever you’ve moved src, thumb, etc.)
    • Configure imager.config.MEDIA_URL appropriately
    • Then turn off SERVE_STATIC_FILES and SERVE_IMAGES
  • If you’re behind Cloudflare turn on CLOUDFLARE
    • Or if you’re behind any reverse proxy (nginx etc) turn on TRUST_X_FORWARDED_FOR
  • Run node server/server.js for just the server
  • You can update client code & hot.js on-the-fly with node server/kill.js
  • For nginx hosting/reverse proxying, refer to docs/nginx.conf.example
  • For a sample init script, refer to docs/doushio.initscript.example
  • config.DAEMON support is old and broken, PRs welcome

Dependencies:

  • ImageMagick
  • libpng
  • node.js + npm
  • npm install -g node-gyp
  • redis
  • ffmpeg 2.2+ if supporting WebM
  • jhead and jpegtran optionally, for EXIF autorotation

Optional npm deps for various features:

  • daemon (broken currently)
  • send (if you want to serve static files directly from the node.js process; useful in debug mode also)

Standalone upkeep scripts:

  • archive/daemon.js - moves old threads to the archive
  • upkeep/backup.js - uploads rdb to S3
  • upkeep/clean.js - deletes archived images