6f870501a0
* Add tests for --local-time option * Update Readme
158 lines
11 KiB
Markdown
158 lines
11 KiB
Markdown
gollum -- A git-based Wiki
|
|
====================================
|
|
|
|
[](http://badge.fury.io/rb/gollum)
|
|

|
|
[](https://www.codetriage.com/gollum/gollum)
|
|
[](https://dometto-cuttingedge.herokuapp.com/github/gollum/gollum/info)
|
|
|
|
|
|
**Gollum version 5.0 is out!** See [here](https://github.com/gollum/gollum/wiki/5.0-release-notes) for a list of changes and new features compared to Gollum version 4.x, and see some [Screenshots](https://github.com/gollum/gollum/wiki/Screenshots) of Gollum's features.
|
|
|
|
## DESCRIPTION
|
|
|
|
Gollum is a simple wiki system built on top of Git. A Gollum Wiki is simply a git repository of a specific nature:
|
|
* A Gollum repository's contents are human-editable text or markup files.
|
|
* Pages may be organized into directories any way you choose.
|
|
* Other content can also be included, for example images, PDFs and headers/footers for your pages.
|
|
* Gollum pages:
|
|
* May be written in a variety of [markups](#markups).
|
|
* Can be edited with your favourite system editor or IDE (changes will be visible after committing) or with the built-in web interface.
|
|
* Can be displayed in all versions, reverted, etc.
|
|
* Gollum strives to be compatible with GitHub wikis (see `--lenient-tag-lookup`)
|
|
* Gollum supports advanced functionality like:
|
|
* [UML diagrams](https://github.com/gollum/gollum/wiki#plantuml-diagrams)
|
|
* [BibTeX and Citation support](https://github.com/gollum/gollum/wiki/BibTeX-and-Citations)
|
|
* Annotations using [CriticMarkup](https://github.com/gollum/gollum/wiki#criticmarkup-annotations)
|
|
* Mathematics via [MathJax](https://github.com/gollum/gollum/wiki#mathematics)
|
|
* [Macros](https://github.com/gollum/gollum/wiki/Standard-Macros)
|
|
* [Redirects](https://github.com/gollum/gollum/wiki#redirects)
|
|
* [RSS Feed](https://github.com/gollum/gollum/wiki/5.0-release-notes#rss-feed) of latest changes
|
|
* ...and [more](https://github.com/gollum/gollum/wiki)
|
|
|
|
### SYSTEM REQUIREMENTS
|
|
|
|
Gollum runs on Unix-like systems using its [adapter](https://github.com/gollum/rugged_adapter) for [rugged](https://github.com/libgit2/rugged) by default. You can also run Gollum on [JRuby](https://github.com/jruby/jruby) via its [adapter](https://github.com/repotag/gollum-lib_rjgit_adapter) for [RJGit](https://github.com/repotag/rjgit/). On Windows, Gollum runs only on JRuby.
|
|
|
|
## INSTALLATION
|
|
|
|
1. Ruby is best installed either via [RVM](https://rvm.io/) or a package manager of choice.
|
|
2. Gollum is best installed via RubyGems:
|
|
```
|
|
[sudo] gem install gollum
|
|
```
|
|
|
|
Installation examples for individual systems can be seen [here](https://github.com/gollum/gollum/wiki/Installation).
|
|
|
|
To run, simply:
|
|
|
|
1. Run: `gollum /path/to/wiki` where `/path/to/wiki` is an initialized Git repository.
|
|
2. Open `http://localhost:4567` in your browser.
|
|
|
|
See [below](#running-from-source) for information on running Gollum from source, as a Rack app, and more.
|
|
|
|
### Markups
|
|
|
|
Gollum allows using different markup languages on different wiki pages. It presently ships with support for the following markups:
|
|
* [Markdown](http://daringfireball.net/projects/markdown/syntax) (see [below](#Markdown-flavors) for more information on Markdown flavors)
|
|
* [RDoc](http://rdoc.sourceforge.net/)
|
|
|
|
You can easily activate support for other markups by installing additional renderers (any that are supported by [github-markup](https://github.com/github/markup)):
|
|
* [AsciiDoc](http://asciidoctor.org/docs/asciidoc-syntax-quick-reference/) -- `[sudo] gem install asciidoctor`
|
|
* [Creole](http://www.wikicreole.org/wiki/CheatSheet) -- `[sudo] gem install creole`
|
|
* [MediaWiki](http://www.mediawiki.org/wiki/Help:Formatting) -- `[sudo] gem install wikicloth`
|
|
* [Org](http://orgmode.org/worg/dev/org-syntax.html) -- `[sudo] gem install org-ruby`
|
|
* [Pod](http://perldoc.perl.org/perlpod.html) -- requires Perl >= 5.10 (the `perl` command must be available on your command line)
|
|
* Lower versions should install `Pod::Simple` from CPAN.
|
|
* [ReStructuredText](http://docutils.sourceforge.net/docs/ref/rst/restructuredtext.html) -- requires python >= 2 (the `python2` command must be available on your command line)
|
|
* Note that Gollum will also need you to install `docutils` for your Python 2.
|
|
* [Textile](http://redcloth.org/hobix.com/textile/quick.html) -- `[sudo] gem install RedCloth`
|
|
|
|
### Markdown flavors
|
|
|
|
By default, Gollum ships with the `kramdown` gem to render Markdown. However, you can use any [Markdown renderer supported by github-markup](https://github.com/github/markup/blob/master/lib/github/markup/markdown.rb). This includes [CommonMark](https://commonmark.org/) support via the `commonmarker` gem. The first installed renderer from the list will be used (e.g., `redcarpet` will NOT be used if `github/markdown` is installed). Just `gem install` the renderer of your choice.
|
|
|
|
See [here](https://github.com/gollum/gollum/wiki/Custom-rendering-gems) for instructions on how to use custom rendering gems and set custom options.
|
|
|
|
## RUNNING FROM SOURCE
|
|
|
|
1. `git clone https://github.com/gollum/gollum`
|
|
2. `cd gollum`
|
|
3. `[sudo] bundle install`
|
|
4. `bundle exec bin/gollum`
|
|
5. Open `http://localhost:4567` in your browser.
|
|
|
|
### Rack
|
|
|
|
Gollum can also be run with any [rack-compatible web server](https://github.com/rack/rack#supported-web-servers). More on that [over here](https://github.com/gollum/gollum/wiki/Gollum-via-Rack).
|
|
|
|
### Rack, with an authentication server
|
|
|
|
Gollum can also be run alongside a CAS (Central Authentication Service) SSO (single sign-on) server. With a bit of tweaking, this adds basic user-support to Gollum. To see an example and an explanation, navigate [over here](https://github.com/gollum/gollum/wiki/Gollum-via-Rack-and-CAS-SSO).
|
|
|
|
### Docker
|
|
|
|
Gollum can also be run via [Docker](https://www.docker.com/). More on that [over here](https://github.com/gollum/gollum/wiki/Gollum-via-Docker).
|
|
|
|
### Service
|
|
|
|
Gollum can also be run as a service. More on that [over here](https://github.com/gollum/gollum/wiki/Gollum-as-a-service).
|
|
|
|
## CONFIGURATION
|
|
|
|
Gollum comes with the following command line options:
|
|
|
|
| Option | Arguments | Description |
|
|
| ----------------- | --------- | ----------- |
|
|
| --host | [HOST] | Specify the hostname or IP address to listen on. Default: '0.0.0.0'.<sup>1</sup> |
|
|
| --port | [PORT] | Specify the port to bind Gollum with. Default: `4567`. |
|
|
| --config | [FILE] | Specify path to Gollum's configuration file. |
|
|
| --ref | [REF] | Specify the git branch to serve. Default: `master`. |
|
|
| --bare | none | Tell Gollum that the git repository should be treated as bare. |
|
|
| --adapter | [ADAPTER] | Launch Gollum using a specific git adapter. Default: `rugged`.<sup>2</sup> |
|
|
| --base-path | [PATH] | Specify the leading portion of all Gollum URLs (path info). Setting this to `/wiki` will make the wiki accessible under `http://localhost:4567/wiki/`. Default: `/`. |
|
|
| --page-file-dir | [PATH] | Specify the subdirectory for all pages. If set, Gollum will only serve pages from this directory and its subdirectories. Default: repository root. |
|
|
| --static, --no-static | none | Use static assets. Defaults to false in development/test, true in production/staging. |
|
|
| --assets | [PATH] | Set the path to look for static assets. |
|
|
| --css | none | Tell Gollum to inject custom CSS into each page. Uses `custom.css` from wiki root.<sup>3</sup> |
|
|
| --js | none | Tell Gollum to inject custom JS into each page. Uses `custom.js` from wiki root.<sup>3</sup> |
|
|
| --no-edit | none | Disable the feature of editing pages. |
|
|
| --local-time | none | Use the browser's local timezone instead of the server's for displaying dates. Default: false.
|
|
| --follow-renames, --no-follow-renames | none | Follow pages across renames in the History view. Default: true.
|
|
| --allow-uploads | [MODE] | Enable file uploads. If set to `dir`, Gollum will store all uploads in the `/uploads/` directory in repository root. If set to `page`, Gollum will store each upload at the currently edited page.<sup>4</sup> |
|
|
| --mathjax | none | Enables MathJax (renders mathematical equations). By default, uses the `TeX-AMS-MML_HTMLorMML` config with the `autoload-all` extension.<sup>5</sup> |
|
|
| --critic-markup | none | Enable support for annotations using [CriticMarkup](http://criticmarkup.com/). |
|
|
| --irb | none | Launch Gollum in "console mode", with a [predefined API](https://github.com/gollum/gollum-lib/). |
|
|
| --h1-title | none | Tell Gollum to use the first `<h1>` as page title. |
|
|
| --no-display-metadata | none | Do not render metadata tables in pages. |
|
|
| --user-icons | [MODE] | Tell Gollum to use specific user icons for history view. Can be set to `gravatar`, `identicon` or `none`. Default: `none`. |
|
|
| --mathjax-config | [FILE] | Specify path to a custom MathJax configuration. If not specified, uses the `mathjax.config.js` file from repository root. |
|
|
| --template-dir | [PATH] | Specify custom mustache template directory. Only overrides templates that exist in this directory. |
|
|
| --template-page | none | Use _Template in root as a template for new pages. Must be committed. |
|
|
| --emoji | none | Parse and interpret emoji tags (e.g. `:heart:`) except when the leading colon is backslashed (e.g. `\:heart:`). |
|
|
| --lenient-tag-lookup | none | Internal links resolve case-insensitively, will treat spaces as hyphens, and will match the first page found with a certain filename, anywhere in the repository. Provides compatibility with Gollum 4.x. |
|
|
| --help | none | Display the list of options on the command line. |
|
|
| --version | none | Display the current version of Gollum. |
|
|
| --versions | none | Display the current version of Gollum and auxiliary gems. |
|
|
|
|
**Notes:**
|
|
|
|
1. The `0.0.0.0` IP address allows remote access. Should you wish for Gollum to turn into a personal Wiki, use `127.0.0.1`.
|
|
2. Before using `--adapter`, you should probably read [this](https://github.com/gollum/gollum/wiki/Git-adapters) first.
|
|
3. When `--css` or `--js` is used, respective files must be committed to your git repository or you will get a 302 redirect to the create a page.
|
|
4. Files can be uploaded simply by dragging and dropping them onto the editor's text area when `--allow-uploads` is used.
|
|
|
|
### Config file
|
|
|
|
When `--config` option is used, certain inner parts of Gollum can be customized. This is used throughout our wiki for certain user-level alterations, among which [customizing supported markups](https://github.com/gollum/gollum/wiki/Formats-and-extensions) will probably stand out.
|
|
|
|
**All of the mentioned alterations work both for Gollum's config file (`config.rb`) and Rack's config file (`config.ru`).**
|
|
|
|
## CONTRIBUTING
|
|
|
|
Please consider helping out! See [CONTRIBUTING](CONTRIBUTING.md) for information on how to submit issues, and how to start hacking on gollum.
|
|
|
|
## THANKS TO
|
|
|
|
[](https://saucelabs.com)
|