mirror of
https://github.com/ipfs/kubo.git
synced 2026-02-23 11:27:42 +08:00
License: MIT Signed-off-by: Jeromy <jeromyj@gmail.com> implement rabin fingerprinting as a chunker for ipfs License: MIT Signed-off-by: Jeromy <jeromyj@gmail.com> vendor correctly License: MIT Signed-off-by: Jeromy <jeromyj@gmail.com> refactor chunking interface a little License: MIT Signed-off-by: Jeromy <jeromyj@gmail.com> work chunking interface changes up into importer License: MIT Signed-off-by: Jeromy <jeromyj@gmail.com> move chunker type parsing into its own file in chunk License: MIT Signed-off-by: Jeromy <jeromyj@gmail.com>
95 lines
2.1 KiB
Go
95 lines
2.1 KiB
Go
// package importer implements utilities used to create ipfs DAGs from files
|
|
// and readers
|
|
package importer
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
|
|
bal "github.com/ipfs/go-ipfs/importer/balanced"
|
|
"github.com/ipfs/go-ipfs/importer/chunk"
|
|
h "github.com/ipfs/go-ipfs/importer/helpers"
|
|
trickle "github.com/ipfs/go-ipfs/importer/trickle"
|
|
dag "github.com/ipfs/go-ipfs/merkledag"
|
|
"github.com/ipfs/go-ipfs/pin"
|
|
u "github.com/ipfs/go-ipfs/util"
|
|
)
|
|
|
|
var log = u.Logger("importer")
|
|
|
|
// Builds a DAG from the given file, writing created blocks to disk as they are
|
|
// created
|
|
func BuildDagFromFile(fpath string, ds dag.DAGService, mp pin.ManualPinner) (*dag.Node, error) {
|
|
stat, err := os.Stat(fpath)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if stat.IsDir() {
|
|
return nil, fmt.Errorf("`%s` is a directory", fpath)
|
|
}
|
|
|
|
f, err := os.Open(fpath)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
defer f.Close()
|
|
|
|
return BuildDagFromReader(ds, chunk.NewSizeSplitter(f, chunk.DefaultBlockSize), BasicPinnerCB(mp))
|
|
}
|
|
|
|
func BuildDagFromReader(ds dag.DAGService, spl chunk.Splitter, ncb h.NodeCB) (*dag.Node, error) {
|
|
// Start the splitter
|
|
blkch, errch := chunk.Chan(spl)
|
|
|
|
dbp := h.DagBuilderParams{
|
|
Dagserv: ds,
|
|
Maxlinks: h.DefaultLinksPerBlock,
|
|
NodeCB: ncb,
|
|
}
|
|
|
|
return bal.BalancedLayout(dbp.New(blkch, errch))
|
|
}
|
|
|
|
func BuildTrickleDagFromReader(ds dag.DAGService, spl chunk.Splitter, ncb h.NodeCB) (*dag.Node, error) {
|
|
// Start the splitter
|
|
blkch, errch := chunk.Chan(spl)
|
|
|
|
dbp := h.DagBuilderParams{
|
|
Dagserv: ds,
|
|
Maxlinks: h.DefaultLinksPerBlock,
|
|
NodeCB: ncb,
|
|
}
|
|
|
|
return trickle.TrickleLayout(dbp.New(blkch, errch))
|
|
}
|
|
|
|
func BasicPinnerCB(p pin.ManualPinner) h.NodeCB {
|
|
return func(n *dag.Node, last bool) error {
|
|
k, err := n.Key()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if last {
|
|
p.PinWithMode(k, pin.Recursive)
|
|
return p.Flush()
|
|
} else {
|
|
p.PinWithMode(k, pin.Indirect)
|
|
return nil
|
|
}
|
|
}
|
|
}
|
|
|
|
func PinIndirectCB(p pin.ManualPinner) h.NodeCB {
|
|
return func(n *dag.Node, last bool) error {
|
|
k, err := n.Key()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
p.PinWithMode(k, pin.Indirect)
|
|
return nil
|
|
}
|
|
}
|