1
0
Fork 0
mirror of https://github.com/Eggbertx/gochan.git synced 2025-08-01 22:26:24 -07:00
No description
Find a file
2021-03-01 20:23:53 -08:00
.vscode Add debug improvements to read full strings 2020-07-08 20:49:43 +02:00
cmd Fix anti-patterns pointed out by DeepSource 2020-07-09 15:54:31 -07:00
devtools Add #if flag markers in sql macro script 2020-06-11 17:20:59 +02:00
docker Publish ports and detach from container by default 2021-03-01 20:23:53 -08:00
frontend Update npm packages to (hopefully) appease Dependabot 2021-01-29 13:34:34 -08:00
html re-add closeHandle to avoid trying to run Close on potentially nil pointers 2020-04-04 23:06:29 -07:00
pkg Add build.py to eventually replace build.ps1 and Makefile 2020-10-23 19:13:06 -07:00
sample-configs Change default gochan installation prefix path to /usr instead of /usr/local 2021-02-22 15:05:16 -08:00
sass Remove old manage.js reference, fix dropdown menu color 2020-03-23 17:01:04 -07:00
sql/preapril2020migration Remove wordfilter migration 2020-07-08 19:44:17 +02:00
templates Replace strings.ReplaceAll with strings.Replace for compatibility 2020-07-27 18:19:56 -07:00
vagrant Change default gochan installation prefix path to /usr instead of /usr/local 2021-02-22 15:05:16 -08:00
.deepsource.toml Add .deepsource.toml 2020-04-04 21:59:26 +00:00
.gitignore Add HTTP support to the vagrant VM 2020-10-11 14:59:06 -07:00
build.py Publish ports and detach from container by default 2021-03-01 20:23:53 -08:00
Database ERD.drawio Remove wordfilter migration 2020-07-08 19:44:17 +02:00
Database ERD.png Remove wordfilter migration 2020-07-08 19:44:17 +02:00
go.mod Change default gochan installation prefix path to /usr instead of /usr/local 2021-02-22 15:05:16 -08:00
go.sum Change default gochan installation prefix path to /usr instead of /usr/local 2021-02-22 15:05:16 -08:00
initdb_master.sql Remove wordfilter migration 2020-07-08 19:44:17 +02:00
initdb_mysql.sql Remove wordfilter migration 2020-07-08 19:44:17 +02:00
initdb_postgres.sql Remove wordfilter migration 2020-07-08 19:44:17 +02:00
LICENSE Use v1 base64captcha API 2020-02-07 21:46:30 -08:00
README.md Fix gochan sample config and fix readme 2020-07-08 21:40:22 +02:00
refactorgcfs.sh refactor/reorganize gochan's source code into subpackages 2020-04-29 17:44:29 -07:00
version re-add closeHandle to avoid trying to run Close on potentially nil pointers 2020-04-04 23:06:29 -07:00

Gochan

A semi-standalone imageboard server written in Go

Gochan works in a manner similar to Kusaba X, Tinyboard and others. As such, Gochan generates static HTML files which can optionally be served by a separate web server.

Demo installation: https://gochan.org

Installation

Basic installation (from a release)

  1. Extract the .tar.gz or the .zip file into a directory (for example, your home directory)
  2. Copy gochan.example.json to either gochan.json or (if you're in a UNIX-like OS) /etc/gochan/gochan.json and modify it as needed. See the Configuration section for more info.
  3. If you're using nginx, copy gochan-http.nginx, or gochan-fastcgi.nginx if UseFastCGI is set to true to /etc/nginx/sites-enabled/, or the appropriate folder in Windows.
  4. If you're using a Linux distribution with systemd, you can optionally copy gochan.service to /lib/systemd/system/gochan.service and run systemctl enable gochan.service to have it run on startup. Then run systemctl start gochan.service to start it as a background service.
    1. If you aren't using a distro with systemd, you can start a screen session and run /path/to/gochan
  5. Go to http://[gochan url]/manage?action=staff, log in (default username/password is admin/password), and create a new admin user (and any other staff users as necessary). Then delete the admin user for security.

Configuration

  1. Make sure to set DBtype, DBhost, DBname, DBusername, and DBpassword, since these are required to connect to your SQL database. Valid DBtype values are "mysql" and "postgres" (sqlite3 is no longer supported for stability reasons).
    1. To connect to a MySQL database, set DBhost to "ip:3306" or a different port, if necessary.
    2. To connect to a PostgreSQL database, set DBhost to the IP address or hostname. Using a UNIX socket may work as well, but it is currently untested.
  2. Set DomainRegex,SiteDomain, since these are necessary in order to post and log in as a staff member.
  3. If you want to see debugging info/noncritical warnings, set verbosity to 1.

Installation using Docker

See docker/README.md

Migration

If you run gochan and get a message telling you your database is out of data, please run gochan-migration. If this does not work, please contact the developers.

For developers (using Vagrant)

  1. Install Vagrant and Virtualbox. Vagrant lets you create a virtual machine and run a custom setup/installation script to make installation easier and faster.
  2. From the command line, cd into vagrant/ and run vagrant up. By default, MySQL/MariaDB is used, but if you want to test with a different SQL type, run GC_DBTYPE=dbtype vagrant up, replacing "dbtype" with either mysql or postgresql
  3. After it finishes installing the Ubuntu VM, follow the printed instructions.

For developers (using vscode)

  1. Install go, the vs-go extention and gcc (I think, let me know if you need something else)
  2. Install either postgreSQL or mariaDB. Setup a database with an account and enter the ip:post and login information into the gochan.json config. See "Configuration". (Tools like PG admin highly recommended for easy debugging of the database)
  3. Set "DebugMode" to true. This will log all logs to the console and disable some checks.
  4. Open the folder containing everything in vscode (named gochan most likely), go to "Run"
    1. Select "gochan" if you wish to run/debug the website itself
    2. Select "gochan-migrate" if you wish to run/debug the migrator
  5. (Optional) Change go extention configs. Examples: save all files on start debugging
  6. Press F5 or "Start Debugging" to debug.

Theme development

See sass/README.md for information on working with Sass and stylesheets.

Development

Styleguide

  • Follow the standard go styleguide
  • All exported functions and variables should have a documentation comment explaining their functionality, as per go style guides.
  • Unexported functions are preferred to have a documentation comment explaining it, unless it is sufficiently self explanatory or simple.
  • Git commits should be descriptive. Put further explanation in the comment of the commit.
  • Function names should not be too long
  • Avoid single letter variables, use descriptive variables names if possible, within reason

Roadmap

Near future

All features that are to be realised for the near future are found in the issues tab with the milestone "Next Release"

Lower priority

  • Improve moderation tools heavily
  • Rework board creation to correctly use new fields.
  • Rework any legacy structs that uses comma separated fields to use a slice instead.
  • Replace all occurrences of “interfaceslice(items)” with []interface{}{items} notation, then remove interfaceslice.
  • Remove all references/code related to sqlite
  • RSS feeds from boards/specific threads/specific usernames+tripcodes (such as newsanon)
  • Pinning a post within a thread even if its not the OP, to prevent its deletion in a cyclical thread.

Later down the line

  • Look into the possibility of a plugin system, preferably in go, a scripting language if that is not possible
  • Move frontend to its own git to allow easier frontend swapping
  • API support for existing chan browing phone apps
  • Social credit system to deal with tor/spam posters in a better way
  • Better image fingerpringing and banning system (as opposed to a hash)

Possible experimental features:

  • Allow users to be mini-moderators within threads they posted themselves, to prevent spammers/derailers.