Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
dms3
go-dms3
Commits
d1f01124
Commit
d1f01124
authored
10 years ago
by
Jeromy
Committed by
Juan Batiz-Benet
10 years ago
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
address comments from the PR #45
parent
2aa2b8c6
Changes
9
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
64 additions
and
21 deletions
+64
-21
crypto/key.go
crypto/key.go
+3
-0
crypto/rsa.go
crypto/rsa.go
+17
-0
crypto/spipe/handshake.go
crypto/spipe/handshake.go
+2
-2
namesys/dns.go
namesys/dns.go
+4
-0
namesys/nsresolver.go
namesys/nsresolver.go
+1
-0
namesys/proquint.go
namesys/proquint.go
+5
-0
namesys/publisher.go
namesys/publisher.go
+2
-2
namesys/resolver.go
namesys/resolver.go
+21
-13
namesys/routing.go
namesys/routing.go
+9
-4
No files found.
crypto/key.go
View file @
d1f01124
...
...
@@ -27,6 +27,9 @@ type Key interface {
// Bytes returns a serialized, storeable representation of this key
Bytes
()
([]
byte
,
error
)
// Hash returns the hash of this key
Hash
()
([]
byte
,
error
)
// Equals checks whether two PubKeys are the same
Equals
(
Key
)
bool
}
...
...
This diff is collapsed.
Click to expand it.
crypto/rsa.go
View file @
d1f01124
...
...
@@ -9,6 +9,7 @@ import (
"errors"
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/goprotobuf/proto"
u
"github.com/jbenet/go-ipfs/util"
)
type
RsaPrivateKey
struct
{
...
...
@@ -46,6 +47,14 @@ func (pk *RsaPublicKey) Equals(k Key) bool {
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
{
buf
:=
make
([]
byte
,
16
)
rand
.
Read
(
buf
)
...
...
@@ -75,6 +84,14 @@ func (sk *RsaPrivateKey) Equals(k Key) bool {
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
)
{
sk
,
err
:=
x509
.
ParsePKCS1PrivateKey
(
b
)
if
err
!=
nil
{
...
...
This diff is collapsed.
Click to expand it.
crypto/spipe/handshake.go
View file @
d1f01124
...
...
@@ -230,7 +230,7 @@ func (s *SecurePipe) handleSecureIn(hashType string, tIV, tCKey, tMKey []byte) {
data
,
ok
:=
<-
s
.
insecure
.
In
if
!
ok
{
u
.
DOut
(
"Closing incoming proxy.
\n
"
)
close
(
s
ecure
In
)
close
(
s
.
In
)
return
}
...
...
@@ -268,7 +268,7 @@ func (s *SecurePipe) handleSecureOut(hashType string, mIV, mCKey, mMKey []byte)
data
,
ok
:=
<-
s
.
Out
if
!
ok
{
u
.
DOut
(
"Closing outgoing proxy.
\n
"
)
close
(
s
ecure
Out
)
close
(
s
.
Out
)
return
}
...
...
This diff is collapsed.
Click to expand it.
namesys/dns.go
View file @
d1f01124
...
...
@@ -12,6 +12,10 @@ type DNSResolver struct {
// cache would need a timeout
}
func
(
r
*
DNSResolver
)
Matches
(
name
string
)
bool
{
return
strings
.
Contains
(
name
,
"."
)
}
func
(
r
*
DNSResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
txt
,
err
:=
net
.
LookupTXT
(
name
)
if
err
!=
nil
{
...
...
This diff is collapsed.
Click to expand it.
namesys/nsresolver.go
View file @
d1f01124
...
...
@@ -2,4 +2,5 @@ package namesys
type
Resolver
interface
{
Resolve
(
string
)
(
string
,
error
)
Matches
(
string
)
bool
}
This diff is collapsed.
Click to expand it.
namesys/proquint.go
View file @
d1f01124
...
...
@@ -10,6 +10,11 @@ var _ = proquint.Encode
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
)
{
ok
,
err
:=
proquint
.
IsProquint
(
name
)
if
err
!=
nil
{
...
...
This diff is collapsed.
Click to expand it.
namesys/publisher.go
View file @
d1f01124
...
...
@@ -32,7 +32,7 @@ func (p *IpnsPublisher) Publish(k ci.PrivKey, value u.Key) error {
}
namekey
:=
u
.
Key
(
nameb
)
.
Pretty
()
ipnskey
,
err
:=
u
.
Hash
([]
byte
(
"ipns
:
"
+
namekey
))
ipnskey
,
err
:=
u
.
Hash
([]
byte
(
"
/
ipns
/
"
+
namekey
))
if
err
!=
nil
{
return
err
}
...
...
@@ -43,7 +43,7 @@ func (p *IpnsPublisher) Publish(k ci.PrivKey, value u.Key) error {
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
)
if
err
!=
nil
{
return
err
...
...
This diff is collapsed.
Click to expand it.
namesys/resolver.go
View file @
d1f01124
package
namesys
import
(
"
string
s"
"
error
s"
mdag
"github.com/jbenet/go-ipfs/merkledag"
"github.com/jbenet/go-ipfs/routing"
)
var
ErrCouldntResolve
=
errors
.
New
(
"could not resolve name."
)
type
MasterResolver
struct
{
dns
*
DNSResolver
routing
*
RoutingResolver
pro
*
ProquintResolver
res
[]
Resolver
}
func
NewMasterResolver
(
r
routing
.
IpfsRouting
,
dag
*
mdag
.
DAGService
)
*
MasterResolver
{
mr
:=
new
(
MasterResolver
)
mr
.
dns
=
new
(
DNSResolver
)
mr
.
pro
=
new
(
ProquintResolver
)
mr
.
routing
=
NewRoutingResolver
(
r
,
dag
)
mr
.
res
=
[]
Resolver
{
new
(
DNSResolver
),
new
(
ProquintResolver
),
NewRoutingResolver
(
r
,
dag
),
}
return
mr
}
func
(
mr
*
MasterResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
if
strings
.
Contains
(
name
,
"."
)
{
return
mr
.
dns
.
Resolve
(
name
)
for
_
,
r
:=
range
mr
.
res
{
if
r
.
Matches
(
name
)
{
return
r
.
Resolve
(
name
)
}
}
return
""
,
ErrCouldntResolve
}
if
strings
.
Contains
(
name
,
"-"
)
{
return
mr
.
pro
.
Resolve
(
name
)
func
(
mr
*
MasterResolver
)
Matches
(
name
string
)
bool
{
for
_
,
r
:=
range
mr
.
res
{
if
r
.
Matches
(
name
)
{
return
true
}
}
return
mr
.
routing
.
Resolve
(
name
)
return
false
}
This diff is collapsed.
Click to expand it.
namesys/routing.go
View file @
d1f01124
...
...
@@ -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
)
{
hash
,
err
:=
mh
.
FromB58String
(
name
)
if
err
!=
nil
{
...
...
@@ -36,13 +41,13 @@ func (r *RoutingResolver) Resolve(name string) (string, error) {
// use the routing system to get the name.
// /ipns/<name>
h
,
err
:=
u
.
Hash
([]
byte
(
"ipns
:
"
+
name
))
h
,
err
:=
u
.
Hash
([]
byte
(
"
/
ipns
/
"
+
name
))
if
err
!=
nil
{
return
""
,
err
}
i
n
psKey
:=
u
.
Key
(
h
)
val
,
err
:=
r
.
routing
.
GetValue
(
i
n
psKey
,
time
.
Second
*
10
)
ip
n
sKey
:=
u
.
Key
(
h
)
val
,
err
:=
r
.
routing
.
GetValue
(
ip
n
sKey
,
time
.
Second
*
10
)
if
err
!=
nil
{
u
.
DOut
(
"RoutingResolve get failed.
\n
"
)
return
""
,
err
...
...
@@ -70,7 +75,7 @@ func (r *RoutingResolver) Resolve(name string) (string, error) {
}
// 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
)
}
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment