mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2024-12-23 01:20:24 +03:00
Improved documentation mentioning how to pre-configure servers
This commit is contained in:
parent
4c11d9c6d5
commit
a1a0b935c7
1 changed files with 43 additions and 11 deletions
54
README.md
54
README.md
|
@ -14,9 +14,9 @@ A ReactJS-based progressive web application for [Shlink](https://shlink.io).
|
||||||
|
|
||||||
There are three ways in which you can use this application.
|
There are three ways in which you can use this application.
|
||||||
|
|
||||||
* The easiest way to use shlink-web-client is by just going to https://app.shlink.io.
|
* The easiest way to use shlink-web-client is by just going to <https://app.shlink.io>.
|
||||||
|
|
||||||
The application runs 100% in the browser, so you can use that instance and access any shlink instance from it.
|
The application runs 100% in the browser, so you can safely access any shlink instance from there.
|
||||||
|
|
||||||
* Self hosting the application yourself.
|
* Self hosting the application yourself.
|
||||||
|
|
||||||
|
@ -24,28 +24,60 @@ There are three ways in which you can use this application.
|
||||||
|
|
||||||
The package contains static files only, so just put it in a folder and serve it with the web server of your choice.
|
The package contains static files only, so just put it in a folder and serve it with the web server of your choice.
|
||||||
|
|
||||||
Provided dist files are configured to be served from the root of your domain. If you need to serve shlink-web-client from a subpath, you will have to build it yourself following [these simple steps](#serve-shlink-in-subpath).
|
Provided dist files are configured to be served from the root of your domain. If you need to serve shlink-web-client from a subpath, you will have to build it yourself following [these steps](#serve-shlink-in-subpath).
|
||||||
|
|
||||||
* Use the official [docker image](https://hub.docker.com/r/shlinkio/shlink-web-client/)
|
* Using the official [docker image](https://hub.docker.com/r/shlinkio/shlink-web-client/)
|
||||||
|
|
||||||
If you want to deploy shlink-web-client in a container-based cluster (kubernetes, docker swarm, etc), just pick the image and do it.
|
If you want to deploy shlink-web-client in a container-based cluster (kubernetes, docker swarm, etc), just pick the `shlinkio/shlink-web-client` image and do it.
|
||||||
|
|
||||||
It's a lightweight [nginx:alpine](https://hub.docker.com/r/library/nginx/) image serving the assets on port 80.
|
It's a lightweight [nginx:alpine](https://hub.docker.com/r/library/nginx/) image serving the static app on port 80.
|
||||||
|
|
||||||
|
## Pre-configuring servers
|
||||||
|
|
||||||
|
The first time you access shlink-web-client from a browser, you will have to configure the list of shlink servers you want to manage, and they will be saved in the local storage.
|
||||||
|
|
||||||
|
Those servers can be exported and imported in other browsers, but if for some reason you need some servers to be there from the beginning, you can provide a `servers.json` file in the project root folder (the same containing the `index.html`, `favicon.ico`, etc) with a structure like this:
|
||||||
|
|
||||||
|
```json
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"name": "Main server",
|
||||||
|
"url": "https://doma.in",
|
||||||
|
"apiKey": "09c972b7-506b-49f1-a19a-d729e22e599c"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Local",
|
||||||
|
"url": "http://localhost:8080",
|
||||||
|
"apiKey": "580d0b42-4dea-419a-96bf-6c876b901451"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
|
> The list can contain as many servers as you need.
|
||||||
|
|
||||||
|
If you are using the shlink-web-client docker image, you can mount the `servers.json` file in a volume inside `/usr/share/nginx/html`, which is the app's document root inside the container.
|
||||||
|
|
||||||
|
docker run --name shlink-web-client -p 8000:80 -v ${PWD}/servers.json:/usr/share/nginx/html/servers.json shlinkio/shlink-web-client
|
||||||
|
|
||||||
## Serve project in subpath
|
## Serve project in subpath
|
||||||
|
|
||||||
Official distributable files have been build so that they are served from the root of a domain.
|
Official distributable files have been built so that they are served from the root of a domain.
|
||||||
|
|
||||||
If you need to host shlink-web-client yourself and serve it from a subpath, follow these steps:
|
If you need to host shlink-web-client yourself and serve it from a subpath, follow these steps:
|
||||||
|
|
||||||
* Download [node](https://nodejs.org/en/download/package-manager/) 10.15 or later (if you don't have it yet).
|
|
||||||
* Download shlink-web-client source code for the version you want to build.
|
* Download shlink-web-client source code for the version you want to build.
|
||||||
* For example, if you want to build `v1.0.1`, use this link https://github.com/shlinkio/shlink-web-client/archive/v1.0.1.zip
|
* For example, if you want to build `v1.0.1`, use this link https://github.com/shlinkio/shlink-web-client/archive/v1.0.1.zip
|
||||||
* Replace the `v1.0.1` part in the link with the one of the version you want to build.
|
* Replace the `v1.0.1` part in the link with the one of the version you want to build.
|
||||||
* Decompress the file and `cd` into the resulting folder.
|
* Decompress the file and `cd` into the resulting folder.
|
||||||
* Install project dependencies by running `npm install`.
|
|
||||||
* Open the `package.json` file in the root of the project, locate the `homepage` property and replace the value (which should be an empty string) by the path from which you want to serve shlink-web-client.
|
* Open the `package.json` file in the root of the project, locate the `homepage` property and replace the value (which should be an empty string) by the path from which you want to serve shlink-web-client.
|
||||||
* For example: `"homepage": "/my-projects/shlink-web-client",`.
|
* For example: `"homepage": "/my-projects/shlink-web-client",`.
|
||||||
* Build the project:
|
* Build the project:
|
||||||
* For a static distributable file, run `npm run build`. Once the command finishes, you will have a `build` folder with all the static assets you need to run shlink-web-client. Just place them wherever you want them to be served from.
|
* For classic hosting:
|
||||||
* For a docker image, run `docker build . -t shlink-web-client`. Once the command finishes, you will have an image with the name `shlink-web-client`.
|
* Download [node](https://nodejs.org/en/download/package-manager/) 10.15 or later.
|
||||||
|
* Install project dependencies by running `npm install`.
|
||||||
|
* Build the project by running `npm run build`.
|
||||||
|
* Once the command finishes, you will have a `build` folder with all the static assets you need to run shlink-web-client. Just place them wherever you want them to be served from.
|
||||||
|
* For docker image:
|
||||||
|
* Download [docker](https://docs.docker.com/install/).
|
||||||
|
* Build the docker image by running `docker build . -t shlink-web-client`.
|
||||||
|
* Once the command finishes, you will have an image with the name `shlink-web-client`.
|
||||||
|
|
Loading…
Reference in a new issue