Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/luzifer/wiki
File-based Wiki implementation with web-editing capabilities and a Git backed storage
https://github.com/luzifer/wiki
git golang wiki
Last synced: 2 months ago
JSON representation
File-based Wiki implementation with web-editing capabilities and a Git backed storage
- Host: GitHub
- URL: https://github.com/luzifer/wiki
- Owner: Luzifer
- License: apache-2.0
- Created: 2019-08-07T05:23:43.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-04-19T17:55:54.000Z (9 months ago)
- Last Synced: 2024-06-20T11:09:38.910Z (7 months ago)
- Topics: git, golang, wiki
- Language: Go
- Homepage:
- Size: 4.47 MB
- Stars: 14
- Watchers: 3
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: History.md
- License: LICENSE
Awesome Lists containing this project
README
[![Go Report Card](https://goreportcard.com/badge/github.com/Luzifer/wiki)](https://goreportcard.com/report/github.com/Luzifer/wiki)
![](https://badges.fyi/github/license/Luzifer/wiki)
![](https://badges.fyi/github/downloads/Luzifer/wiki)
![](https://badges.fyi/github/latest-release/Luzifer/wiki)
![](https://knut.in/project-status/wiki)# Luzifer / wiki
`wiki` is a small file-based Wiki implementation with web-editing capabilities and a Git backed storage for history of pages.
The goal of this project was to have a small application to be deployed without any dependencies to open a Wiki for note taking or documentation purpose.
The software itself has no concept of users or authentication and is held as simple as possible. Saved pages are stored as plain Markdown file onto the local disk inside a Git repository which on the one hand can be used to backup the state (just add a remote and set up a cron to push changes) and on the other hand to recover contents if someone deleted contents from a page.
## Usage
```console
# wiki --help
Usage of wiki:
--author-email-header string Header to use as Author email
--author-name-header string Header to use as Author name
--data-dir string Directory to store data to (default "./data/")
--listen string Port/IP to listen on (default ":3000")
--log-level string Log level (debug, info, warn, error, fatal) (default "info")
--version Prints current version and exits
```To use this you can
- download pre-build binaries from the [releases](https://github.com/Luzifer/wiki/releases)
- pull the [Docker image](https://hub.docker.com/r/luzifer/wiki)
- or `go get -u github.com/Luzifer/wiki` the projectGiven you've used the binary you can now just execute `./wiki` and go to `http://localhost:3000`. Everything you save will be stored in the `./data` directory.
## Setting the author name of the commit
If you've put the wiki behind an auth-proxy which is able to set headers containing the username / email of the authenticated user (for example nginx with [nginx-sso](https://github.com/Luzifer/nginx-sso)) you can specify the `--author-email-header` and/or `--author-name-header` and provide the header names you've used there. These values will then be used as the author of the commit while the committer will still be the wiki-user.