DokuWiki Satellite for Gemini Protocol
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

57 lines
2.0 KiB

4 months ago
# β-Doku is DokuWiki Satellite for Gemini Protocol
4 months ago
Allows to launch read-only DokuWiki instance using [Gemini Protocol](https://geminiprotocol.net/)
4 months ago
It based on [titan-II](https://github.com/YGGverse/titan-II) server, [gemini-php](https://github.com/YGGverse/gemini-php) to parse DokuWiki data folder, [cache-php](https://github.com/YGGverse/cache-php) to save compiled pages in memory and [manticore](https://github.com/manticoresoftware) for full-text search.
4 months ago
Project under development, please join to work by sending PR or bug report!
## Examples
4 months ago
* `gemini://[301:23b4:991a:634d::b]` - Mirror of `http://[222:a8e4:50cd:55c:788e:b0a5:4e2f:a92c]`
4 months ago
* `gemini://betahowto.ygg` - Alfis / Yggdrasil alias
* `gemini://betahowto.duckdns.org` - Clearnet alias
4 months ago
## Install
1. `wget https://repo.manticoresearch.com/manticore-repo.noarch.deb`
2. `dpkg -i manticore-repo.noarch.deb`
3. `apt update`
4. `apt install git composer memcached manticore manticore-extra php-fpm php-memcached php-mysql php-mbstring`
5. `git clone https://github.com/YGGverse/bdoku.git`
6. `cd bdoku`
4 months ago
7. `composer update`
## Setup
1. `cd bdoku`
4 months ago
2. `mkdir host/127.0.0.1`
3. `cp example/config.json host/127.0.0.1/config.json`
4 months ago
4. `cd host/127.0.0.1`
5. `openssl req -x509 -newkey rsa:4096 -keyout key.rsa -out cert.pem -days 365 -nodes -subj "/CN=127.0.0.1"`
4 months ago
## Start
Before launch the server, copy or create alias of `path/to/dokuwiki/data` folder to `bdoku/host/127.0.0.1` on example above.
4 months ago
4 months ago
On every start, previous memory cache will be cleaned and new search index created.
4 months ago
After `data` folder update, you need just to restart your server with systemd or another process manager.
3 months ago
When launching with systemd, just make sure that manticore server already running:
```
[Unit]
Wants=manticore.service
After=manticore.service
...
```
4 months ago
`php src/server.php 127.0.0.1`
4 months ago
Open `gemini://127.0.0.1` in your favorite [Gemini browser](https://github.com/kr1sp1n/awesome-gemini)!
4 months ago
## Update
1. `cd bdoku`
4 months ago
2. `git pull` - get latest codebase from this repository
3. `composer update` - update vendor libraries