Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var DagCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Interact with IPLD DAG objects.", ShortDescription: ` 'ipfs dag' is used for creating and manipulating DAG objects/hierarchies. This subcommand is currently an experimental feature, but it is intended to deprecate and replace the existing 'ipfs object' command moving forward. `, }, Subcommands: map[string]*cmds.Command{ "put": DagPutCmd, "get": DagGetCmd, "resolve": DagResolveCmd, "import": DagImportCmd, "export": DagExportCmd, "stat": DagStatCmd, }, }
DagCmd provides a subset of commands for interacting with ipld dag objects
View Source
var DagExportCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Streams the selected DAG as a .car stream on stdout.", ShortDescription: ` 'ipfs dag export' fetches a DAG and streams it out as a well-formed .car file. Note that at present only single root selections / .car files are supported. The output of blocks happens in strict DAG-traversal, first-seen, order. `, }, Arguments: []cmds.Argument{ cmds.StringArg("root", true, false, "CID of a root to recursively export").EnableStdin(), }, Options: []cmds.Option{ cmds.BoolOption(progressOptionName, "p", "Display progress on CLI. Defaults to true when STDERR is a TTY."), }, Run: dagExport, PostRun: cmds.PostRunMap{ cmds.CLI: finishCLIExport, }, }
DagExportCmd is a command for exporting an ipfs dag to a car
View Source
var DagGetCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Get a DAG node from IPFS.", ShortDescription: ` 'ipfs dag get' fetches a DAG node from IPFS and prints it out in the specified format. `, }, Arguments: []cmds.Argument{ cmds.StringArg("ref", true, false, "The object to get").EnableStdin(), }, Options: []cmds.Option{ cmds.StringOption("format", "f", "Format that the object will be serialized as.").WithDefault("dag-json"), }, Run: dagGet, }
DagGetCmd is a command for getting a dag node from IPFS
View Source
var DagImportCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Import the contents of .car files", ShortDescription: ` 'ipfs dag import' imports all blocks present in supplied .car ( Content Address aRchive ) files, recursively pinning any roots specified in the CAR file headers, unless --pin-roots is set to false. Note: This command will import all blocks in the CAR file, not just those reachable from the specified roots. However, these other blocks will not be pinned and may be garbage collected later. The pinning of the roots happens after all car files are processed, permitting import of DAGs spanning multiple files. Pinning takes place in offline-mode exclusively, one root at a time. If the combination of blocks from the imported CAR files and what is currently present in the blockstore does not represent a complete DAG, pinning of that individual root will fail. Maximum supported CAR version: 1 `, }, Arguments: []cmds.Argument{ cmds.FileArg("path", true, true, "The path of a .car file.").EnableStdin(), }, Options: []cmds.Option{ cmds.BoolOption(pinRootsOptionName, "Pin optional roots listed in the .car headers after importing.").WithDefault(true), cmds.BoolOption(silentOptionName, "No output."), cmds.BoolOption(statsOptionName, "Output stats."), }, Type: CarImportOutput{}, Run: dagImport, Encoders: cmds.EncoderMap{ cmds.Text: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, event *CarImportOutput) error { silent, _ := req.Options[silentOptionName].(bool) if silent { return nil } if event.Root == nil { if event.Stats == nil { return fmt.Errorf("Unexpected message from DAG import") } stats, _ := req.Options[statsOptionName].(bool) if stats { fmt.Fprintf(w, "Imported %d blocks (%d bytes)\n", event.Stats.BlockCount, event.Stats.BlockBytesCount) } return nil } if event.Stats != nil { return fmt.Errorf("Unexpected message from DAG import") } enc, err := cmdenv.GetLowLevelCidEncoder(req) if err != nil { return err } if event.Root.PinErrorMsg != "" { event.Root.PinErrorMsg = fmt.Sprintf("FAILED: %s", event.Root.PinErrorMsg) } else { event.Root.PinErrorMsg = "success" } _, err = fmt.Fprintf( w, "Pinned root\t%s\t%s\n", enc.Encode(event.Root.Cid), event.Root.PinErrorMsg, ) return err }), }, }
DagImportCmd is a command for importing a car to ipfs
View Source
var DagPutCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Add a DAG node to IPFS.", ShortDescription: ` 'ipfs dag put' accepts input from a file or stdin and parses it into an object of the specified format. `, }, Arguments: []cmds.Argument{ cmds.FileArg("object data", true, true, "The object to put").EnableStdin(), }, Options: []cmds.Option{ cmds.StringOption("format", "f", "Format that the object will be added as.").WithDefault("dag-cbor"), cmds.StringOption("input-enc", "Format that the input object will be.").WithDefault("dag-json"), cmds.BoolOption("pin", "Pin this object when adding."), cmds.StringOption("hash", "Hash function to use").WithDefault("sha2-256"), }, Run: dagPut, Type: OutputObject{}, Encoders: cmds.EncoderMap{ cmds.Text: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, out *OutputObject) error { enc, err := cmdenv.GetLowLevelCidEncoder(req) if err != nil { return err } fmt.Fprintln(w, enc.Encode(out.Cid)) return nil }), }, }
DagPutCmd is a command for adding a dag node
View Source
var DagResolveCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Resolve IPLD block.", ShortDescription: ` 'ipfs dag resolve' fetches a DAG node from IPFS, prints its address and remaining path. `, }, Arguments: []cmds.Argument{ cmds.StringArg("ref", true, false, "The path to resolve").EnableStdin(), }, Run: dagResolve, Encoders: cmds.EncoderMap{ cmds.Text: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, out *ResolveOutput) error { var ( enc cidenc.Encoder err error ) switch { case !cmdenv.CidBaseDefined(req): enc, err = cmdenv.CidEncoderFromPath(req.Arguments[0]) if err == nil { break } fallthrough default: enc, err = cmdenv.GetLowLevelCidEncoder(req) if err != nil { return err } } p := enc.Encode(out.Cid) if out.RemPath != "" { p = ipfspath.Join([]string{p, out.RemPath}) } fmt.Fprint(w, p) return nil }), }, Type: ResolveOutput{}, }
DagResolveCmd returns address of highest block within a path and a path remainder
View Source
var DagStatCmd = &cmds.Command{ Helptext: cmds.HelpText{ Tagline: "Gets stats for a DAG.", ShortDescription: ` 'ipfs dag stat' fetches a DAG and returns various statistics about it. Statistics include size and number of blocks. Note: This command skips duplicate blocks in reporting both size and the number of blocks `, }, Arguments: []cmds.Argument{ cmds.StringArg("root", true, false, "CID of a DAG root to get statistics for").EnableStdin(), }, Options: []cmds.Option{ cmds.BoolOption(progressOptionName, "p", "Return progressive data while reading through the DAG").WithDefault(true), }, Run: dagStat, Type: DagStat{}, PostRun: cmds.PostRunMap{ cmds.CLI: finishCLIStat, }, Encoders: cmds.EncoderMap{ cmds.Text: cmds.MakeTypedEncoder(func(req *cmds.Request, w io.Writer, event *DagStat) error { _, err := fmt.Fprintf( w, "%v\n", event, ) return err }), }, }
DagStatCmd is a command for getting size information about an ipfs-stored dag
Functions ¶
This section is empty.
Types ¶
type CarImportOutput ¶
type CarImportOutput struct { Root *RootMeta `json:",omitempty"` Stats *CarImportStats `json:",omitempty"` }
CarImportOutput is the output type of the 'dag import' commands
type CarImportStats ¶
type OutputObject ¶
OutputObject is the output type of 'dag put' command
type ResolveOutput ¶
ResolveOutput is the output type of 'dag resolve' command
Click to show internal directories.
Click to hide internal directories.