Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devaoto/rust-m3u8-proxy
A M3U8 CORS Proxy written in Rust
https://github.com/devaoto/rust-m3u8-proxy
cors cors-proxy m3u8-cors-proxy m3u8-proxy rust rust-lang rust-warp warp warp-rust
Last synced: 2 months ago
JSON representation
A M3U8 CORS Proxy written in Rust
- Host: GitHub
- URL: https://github.com/devaoto/rust-m3u8-proxy
- Owner: devaoto
- License: mit
- Created: 2024-08-11T09:44:02.000Z (6 months ago)
- Default Branch: master
- Last Pushed: 2024-08-12T06:32:18.000Z (6 months ago)
- Last Synced: 2024-10-12T15:20:44.199Z (3 months ago)
- Topics: cors, cors-proxy, m3u8-cors-proxy, m3u8-proxy, rust, rust-lang, rust-warp, warp, warp-rust
- Language: Rust
- Homepage:
- Size: 47.9 KB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# M3U8 CORS Proxy
This is a simple CORS proxy built with Rust and Warp. It allows you to forward requests to a specified URL while handling CORS headers.
## Features
- Handles GET requests and proxies them to the specified target URL.
- Supports adding `Referer` and `Origin` headers.
- Optionally proxies all URLs in `.m3u8` playlists.## Requirements
- Rust (latest stable version)
- Cargo (comes with Rust)## Setup
1. **Clone the repository:**
```bash
git clone https://github.com/devaoto/rust-m3u8-proxy.git
cd rust-m3u8-proxy
```2. **Build the project:**
```bash
cargo build --release
```3. **Run the application:**
```bash
cargo run --release
```The server will start on `http://127.0.0.1:3030`.
## Usage
Make a GET request to the `/proxy` endpoint with the following query parameters:
- `url`: The target URL to fetch.
- `referer`: (Optional) The Referer header value.
- `origin`: (Optional) The Origin header value.
- `all`: (Optional) Set to `yes` to proxy all HTTP links in `.m3u8` playlists.Example:
```bash
curl "http://127.0.0.1:3030/proxy?url=https://example.com/stream.m3u8&referer=https://yourreferer.com&origin=https://yourorigin.com&all=yes"
```#### Note: All the links must be URI Encoded
## Hosting
You can host this application using services like:
- **Railway**: [railway.app](https://railway.app/) (Paid)
- **Render**: [render.com](https://render.com/) (Free)
- **Heroku**: [heroku.com](https://www.heroku.com/) (Half-paid, CC required)## Docker Support
You can run this application in a Docker container. See the `Dockerfile` section below for instructions.
## Contributing
Feel free to open issues or submit pull requests to enhance the functionality of this CORS proxy.
## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
### Dockerfile
```dockerfile
# Use the official Rust image as the base image
FROM rust:latest AS builder# Set the working directory
WORKDIR /usr/src/app# Copy the source code
COPY . .# Build the application
RUN cargo build --release# Use a minimal base image for the final image
FROM debian:buster-slim# Copy the compiled binary from the builder stage
COPY --from=builder /usr/src/app/target/release/rust-m3u8-proxy /usr/local/bin/rust-m3u8-proxy# Expose the port
EXPOSE 3030# Run the application
CMD ["rust-m3u8-proxy"]
```### Running with Docker
1. **Build the Docker image:**
```bash
docker build -t rust-m3u8-proxy .
```2. **Run the Docker container:**
```bash
docker run -p 3030:3030 rust-m3u8-proxy
```Your application should now be accessible at `http://localhost:3030`.
```
```
## Important Notice
This project was inspired by Chance's Cloudflare Worker M3U8 Proxy
URL: https://github.com/Gratenes/m3u8CloudflareWorkerProxy