Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var ErrDataEncoding = errors.New("unknown data field encoding")
View Source
var ObjectCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Interact with BTFS objects.", ShortDescription: ` 'btfs object' is a plumbing command used to manipulate DAG objects directly.`, }, Subcommands: map[string]*cmds.Command{ "data": ObjectDataCmd, "diff": ObjectDiffCmd, "get": ObjectGetCmd, "links": ObjectLinksCmd, "new": ObjectNewCmd, "patch": ObjectPatchCmd, "put": ObjectPutCmd, "stat": ObjectStatCmd, }, }
View Source
var ObjectDataCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Output the raw bytes of an BTFS object.", ShortDescription: ` 'btfs object data' is a plumbing command for retrieving the raw bytes stored in a DAG node. It outputs to stdout, and <key> is a base58 encoded multihash. `, LongDescription: ` 'btfs object data' is a plumbing command for retrieving the raw bytes stored in a DAG node. It outputs to stdout, and <key> is a base58 encoded multihash. Note that the "--encoding" option does not affect the output, since the output is the raw data of the object. `, }, Arguments: []cmds.Argument{ cmds.StringArg("key", true, false, "Key of the object to retrieve, in base58-encoded multihash format.").EnableStdin(), }, Options: []cmds.Option{ cmds.BoolOption(metaDisplayOptionName, "m", "Display token metadata"), }, Run: func(req *cmds.Request, res cmds.ResponseEmitter, env cmds.Environment) error { api, err := cmdenv.GetApi(env, req) if err != nil { return err } meta, _ := req.Options[metaDisplayOptionName].(bool) path := path.New(req.Arguments[0]) data, _, err := api.Object().Data(req.Context, path, true, meta) if err != nil { return err } return res.Emit(data) }, }
ObjectDataCmd object data command
View Source
var ObjectDiffCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Display the diff between two btfs objects.", ShortDescription: ` 'btfs object diff' is a command used to show the differences between two BTFS objects.`, LongDescription: ` 'btfs object diff' is a command used to show the differences between two BTFS objects. Example: > ls foo bar baz/ giraffe > btfs add -r foo ... Added QmegHcnrPgMwC7tBiMxChD54fgQMBUecNw9nE9UUU4x1bz foo > OBJ_A=QmegHcnrPgMwC7tBiMxChD54fgQMBUecNw9nE9UUU4x1bz > echo "different content" > foo/bar > btfs add -r foo ... Added QmcmRptkSPWhptCttgHg27QNDmnV33wAJyUkCnAvqD3eCD foo > OBJ_B=QmcmRptkSPWhptCttgHg27QNDmnV33wAJyUkCnAvqD3eCD > btfs object diff -v $OBJ_A $OBJ_B Changed "bar" from QmNgd5cz2jNftnAHBhcRUGdtiaMzb5Rhjqd4etondHHST8 to QmRfFVsjSXkhFxrfWnLpMae2M4GBVsry6VAuYYcji5MiZb. `, }, Arguments: []cmds.Argument{ cmds.StringArg("obj_a", true, false, "Object to diff against."), cmds.StringArg("obj_b", true, false, "Object to diff."), }, Options: []cmds.Option{ cmds.BoolOption(verboseOptionName, "v", "Print extra information."), }, Run: func(req *cmds.Request, res cmds.ResponseEmitter, env cmds.Environment) error { api, err := cmdenv.GetApi(env, req) if err != nil { return err } pa := path.New(req.Arguments[0]) pb := path.New(req.Arguments[1]) changes, err := api.Object().Diff(req.Context, pa, pb) if err != nil { return err } out := make([]*dagutils.Change, len(changes)) for i, change := range changes { out[i] = &dagutils.Change{ Type: dagutils.ChangeType(change.Type), Path: change.Path, } if change.Before != nil { out[i].Before = change.Before.Cid() } if change.After != nil { out[i].After = change.After.Cid() } } return cmds.EmitOnce(res, &Changes{out}) }, Type: Changes{}, Encoders: cmds.EncoderMap{ cmds.Text: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, out *Changes) error { verbose, _ := req.Options[verboseOptionName].(bool) for _, change := range out.Changes { if verbose { switch change.Type { case dagutils.Add: fmt.Fprintf(w, "Added new link %q pointing to %s.\n", change.Path, change.After) case dagutils.Mod: fmt.Fprintf(w, "Changed %q from %s to %s.\n", change.Path, change.Before, change.After) case dagutils.Remove: fmt.Fprintf(w, "Removed link %q (was %s).\n", change.Path, change.Before) } } else { switch change.Type { case dagutils.Add: fmt.Fprintf(w, "+ %s %q\n", change.After, change.Path) case dagutils.Mod: fmt.Fprintf(w, "~ %s %s %q\n", change.Before, change.After, change.Path) case dagutils.Remove: fmt.Fprintf(w, "- %s %q\n", change.Before, change.Path) } } } return nil }), }, }
View Source
var ObjectGetCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Get and serialize the DAG node named by <key>.", ShortDescription: ` 'btfs object get' is a plumbing command for retrieving DAG nodes. It serializes the DAG node to the format specified by the "--encoding" flag. It outputs to stdout, and <key> is a base58 encoded multihash. `, LongDescription: ` 'btfs object get' is a plumbing command for retrieving DAG nodes. It serializes the DAG node to the format specified by the "--encoding" flag. It outputs to stdout, and <key> is a base58 encoded multihash. This command outputs data in the following encodings: * "protobuf" * "json" * "xml" (Specified by the "--encoding" or "--enc" flag) The encoding of the object's data field can be specified by using the --data-encoding flag Supported values are: * "text" (default) * "base64" `, }, Arguments: []cmds.Argument{ cmds.StringArg("key", true, false, "Key of the object to retrieve, in base58-encoded multihash format.").EnableStdin(), }, Options: []cmds.Option{ cmds.StringOption(encodingOptionName, "Encoding type of the data field, either \"text\" or \"base64\".").WithDefault("text"), cmds.BoolOption(metaDisplayOptionName, "m", "Display token metadata"), }, Run: func(req *cmds.Request, res cmds.ResponseEmitter, env cmds.Environment) error { api, err := cmdenv.GetApi(env, req) if err != nil { return err } meta, _ := req.Options[metaDisplayOptionName].(bool) enc, err := cmdenv.GetLowLevelCidEncoder(req) if err != nil { return err } path := path.New(req.Arguments[0]) datafieldenc, _ := req.Options[encodingOptionName].(string) if err != nil { return err } nd, err := api.Object().Get(req.Context, path, false) if err != nil { return err } r, mr, err := api.Object().Data(req.Context, path, true, true) if err != nil { return err } if meta && mr != nil { return getObjectWithMeta(res, r, mr, datafieldenc, nd, enc) } else { return getObject(res, r, datafieldenc, nd, enc) } }, Type: Node{}, Encoders: cmds.EncoderMap{ cmds.Protobuf: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, out *Node) error { object, err := deserializeNode(out, "text") if err != nil { return nil } marshaled, err := object.Marshal() if err != nil { return err } _, err = w.Write(marshaled) return err }), }, }
ObjectGetCmd object get command
View Source
var ObjectLinksCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Output the links pointed to by the specified object.", ShortDescription: ` 'btfs object links' is a plumbing command for retrieving the links from a DAG node. It outputs to stdout, and <key> is a base58 encoded multihash. `, }, Arguments: []cmds.Argument{ cmds.StringArg("key", true, false, "Key of the object to retrieve, in base58-encoded multihash format.").EnableStdin(), }, Options: []cmds.Option{ cmds.BoolOption(headersOptionName, "v", "Print table headers (Hash, Size, Name)."), }, Run: func(req *cmds.Request, res cmds.ResponseEmitter, env cmds.Environment) error { api, err := cmdenv.GetApi(env, req) if err != nil { return err } enc, err := cmdenv.GetLowLevelCidEncoder(req) if err != nil { return err } path := path.New(req.Arguments[0]) rp, err := api.ResolvePath(req.Context, path) if err != nil { return err } links, err := api.Object().Links(req.Context, rp) if err != nil { return err } outLinks := make([]Link, len(links)) for i, link := range links { outLinks[i] = Link{ Hash: enc.Encode(link.Cid), Name: link.Name, Size: link.Size, } } out := &Object{ Hash: enc.Encode(rp.Cid()), Links: outLinks, } return cmds.EmitOnce(res, out) }, Encoders: cmds.EncoderMap{ cmds.Text: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, out *Object) error { tw := tabwriter.NewWriter(w, 1, 2, 1, ' ', 0) headers, _ := req.Options[headersOptionName].(bool) if headers { fmt.Fprintln(tw, "Hash\tSize\tName") } for _, link := range out.Links { fmt.Fprintf(tw, "%s\t%v\t%s\n", link.Hash, link.Size, link.Name) } tw.Flush() return nil }), }, Type: &Object{}, }
ObjectLinksCmd object links command
View Source
var ObjectNewCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Create a new object from an btfs template.", ShortDescription: ` 'btfs object new' is a plumbing command for creating new DAG nodes. `, LongDescription: ` 'btfs object new' is a plumbing command for creating new DAG nodes. By default it creates and returns a new empty merkledag node, but you may pass an optional template argument to create a preformatted node. Available templates: * unixfs-dir `, }, Arguments: []cmds.Argument{ cmds.StringArg("template", false, false, "Template to use. Optional."), }, Run: func(req *cmds.Request, res cmds.ResponseEmitter, env cmds.Environment) error { api, err := cmdenv.GetApi(env, req) if err != nil { return err } enc, err := cmdenv.GetLowLevelCidEncoder(req) if err != nil { return err } template := "empty" if len(req.Arguments) == 1 { template = req.Arguments[0] } nd, err := api.Object().New(req.Context, options.Object.Type(template)) if err != nil && err != io.EOF { return err } return cmds.EmitOnce(res, &Object{Hash: enc.Encode(nd.Cid())}) }, Encoders: cmds.EncoderMap{ cmds.Text: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, out *Object) error { fmt.Fprintln(w, out.Hash) return nil }), }, Type: Object{}, }
ObjectNewCmd object new command
View Source
var ObjectPatchCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Create a new merkledag object based on an existing one.", ShortDescription: ` 'btfs object patch <root> <cmd> <args>' is a plumbing command used to build custom DAG objects. It mutates objects, creating new objects as a result. This is the Merkle-DAG version of modifying an object. `, }, Arguments: []cmds.Argument{}, Subcommands: map[string]*cmds.Command{ "append-data": patchAppendDataCmd, "add-link": patchAddLinkCmd, "rm-link": patchRmLinkCmd, "set-data": patchSetDataCmd, }, }
View Source
var ObjectPutCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Store input as a DAG object, print its key.", ShortDescription: ` 'btfs object put' is a plumbing command for storing DAG nodes. It reads from stdin, and the output is a base58 encoded multihash. `, LongDescription: ` 'btfs object put' is a plumbing command for storing DAG nodes. It reads from stdin, and the output is a base58 encoded multihash. Data should be in the format specified by the --inputenc flag. --inputenc may be one of the following: * "protobuf" * "json" (default) Examples: $ echo '{ "Data": "abc" }' | btfs object put This creates a node with the data 'abc' and no links. For an object with links, create a file named 'node.json' with the contents: { "Data": "another", "Links": [ { "Name": "some link", "Hash": "QmXg9Pp2ytZ14xgmQjYEiHjVjMFXzCVVEcRTWJBmLgR39V", "Size": 8 } ] } And then run: $ btfs object put node.json `, }, Arguments: []cmds.Argument{ cmds.FileArg("data", true, false, "Data to be stored as a DAG object.").EnableStdin(), }, Options: []cmds.Option{ cmds.StringOption(inputencOptionName, "Encoding type of input data. One of: {\"protobuf\", \"json\"}.").WithDefault("json"), cmds.StringOption(datafieldencOptionName, "Encoding type of the data field, either \"text\" or \"base64\".").WithDefault("text"), cmds.BoolOption(pinOptionName, "Pin this object when adding."), cmds.BoolOption(quietOptionName, "q", "Write minimal output."), }, Run: func(req *cmds.Request, res cmds.ResponseEmitter, env cmds.Environment) error { api, err := cmdenv.GetApi(env, req) if err != nil { return err } enc, err := cmdenv.GetLowLevelCidEncoder(req) if err != nil { return err } file, err := cmdenv.GetFileArg(req.Files.Entries()) if err != nil { return err } inputenc, _ := req.Options[inputencOptionName].(string) if err != nil { return err } datafieldenc, _ := req.Options[datafieldencOptionName].(string) if err != nil { return err } dopin, _ := req.Options[pinOptionName].(bool) if err != nil { return err } p, err := api.Object().Put(req.Context, file, options.Object.DataType(datafieldenc), options.Object.InputEnc(inputenc), options.Object.Pin(dopin)) if err != nil { return err } return cmds.EmitOnce(res, &Object{Hash: enc.Encode(p.Cid())}) }, Encoders: cmds.EncoderMap{ cmds.Text: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, out *Object) error { quiet, _ := req.Options[quietOptionName].(bool) o := out.Hash if !quiet { o = "added " + o } fmt.Fprintln(w, o) return nil }), }, Type: Object{}, }
ObjectPutCmd object put command
View Source
var ObjectStatCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Get stats for the DAG node named by <key>.", ShortDescription: ` 'btfs object stat' is a plumbing command to print DAG node statistics. <key> is a base58 encoded multihash. It outputs to stdout: NumLinks int number of links in link table BlockSize int size of the raw, encoded data LinksSize int size of the links segment DataSize int size of the data segment CumulativeSize int cumulative size of object and its references `, }, Arguments: []cmds.Argument{ cmds.StringArg("key", true, false, "Key of the object to retrieve, in base58-encoded multihash format.").EnableStdin(), }, Options: []cmds.Option{ cmds.BoolOption(humanOptionName, "Print sizes in human readable format (e.g., 1K 234M 2G)"), }, Run: func(req *cmds.Request, res cmds.ResponseEmitter, env cmds.Environment) error { api, err := cmdenv.GetApi(env, req) if err != nil { return err } enc, err := cmdenv.GetLowLevelCidEncoder(req) if err != nil { return err } ns, err := api.Object().Stat(req.Context, path.New(req.Arguments[0])) if err != nil { return err } oldStat := &ipld.NodeStat{ Hash: enc.Encode(ns.Cid), NumLinks: ns.NumLinks, BlockSize: ns.BlockSize, LinksSize: ns.LinksSize, DataSize: ns.DataSize, CumulativeSize: ns.CumulativeSize, } return cmds.EmitOnce(res, oldStat) }, Type: ipld.NodeStat{}, Encoders: cmds.EncoderMap{ cmds.Text: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, out *ipld.NodeStat) error { wtr := tabwriter.NewWriter(w, 0, 0, 1, ' ', 0) defer wtr.Flush() fw := func(s string, n int) { fmt.Fprintf(wtr, "%s:\t%d\n", s, n) } human, _ := req.Options[humanOptionName].(bool) fw("NumLinks", out.NumLinks) fw("BlockSize", out.BlockSize) fw("LinksSize", out.LinksSize) fw("DataSize", out.DataSize) if human { fmt.Fprintf(wtr, "%s:\t%s\n", "CumulativeSize", humanize.Bytes(uint64(out.CumulativeSize))) } else { fw("CumulativeSize", out.CumulativeSize) } return nil }), }, }
ObjectStatCmd object stat command
Functions ¶
This section is empty.
Types ¶
type NodeWithMetaMap ¶ added in v1.5.0
type NodeWithMetaString ¶ added in v1.5.0
Click to show internal directories.
Click to hide internal directories.