Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
476ad38e
Unverified
提交
476ad38e
authored
2月 15, 2018
作者:
Whyrusleeping
提交者:
GitHub
2月 15, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #4700 from matrushka/ignore_invalid_key_files
Ignore invalid key files in keystore directory.
上级
b9b1495a
e338cdf5
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
84 行增加
和
1 行删除
+84
-1
keystore.go
keystore/keystore.go
+24
-1
keystore_test.go
keystore/keystore_test.go
+60
-0
没有找到文件。
keystore/keystore.go
浏览文件 @
476ad38e
...
@@ -7,9 +7,12 @@ import (
...
@@ -7,9 +7,12 @@ import (
"path/filepath"
"path/filepath"
"strings"
"strings"
logging
"gx/ipfs/QmRb5jh8z2E8hMGN2tkvs1yHynUanqnZ3UeKwgN1i9P1F8/go-log"
ci
"gx/ipfs/QmaPbCnUMBohSGo3KnxEa2bHqyJVVeEEcwtqJAYxerieBo/go-libp2p-crypto"
ci
"gx/ipfs/QmaPbCnUMBohSGo3KnxEa2bHqyJVVeEEcwtqJAYxerieBo/go-libp2p-crypto"
)
)
var
log
=
logging
.
Logger
(
"keystore"
)
// Keystore provides a key management interface
// Keystore provides a key management interface
type
Keystore
interface
{
type
Keystore
interface
{
// Has returns whether or not a key exist in the Keystore
// Has returns whether or not a key exist in the Keystore
...
@@ -77,6 +80,10 @@ func (ks *FSKeystore) Has(name string) (bool, error) {
...
@@ -77,6 +80,10 @@ func (ks *FSKeystore) Has(name string) (bool, error) {
return
false
,
err
return
false
,
err
}
}
if
err
:=
validateName
(
name
);
err
!=
nil
{
return
false
,
err
}
return
true
,
nil
return
true
,
nil
}
}
...
@@ -149,5 +156,21 @@ func (ks *FSKeystore) List() ([]string, error) {
...
@@ -149,5 +156,21 @@ func (ks *FSKeystore) List() ([]string, error) {
return
nil
,
err
return
nil
,
err
}
}
return
dir
.
Readdirnames
(
0
)
dirs
,
err
:=
dir
.
Readdirnames
(
0
)
if
err
!=
nil
{
return
nil
,
err
}
list
:=
make
([]
string
,
0
,
len
(
dirs
))
for
_
,
name
:=
range
dirs
{
err
:=
validateName
(
name
)
if
err
==
nil
{
list
=
append
(
list
,
name
)
}
else
{
log
.
Warningf
(
"Ignoring the invalid keyfile: %s"
,
name
)
}
}
return
list
,
nil
}
}
keystore/keystore_test.go
浏览文件 @
476ad38e
...
@@ -4,6 +4,8 @@ import (
...
@@ -4,6 +4,8 @@ import (
"fmt"
"fmt"
"io/ioutil"
"io/ioutil"
"math/rand"
"math/rand"
"os"
"path/filepath"
"sort"
"sort"
"testing"
"testing"
...
@@ -143,6 +145,64 @@ func TestKeystoreBasics(t *testing.T) {
...
@@ -143,6 +145,64 @@ func TestKeystoreBasics(t *testing.T) {
}
}
}
}
func
TestInvalidKeyFiles
(
t
*
testing
.
T
)
{
tdir
,
err
:=
ioutil
.
TempDir
(
""
,
"keystore-test"
)
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
defer
os
.
RemoveAll
(
tdir
)
ks
,
err
:=
NewFSKeystore
(
tdir
)
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
key
:=
privKeyOrFatal
(
t
)
bytes
,
err
:=
key
.
Bytes
()
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
err
=
ioutil
.
WriteFile
(
filepath
.
Join
(
ks
.
dir
,
"valid"
),
bytes
,
0644
)
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
err
=
ioutil
.
WriteFile
(
filepath
.
Join
(
ks
.
dir
,
".invalid"
),
bytes
,
0644
)
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
l
,
err
:=
ks
.
List
()
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
sort
.
Strings
(
l
)
if
len
(
l
)
!=
1
{
t
.
Fatal
(
"wrong entry count"
)
}
if
l
[
0
]
!=
"valid"
{
t
.
Fatal
(
"wrong entries listed"
)
}
exist
,
err
:=
ks
.
Has
(
"valid"
)
if
!
exist
{
t
.
Fatal
(
"should know it has a key named valid"
)
}
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
if
exist
,
err
=
ks
.
Has
(
".invalid"
);
err
==
nil
{
t
.
Fatal
(
"shouldnt be able to put a key with a 'hidden' name"
)
}
}
func
TestNonExistingKey
(
t
*
testing
.
T
)
{
func
TestNonExistingKey
(
t
*
testing
.
T
)
{
tdir
,
err
:=
ioutil
.
TempDir
(
""
,
"keystore-test"
)
tdir
,
err
:=
ioutil
.
TempDir
(
""
,
"keystore-test"
)
if
err
!=
nil
{
if
err
!=
nil
{
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论