Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
企猫商务
frp
提交
809f517d
F
frp
项目概览
企猫商务
/
frp
与 Fork 源项目一致
从无法访问的项目Fork
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
F
frp
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
809f517d
编写于
3月 20, 2020
作者:
F
fatedier
提交者:
GitHub
3月 20, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
server plugin: set version and op in http request query (#1707)
上级
a4b105de
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
22 addition
and
2 deletion
+22
-2
doc/server_plugin.md
doc/server_plugin.md
+1
-1
models/plugin/server/http.go
models/plugin/server/http.go
+5
-1
models/plugin/server/manager.go
models/plugin/server/manager.go
+16
-0
未找到文件。
doc/server_plugin.md
浏览文件 @
809f517d
...
@@ -22,7 +22,7 @@ HTTP path can be configured for each manage plugin in frps. We'll assume for thi
...
@@ -22,7 +22,7 @@ HTTP path can be configured for each manage plugin in frps. We'll assume for thi
A request to the RPC server will look like:
A request to the RPC server will look like:
```
```
POST /handler
POST /handler
?version=0.1.0&op=Login
{
{
"version": "0.1.0",
"version": "0.1.0",
"op": "Login",
"op": "Login",
...
...
models/plugin/server/http.go
浏览文件 @
809f517d
...
@@ -21,6 +21,7 @@ import (
...
@@ -21,6 +21,7 @@ import (
"fmt"
"fmt"
"io/ioutil"
"io/ioutil"
"net/http"
"net/http"
"net/url"
"reflect"
"reflect"
)
)
...
@@ -78,7 +79,10 @@ func (p *httpPlugin) do(ctx context.Context, r *Request, res *Response) error {
...
@@ -78,7 +79,10 @@ func (p *httpPlugin) do(ctx context.Context, r *Request, res *Response) error {
if
err
!=
nil
{
if
err
!=
nil
{
return
err
return
err
}
}
req
,
err
:=
http
.
NewRequest
(
"POST"
,
p
.
url
,
bytes
.
NewReader
(
buf
))
v
:=
url
.
Values
{}
v
.
Set
(
"version"
,
r
.
Version
)
v
.
Set
(
"op"
,
r
.
Op
)
req
,
err
:=
http
.
NewRequest
(
"POST"
,
p
.
url
+
"?"
+
v
.
Encode
(),
bytes
.
NewReader
(
buf
))
if
err
!=
nil
{
if
err
!=
nil
{
return
err
return
err
}
}
...
...
models/plugin/server/manager.go
浏览文件 @
809f517d
...
@@ -55,6 +55,10 @@ func (m *Manager) Register(p Plugin) {
...
@@ -55,6 +55,10 @@ func (m *Manager) Register(p Plugin) {
}
}
func
(
m
*
Manager
)
Login
(
content
*
LoginContent
)
(
*
LoginContent
,
error
)
{
func
(
m
*
Manager
)
Login
(
content
*
LoginContent
)
(
*
LoginContent
,
error
)
{
if
len
(
m
.
loginPlugins
)
==
0
{
return
content
,
nil
}
var
(
var
(
res
=
&
Response
{
res
=
&
Response
{
Reject
:
false
,
Reject
:
false
,
...
@@ -85,6 +89,10 @@ func (m *Manager) Login(content *LoginContent) (*LoginContent, error) {
...
@@ -85,6 +89,10 @@ func (m *Manager) Login(content *LoginContent) (*LoginContent, error) {
}
}
func
(
m
*
Manager
)
NewProxy
(
content
*
NewProxyContent
)
(
*
NewProxyContent
,
error
)
{
func
(
m
*
Manager
)
NewProxy
(
content
*
NewProxyContent
)
(
*
NewProxyContent
,
error
)
{
if
len
(
m
.
newProxyPlugins
)
==
0
{
return
content
,
nil
}
var
(
var
(
res
=
&
Response
{
res
=
&
Response
{
Reject
:
false
,
Reject
:
false
,
...
@@ -115,6 +123,10 @@ func (m *Manager) NewProxy(content *NewProxyContent) (*NewProxyContent, error) {
...
@@ -115,6 +123,10 @@ func (m *Manager) NewProxy(content *NewProxyContent) (*NewProxyContent, error) {
}
}
func
(
m
*
Manager
)
Ping
(
content
*
PingContent
)
(
*
PingContent
,
error
)
{
func
(
m
*
Manager
)
Ping
(
content
*
PingContent
)
(
*
PingContent
,
error
)
{
if
len
(
m
.
pingPlugins
)
==
0
{
return
content
,
nil
}
var
(
var
(
res
=
&
Response
{
res
=
&
Response
{
Reject
:
false
,
Reject
:
false
,
...
@@ -145,6 +157,10 @@ func (m *Manager) Ping(content *PingContent) (*PingContent, error) {
...
@@ -145,6 +157,10 @@ func (m *Manager) Ping(content *PingContent) (*PingContent, error) {
}
}
func
(
m
*
Manager
)
NewWorkConn
(
content
*
NewWorkConnContent
)
(
*
NewWorkConnContent
,
error
)
{
func
(
m
*
Manager
)
NewWorkConn
(
content
*
NewWorkConnContent
)
(
*
NewWorkConnContent
,
error
)
{
if
len
(
m
.
newWorkConnPlugins
)
==
0
{
return
content
,
nil
}
var
(
var
(
res
=
&
Response
{
res
=
&
Response
{
Reject
:
false
,
Reject
:
false
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录