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
63feb68c
Commit
63feb68c
authored
Nov 07, 2014
by
Brian Tiger Chow
Committed by
Juan Batiz-Benet
Nov 14, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactor(name, pub, resolve) separate files
parent
092e346f
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
199 additions
and
188 deletions
+199
-188
core/commands2/name.go
core/commands2/name.go
+1
-188
core/commands2/publish.go
core/commands2/publish.go
+106
-0
core/commands2/resolve.go
core/commands2/resolve.go
+92
-0
No files found.
core/commands2/name.go
View file @
63feb68c
package
commands
import
(
"errors"
"fmt"
cmds
"github.com/jbenet/go-ipfs/commands"
core
"github.com/jbenet/go-ipfs/core"
crypto
"github.com/jbenet/go-ipfs/crypto"
nsys
"github.com/jbenet/go-ipfs/namesys"
u
"github.com/jbenet/go-ipfs/util"
)
import
cmds
"github.com/jbenet/go-ipfs/commands"
type
IpnsEntry
struct
{
Name
string
Value
string
}
type
ResolveOutput
struct
{
Entries
[]
IpnsEntry
}
var
errNotOnline
=
errors
.
New
(
"This command must be run in online mode. Try running 'ipfs daemon' first."
)
var
nameCmd
=
&
cmds
.
Command
{
// TODO UsageLine: "name [publish | resolve]",
// TODO Short: "ipfs namespace (ipns) tool",
...
...
@@ -63,175 +48,3 @@ Resolve te value of another name:
"resolve"
:
resolveCmd
,
},
}
var
publishCmd
=
&
cmds
.
Command
{
// TODO UsageLine: "publish",
// TODO Short: "publish a <ref> to ipns.",
Help
:
`ipfs publish [<name>] <ref> - publish a <ref> to ipns.
IPNS is a PKI namespace, where names are the hashes of public keys, and
the private key enables publishing new (signed) values. In publish, the
default value of <name> is your own identity public key.
Examples:
Publish a <ref> to your identity name:
> ipfs name publish QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
published name QmbCMUZw6JFeZ7Wp9jkzbye3Fzp2GGcPgC3nmeUjfVF87n to QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
Publish a <ref> to another public key:
> ipfs name publish QmbCMUZw6JFeZ7Wp9jkzbye3Fzp2GGcPgC3nmeUjfVF87n QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
published name QmbCMUZw6JFeZ7Wp9jkzbye3Fzp2GGcPgC3nmeUjfVF87n to QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
`
,
Arguments
:
[]
cmds
.
Argument
{
cmds
.
Argument
{
"name"
,
cmds
.
ArgString
,
false
,
false
},
cmds
.
Argument
{
"object"
,
cmds
.
ArgString
,
true
,
false
},
},
Run
:
func
(
res
cmds
.
Response
,
req
cmds
.
Request
)
{
n
:=
req
.
Context
()
.
Node
args
:=
req
.
Arguments
()
if
n
.
Network
==
nil
{
res
.
SetError
(
errNotOnline
,
cmds
.
ErrNormal
)
return
}
if
n
.
Identity
==
nil
{
res
.
SetError
(
errors
.
New
(
"Identity not loaded!"
),
cmds
.
ErrNormal
)
return
}
// name := ""
ref
:=
""
switch
len
(
args
)
{
case
2
:
// name = args[0]
ref
=
args
[
1
]
.
(
string
)
res
.
SetError
(
errors
.
New
(
"keychains not yet implemented"
),
cmds
.
ErrNormal
)
return
case
1
:
// name = n.Identity.ID.String()
ref
=
args
[
0
]
.
(
string
)
}
// TODO n.Keychain.Get(name).PrivKey
k
:=
n
.
Identity
.
PrivKey
()
publishOutput
,
err
:=
publish
(
n
,
k
,
ref
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmds
.
ErrNormal
)
return
}
res
.
SetOutput
(
publishOutput
)
},
Marshallers
:
map
[
cmds
.
EncodingType
]
cmds
.
Marshaller
{
cmds
.
Text
:
func
(
res
cmds
.
Response
)
([]
byte
,
error
)
{
v
:=
res
.
Output
()
.
(
*
IpnsEntry
)
s
:=
fmt
.
Sprintf
(
"Published name %s to %s
\n
"
,
v
.
Name
,
v
.
Value
)
return
[]
byte
(
s
),
nil
},
},
Type
:
&
IpnsEntry
{},
}
var
resolveCmd
=
&
cmds
.
Command
{
// TODO UsageLine: "resolve",
// TODO Short: "resolve an ipns name to a <ref>",
Help
:
`ipfs resolve [<name>] - Resolve an ipns name to a <ref>.
IPNS is a PKI namespace, where names are the hashes of public keys, and
the private key enables publishing new (signed) values. In resolve, the
default value of <name> is your own identity public key.
Examples:
Resolve the value of your identity:
> ipfs name resolve
QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
Resolve te value of another name:
> ipfs name resolve QmbCMUZw6JFeZ7Wp9jkzbye3Fzp2GGcPgC3nmeUjfVF87n
QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
`
,
Arguments
:
[]
cmds
.
Argument
{
cmds
.
Argument
{
"name"
,
cmds
.
ArgString
,
false
,
true
},
},
Run
:
func
(
res
cmds
.
Response
,
req
cmds
.
Request
)
{
n
:=
req
.
Context
()
.
Node
var
names
[]
string
if
n
.
Network
==
nil
{
res
.
SetError
(
errNotOnline
,
cmds
.
ErrNormal
)
return
}
if
len
(
req
.
Arguments
())
==
0
{
if
n
.
Identity
==
nil
{
res
.
SetError
(
errors
.
New
(
"Identity not loaded!"
),
cmds
.
ErrNormal
)
return
}
names
=
append
(
names
,
n
.
Identity
.
ID
()
.
String
())
}
else
{
for
_
,
arg
:=
range
req
.
Arguments
()
{
name
,
ok
:=
arg
.
(
string
)
if
!
ok
{
res
.
SetError
(
errors
.
New
(
"cast error"
),
cmds
.
ErrNormal
)
return
}
names
=
append
(
names
,
name
)
}
}
entries
,
err
:=
resolve
(
n
,
names
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmds
.
ErrNormal
)
return
}
res
.
SetOutput
(
&
ResolveOutput
{
entries
})
},
Type
:
&
ResolveOutput
{},
}
func
publish
(
n
*
core
.
IpfsNode
,
k
crypto
.
PrivKey
,
ref
string
)
(
*
IpnsEntry
,
error
)
{
pub
:=
nsys
.
NewRoutingPublisher
(
n
.
Routing
)
err
:=
pub
.
Publish
(
k
,
ref
)
if
err
!=
nil
{
return
nil
,
err
}
hash
,
err
:=
k
.
GetPublic
()
.
Hash
()
if
err
!=
nil
{
return
nil
,
err
}
return
&
IpnsEntry
{
Name
:
u
.
Key
(
hash
)
.
String
(),
Value
:
ref
,
},
nil
}
func
resolve
(
n
*
core
.
IpfsNode
,
names
[]
string
)
([]
IpnsEntry
,
error
)
{
var
entries
[]
IpnsEntry
for
_
,
name
:=
range
names
{
resolved
,
err
:=
n
.
Namesys
.
Resolve
(
name
)
if
err
!=
nil
{
return
nil
,
err
}
entries
=
append
(
entries
,
IpnsEntry
{
Name
:
name
,
Value
:
resolved
,
})
}
return
entries
,
nil
}
core/commands2/publish.go
0 → 100644
View file @
63feb68c
package
commands
import
(
"errors"
"fmt"
cmds
"github.com/jbenet/go-ipfs/commands"
core
"github.com/jbenet/go-ipfs/core"
crypto
"github.com/jbenet/go-ipfs/crypto"
nsys
"github.com/jbenet/go-ipfs/namesys"
u
"github.com/jbenet/go-ipfs/util"
)
var
errNotOnline
=
errors
.
New
(
"This command must be run in online mode. Try running 'ipfs daemon' first."
)
var
publishCmd
=
&
cmds
.
Command
{
// TODO UsageLine: "publish",
// TODO Short: "publish a <ref> to ipns.",
Help
:
`ipfs publish [<name>] <ref> - publish a <ref> to ipns.
IPNS is a PKI namespace, where names are the hashes of public keys, and
the private key enables publishing new (signed) values. In publish, the
default value of <name> is your own identity public key.
Examples:
Publish a <ref> to your identity name:
> ipfs name publish QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
published name QmbCMUZw6JFeZ7Wp9jkzbye3Fzp2GGcPgC3nmeUjfVF87n to QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
Publish a <ref> to another public key:
> ipfs name publish QmbCMUZw6JFeZ7Wp9jkzbye3Fzp2GGcPgC3nmeUjfVF87n QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
published name QmbCMUZw6JFeZ7Wp9jkzbye3Fzp2GGcPgC3nmeUjfVF87n to QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
`
,
Arguments
:
[]
cmds
.
Argument
{
cmds
.
Argument
{
"name"
,
cmds
.
ArgString
,
false
,
false
},
cmds
.
Argument
{
"object"
,
cmds
.
ArgString
,
true
,
false
},
},
Run
:
func
(
res
cmds
.
Response
,
req
cmds
.
Request
)
{
n
:=
req
.
Context
()
.
Node
args
:=
req
.
Arguments
()
if
n
.
Network
==
nil
{
res
.
SetError
(
errNotOnline
,
cmds
.
ErrNormal
)
return
}
if
n
.
Identity
==
nil
{
res
.
SetError
(
errors
.
New
(
"Identity not loaded!"
),
cmds
.
ErrNormal
)
return
}
// name := ""
ref
:=
""
switch
len
(
args
)
{
case
2
:
// name = args[0]
ref
=
args
[
1
]
.
(
string
)
res
.
SetError
(
errors
.
New
(
"keychains not yet implemented"
),
cmds
.
ErrNormal
)
return
case
1
:
// name = n.Identity.ID.String()
ref
=
args
[
0
]
.
(
string
)
}
// TODO n.Keychain.Get(name).PrivKey
k
:=
n
.
Identity
.
PrivKey
()
publishOutput
,
err
:=
publish
(
n
,
k
,
ref
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmds
.
ErrNormal
)
return
}
res
.
SetOutput
(
publishOutput
)
},
Marshallers
:
map
[
cmds
.
EncodingType
]
cmds
.
Marshaller
{
cmds
.
Text
:
func
(
res
cmds
.
Response
)
([]
byte
,
error
)
{
v
:=
res
.
Output
()
.
(
*
IpnsEntry
)
s
:=
fmt
.
Sprintf
(
"Published name %s to %s
\n
"
,
v
.
Name
,
v
.
Value
)
return
[]
byte
(
s
),
nil
},
},
Type
:
&
IpnsEntry
{},
}
func
publish
(
n
*
core
.
IpfsNode
,
k
crypto
.
PrivKey
,
ref
string
)
(
*
IpnsEntry
,
error
)
{
pub
:=
nsys
.
NewRoutingPublisher
(
n
.
Routing
)
err
:=
pub
.
Publish
(
k
,
ref
)
if
err
!=
nil
{
return
nil
,
err
}
hash
,
err
:=
k
.
GetPublic
()
.
Hash
()
if
err
!=
nil
{
return
nil
,
err
}
return
&
IpnsEntry
{
Name
:
u
.
Key
(
hash
)
.
String
(),
Value
:
ref
,
},
nil
}
core/commands2/resolve.go
0 → 100644
View file @
63feb68c
package
commands
import
(
"errors"
cmds
"github.com/jbenet/go-ipfs/commands"
core
"github.com/jbenet/go-ipfs/core"
)
type
ResolveOutput
struct
{
Entries
[]
IpnsEntry
}
var
resolveCmd
=
&
cmds
.
Command
{
// TODO UsageLine: "resolve",
// TODO Short: "resolve an ipns name to a <ref>",
Help
:
`ipfs resolve [<name>] - Resolve an ipns name to a <ref>.
IPNS is a PKI namespace, where names are the hashes of public keys, and
the private key enables publishing new (signed) values. In resolve, the
default value of <name> is your own identity public key.
Examples:
Resolve the value of your identity:
> ipfs name resolve
QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
Resolve te value of another name:
> ipfs name resolve QmbCMUZw6JFeZ7Wp9jkzbye3Fzp2GGcPgC3nmeUjfVF87n
QmatmE9msSfkKxoffpHwNLNKgwZG8eT9Bud6YoPab52vpy
`
,
Arguments
:
[]
cmds
.
Argument
{
cmds
.
Argument
{
"name"
,
cmds
.
ArgString
,
false
,
true
},
},
Run
:
func
(
res
cmds
.
Response
,
req
cmds
.
Request
)
{
n
:=
req
.
Context
()
.
Node
var
names
[]
string
if
n
.
Network
==
nil
{
res
.
SetError
(
errNotOnline
,
cmds
.
ErrNormal
)
return
}
if
len
(
req
.
Arguments
())
==
0
{
if
n
.
Identity
==
nil
{
res
.
SetError
(
errors
.
New
(
"Identity not loaded!"
),
cmds
.
ErrNormal
)
return
}
names
=
append
(
names
,
n
.
Identity
.
ID
()
.
String
())
}
else
{
for
_
,
arg
:=
range
req
.
Arguments
()
{
name
,
ok
:=
arg
.
(
string
)
if
!
ok
{
res
.
SetError
(
errors
.
New
(
"cast error"
),
cmds
.
ErrNormal
)
return
}
names
=
append
(
names
,
name
)
}
}
entries
,
err
:=
resolve
(
n
,
names
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmds
.
ErrNormal
)
return
}
res
.
SetOutput
(
&
ResolveOutput
{
entries
})
},
Type
:
&
ResolveOutput
{},
}
func
resolve
(
n
*
core
.
IpfsNode
,
names
[]
string
)
([]
IpnsEntry
,
error
)
{
var
entries
[]
IpnsEntry
for
_
,
name
:=
range
names
{
resolved
,
err
:=
n
.
Namesys
.
Resolve
(
name
)
if
err
!=
nil
{
return
nil
,
err
}
entries
=
append
(
entries
,
IpnsEntry
{
Name
:
name
,
Value
:
resolved
,
})
}
return
entries
,
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