2020-07-02 11:22:52 -04:00
|
|
|
# Minio Guide for HedgeDoc
|
2018-01-23 05:47:47 -05:00
|
|
|
|
2020-07-02 11:22:52 -04:00
|
|
|
*Note:* This guide was written before the renaming. Just replace `HackMD` with `HedgeDoc` in your mind :smile: thanks!
|
2018-06-24 08:04:35 -04:00
|
|
|
|
2018-01-23 05:47:47 -05:00
|
|
|
1. First of all you need to setup Minio itself.
|
|
|
|
|
|
|
|
Please refer to the [official Minio docs](https://docs.minio.io/) for an
|
|
|
|
production setup.
|
|
|
|
|
|
|
|
For checking it out and development purposes a non-persistent setup is enough:
|
2019-03-31 14:10:32 -04:00
|
|
|
```sh
|
2018-01-23 05:47:47 -05:00
|
|
|
docker run --name test-minio --rm -d -p 9000:9000 minio/minio server /data
|
|
|
|
```
|
|
|
|
|
|
|
|
*Please notice this is not for productive use as all your data gets lost
|
|
|
|
when you stop this container*
|
|
|
|
|
|
|
|
2. Next step is to get the credentials form the container:
|
|
|
|
|
2019-03-31 14:10:32 -04:00
|
|
|
```sh
|
2018-01-23 05:47:47 -05:00
|
|
|
docker logs test-minio
|
|
|
|
```
|
|
|
|
|
2019-03-31 10:02:05 -04:00
|
|
|
![docker logs](../images/minio-image-upload/docker-logs.png)
|
2018-01-23 05:47:47 -05:00
|
|
|
|
2020-07-01 05:52:17 -04:00
|
|
|
3. Open <http://localhost:9000> and login with the shown credentials.
|
2018-01-23 05:47:47 -05:00
|
|
|
|
2019-03-31 10:02:05 -04:00
|
|
|
![minio default view](../images/minio-image-upload/default-view.png)
|
2018-01-23 05:47:47 -05:00
|
|
|
|
2020-07-02 11:22:52 -04:00
|
|
|
4. Create a bucket for HedgeDoc
|
2018-01-23 05:47:47 -05:00
|
|
|
|
2019-03-31 10:02:05 -04:00
|
|
|
![minio create bucket](../images/minio-image-upload/create-bucket.png)
|
2018-01-23 05:47:47 -05:00
|
|
|
|
|
|
|
5. Add a policy for the prefix `uploads` and make it read-only.
|
|
|
|
|
2019-03-31 10:02:05 -04:00
|
|
|
![minio edit policy](../images/minio-image-upload/open-edit-policy.png)
|
2018-01-23 05:47:47 -05:00
|
|
|
*Open policy editor*
|
|
|
|
|
2019-03-31 10:02:05 -04:00
|
|
|
![minio policy adding](../images/minio-image-upload/create-policy.png)
|
2018-01-23 05:47:47 -05:00
|
|
|
*Add policy for uploads*
|
|
|
|
|
2020-07-02 11:22:52 -04:00
|
|
|
6. Set credentials and configs for Minio in HedgeDoc's `config.json`
|
2018-01-23 05:47:47 -05:00
|
|
|
|
|
|
|
```JSON
|
|
|
|
"minio": {
|
|
|
|
"accessKey": "888MXJ7EP4XXXXXXXXX",
|
|
|
|
"secretKey": "yQS2EbM1Y6IJrp/1BUKWq2/XXXXXXXXXXXXXXX",
|
|
|
|
"endPoint": "localhost",
|
|
|
|
"port": 9000,
|
|
|
|
"secure": false
|
|
|
|
}
|
|
|
|
```
|
|
|
|
*You have to use different values for `endpoint` and `port` for a production
|
|
|
|
setup. Keep in mind the `endpoint`-address has to be public accessible from
|
|
|
|
your browser.*
|
|
|
|
|
|
|
|
7. Set bucket name
|
|
|
|
|
|
|
|
```JSON
|
2020-07-02 11:22:52 -04:00
|
|
|
"s3bucket": "hedgedoc"
|
2018-01-23 05:47:47 -05:00
|
|
|
```
|
|
|
|
|
|
|
|
8. Set upload type.
|
|
|
|
|
|
|
|
```JSON
|
2018-01-26 08:00:48 -05:00
|
|
|
"imageuploadtype": "minio"
|
2018-01-23 05:47:47 -05:00
|
|
|
```
|
|
|
|
|
|
|
|
9. Review your config.
|
|
|
|
|
|
|
|
```json
|
|
|
|
{
|
|
|
|
// all your other config…
|
|
|
|
"minio": {
|
|
|
|
"accessKey": "888MXJ7EP4XXXXXXXXX",
|
|
|
|
"secretKey": "yQS2EbM1Y6IJrp/1BUKWq2/XXXXXXXXXXXXXXX",
|
|
|
|
"endPoint": "localhost",
|
|
|
|
"port": 9000,
|
|
|
|
"secure": false
|
|
|
|
},
|
2020-07-02 11:22:52 -04:00
|
|
|
"s3bucket": "hedgedoc",
|
2018-01-26 08:00:48 -05:00
|
|
|
"imageuploadtype": "minio"
|
2018-01-23 05:47:47 -05:00
|
|
|
}
|
|
|
|
```
|
2020-09-22 13:41:15 -04:00
|
|
|
|
|
|
|
10. If you were using filesystem before
|
|
|
|
|
|
|
|
and you want to migrate assets to minio.
|
|
|
|
|
|
|
|
You could use a convenience script located in `bin/migrate_from_fs_to_minio`.
|
|
|
|
|
|
|
|
Be careful, read carefully what it does, it was not tested in all environments.
|
|
|
|
|
|
|
|
Take it as an inspiration to make your own migration script.
|