Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
51d031c1
提交
51d031c1
authored
11月 20, 2015
作者:
Jeromy
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
return sentinel error for invalid records
License: MIT Signed-off-by:
Jeromy
<
jeromyj@gmail.com
>
上级
6b1f1ec1
显示空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
15 行增加
和
8 行删除
+15
-8
dht.go
routing/dht/dht.go
+5
-3
routing.go
routing/dht/routing.go
+10
-5
没有找到文件。
routing/dht/dht.go
浏览文件 @
51d031c1
...
...
@@ -150,6 +150,8 @@ func (dht *IpfsDHT) putProvider(ctx context.Context, p peer.ID, skey string) err
return
nil
}
var
errInvalidRecord
=
errors
.
New
(
"received invalid record"
)
// getValueOrPeers queries a particular peer p for the value for
// key. It returns either the value or a list of closer peers.
// NOTE: it will update the dht's peerstore with any new addresses
...
...
@@ -173,11 +175,11 @@ func (dht *IpfsDHT) getValueOrPeers(ctx context.Context, p peer.ID,
err
=
dht
.
verifyRecordOnline
(
ctx
,
record
)
if
err
!=
nil
{
log
.
Info
(
"Received invalid record! (discarded)"
)
//
still return a non-nil record to signify that we
received
// a bad record from this peer
//
return a sentinal to signify an invalid record was
received
err
=
errInvalidRecord
record
=
new
(
pb
.
Record
)
}
return
record
,
peers
,
nil
return
record
,
peers
,
err
}
if
len
(
peers
)
>
0
{
...
...
routing/dht/routing.go
浏览文件 @
51d031c1
...
...
@@ -171,21 +171,26 @@ func (dht *IpfsDHT) GetValues(ctx context.Context, key key.Key, nvals int) ([]ro
})
rec
,
peers
,
err
:=
dht
.
getValueOrPeers
(
ctx
,
p
,
key
)
if
err
!=
nil
{
if
err
==
routing
.
ErrNotFound
{
switch
err
{
case
routing
.
ErrNotFound
:
// in this case, they responded with nothing,
// still send a notification
// still send a notification so listeners can know the
// request has completed 'successfully'
notif
.
PublishQueryEvent
(
parent
,
&
notif
.
QueryEvent
{
Type
:
notif
.
PeerResponse
,
ID
:
p
,
})
}
return
nil
,
err
default
:
return
nil
,
err
case
nil
,
errInvalidRecord
:
// in either of these cases, we want to keep going
}
res
:=
&
dhtQueryResult
{
closerPeers
:
peers
}
if
rec
.
GetValue
()
!=
nil
{
if
rec
.
GetValue
()
!=
nil
||
err
==
errInvalidRecord
{
rv
:=
routing
.
RecvdVal
{
Val
:
rec
.
GetValue
(),
From
:
p
,
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论