Skip to content

Commit

Permalink
coreapi unixfs: cleanup options
Browse files Browse the repository at this point in the history
License: MIT
Signed-off-by: Łukasz Magiera <magik6k@gmail.com>
  • Loading branch information
magik6k committed Sep 25, 2018
1 parent cd032b1 commit 765d55e
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 37 deletions.
41 changes: 38 additions & 3 deletions core/coreapi/interface/options/unixfs.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,12 @@
package options

import (
"errors"
"fmt"

cid "gx/ipfs/QmPSQnBKM9g7BaUcZCvswUJVscQ1ipjmwxN5PXCjkp9EQ7/go-cid"
mh "gx/ipfs/QmPnFwZ2JXKnXgMw8CdBPxn7FWh6LLdjUjxV1fKHuJnkr8/go-multihash"
dag "gx/ipfs/QmcBoNcAP6qDjgRBew7yjvCqHq7p5jMstE44jPUBWBxzsV/go-merkledag"
)

type Layout int
Expand Down Expand Up @@ -29,7 +34,7 @@ type UnixfsAddSettings struct {

type UnixfsAddOption func(*UnixfsAddSettings) error

func UnixfsAddOptions(opts ...UnixfsAddOption) (*UnixfsAddSettings, error) {
func UnixfsAddOptions(opts ...UnixfsAddOption) (*UnixfsAddSettings, cid.Prefix, error) {
options := &UnixfsAddSettings{
CidVersion: -1,
MhType: mh.SHA2_256,
Expand All @@ -49,11 +54,41 @@ func UnixfsAddOptions(opts ...UnixfsAddOption) (*UnixfsAddSettings, error) {
for _, opt := range opts {
err := opt(options)
if err != nil {
return nil, err
return nil, cid.Prefix{}, err
}
}

// (hash != "sha2-256") -> CIDv1
if options.MhType != mh.SHA2_256 {
switch options.CidVersion {
case 0:
return nil, cid.Prefix{}, errors.New("CIDv0 only supports sha2-256")
case 1, -1:
options.CidVersion = 1
default:
return nil, cid.Prefix{}, fmt.Errorf("unknown CID version: %d", options.CidVersion)
}
} else {
if options.CidVersion < 0 {
// Default to CIDv0
options.CidVersion = 0
}
}

return options, nil
// cidV1 -> raw blocks (by default)
if options.CidVersion > 0 && !options.RawLeavesSet {
options.RawLeaves = true
}

prefix, err := dag.PrefixForCidVersion(options.CidVersion)
if err != nil {
return nil, cid.Prefix{}, err
}

prefix.MhType = options.MhType
prefix.MhLength = -1

return options, prefix, nil
}

type unixfsOpts struct{}
Expand Down
35 changes: 1 addition & 34 deletions core/coreapi/unixfs.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package coreapi

import (
"context"
"errors"
"fmt"
"github.com/ipfs/go-ipfs/core"
"io"
Expand All @@ -11,7 +10,6 @@ import (
"github.com/ipfs/go-ipfs/core/coreapi/interface/options"
"github.com/ipfs/go-ipfs/core/coreunix"

mh "gx/ipfs/QmPnFwZ2JXKnXgMw8CdBPxn7FWh6LLdjUjxV1fKHuJnkr8/go-multihash"
cidutil "gx/ipfs/QmQJSeE3CX4zos9qeaG8EhecEK9zvrTEfTG84J8C5NVRwt/go-cidutil"
offline "gx/ipfs/QmR5miWuikPxWyUrzMYJVmFUcD44pGdtc98h9Qsbp4YcJw/go-ipfs-exchange-offline"
"gx/ipfs/QmSP88ryZkHSRn1fnngAaV2Vcn63WUJzAavnRM9CVdU1Ky/go-ipfs-cmdkit/files"
Expand All @@ -30,42 +28,11 @@ type UnixfsAPI CoreAPI
// Add builds a merkledag node from a reader, adds it to the blockstore,
// and returns the key representing that node.
func (api *UnixfsAPI) Add(ctx context.Context, r io.ReadCloser, opts ...options.UnixfsAddOption) (coreiface.ResolvedPath, error) {
settings, err := options.UnixfsAddOptions(opts...)
settings, prefix, err := options.UnixfsAddOptions(opts...)
if err != nil {
return nil, err
}

// TODO: move to options
// (hash != "sha2-256") -> CIDv1
if settings.MhType != mh.SHA2_256 {
switch settings.CidVersion {
case 0:
return nil, errors.New("CIDv0 only supports sha2-256")
case 1, -1:
settings.CidVersion = 1
default:
return nil, fmt.Errorf("unknown CID version: %d", settings.CidVersion)
}
} else {
if settings.CidVersion < 0 {
// Default to CIDv0
settings.CidVersion = 0
}
}

// cidV1 -> raw blocks (by default)
if settings.CidVersion > 0 && !settings.RawLeavesSet {
settings.RawLeaves = true
}

prefix, err := dag.PrefixForCidVersion(settings.CidVersion)
if err != nil {
return nil, err
}

prefix.MhType = settings.MhType
prefix.MhLength = -1

n := api.node
if settings.OnlyHash {
nilnode, err := core.NewNode(ctx, &core.BuildCfg{
Expand Down

0 comments on commit 765d55e

Please sign in to comment.