Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
4c0f18cb
提交
4c0f18cb
authored
9月 12, 2014
作者:
Jeromy
提交者:
Juan Batiz-Benet
10月 01, 2014
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
implement ipns publisher code
上级
8ddfb57c
隐藏空白字符变更
内嵌
并排
正在显示
6 个修改的文件
包含
95 行增加
和
21 行删除
+95
-21
core.go
core/core.go
+0
-2
entry.pb.go
namesys/entry.pb.go
+7
-7
entry.proto
namesys/entry.proto
+1
-1
publisher.go
namesys/publisher.go
+64
-0
resolver.go
namesys/resolver.go
+14
-1
routing.go
namesys/routing.go
+9
-10
没有找到文件。
core/core.go
浏览文件 @
4c0f18cb
...
...
@@ -238,5 +238,3 @@ func (n *IpfsNode) PinDagNode(nd *merkledag.Node) error {
u
.
DOut
(
"Pinning node. Currently No-Op
\n
"
)
return
nil
}
func
(
n
*
IpfsNode
)
SetIpnsEntry
()
{}
namesys/entry.pb.go
浏览文件 @
4c0f18cb
...
...
@@ -9,7 +9,7 @@ It is generated from these files:
entry.proto
It has these top-level messages:
I
np
sEntry
I
pn
sEntry
*/
package
namesys
...
...
@@ -20,24 +20,24 @@ import math "math"
var
_
=
proto
.
Marshal
var
_
=
math
.
Inf
type
I
np
sEntry
struct
{
type
I
pn
sEntry
struct
{
Value
[]
byte
`protobuf:"bytes,1,req,name=value" json:"value,omitempty"`
Signature
[]
byte
`protobuf:"bytes,2,req,name=signature" json:"signature,omitempty"`
XXX_unrecognized
[]
byte
`json:"-"`
}
func
(
m
*
I
npsEntry
)
Reset
()
{
*
m
=
Inp
sEntry
{}
}
func
(
m
*
I
np
sEntry
)
String
()
string
{
return
proto
.
CompactTextString
(
m
)
}
func
(
*
I
np
sEntry
)
ProtoMessage
()
{}
func
(
m
*
I
pnsEntry
)
Reset
()
{
*
m
=
Ipn
sEntry
{}
}
func
(
m
*
I
pn
sEntry
)
String
()
string
{
return
proto
.
CompactTextString
(
m
)
}
func
(
*
I
pn
sEntry
)
ProtoMessage
()
{}
func
(
m
*
I
np
sEntry
)
GetValue
()
[]
byte
{
func
(
m
*
I
pn
sEntry
)
GetValue
()
[]
byte
{
if
m
!=
nil
{
return
m
.
Value
}
return
nil
}
func
(
m
*
I
np
sEntry
)
GetSignature
()
[]
byte
{
func
(
m
*
I
pn
sEntry
)
GetSignature
()
[]
byte
{
if
m
!=
nil
{
return
m
.
Signature
}
...
...
namesys/entry.proto
浏览文件 @
4c0f18cb
package
namesys
;
message
I
np
sEntry
{
message
I
pn
sEntry
{
required
bytes
value
=
1
;
required
bytes
signature
=
2
;
}
namesys/publisher.go
0 → 100644
浏览文件 @
4c0f18cb
package
namesys
import
(
"code.google.com/p/goprotobuf/proto"
ci
"github.com/jbenet/go-ipfs/crypto"
mdag
"github.com/jbenet/go-ipfs/merkledag"
routing
"github.com/jbenet/go-ipfs/routing"
u
"github.com/jbenet/go-ipfs/util"
)
type
IpnsPublisher
struct
{
dag
*
mdag
.
DAGService
routing
routing
.
IpfsRouting
}
// Publish accepts a keypair and a value,
func
(
p
*
IpnsPublisher
)
Publish
(
k
ci
.
PrivKey
,
value
u
.
Key
)
error
{
data
,
err
:=
CreateEntryData
(
k
,
value
)
if
err
!=
nil
{
return
err
}
pubkey
:=
k
.
GetPublic
()
pkbytes
,
err
:=
pubkey
.
Bytes
()
if
err
!=
nil
{
return
nil
}
nameb
,
err
:=
u
.
Hash
(
pkbytes
)
if
err
!=
nil
{
return
nil
}
namekey
:=
u
.
Key
(
nameb
)
.
Pretty
()
ipnskey
,
err
:=
u
.
Hash
([]
byte
(
"ipns:"
+
namekey
))
if
err
!=
nil
{
return
err
}
// Store associated public key
err
=
p
.
routing
.
PutValue
(
u
.
Key
(
nameb
),
pkbytes
)
if
err
!=
nil
{
return
err
}
// Store ipns entry at h("ipns:"+b58(h(pubkey)))
err
=
p
.
routing
.
PutValue
(
u
.
Key
(
ipnskey
),
data
)
if
err
!=
nil
{
return
err
}
return
nil
}
func
CreateEntryData
(
pk
ci
.
PrivKey
,
val
u
.
Key
)
([]
byte
,
error
)
{
entry
:=
new
(
IpnsEntry
)
sig
,
err
:=
pk
.
Sign
([]
byte
(
val
))
if
err
!=
nil
{
return
nil
,
err
}
entry
.
Signature
=
sig
entry
.
Value
=
[]
byte
(
val
)
return
proto
.
Marshal
(
entry
)
}
namesys/resolver.go
浏览文件 @
4c0f18cb
package
namesys
import
"strings"
import
(
"strings"
mdag
"github.com/jbenet/go-ipfs/merkledag"
"github.com/jbenet/go-ipfs/routing"
)
type
MasterResolver
struct
{
dns
*
DNSResolver
...
...
@@ -8,6 +13,14 @@ type MasterResolver struct {
pro
*
ProquintResolver
}
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
)
return
mr
}
func
(
mr
*
MasterResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
if
strings
.
Contains
(
name
,
"."
)
{
return
mr
.
dns
.
Resolve
(
name
)
...
...
namesys/routing.go
浏览文件 @
4c0f18cb
...
...
@@ -13,18 +13,17 @@ import (
mh
"github.com/jbenet/go-multihash"
)
// RoutingName is the de-serialized name structure that is stored (serialized)
// in the routing system. Basically, a hash + a digital signature. (serialization can be
// protobuf, or a simple binary format)
type
RoutingName
struct
{
Hash
u
.
Key
Signature
[]
byte
}
// RoutingResolver implements NSResolver for the main IPFS SFS-like naming
type
RoutingResolver
struct
{
routing
routing
.
IpfsRouting
dag
mdag
.
DAGService
dag
*
mdag
.
DAGService
}
func
NewRoutingResolver
(
route
routing
.
IpfsRouting
,
dagservice
*
mdag
.
DAGService
)
*
RoutingResolver
{
return
&
RoutingResolver
{
routing
:
route
,
dag
:
dagservice
,
}
}
func
(
r
*
RoutingResolver
)
Resolve
(
name
string
)
(
string
,
error
)
{
...
...
@@ -47,7 +46,7 @@ func (r *RoutingResolver) Resolve(name string) (string, error) {
return
""
,
err
}
entry
:=
new
(
I
np
sEntry
)
entry
:=
new
(
I
pn
sEntry
)
err
=
proto
.
Unmarshal
(
val
,
entry
)
if
err
!=
nil
{
return
""
,
err
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论