forked from Shiloh/githaven
86 lines
2.0 KiB
Markdown
86 lines
2.0 KiB
Markdown
|
# Nextcloud OAuth2
|
||
|
|
||
|
For this backend, you need to have an OAuth2 enabled Nextcloud Instance, e.g.
|
||
|
on your own private server.
|
||
|
|
||
|
## Setting up Nextcloud Test Environment
|
||
|
|
||
|
To test, you only need a working Docker image of Nextcloud running on a public
|
||
|
URL, e.g. through [traefik](https://traefik.io/)
|
||
|
|
||
|
```docker-compose.yml
|
||
|
version: '2'
|
||
|
|
||
|
networks:
|
||
|
traefik-web:
|
||
|
external: true
|
||
|
|
||
|
services:
|
||
|
app:
|
||
|
image: nextcloud
|
||
|
restart: always
|
||
|
networks:
|
||
|
- traefik-web
|
||
|
labels:
|
||
|
- traefik.enable=true
|
||
|
- traefik.frontend.rule=Host:${NEXTCLOUD_DNS}
|
||
|
- traefik.docker.network=traefik-web
|
||
|
environment:
|
||
|
SQLITE_DATABASE: "database.sqlite3"
|
||
|
NEXTCLOUD_ADMIN_USER: admin
|
||
|
NEXTCLOUD_ADMIN_PASSWORD: admin
|
||
|
NEXTCLOUD_TRUSTED_DOMAINS: ${NEXTCLOUD_DNS}
|
||
|
```
|
||
|
|
||
|
and start it up via
|
||
|
|
||
|
```
|
||
|
NEXTCLOUD_DNS=goth.my.server.name docker-compose up -d
|
||
|
```
|
||
|
|
||
|
afterwards, you will have a running Nextcloud instance with credentials
|
||
|
|
||
|
```
|
||
|
admin / admin
|
||
|
```
|
||
|
|
||
|
Then add a new OAuth 2.0 Client by going to
|
||
|
|
||
|
```
|
||
|
Settings -> Security -> OAuth 2.0 client
|
||
|
```
|
||
|
|
||
|
![Nextcloud Setup](nextcloud_setup.png)
|
||
|
|
||
|
and add a new client with the name `goth` and redirection uri `http://localhost:3000/auth/nextcloud/callback`. The imporant part here the
|
||
|
two cryptic entries `Client Identifier` and `Secret`, which needs to be
|
||
|
used in your application.
|
||
|
|
||
|
## Running Login Example
|
||
|
|
||
|
If you want to run the default example in `<goth>/examples`, you have to
|
||
|
retrieve the keys described in the previous section and run the example
|
||
|
as follows:
|
||
|
|
||
|
```
|
||
|
NEXTCLOUD_URL=https://goth.my.server.name \
|
||
|
NEXTCLOUD_KEY=<your-key> \
|
||
|
NEXTCLOUD_SECRET=<your-secret> \
|
||
|
SESSION_SECRET=1 \
|
||
|
./examples
|
||
|
```
|
||
|
|
||
|
Afterwards, you should be able to login via Nextcloud in the examples app.
|
||
|
|
||
|
## Running the Provider Test
|
||
|
|
||
|
The test has the same arguments as the login example test, but starts the test itself
|
||
|
|
||
|
```
|
||
|
NEXTCLOUD_URL=https://goth.my.server.name \
|
||
|
NEXTCLOUD_KEY=<your-key> \
|
||
|
NEXTCLOUD_SECRET=<your-secret> \
|
||
|
SESSION_SECRET=1 \
|
||
|
go test -v
|
||
|
```
|