meguca

module
v4.1.0+incompatible Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 22, 2017 License: AGPL-3.0, AGPL-3.0-or-later

README

GoDoc Build Status

Platforms: Linux, OSX, Win64

License: GNU AGPL

##Features

  • Posts and posting
    • Character by character post updates
    • Hovering quick reply for post authoring
    • Dice roll, coin flip and eightball commands
    • Desktop notifications, post highlighting and "(You)" on quote
    • Post link hover previews, including cross-thread
    • Inline post link expansion
    • Optional relative post timestamps
    • Image spoilering after closing a post
    • Non-temporal and recursive post linking
    • No posts per thread or threads per board limit
    • Forced anonymity display mode
    • Post hiding
    • Option to display only the last 100 posts in a thread
    • Optional automatic deletion of unused threads and boards
    • Automatic HTTP(S) and magnet URL linkification
    • Automatic quoting of selected text, when quoting a post
    • Live programming code tags with syntax highlighting
  • Files and images
    • JPEG, PNG, APNG, WEBM, MP3, MP4, OGG, PDF, ZIP, 7Z, TAR.GZ and TAR.XZ supported
    • Transparent PNG and GIF thumbnails
    • Configurable size limits
    • Inbuilt reverse image search
    • No file is ever thumbnailed or stored twice, reducing server load and disk space usage
    • Any file already present on the server is "uploaded and thumbnailed" instantly
  • Performance
    • Low memory and CPU usage
    • No frameworks and optimized code on both client and server
    • File upload processing written in C with GraphicsMagick and ffmpeg
    • Inbuilt custom LRU cache
  • Client UI
    • Works with all modern and most outdated browsers (such as PaleMoon)
    • Read-only functionality preserved with JavaScript disabled
    • Multiple themes
    • Custom user-set backgrounds and CSS
    • Mascots
    • Configurable keyboard shortcuts
    • Work mode aka Boss key
    • Customisable top banner board link list
    • Optional animated GIF thumbnails
    • Settings export/import to/from JSON file
  • Board administration
    • User board creation and configuration panels
  • Internationalization
    • Client almost entirely localized in multiple languages
    • More languages can be added by editing simple JSON files
  • Miscellaneous
    • Documented public JSON API and WebSocket protocol
    • Optional R/a/dio Now Playing banner
    • Synchronized time counters (for group watching sessions and such)

##Runtime dependencies

##Building from source A reference list of commands can be found in ./docs/installation.md

###Build dependencies

  • Go >=1.8 (for building server)
  • Node.js >=5.0 (for building client)
  • GCC or Clang
  • make
  • pkg-config
  • pthread
  • ffmpeg >= 3.0 libraries (libavcodec, libavutil, libavformat) compiled with:
    • libvpx
    • libvorbis
    • libopus
    • libtheora
    • libx264
    • libmp3lame
  • GraphicsMagick compiler with:
    • zlib
    • libpng
    • libjpeg
    • postscript
  • git
  • zip

###Linux and OSX

  • Run make

###Windows

  • Install MSYS2
  • Open MSYS2 shell
  • Install dependencies listed above with the mingw-w64-x86_64- prefix with pacman
  • Navigate to the meguca root directory
  • Run make

##Setup

  • See ./meguca help for server operation
  • Login into the "admin" account via the infinity symbol in the top banner with the password "password"
  • Change the default password
  • Create a board from the administration panel
  • Configure server from the administration panel

##Development

  • See ./docs for more documentation
  • ./meguca or ./meguca debug run the server in development mode
  • make server and make client build the server and client separately
  • make watch watches the file system for changes and incrementally rebuilds the client
  • make update_deps updates all dependencies
  • make clean removes files from the previous compilation
  • make dist_clean in addition to the above removes uploaded files and their thumbnails
  • To enable using Go tools in the project add the absolute path of ./go to your $GOPATH environment variable

Directories

Path Synopsis
go
src/meguca/auth
Package auth determines and asserts client permissions to access and modify server resources.
Package auth determines and asserts client permissions to access and modify server resources.
src/meguca/cache
Package cache provides an in-memory LRU cache for reducing the duplicate workload of database requests and post HTML and JSON generation
Package cache provides an in-memory LRU cache for reducing the duplicate workload of database requests and post HTML and JSON generation
src/meguca/common
Package common contains common shared types, variables and constants used throughout the project
Package common contains common shared types, variables and constants used throughout the project
src/meguca/config
Package config stores and exports the configuration for server-side use and the public availability JSON struct, which includes a small subset of the server configuration.
Package config stores and exports the configuration for server-side use and the public availability JSON struct, which includes a small subset of the server configuration.
src/meguca/db
Package db handles all core database interactions of the server
Package db handles all core database interactions of the server
src/meguca/imager
Package imager handles image, video, etc.
Package imager handles image, video, etc.
src/meguca/imager/assets
Package assets manages imager file asset allocation and deallocation
Package assets manages imager file asset allocation and deallocation
src/meguca/parser
Package parser parses and verifies user-sent post data
Package parser parses and verifies user-sent post data
src/meguca/server
Package server handles client requests for HTML page rendering, JSON and websocket connections
Package server handles client requests for HTML page rendering, JSON and websocket connections
src/meguca/server/websockets
Package websockets manages active websocket connections and messages received from and sent to them
Package websockets manages active websocket connections and messages received from and sent to them
src/meguca/templates
Package templates generates and stores HTML templates
Package templates generates and stores HTML templates
src/meguca/test
Package test contains utility functions used throughout the project in tests
Package test contains utility functions used throughout the project in tests
src/meguca/util
Package util contains various general utility functions used throughout the project.
Package util contains various general utility functions used throughout the project.
scripts

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL