Tunnelfy
Managing Cloudflare tunnels directly from a VS Code extension has never been easier. Streamline your development workflow by creating and managing permanent and quick tunnels without leaving your IDE.
data:image/s3,"s3://crabby-images/c33df/c33df62e1bb9cd02dbfb18904cafbec9b32d45a3" alt="Tunnelfy Cloudflare Overview"
Features
Profile Management
- Manage multiple Cloudflare profiles with API keys
- Securely store API keys using VS Code's built-in secret storage
- Switch between profiles easily
- Each profile maintains its own configuration and tunnels
Tunnel Monitoring and Control
- View all your Cloudflare tunnels with status indicators
- Start and stop tunnels
- Manage permanent and quick tunnels
- Securely access tunnel tokens for configuration
- View detailed tunnel information
- Run tunnels with persistent background operation
Prerequisites
- VS Code (v1.85.0 or higher)
- A Cloudflare account with API key access
- Cloudflare Tunnel CLI (
cloudflared
) installed
Getting Started
1. Install the Extension
- Open VS Code
- Go to Extensions (Ctrl+Shift+X / Cmd+Shift+X)
- Search for "Tunnelfy"
- Click Install
2. Install Cloudflare Tunnel CLI (cloudflared
)
data:image/s3,"s3://crabby-images/03f63/03f63869acf8fd5772c119935b98a6e9ecaf66fd" alt="Creating a Cloudflare API Token"
- Follow the instructions in the Installing Cloudflare Tunnel CLI (
cloudflared
) section
3. Create a Profile
data:image/s3,"s3://crabby-images/964a4/964a47a7ea3023c98b9e0e52ef5ff511d8d3f30a" alt="Creating Cloudflare Profiles"
- Click the cloud icon in the activity bar
- Click the + button in the Profiles section
- Enter a name for your profile
- Enter your Cloudflare API key. You can create one by:
- Navigating to the Cloudflare Dashboard
- Clicking on the "My Profile" icon
- Clicking on "API Tokens"
- Clicking on "Create Token"
- Selecting the following permissions:
- Account: Account Settings: Read
- Account: Cloudflare Tunnel: Edit
- Zone: DNS: Edit
- Client IP Address Filtering (OPTIONAL but recommended):
4. Persistent Tunnels
data:image/s3,"s3://crabby-images/c42b6/c42b6fa8a29c185f709a1b9f3b39acfe81b54578" alt="Creating Persistent Tunnels"
- Click the + button in the Tunnels section
- Enter a name for your tunnel
- Once created, you can:
- Start and stop the tunnel
- View tunnel information and sample configuration setups
- Copy the tunnel token
- Delete the tunnel
5. Quick Tunnels
data:image/s3,"s3://crabby-images/b737f/b737f1df15e9b47771ae05faddba5a8da7cc0cfa" alt="Creating Quick Tunnels"
- Click the + button in the Quick Tunnels section
- Configure your local service details:
- Once running, you can:
- Copy the Cloudflare-assigned hostname
- Stop the tunnel
Extension Commands
Several commands are accessible via the Command Palette (Ctrl+Shift+P / Cmd+Shift+P):
Profile Management
Tunnelfy: Create Profile
- Create a new Cloudflare profile with an API key
Tunnelfy: Switch Profile
- Switch between Cloudflare profiles
Tunnelfy: Delete Profile
- Delete a Cloudflare profile
Permanent Tunnel Management
Tunnelfy: Create Tunnel
- Create a new permanent tunnel
Tunnelfy: Refresh Tunnels
- Refresh the list of tunnels
Tunnelfy: Start Tunnel
- Start a tunnel
Tunnelfy: Stop Tunnel
- Stop a tunnel
Tunnelfy: View Tunnel Info
- View detailed information about a tunnel
Tunnelfy: Copy Tunnel Token
- Copy the token of a tunnel
Tunnelfy: Delete Tunnel
- Delete a tunnel
Quick Tunnel Management
Tunnelfy: Create Quick Tunnel
- Create a new quick tunnel
Tunnelfy: Copy Quick Tunnel URL
- Copy the URL of a quick tunnel
Tunnelfy: Stop Quick Tunnel
- Stop a quick tunnel
Troubleshooting
Common Issues
Invalid API Key
- Make sure your API key has the correct permissions (Cloudflare Tunnel:Edit)
- Verify the API key is still active in your Cloudflare dashboard
- Try creating a new API key if issues persist
Profile Switching Issues
- Ensure the API key for the profile is still valid
- Check your internet connection
- Try deleting and recreating the profile if issues persist
Tunnel Creation Fails
- Verify your API key has sufficient permissions
- Check if you've reached your account's tunnel limit
- Ensure you have a stable internet connection
Quick Tunnel Issues
- Verify cloudflared is installed and accessible
- Check if the port is already in use
- Look for rate limiting messages in the output
- Ensure you have a stable internet connection
Development Environment Issues
- Run
npm install
to ensure all dependencies are installed
- Clear the VS Code extension development host:
rm -rf .vscode-test
- Check the extension logs in the Output panel
- Verify cloudflared installation and permissions
Security
- API keys are stored securely using VS Code's built-in secret storage
- Keys are never displayed after initial entry
- Each profile maintains its own isolated API key
- No sensitive data is stored in plain text
Contributing
We welcome contributions! Here's how you can help:
Fork the Repository
- Create a fork of the repository
- Clone your fork locally
Set Up Development Environment
# Install dependencies
npm install
npm install -g yo generator-code
# Install recommended VS Code extensions
code --install-extension dbaeumer.vscode-eslint
code --install-extension esbenp.prettier-vscode
Create a Feature Branch
git checkout -b feature/your-feature
Make Your Changes
- Write code following our style guidelines
- Add tests for new functionality
- Update documentation as needed
Test Your Changes
# Run the test suite
npm test
# Run ESLint
npm run lint
Merge to Development
# Use our merge script
./scripts/merge-to-development.sh
Create a Pull Request
- Push your changes to your fork
- Create a pull request to our development branch
- Follow the pull request template
- Wait for review and address any feedback
For more detailed information about development, please see our Development Guide.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Support
If you encounter any issues or have suggestions, please:
- Check the Troubleshooting section
- View the extension logs
- Open an issue on GitHub
- Email info@tunnelfy.com if all else fails (response time will be slow)
Installing Cloudflare Tunnel CLI (cloudflared
)
Cloudflare Tunnel CLI (cloudflared
) allows you to securely control exposing local applications to the internet without opening firewall ports. It is an essential part of Tunnelfy functionality.
Linux Installation
Debian/Ubuntu-based distributions
sudo apt update && sudo apt install -y curl
curl -fsSL https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 -o cloudflared
sudo chmod +x cloudflared
sudo mv cloudflared /usr/local/bin/
cloudflared --version
RHEL/Fedora-based distributions
sudo dnf install -y curl
curl -fsSL https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 -o cloudflared
sudo chmod +x cloudflared
sudo mv cloudflared /usr/local/bin/
cloudflared --version
Arch Linux-based distributions
yay -S cloudflared-bin
cloudflared --version
Windows Installation
Using the MSI Installer
- Download the latest Cloudflare Tunnel client from:
- Run the installer and follow the prompts.
- Verify installation in Command Prompt or PowerShell:
cloudflared --version
Using Chocolatey
choco install cloudflared
cloudflared --version
Using Winget
winget install Cloudflare.cloudflared
cloudflared --version
macOS Installation (Homebrew)
brew install cloudflare/cloudflare/cloudflared
brew services start cloudflared
cloudflared --version