---
title: 'Deploy'
---
# Deploying the client
## Method 1 - Cloudflare Pages (Best host)
[Fork P-Stream](https://github.com/p-stream/p-stream/fork) on Github.
{' '}
Go to [Cloudflare pages](https://pages.dev) and click "Sign Up".
{' '}
Create a Cloudflare account.
If you already have a Cloudflare account you will be redirected to the
workers and pages dashboard.
{' '}
Now, click the blue "Create" button at the top of the page.
{' '}
By default Cloudflare assumes your creating a worker instead, change the
"Workers" tab to "Pages".
{' '}
Select the blue button that says "Connect to git" and then connect the Github
account you forked P-Stream on.
{' '}
Now you can select repositories from your github account, select your fork of
P-Stream and click "Begin setup".
{' '}
Give your project a silly name and select `main` as the production branch.
{' '}
In "Build settings" change the "Build command" to `pnpm build` and the "Build
output directory" to `dist`.
{' '}
Select the `Environment variable` drop down and add the below variables.
```env VITE_CORS_PROXY_URL = PUT_A_PROXY_URL_HERE VITE_TMDB_READ_API_KEY =
eyJhbGciOiJIUzI1NiJ9.eyJhdWQiOiI1NzlkZWYyZDY5ZWFlNDk4ZjJiOTI4MTgyNDdjM2ViMCIsInN1YiI6IjY2MjdmMGJlNjJmMzM1MDE0YmQ4NTFmMiIsInNjb3BlcyI6WyJhcGlfcmVhZCJdLCJ2ZXJzaW9uIjoxfQ.h3KpPvkiaz8uNz1bntAKqsPrxG_4UUWaY3kYME6N6m8
```
{' '}
Click "Save and Deploy" to watch your new site deploy.
Congrats! You have your own version of P-Stream hosted for **FREE**.
## Method 2 - Vercel (Might be broken idk)
Click [here](https://github.com/p-stream/p-stream/fork) to fork the P-Stream
Github repository
Click [here](https://vercel.com/) to go to Vercel
Sign in using either a GitHub, GitLab, or Bitbucket.
Clicking the "New Project" button on the top right of your dashboard and
following the steps to create a new project for your self hosted version of
movie web.
After clicking it, you'll be presented with a list of Git repositories that
the Git account you've signed up with has write access to.
Select your own fork of the P-Stream Github repository.
Configure the environment variables: - `VITE_CORS_PROXY_URL`: Enter your
proxy URL here. Make sure to not have a slash at the end of your URL.
Example (THIS IS AN EXAMPLE, IT WON'T WORK FOR YOU):
`https://test-proxy.test.workers.dev` - `VITE_TMDB_READ_API_KEY`: Enter your
TMDB Read Access Token here. Please read [the TMDB page](./tmdb.mdx) on how
to get an API key. - `VITE_BACKEND_URL`: Only set if you have a self-hosted
backend. Put in your backend URL. Check out [configuration
reference](../client/configuration.mdx) for details. Make sure to not have a
slash at the end of the URL.
Click "Deploy"
Congrats! You have your own version of P-Stream hosted.
You may wish to configure a custom domain - Please consult [the Vercel docs
for how to do
this](https://vercel.com/docs/getting-started-with-vercel/domains).
## Method 3 - Static Web Host
Download the file `P-Stream.zip` from the latest release:
https://github.com/p-stream/p-stream/releases/latest.
Extract the ZIP file so you can edit the files.
Open `config.js` in an editor such as Notepad, Visual Studio Code or
similar.
Put your proxy URL in-between the double quotes of `VITE_CORS_PROXY_URL:
""`. Make sure to not have a slash at the end of your URL. Example (THIS IS
AN EXAMPLE, IT WON'T WORK FOR YOU): `VITE_CORS_PROXY_URL:
"https://test-proxy.test.workers.dev"`
Put your TMDB Read Access Token inside the quotes of
`VITE_TMDB_READ_API_KEY: ""`. Please read [the TMDB page](./tmdb.mdx) on how
to get an API key.
If you have a self-hosted backend server, enter your URL in the
`VITE_BACKEND_URL` variable. Check out [configuration
reference](../client/configuration.mdx) for details. Make sure to not have a
slash at the end of the URL.
Save the file.
Upload **all** of the files to a static website hosting such as: - GitHub
Pages - Netlify - Vercel - Etc, [there are lots of
options](https://www.staticwebsitehosting.org/).
Congrats! You have your own version of P-Stream hosted.
## Method 4 - Docker Compose - Home Network
Docker is not recommended! It's much easier to host the static site and use a proxy like nginx to access.
This method is meant for those using a desktop device or single board computer with a minimum of 4GB of RAM such as a [Raspberry Pi](https://www.raspberrypi.com/) to run P-Stream on there home network for network connected devices.
1. Ensure you have [docker](https://docs.docker.com/get-docker/) installed. In a newly created directory called `P-Stream` create a file called `docker-compose.yaml`. Paste the contents of the code block below into this file.
```yaml
version: "3.8"
services:
movieweb:
build:
context: https://github.com/p-stream/p-stream.git#production
# args:
# TMDB_READ_API_KEY: ""
# CORS_PROXY_URL: ""
# BACKEND_URL: ""
ports:
- "80:80"
restart: unless-stopped
```
Within the `docker-compose.yaml` file uncomment `args`, `TMDB_READ_API_KEY`, `CORS_PROXY_URL`.
- Make sure `args` is in-line with `context`
- Make sure `TMDB_READ_API_KEY` and `CORS_PROXY_URL` are tabbed once to the right of `args`.
Put your proxy URL in-between the double quotes of `CORS_PROXY_URL: ""`. Make sure to not have a slash at the end of your URL.
Example (THIS IS AN EXAMPLE, IT WON'T WORK FOR YOU): `CORS_PROXY_URL: "https://test-proxy.test.workers.dev"`
Put your TMDB Read Access Token inside the quotes of `TMDB_READ_API_KEY: ""`. Please read [the TMDB page](./tmdb.mdx) on how to get an API key.
Uncomment and add any [additional environment variables](configuration.mdx) you may need. Remove the `VITE_` prefix when adding an environment variable to `args`.
Save the file!
Now use [docker](https://docs.docker.com/get-docker/) to run `movieweb` as background service.
```bash
# P-Stream is the current working directory
$ docker compose up --detach
```
Verify that setup was successful
- Navigate to `http://localhost`. You should see the UI for `P-Stream`. Find something to watch and make sure that it plays.
- View logs with
```bash
$ docker compose logs --follow movieweb
```
Set a static IP address for your device.
- For Raspberry Pi: [guide](https://www.makeuseof.com/raspberry-pi-set-static-ip/)
- For Mac: [guide](https://www.macinstruct.com/tutorials/how-to-set-a-static-ip-address-on-a-mac/)
- For Windows: [guide](https://www.pcmag.com/how-to/how-to-set-up-a-static-ip-address)
Navigate to movie web at `http://
### To Perform Updates For New Releases of Movie Web
Make sure `P-Stream` is your current working directory and run:
```bash
# Re-build the image and start the container
$ docker compose up --build --detach
```