提交 219b41bf 作者: Jeromy Johnson 提交者: GitHub

Merge pull request #3915 from ipfs/kevina/repo-stat-storagemax

Add MaxStorage field to output of "repo stat".
...@@ -7,6 +7,7 @@ import ( ...@@ -7,6 +7,7 @@ import (
"os" "os"
"path/filepath" "path/filepath"
"strings" "strings"
"text/tabwriter"
bstore "github.com/ipfs/go-ipfs/blocks/blockstore" bstore "github.com/ipfs/go-ipfs/blocks/blockstore"
cmds "github.com/ipfs/go-ipfs/commands" cmds "github.com/ipfs/go-ipfs/commands"
...@@ -182,15 +183,23 @@ Version string The repo version. ...@@ -182,15 +183,23 @@ Version string The repo version.
} }
buf := new(bytes.Buffer) buf := new(bytes.Buffer)
fmt.Fprintf(buf, "NumObjects \t %d\n", stat.NumObjects) wtr := tabwriter.NewWriter(buf, 0, 0, 1, ' ', 0)
fmt.Fprintf(wtr, "NumObjects:\t%d\n", stat.NumObjects)
sizeInMiB := stat.RepoSize / (1024 * 1024) sizeInMiB := stat.RepoSize / (1024 * 1024)
if human && sizeInMiB > 0 { if human && sizeInMiB > 0 {
fmt.Fprintf(buf, "RepoSize (MiB) \t %d\n", sizeInMiB) fmt.Fprintf(wtr, "RepoSize (MiB):\t%d\n", sizeInMiB)
} else { } else {
fmt.Fprintf(buf, "RepoSize \t %d\n", stat.RepoSize) fmt.Fprintf(wtr, "RepoSize:\t%d\n", stat.RepoSize)
} }
fmt.Fprintf(buf, "RepoPath \t %s\n", stat.RepoPath) maxSizeInMiB := stat.StorageMax / (1024 * 1024)
fmt.Fprintf(buf, "Version \t %s\n", stat.Version) if human && maxSizeInMiB > 0 {
fmt.Fprintf(wtr, "StorageMax (MiB):\t%d\n", maxSizeInMiB)
} else {
fmt.Fprintf(wtr, "StorageMax:\t%d\n", stat.StorageMax)
}
fmt.Fprintf(wtr, "RepoPath:\t%s\n", stat.RepoPath)
fmt.Fprintf(wtr, "Version:\t%s\n", stat.Version)
wtr.Flush()
return buf, nil return buf, nil
}, },
......
...@@ -6,6 +6,8 @@ import ( ...@@ -6,6 +6,8 @@ import (
context "context" context "context"
"github.com/ipfs/go-ipfs/core" "github.com/ipfs/go-ipfs/core"
fsrepo "github.com/ipfs/go-ipfs/repo/fsrepo" fsrepo "github.com/ipfs/go-ipfs/repo/fsrepo"
humanize "gx/ipfs/QmPSBJL4momYnE7DcUyk2DVhD6rH488ZmHBGLbxNdhU44K/go-humanize"
) )
type Stat struct { type Stat struct {
...@@ -13,6 +15,7 @@ type Stat struct { ...@@ -13,6 +15,7 @@ type Stat struct {
RepoSize uint64 // size in bytes RepoSize uint64 // size in bytes
RepoPath string RepoPath string
Version string Version string
StorageMax uint64 // size in bytes
} }
func RepoStat(n *core.IpfsNode, ctx context.Context) (*Stat, error) { func RepoStat(n *core.IpfsNode, ctx context.Context) (*Stat, error) {
...@@ -38,10 +41,21 @@ func RepoStat(n *core.IpfsNode, ctx context.Context) (*Stat, error) { ...@@ -38,10 +41,21 @@ func RepoStat(n *core.IpfsNode, ctx context.Context) (*Stat, error) {
return nil, err return nil, err
} }
cfg, err := r.Config()
if err != nil {
return nil, err
}
storageMax, err := humanize.ParseBytes(cfg.Datastore.StorageMax)
if err != nil {
return nil, err
}
return &Stat{ return &Stat{
NumObjects: count, NumObjects: count,
RepoSize: usage, RepoSize: usage,
RepoPath: path, RepoPath: path,
Version: fmt.Sprintf("fs-repo@%d", fsrepo.RepoVersion), Version: fmt.Sprintf("fs-repo@%d", fsrepo.RepoVersion),
StorageMax: storageMax,
}, nil }, nil
} }
...@@ -232,8 +232,9 @@ test_expect_success "'ipfs repo stat' succeeds" ' ...@@ -232,8 +232,9 @@ test_expect_success "'ipfs repo stat' succeeds" '
test_expect_success "repo stats came out correct" ' test_expect_success "repo stats came out correct" '
grep "RepoPath" repo-stats && grep "RepoPath" repo-stats &&
grep "RepoSize" repo-stats && grep "RepoSize" repo-stats &&
grep "NumObjects" repo-stats grep "NumObjects" repo-stats &&
grep "Version" repo-stats grep "Version" repo-stats &&
grep "StorageMax" repo-stats
' '
test_expect_success "'ipfs repo stat' after adding a file" ' test_expect_success "'ipfs repo stat' after adding a file" '
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论