mirror of
https://github.com/ipfs/kubo.git
synced 2025-06-19 01:39:35 +08:00
174 lines
4.2 KiB
Go
174 lines
4.2 KiB
Go
package commands
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"io"
|
|
|
|
"gx/ipfs/QmPSBJL4momYnE7DcUyk2DVhD6rH488ZmHBGLbxNdhU44K/go-humanize"
|
|
|
|
key "github.com/ipfs/go-ipfs/blocks/key"
|
|
cmds "github.com/ipfs/go-ipfs/commands"
|
|
bitswap "github.com/ipfs/go-ipfs/exchange/bitswap"
|
|
peer "gx/ipfs/QmRBqJF7hb8ZSpRcMwUt8hNhydWcxGEhtk81HKq6oUwKvs/go-libp2p-peer"
|
|
u "gx/ipfs/QmZNVWh8LLjAavuQ2JXuFmuYH3C11xo988vSgp7UQrTRj1/go-ipfs-util"
|
|
)
|
|
|
|
var BitswapCmd = &cmds.Command{
|
|
Helptext: cmds.HelpText{
|
|
Tagline: "Interact with the bitswap agent.",
|
|
ShortDescription: ``,
|
|
},
|
|
Subcommands: map[string]*cmds.Command{
|
|
"wantlist": showWantlistCmd,
|
|
"stat": bitswapStatCmd,
|
|
"unwant": unwantCmd,
|
|
},
|
|
}
|
|
|
|
var unwantCmd = &cmds.Command{
|
|
Helptext: cmds.HelpText{
|
|
Tagline: "Remove a given block from your wantlist.",
|
|
},
|
|
Arguments: []cmds.Argument{
|
|
cmds.StringArg("key", true, true, "Key(s) to remove from your wantlist.").EnableStdin(),
|
|
},
|
|
Run: func(req cmds.Request, res cmds.Response) {
|
|
nd, err := req.InvocContext().GetNode()
|
|
if err != nil {
|
|
res.SetError(err, cmds.ErrNormal)
|
|
return
|
|
}
|
|
|
|
if !nd.OnlineMode() {
|
|
res.SetError(errNotOnline, cmds.ErrClient)
|
|
return
|
|
}
|
|
|
|
bs, ok := nd.Exchange.(*bitswap.Bitswap)
|
|
if !ok {
|
|
res.SetError(u.ErrCast(), cmds.ErrNormal)
|
|
return
|
|
}
|
|
|
|
var ks []key.Key
|
|
for _, arg := range req.Arguments() {
|
|
dec := key.B58KeyDecode(arg)
|
|
if dec == "" {
|
|
res.SetError(fmt.Errorf("Incorrectly formatted key: %s", arg), cmds.ErrNormal)
|
|
return
|
|
}
|
|
|
|
ks = append(ks, dec)
|
|
}
|
|
|
|
bs.CancelWants(ks)
|
|
},
|
|
}
|
|
|
|
var showWantlistCmd = &cmds.Command{
|
|
Helptext: cmds.HelpText{
|
|
Tagline: "Show blocks currently on the wantlist.",
|
|
ShortDescription: `
|
|
Print out all blocks currently on the bitswap wantlist for the local peer.`,
|
|
},
|
|
Options: []cmds.Option{
|
|
cmds.StringOption("peer", "p", "Specify which peer to show wantlist for. Default: self."),
|
|
},
|
|
Type: KeyList{},
|
|
Run: func(req cmds.Request, res cmds.Response) {
|
|
nd, err := req.InvocContext().GetNode()
|
|
if err != nil {
|
|
res.SetError(err, cmds.ErrNormal)
|
|
return
|
|
}
|
|
|
|
if !nd.OnlineMode() {
|
|
res.SetError(errNotOnline, cmds.ErrClient)
|
|
return
|
|
}
|
|
|
|
bs, ok := nd.Exchange.(*bitswap.Bitswap)
|
|
if !ok {
|
|
res.SetError(u.ErrCast(), cmds.ErrNormal)
|
|
return
|
|
}
|
|
|
|
pstr, found, err := req.Option("peer").String()
|
|
if err != nil {
|
|
res.SetError(err, cmds.ErrNormal)
|
|
return
|
|
}
|
|
if found {
|
|
pid, err := peer.IDB58Decode(pstr)
|
|
if err != nil {
|
|
res.SetError(err, cmds.ErrNormal)
|
|
return
|
|
}
|
|
res.SetOutput(&KeyList{bs.WantlistForPeer(pid)})
|
|
} else {
|
|
res.SetOutput(&KeyList{bs.GetWantlist()})
|
|
}
|
|
},
|
|
Marshalers: cmds.MarshalerMap{
|
|
cmds.Text: KeyListTextMarshaler,
|
|
},
|
|
}
|
|
|
|
var bitswapStatCmd = &cmds.Command{
|
|
Helptext: cmds.HelpText{
|
|
Tagline: "Show some diagnostic information on the bitswap agent.",
|
|
ShortDescription: ``,
|
|
},
|
|
Type: bitswap.Stat{},
|
|
Run: func(req cmds.Request, res cmds.Response) {
|
|
nd, err := req.InvocContext().GetNode()
|
|
if err != nil {
|
|
res.SetError(err, cmds.ErrNormal)
|
|
return
|
|
}
|
|
|
|
if !nd.OnlineMode() {
|
|
res.SetError(errNotOnline, cmds.ErrClient)
|
|
return
|
|
}
|
|
|
|
bs, ok := nd.Exchange.(*bitswap.Bitswap)
|
|
if !ok {
|
|
res.SetError(u.ErrCast(), cmds.ErrNormal)
|
|
return
|
|
}
|
|
|
|
st, err := bs.Stat()
|
|
if err != nil {
|
|
res.SetError(err, cmds.ErrNormal)
|
|
return
|
|
}
|
|
|
|
res.SetOutput(st)
|
|
},
|
|
Marshalers: cmds.MarshalerMap{
|
|
cmds.Text: func(res cmds.Response) (io.Reader, error) {
|
|
out, ok := res.Output().(*bitswap.Stat)
|
|
if !ok {
|
|
return nil, u.ErrCast()
|
|
}
|
|
buf := new(bytes.Buffer)
|
|
fmt.Fprintln(buf, "bitswap status")
|
|
fmt.Fprintf(buf, "\tprovides buffer: %d / %d\n", out.ProvideBufLen, bitswap.HasBlockBufferSize)
|
|
fmt.Fprintf(buf, "\tblocks received: %d\n", out.BlocksReceived)
|
|
fmt.Fprintf(buf, "\tdup blocks received: %d\n", out.DupBlksReceived)
|
|
fmt.Fprintf(buf, "\tdup data received: %s\n", humanize.Bytes(out.DupDataReceived))
|
|
fmt.Fprintf(buf, "\twantlist [%d keys]\n", len(out.Wantlist))
|
|
for _, k := range out.Wantlist {
|
|
fmt.Fprintf(buf, "\t\t%s\n", k.B58String())
|
|
}
|
|
fmt.Fprintf(buf, "\tpartners [%d]\n", len(out.Peers))
|
|
for _, p := range out.Peers {
|
|
fmt.Fprintf(buf, "\t\t%s\n", p)
|
|
}
|
|
return buf, nil
|
|
},
|
|
},
|
|
}
|