Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
d1f01124
提交
d1f01124
authored
9月 15, 2014
作者:
Jeromy
提交者:
Juan Batiz-Benet
10月 01, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
address comments from the PR #45
上级
2aa2b8c6
隐藏空白字符变更
内嵌
并排
正在显示
9 个修改的文件
包含
64 行增加
和
21 行删除
+64
-21
key.go
crypto/key.go
+3
-0
rsa.go
crypto/rsa.go
+17
-0
handshake.go
crypto/spipe/handshake.go
+2
-2
dns.go
namesys/dns.go
+4
-0
nsresolver.go
namesys/nsresolver.go
+1
-0
proquint.go
namesys/proquint.go
+5
-0
publisher.go
namesys/publisher.go
+2
-2
resolver.go
namesys/resolver.go
+21
-13
routing.go
namesys/routing.go
+9
-4
没有找到文件。
crypto/key.go
浏览文件 @
d1f01124
...
@@ -27,6 +27,9 @@ type Key interface {
...
@@ -27,6 +27,9 @@ type Key interface {
// Bytes returns a serialized, storeable representation of this key
// Bytes returns a serialized, storeable representation of this key
Bytes
()
([]
byte
,
error
)
Bytes
()
([]
byte
,
error
)
// Hash returns the hash of this key
Hash
()
([]
byte
,
error
)
// Equals checks whether two PubKeys are the same
// Equals checks whether two PubKeys are the same
Equals
(
Key
)
bool
Equals
(
Key
)
bool
}
}
...
...
crypto/rsa.go
浏览文件 @
d1f01124
...
@@ -9,6 +9,7 @@ import (
...
@@ -9,6 +9,7 @@ import (
"errors"
"errors"
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/goprotobuf/proto"
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/goprotobuf/proto"
u
"github.com/jbenet/go-ipfs/util"
)
)
type
RsaPrivateKey
struct
{
type
RsaPrivateKey
struct
{
...
@@ -46,6 +47,14 @@ func (pk *RsaPublicKey) Equals(k Key) bool {
...
@@ -46,6 +47,14 @@ func (pk *RsaPublicKey) Equals(k Key) bool {
return
KeyEqual
(
pk
,
k
)
return
KeyEqual
(
pk
,
k
)
}
}
func
(
pk
*
RsaPublicKey
)
Hash
()
([]
byte
,
error
)
{
pkb
,
err
:=
pk
.
Bytes
()
if
err
!=
nil
{
return
nil
,
err
}
return
u
.
Hash
(
pkb
)
}
func
(
sk
*
RsaPrivateKey
)
GenSecret
()
[]
byte
{
func
(
sk
*
RsaPrivateKey
)
GenSecret
()
[]
byte
{
buf
:=
make
([]
byte
,
16
)
buf
:=
make
([]
byte
,
16
)
rand
.
Read
(
buf
)
rand
.
Read
(
buf
)
...
@@ -75,6 +84,14 @@ func (sk *RsaPrivateKey) Equals(k Key) bool {
...
@@ -75,6 +84,14 @@ func (sk *RsaPrivateKey) Equals(k Key) bool {
return
KeyEqual
(
sk
,
k
)
return
KeyEqual
(
sk
,
k
)
}
}
func
(
sk
*
RsaPrivateKey
)
Hash
()
([]
byte
,
error
)
{
skb
,
err
:=
sk
.
Bytes
()
if
err
!=
nil
{
return
nil
,
err
}
return
u
.
Hash
(
skb
)
}
func
UnmarshalRsaPrivateKey
(
b
[]
byte
)
(
*
RsaPrivateKey
,
error
)
{
func
UnmarshalRsaPrivateKey
(
b
[]
byte
)
(
*
RsaPrivateKey
,
error
)
{
sk
,
err
:=
x509
.
ParsePKCS1PrivateKey
(
b
)
sk
,
err
:=
x509
.
ParsePKCS1PrivateKey
(
b
)
if
err
!=
nil
{
if
err
!=
nil
{
...
...
crypto/spipe/handshake.go
浏览文件 @
d1f01124
...
@@ -230,7 +230,7 @@ func (s *SecurePipe) handleSecureIn(hashType string, tIV, tCKey, tMKey []byte) {
...
@@ -230,7 +230,7 @@ func (s *SecurePipe) handleSecureIn(hashType string, tIV, tCKey, tMKey []byte) {
data
,
ok
:=
<-
s
.
insecure
.
In
data
,
ok
:=
<-
s
.
insecure
.
In
if
!
ok
{
if
!
ok
{
u
.
DOut
(
"Closing incoming proxy.
\n
"
)
u
.
DOut
(
"Closing incoming proxy.
\n
"
)
close
(
s
ecure
In
)
close
(
s
.
In
)
return
return
}
}
...
@@ -268,7 +268,7 @@ func (s *SecurePipe) handleSecureOut(hashType string, mIV, mCKey, mMKey []byte)
...
@@ -268,7 +268,7 @@ func (s *SecurePipe) handleSecureOut(hashType string, mIV, mCKey, mMKey []byte)
data
,
ok
:=
<-
s
.
Out
data
,
ok
:=
<-
s
.
Out
if
!
ok
{
if
!
ok
{
u
.
DOut
(
"Closing outgoing proxy.
\n
"
)
u
.
DOut
(
"Closing outgoing proxy.
\n
"
)
close
(
s
ecure
Out
)
close
(
s
.
Out
)
return
return
}
}
...
...
namesys/dns.go
浏览文件 @
d1f01124
...
@@ -12,6 +12,10 @@ type DNSResolver struct {
...
@@ -12,6 +12,10 @@ type DNSResolver struct {
// cache would need a timeout
// cache would need a timeout
}
}
func
(
r
*
DNSResolver
)
Matches
(
name
string
)
bool
{
return
strings
.
Contains
(
name
,
"."
)
}
func
(
r
*
DNSResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
func
(
r
*
DNSResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
txt
,
err
:=
net
.
LookupTXT
(
name
)
txt
,
err
:=
net
.
LookupTXT
(
name
)
if
err
!=
nil
{
if
err
!=
nil
{
...
...
namesys/nsresolver.go
浏览文件 @
d1f01124
...
@@ -2,4 +2,5 @@ package namesys
...
@@ -2,4 +2,5 @@ package namesys
type
Resolver
interface
{
type
Resolver
interface
{
Resolve
(
string
)
(
string
,
error
)
Resolve
(
string
)
(
string
,
error
)
Matches
(
string
)
bool
}
}
namesys/proquint.go
浏览文件 @
d1f01124
...
@@ -10,6 +10,11 @@ var _ = proquint.Encode
...
@@ -10,6 +10,11 @@ var _ = proquint.Encode
type
ProquintResolver
struct
{}
type
ProquintResolver
struct
{}
func
(
r
*
ProquintResolver
)
Matches
(
name
string
)
bool
{
ok
,
err
:=
proquint
.
IsProquint
(
name
)
return
err
==
nil
&&
ok
}
func
(
r
*
ProquintResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
func
(
r
*
ProquintResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
ok
,
err
:=
proquint
.
IsProquint
(
name
)
ok
,
err
:=
proquint
.
IsProquint
(
name
)
if
err
!=
nil
{
if
err
!=
nil
{
...
...
namesys/publisher.go
浏览文件 @
d1f01124
...
@@ -32,7 +32,7 @@ func (p *IpnsPublisher) Publish(k ci.PrivKey, value u.Key) error {
...
@@ -32,7 +32,7 @@ func (p *IpnsPublisher) Publish(k ci.PrivKey, value u.Key) error {
}
}
namekey
:=
u
.
Key
(
nameb
)
.
Pretty
()
namekey
:=
u
.
Key
(
nameb
)
.
Pretty
()
ipnskey
,
err
:=
u
.
Hash
([]
byte
(
"
ipns:
"
+
namekey
))
ipnskey
,
err
:=
u
.
Hash
([]
byte
(
"
/ipns/
"
+
namekey
))
if
err
!=
nil
{
if
err
!=
nil
{
return
err
return
err
}
}
...
@@ -43,7 +43,7 @@ func (p *IpnsPublisher) Publish(k ci.PrivKey, value u.Key) error {
...
@@ -43,7 +43,7 @@ func (p *IpnsPublisher) Publish(k ci.PrivKey, value u.Key) error {
return
err
return
err
}
}
// Store ipns entry at h("
ipns:
"+b58(h(pubkey)))
// Store ipns entry at h("
/ipns/
"+b58(h(pubkey)))
err
=
p
.
routing
.
PutValue
(
u
.
Key
(
ipnskey
),
data
)
err
=
p
.
routing
.
PutValue
(
u
.
Key
(
ipnskey
),
data
)
if
err
!=
nil
{
if
err
!=
nil
{
return
err
return
err
...
...
namesys/resolver.go
浏览文件 @
d1f01124
package
namesys
package
namesys
import
(
import
(
"
string
s"
"
error
s"
mdag
"github.com/jbenet/go-ipfs/merkledag"
mdag
"github.com/jbenet/go-ipfs/merkledag"
"github.com/jbenet/go-ipfs/routing"
"github.com/jbenet/go-ipfs/routing"
)
)
var
ErrCouldntResolve
=
errors
.
New
(
"could not resolve name."
)
type
MasterResolver
struct
{
type
MasterResolver
struct
{
dns
*
DNSResolver
res
[]
Resolver
routing
*
RoutingResolver
pro
*
ProquintResolver
}
}
func
NewMasterResolver
(
r
routing
.
IpfsRouting
,
dag
*
mdag
.
DAGService
)
*
MasterResolver
{
func
NewMasterResolver
(
r
routing
.
IpfsRouting
,
dag
*
mdag
.
DAGService
)
*
MasterResolver
{
mr
:=
new
(
MasterResolver
)
mr
:=
new
(
MasterResolver
)
mr
.
dns
=
new
(
DNSResolver
)
mr
.
res
=
[]
Resolver
{
mr
.
pro
=
new
(
ProquintResolver
)
new
(
DNSResolver
),
mr
.
routing
=
NewRoutingResolver
(
r
,
dag
)
new
(
ProquintResolver
),
NewRoutingResolver
(
r
,
dag
),
}
return
mr
return
mr
}
}
func
(
mr
*
MasterResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
func
(
mr
*
MasterResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
if
strings
.
Contains
(
name
,
"."
)
{
for
_
,
r
:=
range
mr
.
res
{
return
mr
.
dns
.
Resolve
(
name
)
if
r
.
Matches
(
name
)
{
return
r
.
Resolve
(
name
)
}
}
}
return
""
,
ErrCouldntResolve
}
if
strings
.
Contains
(
name
,
"-"
)
{
func
(
mr
*
MasterResolver
)
Matches
(
name
string
)
bool
{
return
mr
.
pro
.
Resolve
(
name
)
for
_
,
r
:=
range
mr
.
res
{
if
r
.
Matches
(
name
)
{
return
true
}
}
}
return
false
return
mr
.
routing
.
Resolve
(
name
)
}
}
namesys/routing.go
浏览文件 @
d1f01124
...
@@ -26,6 +26,11 @@ func NewRoutingResolver(route routing.IpfsRouting, dagservice *mdag.DAGService)
...
@@ -26,6 +26,11 @@ func NewRoutingResolver(route routing.IpfsRouting, dagservice *mdag.DAGService)
}
}
}
}
func
(
r
*
RoutingResolver
)
Matches
(
name
string
)
bool
{
_
,
err
:=
mh
.
FromB58String
(
name
)
return
err
==
nil
}
func
(
r
*
RoutingResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
func
(
r
*
RoutingResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
hash
,
err
:=
mh
.
FromB58String
(
name
)
hash
,
err
:=
mh
.
FromB58String
(
name
)
if
err
!=
nil
{
if
err
!=
nil
{
...
@@ -36,13 +41,13 @@ func (r *RoutingResolver) Resolve(name string) (string, error) {
...
@@ -36,13 +41,13 @@ func (r *RoutingResolver) Resolve(name string) (string, error) {
// use the routing system to get the name.
// use the routing system to get the name.
// /ipns/<name>
// /ipns/<name>
h
,
err
:=
u
.
Hash
([]
byte
(
"
ipns:
"
+
name
))
h
,
err
:=
u
.
Hash
([]
byte
(
"
/ipns/
"
+
name
))
if
err
!=
nil
{
if
err
!=
nil
{
return
""
,
err
return
""
,
err
}
}
i
np
sKey
:=
u
.
Key
(
h
)
i
pn
sKey
:=
u
.
Key
(
h
)
val
,
err
:=
r
.
routing
.
GetValue
(
i
np
sKey
,
time
.
Second
*
10
)
val
,
err
:=
r
.
routing
.
GetValue
(
i
pn
sKey
,
time
.
Second
*
10
)
if
err
!=
nil
{
if
err
!=
nil
{
u
.
DOut
(
"RoutingResolve get failed.
\n
"
)
u
.
DOut
(
"RoutingResolve get failed.
\n
"
)
return
""
,
err
return
""
,
err
...
@@ -70,7 +75,7 @@ func (r *RoutingResolver) Resolve(name string) (string, error) {
...
@@ -70,7 +75,7 @@ func (r *RoutingResolver) Resolve(name string) (string, error) {
}
}
// check sig with pk
// check sig with pk
if
ok
,
err
:=
pk
.
Verify
(
entry
.
GetValue
(),
entry
.
GetSignature
());
err
!=
nil
&&
ok
{
if
ok
,
err
:=
pk
.
Verify
(
entry
.
GetValue
(),
entry
.
GetSignature
());
err
!=
nil
||
!
ok
{
return
""
,
fmt
.
Errorf
(
"Invalid value. Not signed by PrivateKey corresponding to %v"
,
pk
)
return
""
,
fmt
.
Errorf
(
"Invalid value. Not signed by PrivateKey corresponding to %v"
,
pk
)
}
}
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论