1
0
Fork 0
mirror of https://github.com/Eggbertx/gochan.git synced 2025-08-04 20:16:24 -07:00
No description
Find a file
2020-06-29 23:37:17 +02:00
.vscode Move migration logic to cmd/gochan-migration 2020-06-13 21:47:43 +02:00
cmd Remove temporary code. Wrap up. 2020-06-29 23:37:17 +02:00
devtools Add #if flag markers in sql macro script 2020-06-11 17:20:59 +02:00
docker Remove SQLite support due to instability 2020-06-15 11:27:14 -07:00
frontend Add ES6 frontend so far 2020-06-03 15:43:35 -07:00
html re-add closeHandle to avoid trying to run Close on potentially nil pointers 2020-04-04 23:06:29 -07:00
pkg Merge branch 'Database_refactor' of github.com:gochan-org/gochan into Database_refactor 2020-06-26 18:03:17 -07:00
sample-configs Remove SQLite support due to instability 2020-06-15 11:27:14 -07:00
sass Remove old manage.js reference, fix dropdown menu color 2020-03-23 17:01:04 -07:00
sql/preapril2020migration Remove temporary code. Wrap up. 2020-06-29 23:37:17 +02:00
templates Fix catalog 2020-05-27 21:32:15 +02:00
vagrant Remove SQLite support due to instability 2020-06-15 11:27:14 -07:00
.deepsource.toml Add .deepsource.toml 2020-04-04 21:59:26 +00:00
.gitignore Add ES6 frontend so far 2020-06-03 15:43:35 -07:00
build.ps1 Remove SQLite support due to instability 2020-06-15 11:27:14 -07:00
Database ERD.drawio Made wordfilter staff id nullable, fixed mistake 2020-06-29 23:14:53 +02:00
Database ERD.png Made wordfilter staff id nullable, fixed mistake 2020-06-29 23:14:53 +02:00
go.mod Make gcsql.GetCompleteDatabaseVersion return an int flag instead of a bunch of booleans 2020-06-16 13:31:47 -07:00
go.sum Make gcsql.GetCompleteDatabaseVersion return an int flag instead of a bunch of booleans 2020-06-16 13:31:47 -07:00
initdb_master.sql Made wordfilter staff id nullable, fixed mistake 2020-06-29 23:14:53 +02:00
initdb_mysql.sql Made wordfilter staff id nullable, fixed mistake 2020-06-29 23:14:53 +02:00
initdb_postgres.sql Made wordfilter staff id nullable, fixed mistake 2020-06-29 23:14:53 +02:00
LICENSE Use v1 base64captcha API 2020-02-07 21:46:30 -08:00
Makefile Remove SQLite support due to instability 2020-06-15 11:27:14 -07:00
README.md Remove SQLite support due to instability 2020-06-15 11:27:14 -07: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 "tcp(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

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.

Theme development

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