Skip to content

Use Cloudflare Workers to proxy repositories that implement OCI Distribution Spec (ghcr, gcr, etc.)

License

Notifications You must be signed in to change notification settings

ngalioth/registry-proxy

 
 

Repository files navigation

registry-proxy

Use Cloudflare Workers to proxy repositories that implement OCI Distribution Spec (ghcr, gcr, etc.)

Inspired by cloudflare-docker-proxy

GitHub Workflow Status Cloudflare Workers Container Registry License

Features

  • Quick Access: Leverages Cloudflare's network for significantly faster image access.
  • Dynamic Matching: Dynamically fetches records from Cloudflare KV based on the request subdomain for automatic proxying to the correct registry.
  • Authentication: Captures Need-Authentication Response to redirect users for authentication via the proxy, simplifying the auth process.
  • Open-Source Advantage: Fully open-source project, allowing technical personnel to contribute or customize as needed.
  • Simple Configuration: Easily manage proxy settings by editing JSON data in KV.
  • R2 Object Storage Caching: Implement caching of images using Cloudflare's R2 Storage Buckets.
  • Configuration Management RESTful API: Develop a RESTful API for easier and more flexible configuration management.
  • Implement the push API

Sequence Diagram

sequenceDiagram
participant User as User
participant Worker as Cloudflare Worker
participant KV as Cloudflare KV
participant TargetAuthSvc as Target Auth Service
participant OCI_Registry as Target OCI Image Registry

User->>Worker: Sends Initial Request
Note right of Worker: Worker parses the subdomain and fetches configuration from KV.
Worker->>KV: Retrieve Registry Details
KV-->>Worker: Return Details
Worker->>OCI_Registry: Proxy Request to OCI Registry
OCI_Registry-->>Worker: 401 Unauthorized with 'WWW-Authenticate' Header
Note over Worker, User: Worker captures 401 and rewrites the header to point to proxy auth.
Worker->>User: Indicates Proxy Authentication Required
User->>Worker: Sends Auth Request to Proxy
Worker->>TargetAuthSvc: Forwards Auth Request
TargetAuthSvc-->>Worker: Validates and Returns Token
Worker-->>User: Responds with Token
Note over User, Worker: User now has a valid token to access OCI Registry through the Worker proxy.
User->>Worker: Resubmits Request with Token
Worker->>OCI_Registry: Proxies Authenticated Request
OCI_Registry-->>Worker: Successfully Responds
Worker-->>User: Returns Response from OCI Registry
Loading

Demo

Target SVC Proxy SVC
ghcr ghcr.registry.mjolnir.tools , ghcr.registry.haidong.technology
gcr gcr.registry.mjolnir.tools , gcr.registry.haidong.technology
docker docker.registry.mjolnir.tools , docker.registry.haidong.technology
k8s k8s.registry.mjolnir.tools , k8s.registry.haidong.technology

Try it:

docker pull ghcr.registry.mjolnir.tools/haidongpang/hello-world

# or

docker pull ghcr.registry.haidong.technology/haidongpang/hello-world

Local Dev

Requirements

Ensure you have installed the following tools:

And have a Cloudflare account.

Step 1: Clone the Codebase

Firstly, clone the codebase to your local machine:

git clone https://github.com/HaidongPang/registry-proxy.git

cd registry-proxy

Step 2: Install Dependencies

bun install

Step 3: Start the Local Server

bun run dev

Deployment

Automatic Deployment

Deploy to Cloudflare Workers

  • fork this project
  • modify the link of the above button to your fork url
  • click the button, you will be redirected to the deploy page
  • Create a KV Namespace in the Cloudflare dashboard and bind it to your Worker

Manual Deployment

Requirements

Ensure you have installed the following tools:

And have a Cloudflare account.

Step 1: Clone the Codebase

Firstly, clone the codebase to your local machine:

git clone https://github.com/HaidongPang/registry-proxy.git

cd registry-proxy

Step 2: Install Dependencies

bun install

Step 3: Create a KV Namespace and Bind it to Your Worker

wrangler kv:namespace create mjolnir-registry-uploads

Modify the wrangler.toml 'kv_namespaces.id' field to the KV Namespace you created to bind the KV Namespace to the worker

Step 4: Deployment

bun run deploy

Post-Deployment Processing

Add Proxy Repository Mapping

After deployment, you need to add the following record in the bound KV Namespace:

Key Value
ghcr {"targetDomain":"ghcr.io", "authEndpoint":"https://ghcr.io/token"}
gcr {"targetDomain":"gcr.io", "authEndpoint":"https://gcr.io/v2/token"}
docker {"targetDomain":"registry-1.docker.io","authEndpoint":"https://auth.docker.io/token"}
k8s {"targetDomain":"registry.k8s.io","authEndpoint":"https://registry.k8s.io/v2/token"}

Add Domain Name Resolution

Add the following four custom domain names to your worker (assuming you own the example.org domain):

  • ghcr.example.org
  • gcr.example.org
  • docker.example.org
  • k8s.example.org

About

Use Cloudflare Workers to proxy repositories that implement OCI Distribution Spec (ghcr, gcr, etc.)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 100.0%