Reuse content across files
Part-of: <https://dev.funkwhale.audio/funkwhale/funkwhale/-/merge_requests/2415>
This commit is contained in:
		
							parent
							
								
									b46fdaacd5
								
							
						
					
					
						commit
						5b43ae4f2b
					
				|  | @ -316,48 +316,60 @@ That's it! systemd keeps these services running and starts them up in the correc | ||||||
| 
 | 
 | ||||||
| Funkwhale uses a reverse proxy to serve content to users. We use [Nginx](https://nginx.com) to serve this proxy. Follow this guide to install an Nginx configuration using details from your `.env` file. | Funkwhale uses a reverse proxy to serve content to users. We use [Nginx](https://nginx.com) to serve this proxy. Follow this guide to install an Nginx configuration using details from your `.env` file. | ||||||
| 
 | 
 | ||||||
| 1. Install Nginx. | :::{note} Before you begin | ||||||
|  | Nginx isn't preinstalled on Debian. You can install it by running the following commands: | ||||||
| 
 | 
 | ||||||
|    ```{code-block} sh | ```console | ||||||
|    sudo apt-get update | $ sudo apt update | ||||||
|    sudo apt-get install nginx | $ sudo apt install nginx | ||||||
|  | ``` | ||||||
|  | ::: | ||||||
|  | 
 | ||||||
|  | % Nginx update instructions | ||||||
|  | 
 | ||||||
|  | 1. Log in to a root shell to make changes to the config files | ||||||
|  | 
 | ||||||
|  |    ```console | ||||||
|  |    $ sudo su | ||||||
|    ``` |    ``` | ||||||
| 
 | 
 | ||||||
| 2. Download the Nginx templates from Funkwhale. | 2. Download the new Nginx templates from Funkwhale | ||||||
| 
 | 
 | ||||||
|    ```{code-block} sh |    ```console | ||||||
|    sudo curl -L -o /etc/nginx/funkwhale_proxy.conf "https://dev.funkwhale.audio/funkwhale/funkwhale/raw/$FUNKWHALE_VERSION/deploy/funkwhale_proxy.conf" |    # curl -L -o /etc/nginx/funkwhale_proxy.conf "https://dev.funkwhale.audio/funkwhale/funkwhale/raw/$FUNKWHALE_VERSION/deploy/funkwhale_proxy.conf" | ||||||
|    sudo curl -L -o /etc/nginx/sites-available/funkwhale.template "https://dev.funkwhale.audio/funkwhale/funkwhale/raw/$FUNKWHALE_VERSION/deploy/nginx.template" |    # curl -L -o /etc/nginx/sites-available/funkwhale.template "https://dev.funkwhale.audio/funkwhale/funkwhale/raw/$FUNKWHALE_VERSION/deploy/nginx.template" | ||||||
|    ``` |    ``` | ||||||
| 
 | 
 | ||||||
| 3. Create an Nginx template with details from your `.env` file. | 3. Update the Nginx configuration with details from your {file}`.env` file | ||||||
| 
 | 
 | ||||||
|    ```{code-block} sh |    ```console | ||||||
|    # Log in to a root shell. |    # set -a && source /srv/funkwhale/config/.env && set +a | ||||||
| 
 |  | ||||||
|    sudo su |  | ||||||
| 
 |  | ||||||
|    # Create an Nginx configuration using the Funkwhale template with details from your `.env` file. |  | ||||||
| 
 |  | ||||||
|    set -a && source /srv/funkwhale/config/.env && set +a |  | ||||||
|    envsubst "`env | awk -F = '{printf \" $%s\", $$1}'`" \ |    envsubst "`env | awk -F = '{printf \" $%s\", $$1}'`" \ | ||||||
|       < /etc/nginx/sites-available/funkwhale.template \ |       < /etc/nginx/sites-available/funkwhale.template \ | ||||||
|       > /etc/nginx/sites-available/funkwhale.conf |       > /etc/nginx/sites-available/funkwhale.conf | ||||||
| 
 |  | ||||||
|    # Enable the configuration so that Nginx serves it. |  | ||||||
| 
 |  | ||||||
|    ln -s /etc/nginx/sites-available/funkwhale.conf /etc/nginx/sites-enabled/ |  | ||||||
| 
 |  | ||||||
|    # Exit the root shell. |  | ||||||
| 
 |  | ||||||
|    exit |  | ||||||
|    ``` |    ``` | ||||||
| 
 | 
 | ||||||
| That's it! You've created your Nginx file. Run the following command to check the `.env` details populated correctly. | 4. Check the configuration file to make sure the template values have been updated properly | ||||||
| 
 | 
 | ||||||
| ```{code-block} sh |    ```console | ||||||
| grep '${' /etc/nginx/sites-enabled/funkwhale.conf |    # grep '${' /etc/nginx/sites-available/funkwhale.conf | ||||||
| ``` |    ``` | ||||||
|  | 
 | ||||||
|  | % Instructions end | ||||||
|  | 
 | ||||||
|  | 5. Create a symbolic link to the {file}`sites-enabled` directory to enable your configuration | ||||||
|  | 
 | ||||||
|  |    ```console | ||||||
|  |    # ln -s /etc/nginx/sites-available/funkwhale.conf /etc/nginx/sites-enabled/ | ||||||
|  |    ``` | ||||||
|  | 
 | ||||||
|  | 6. Restart Nginx | ||||||
|  | 
 | ||||||
|  |    ```console | ||||||
|  |    # systemctl restart nginx | ||||||
|  |    ``` | ||||||
|  | 
 | ||||||
|  | That's it! You've created your Nginx file. | ||||||
| 
 | 
 | ||||||
| ## 10. Set up TLS | ## 10. Set up TLS | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -37,39 +37,16 @@ If you installed Funkwhale following the [Debian guide](../installation/debian.m | ||||||
| 
 | 
 | ||||||
| To ensure your reverse proxy is up-to-date with changes, you should regenerate your Nginx configuration with each upgrade. To do this: | To ensure your reverse proxy is up-to-date with changes, you should regenerate your Nginx configuration with each upgrade. To do this: | ||||||
| 
 | 
 | ||||||
| 1. Log in to a root shell to make changes to the config files | :::{include} /administrator/installation/debian.md | ||||||
|  | :start-after: Nginx update instructions | ||||||
|  | :end-before: Instructions end | ||||||
|  | ::: | ||||||
| 
 | 
 | ||||||
|    ```console | Once you've updated your configuration, restart Nginx. | ||||||
|    $ sudo su |  | ||||||
|    ``` |  | ||||||
| 
 | 
 | ||||||
| 2. Download the new Nginx templates from Funkwhale | ```console | ||||||
| 
 | # systemctl restart nginx | ||||||
|    ```console | ``` | ||||||
|    # curl -L -o /etc/nginx/funkwhale_proxy.conf "https://dev.funkwhale.audio/funkwhale/funkwhale/raw/$FUNKWHALE_VERSION/deploy/funkwhale_proxy.conf" |  | ||||||
|    # curl -L -o /etc/nginx/sites-available/funkwhale.template "https://dev.funkwhale.audio/funkwhale/funkwhale/raw/$FUNKWHALE_VERSION/deploy/nginx.template" |  | ||||||
|    ``` |  | ||||||
| 
 |  | ||||||
| 3. Update the Nginx configuration with details from your {file}`.env` file |  | ||||||
| 
 |  | ||||||
|    ```console |  | ||||||
|    # set -a && source /srv/funkwhale/config/.env && set +a |  | ||||||
|    envsubst "`env | awk -F = '{printf \" $%s\", $$1}'`" \ |  | ||||||
|       < /etc/nginx/sites-available/funkwhale.template \ |  | ||||||
|       > /etc/nginx/sites-available/funkwhale.conf |  | ||||||
|    ``` |  | ||||||
| 
 |  | ||||||
| 4. Check the configuration file to make sure the template values have been updated properly |  | ||||||
| 
 |  | ||||||
|    ```console |  | ||||||
|    # grep '${' /etc/nginx/sites-enabled/funkwhale.conf |  | ||||||
|    ``` |  | ||||||
| 
 |  | ||||||
| 5. Restart Nginx |  | ||||||
| 
 |  | ||||||
|    ```console |  | ||||||
|    # systemctl restart nginx |  | ||||||
|    ``` |  | ||||||
| 
 | 
 | ||||||
| ## Update your Funkwhale instance | ## Update your Funkwhale instance | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Sporiff
						Sporiff