25f88249c2f72d98bf56fd4fa476ce071729ff4b
Remove sensitive information from instance listing response for all users and add isRunning field Fix backend to prevent starting already running frpc instances
Super-frpc
A backend application for managing local frpc instances, allowing users to easily start, stop, restart, and perform daily maintenance operations on frpc instances. It also provides automated error handling, such as automatic restart when an instance crashes.
Features
- User authentication with token-based login
- Create, delete, and modify frpc instances
- Automatic startup configuration (systemd/init.d)
- User permission management (superuser/admin/visitor)
- SQLite database for data persistence
Supported Platforms
GNU/LinuxWindows
Configuration
Create a config.json file in the project root:
{
"listenAddr": "0.0.0.0",
"listenPort": "8080",
"frpcPath": "/usr/bin/frpc",
"instancePath": "./configs"
}
| Field | Description | Default |
|---|---|---|
| listenAddr | Server listening address | 0.0.0.0 |
| listenPort | Server listening port | 8080 |
| frpcPath | Path to frpc executable | /usr/bin/frpc |
| instancePath | Path to store instance config files | ./configs |
Build
go build -o super-frpc.exe
For Linux:
GOOS=linux GOARCH=amd64 go build -o super-frpc
Run
./super-frpc -config ./config.json -db ./database.db
API Documentation
For detailed API documentation, please see docs/api.md
TODO
- Add Windows boot service support
- Add session list API
- Add session management API
- Add user config modify API
- Add frpc instance running status management API
- Add frpc instance log display API
- Fix random database lock when processing logs
- Add frpc createdBy storage and display
- Fix backend can still start frpc instance when it is already running
License
GPL-3.0
Languages
Go
100%