2020-03-14 15:26:35 +00:00
|
|
|
### Server Plugin
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
frp server plugin is aimed to extend frp's ability without modifying the Golang code.
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
An external server should run in a different process receiving RPC calls from frps.
|
|
|
|
Before frps is doing some operations, it will send RPC requests to notify the external RPC server and act according to its response.
|
2020-01-03 03:35:12 +00:00
|
|
|
|
|
|
|
### RPC request
|
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
RPC requests are based on JSON over HTTP.
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
When a server plugin accepts an operation request, it can respond with three different responses:
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
* Reject operation and return a reason.
|
2020-01-03 03:35:12 +00:00
|
|
|
* Allow operation and keep original content.
|
|
|
|
* Allow operation and return modified content.
|
|
|
|
|
|
|
|
### Interface
|
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
HTTP path can be configured for each manage plugin in frps. We'll assume for this example that it's `/handler`.
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
A request to the RPC server will look like:
|
2020-01-03 03:35:12 +00:00
|
|
|
|
|
|
|
```
|
2020-03-20 12:53:14 +00:00
|
|
|
POST /handler?version=0.1.0&op=Login
|
2020-01-03 03:35:12 +00:00
|
|
|
{
|
|
|
|
"version": "0.1.0",
|
|
|
|
"op": "Login",
|
|
|
|
"content": {
|
|
|
|
... // Operation info
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
Request Header:
|
2020-01-03 03:35:12 +00:00
|
|
|
X-Frp-Reqid: for tracing
|
|
|
|
```
|
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
The response can look like any of the following:
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
* Non-200 HTTP response status code (this will automatically tell frps that the request should fail)
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
* Reject operation:
|
2020-01-03 03:35:12 +00:00
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"reject": true,
|
|
|
|
"reject_reason": "invalid user"
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
* Allow operation and keep original content:
|
2020-01-03 03:35:12 +00:00
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"reject": false,
|
|
|
|
"unchange": true
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
* Allow operation and modify content
|
2020-01-03 03:35:12 +00:00
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"unchange": "false",
|
|
|
|
"content": {
|
|
|
|
... // Replaced content
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Operation
|
|
|
|
|
2020-04-16 05:06:46 +00:00
|
|
|
Currently `Login`, `NewProxy`, `Ping`, `NewWorkConn` and `NewUserConn` operations are supported.
|
2020-01-03 03:35:12 +00:00
|
|
|
|
|
|
|
#### Login
|
|
|
|
|
|
|
|
Client login operation
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"content": {
|
|
|
|
"version": <string>,
|
|
|
|
"hostname": <string>,
|
|
|
|
"os": <string>,
|
|
|
|
"arch": <string>,
|
|
|
|
"user": <string>,
|
|
|
|
"timestamp": <int64>,
|
|
|
|
"privilege_key": <string>,
|
|
|
|
"run_id": <string>,
|
|
|
|
"pool_count": <int>,
|
|
|
|
"metas": map<string>string
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
#### NewProxy
|
|
|
|
|
|
|
|
Create new proxy
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"content": {
|
|
|
|
"user": {
|
|
|
|
"user": <string>,
|
|
|
|
"metas": map<string>string
|
2020-03-14 15:26:35 +00:00
|
|
|
"run_id": <string>
|
2020-01-03 03:35:12 +00:00
|
|
|
},
|
|
|
|
"proxy_name": <string>,
|
|
|
|
"proxy_type": <string>,
|
|
|
|
"use_encryption": <bool>,
|
|
|
|
"use_compression": <bool>,
|
|
|
|
"group": <string>,
|
|
|
|
"group_key": <string>,
|
|
|
|
|
|
|
|
// tcp and udp only
|
|
|
|
"remote_port": <int>,
|
|
|
|
|
|
|
|
// http and https only
|
|
|
|
"custom_domains": []<string>,
|
|
|
|
"subdomain": <string>,
|
|
|
|
"locations": <string>,
|
|
|
|
"http_user": <string>,
|
|
|
|
"http_pwd": <string>,
|
|
|
|
"host_header_rewrite": <string>,
|
|
|
|
"headers": map<string>string,
|
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
// stcp only
|
|
|
|
"sk": <string>,
|
|
|
|
|
|
|
|
// tcpmux only
|
|
|
|
"multiplexer": <string>
|
|
|
|
|
2020-01-03 03:35:12 +00:00
|
|
|
"metas": map<string>string
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-03-17 17:52:44 +00:00
|
|
|
#### Ping
|
|
|
|
|
|
|
|
Heartbeat from frpc
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"content": {
|
|
|
|
"user": {
|
|
|
|
"user": <string>,
|
|
|
|
"metas": map<string>string
|
|
|
|
"run_id": <string>
|
|
|
|
},
|
|
|
|
"timestamp": <int64>,
|
|
|
|
"privilege_key": <string>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
#### NewWorkConn
|
|
|
|
|
|
|
|
New work connection received from frpc (RPC sent after `run_id` is matched with an existing frp connection)
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"content": {
|
|
|
|
"user": {
|
|
|
|
"user": <string>,
|
|
|
|
"metas": map<string>string
|
|
|
|
"run_id": <string>
|
|
|
|
},
|
|
|
|
"run_id": <string>
|
|
|
|
"timestamp": <int64>,
|
|
|
|
"privilege_key": <string>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-04-16 05:06:46 +00:00
|
|
|
#### NewUserConn
|
|
|
|
|
|
|
|
New user connection received from proxy (support `tcp`, `stcp`, `https` and `tcpmux`) .
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"content": {
|
|
|
|
"user": {
|
|
|
|
"user": <string>,
|
|
|
|
"metas": map<string>string
|
|
|
|
"run_id": <string>
|
|
|
|
},
|
|
|
|
"proxy_name": <string>,
|
|
|
|
"proxy_type": <string>,
|
|
|
|
"remote_addr": <string>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
### Server Plugin Configuration
|
2020-01-03 03:35:12 +00:00
|
|
|
|
|
|
|
```ini
|
2020-03-14 15:26:35 +00:00
|
|
|
# frps.ini
|
2020-01-03 03:35:12 +00:00
|
|
|
[common]
|
|
|
|
bind_port = 7000
|
|
|
|
|
|
|
|
[plugin.user-manager]
|
|
|
|
addr = 127.0.0.1:9000
|
|
|
|
path = /handler
|
|
|
|
ops = Login
|
|
|
|
|
|
|
|
[plugin.port-manager]
|
|
|
|
addr = 127.0.0.1:9001
|
|
|
|
path = /handler
|
|
|
|
ops = NewProxy
|
|
|
|
```
|
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
addr: the address where the external RPC service listens on.
|
|
|
|
path: http request url path for the POST request.
|
2020-03-17 17:52:44 +00:00
|
|
|
ops: operations plugin needs to handle (e.g. "Login", "NewProxy", ...).
|
2020-03-14 15:26:35 +00:00
|
|
|
|
|
|
|
### Metadata
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
Metadata will be sent to the server plugin in each RPC request.
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
There are 2 types of metadata entries - 1 under `[common]` and the other under each proxy configuration.
|
|
|
|
Metadata entries under `[common]` will be sent in `Login` under the key `metas`, and in any other RPC request under `user.metas`.
|
|
|
|
Metadata entries under each proxy configuration will be sent in `NewProxy` op only, under `metas`.
|
2020-01-03 03:35:12 +00:00
|
|
|
|
2020-03-14 15:26:35 +00:00
|
|
|
Metadata entries start with `meta_`. This is an example of metadata entries in `[common]` and under the proxy named `[ssh]`:
|
2020-01-03 03:35:12 +00:00
|
|
|
|
|
|
|
```
|
|
|
|
# frpc.ini
|
|
|
|
[common]
|
|
|
|
server_addr = 127.0.0.1
|
|
|
|
server_port = 7000
|
|
|
|
user = fake
|
|
|
|
meta_token = fake
|
|
|
|
meta_version = 1.0.0
|
|
|
|
|
|
|
|
[ssh]
|
|
|
|
type = tcp
|
|
|
|
local_port = 22
|
|
|
|
remote_port = 6000
|
|
|
|
meta_id = 123
|
|
|
|
```
|