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
3a2b83d9
Commit
3a2b83d9
authored
Sep 06, 2015
by
Matt Bell
Committed by
rht
Oct 13, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
resolve cmd: Fully resolve IPFS paths after resolving IPNS names
License: MIT Signed-off-by:
Matt Bell
<
mappum@gmail.com
>
parent
8d370a39
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
14 additions
and
14 deletions
+14
-14
core/commands/resolve.go
core/commands/resolve.go
+14
-14
No files found.
core/commands/resolve.go
View file @
3a2b83d9
...
...
@@ -4,8 +4,8 @@ import (
"io"
"strings"
cmds
"github.com/ipfs/go-ipfs/commands"
context
"github.com/ipfs/go-ipfs/Godeps/_workspace/src/golang.org/x/net/context"
cmds
"github.com/ipfs/go-ipfs/commands"
namesys
"github.com/ipfs/go-ipfs/namesys"
path
"github.com/ipfs/go-ipfs/path"
u
"github.com/ipfs/go-ipfs/util"
...
...
@@ -84,17 +84,22 @@ Resolve the value of an IPFS DAG path:
depth
=
namesys
.
DefaultDepthLimit
}
// for /ipfs/ paths, just parse the path
// for /ipns/ paths, resolve into a /ipfs/ path
var
p
path
.
Path
if
strings
.
HasPrefix
(
name
,
"/ipfs/"
)
||
!
strings
.
HasPrefix
(
name
,
"/"
)
{
resolved
,
err
:
=
resolveIpfsPath
(
req
.
Context
(),
n
.
Resolver
,
name
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmds
.
ErrNormal
)
return
}
res
.
Set
Output
(
&
ResolvedPath
{
resolved
}
)
p
,
err
=
path
.
ParsePath
(
name
)
}
else
{
p
,
err
=
n
.
Namesys
.
ResolveN
(
req
.
Context
(),
name
,
depth
)
}
if
err
!=
nil
{
res
.
Set
Error
(
err
,
cmds
.
ErrNormal
)
return
}
output
,
err
:=
n
.
Namesys
.
ResolveN
(
req
.
Context
(),
name
,
depth
)
// now fully resolve the /ipfs/ path
// (walk DAG links if there is a path of link names)
output
,
err
:=
resolveIpfsPath
(
req
.
Context
(),
n
.
Resolver
,
p
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmds
.
ErrNormal
)
return
...
...
@@ -114,12 +119,7 @@ Resolve the value of an IPFS DAG path:
Type
:
ResolvedPath
{},
}
func
resolveIpfsPath
(
ctx
context
.
Context
,
r
*
path
.
Resolver
,
name
string
)
(
path
.
Path
,
error
)
{
p
,
err
:=
path
.
ParsePath
(
name
)
if
err
!=
nil
{
return
""
,
err
}
func
resolveIpfsPath
(
ctx
context
.
Context
,
r
*
path
.
Resolver
,
p
path
.
Path
)
(
path
.
Path
,
error
)
{
node
,
err
:=
r
.
ResolvePath
(
ctx
,
p
)
if
err
!=
nil
{
return
""
,
err
...
...
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