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
1e007791
Commit
1e007791
authored
Dec 08, 2014
by
Brian Tiger Chow
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactor(peer) impl peerstore with map
License: MIT Signed-off-by:
Brian Tiger Chow
<
brian@perfmode.com
>
parent
3f63e50c
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
78 deletions
+29
-78
peer/peerstore.go
peer/peerstore.go
+29
-78
No files found.
peer/peerstore.go
View file @
1e007791
package
peer
import
(
"errors"
"sync"
u
"github.com/jbenet/go-ipfs/util"
ds
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-datastore"
)
// Peerstore provides a threadsafe collection for peers.
...
...
@@ -19,34 +16,26 @@ type Peerstore interface {
type
peerstore
struct
{
sync
.
RWMutex
peers
ds
.
Datastore
data
map
[
string
]
Peer
// key is string(ID)
}
// NewPeerstore creates a threadsafe collection of peers.
func
NewPeerstore
()
Peerstore
{
return
&
peerstore
{
peers
:
ds
.
NewMapDatastore
(
),
data
:
make
(
map
[
string
]
Peer
),
}
}
func
(
p
*
peerstore
)
Get
(
i
ID
)
(
Peer
,
error
)
{
p
.
Lock
()
defer
p
.
Unlock
()
func
(
p
s
*
peerstore
)
Get
(
i
ID
)
(
Peer
,
error
)
{
p
s
.
Lock
()
defer
p
s
.
Unlock
()
if
i
==
nil
{
panic
(
"wat"
)
}
k
:=
u
.
Key
(
i
)
.
DsKey
()
val
,
err
:=
p
.
peers
.
Get
(
k
)
switch
err
{
// some other datastore error
default
:
return
nil
,
err
// not found, construct it ourselves, add it to datastore, and return.
case
ds
.
ErrNotFound
:
p
,
ok
:=
ps
.
data
[
i
.
String
()]
if
!
ok
{
// not found, construct it ourselves, add it to datastore, and return.
// TODO(brian) kinda dangerous, no? If ID is invalid and doesn't
// correspond to an actual valid peer ID, this peerstore will return an
...
...
@@ -57,84 +46,46 @@ func (p *peerstore) Get(i ID) (Peer, error) {
//
// Potential bad case: Suppose values arrive from untrusted providers
// in the DHT.
peer
:=
&
peer
{
id
:
i
}
if
err
:=
p
.
peers
.
Put
(
k
,
peer
);
err
!=
nil
{
return
nil
,
err
}
return
peer
,
nil
p
=
&
peer
{
id
:
i
}
ps
.
data
[
i
.
String
()]
=
p
}
// no error, got it back fine
case
nil
:
peer
,
ok
:=
val
.
(
*
peer
)
if
!
ok
{
return
nil
,
errors
.
New
(
"stored value was not a Peer"
)
}
return
peer
,
nil
}
return
p
,
nil
}
func
(
p
*
peerstore
)
Add
(
peer
Peer
)
(
Peer
,
error
)
{
p
.
Lock
()
defer
p
.
Unlock
()
k
:=
peer
.
Key
()
.
DsKey
()
val
,
err
:=
p
.
peers
.
Get
(
k
)
switch
err
{
// some other datastore error
default
:
return
nil
,
err
// not found? just add and return.
case
ds
.
ErrNotFound
:
err
:=
p
.
peers
.
Put
(
k
,
peer
)
return
peer
,
err
// no error, already here.
case
nil
:
peer2
,
ok
:=
val
.
(
Peer
)
if
!
ok
{
return
nil
,
errors
.
New
(
"stored value was not a Peer"
)
}
if
peer
==
peer2
{
return
peer
,
nil
}
// must do some merging.
peer2
.
Update
(
peer
)
return
peer2
,
nil
existing
,
ok
:=
p
.
data
[
peer
.
Key
()
.
String
()]
if
!
ok
{
// not found? just add and return.
p
.
data
[
peer
.
Key
()
.
String
()]
=
peer
return
peer
,
nil
}
// already here.
if
peer
==
existing
{
return
peer
,
nil
}
existing
.
Update
(
peer
)
// must do some merging.
return
existing
,
nil
}
func
(
p
*
peerstore
)
Delete
(
i
ID
)
error
{
p
.
Lock
()
defer
p
.
Unlock
()
k
:=
u
.
Key
(
i
)
.
DsKey
()
return
p
.
peers
.
Delete
(
k
)
delete
(
p
.
data
,
i
.
String
()
)
return
nil
}
func
(
p
*
peerstore
)
All
()
(
*
Map
,
error
)
{
p
.
RLock
()
defer
p
.
RUnlock
()
l
,
err
:=
p
.
peers
.
KeyList
()
if
err
!=
nil
{
return
nil
,
err
}
p
.
Lock
()
defer
p
.
Unlock
()
ps
:=
&
Map
{}
for
_
,
k
:=
range
l
{
val
,
err
:=
p
.
peers
.
Get
(
k
)
if
err
!=
nil
{
continue
}
pval
,
ok
:=
val
.
(
*
peer
)
if
ok
{
(
*
ps
)[
pval
.
Key
()]
=
pval
}
ps
:=
Map
{}
for
k
,
v
:=
range
p
.
data
{
ps
[
u
.
Key
(
k
)]
=
v
}
return
ps
,
nil
return
&
ps
,
nil
}
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