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-unixfs
Commits
a5233fae
Commit
a5233fae
authored
Jan 16, 2015
by
Jeromy
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
some comments
parent
feeada0d
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
14 additions
and
1 deletion
+14
-1
core/core.go
core/core.go
+3
-0
fuse/ipns/ipns_unix.go
fuse/ipns/ipns_unix.go
+2
-0
routing/dht/dht.go
routing/dht/dht.go
+2
-0
routing/dht/records.go
routing/dht/records.go
+3
-1
routing/offline/offline.go
routing/offline/offline.go
+4
-0
No files found.
core/core.go
View file @
a5233fae
...
...
@@ -355,6 +355,9 @@ func (n *IpfsNode) loadPrivateKey() error {
return
nil
}
// SetupOfflineRouting loads the local nodes private key and
// uses it to instantiate a routing system in offline mode.
// This is primarily used for offline ipns modifications.
func
(
n
*
IpfsNode
)
SetupOfflineRouting
()
error
{
err
:=
n
.
loadPrivateKey
()
if
err
!=
nil
{
...
...
fuse/ipns/ipns_unix.go
View file @
a5233fae
...
...
@@ -33,6 +33,8 @@ var (
longRepublishTimeout
=
time
.
Millisecond
*
500
)
// InitializeKeyspace sets the ipns record for the given key to
// point to an empty directory.
func
InitializeKeyspace
(
n
*
core
.
IpfsNode
,
key
ci
.
PrivKey
)
error
{
emptyDir
:=
&
mdag
.
Node
{
Data
:
ft
.
FolderPBData
()}
k
,
err
:=
n
.
DAG
.
Add
(
emptyDir
)
...
...
routing/dht/dht.go
View file @
a5233fae
...
...
@@ -235,6 +235,8 @@ func (dht *IpfsDHT) getLocal(key u.Key) ([]byte, error) {
return
rec
.
GetValue
(),
nil
}
// getOwnPrivateKey attempts to load the local peers private
// key from the peerstore.
func
(
dht
*
IpfsDHT
)
getOwnPrivateKey
()
(
ci
.
PrivKey
,
error
)
{
sk
:=
dht
.
peerstore
.
PrivKey
(
dht
.
self
)
if
sk
==
nil
{
...
...
routing/dht/records.go
View file @
a5233fae
...
...
@@ -42,7 +42,7 @@ func RecordBlobForSig(r *pb.Record) []byte {
return
bytes
.
Join
([][]
byte
{
k
,
v
,
a
},
[]
byte
{})
}
// creates and signs a dht record for the given key/value pair
//
MakePutRecord
creates and signs a dht record for the given key/value pair
func
MakePutRecord
(
sk
ci
.
PrivKey
,
key
u
.
Key
,
value
[]
byte
)
(
*
pb
.
Record
,
error
)
{
record
:=
new
(
pb
.
Record
)
...
...
@@ -175,6 +175,8 @@ func (dht *IpfsDHT) verifyRecordOnline(ctx context.Context, r *pb.Record) error
return
dht
.
verifyRecord
(
r
,
pk
)
}
// TODO: make this an independent exported function.
// it might be useful for users to have access to.
func
(
dht
*
IpfsDHT
)
verifyRecord
(
r
*
pb
.
Record
,
pk
ci
.
PubKey
)
error
{
// First, validate the signature
blob
:=
RecordBlobForSig
(
r
)
...
...
routing/offline/offline.go
View file @
a5233fae
...
...
@@ -27,6 +27,9 @@ func NewOfflineRouter(dstore ds.Datastore, privkey ci.PrivKey) routing.IpfsRouti
}
}
// offlineRouting implements the IpfsRouting interface,
// but only provides the capability to Put and Get signed dht
// records to and from the local datastore.
type
offlineRouting
struct
{
datastore
ds
.
Datastore
sk
ci
.
PrivKey
...
...
@@ -86,4 +89,5 @@ func (c *offlineRouting) Ping(ctx context.Context, p peer.ID) (time.Duration, er
return
0
,
ErrOffline
}
// ensure offlineRouting matches the IpfsRouting interface
var
_
routing
.
IpfsRouting
=
&
offlineRouting
{}
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